Skip to content

Instantly share code, notes, and snippets.

@jackiewu
Created November 20, 2015 05:23
Show Gist options
  • Save jackiewu/606c524768a1b3686de8 to your computer and use it in GitHub Desktop.
Save jackiewu/606c524768a1b3686de8 to your computer and use it in GitHub Desktop.
Mole :: property curves example
<div class="mole-scene" id="js-mole-scene">
<div id="js-cube-scene" class="cube-wrapper">
<div class="cube-shadow-wrapper" id="js-shadow-wrapper">
<div class="cube-shadow" id="js-shadow"></div>
</div>
<div id="js-cube" style="opacity: 0;">
<div id="js-cube-squash" class="cube__squash">
<div class="cube">
<div class="cube__side cube__side--front"><!-- front --></div>
<div class="cube__side cube__side--back"><!-- back --></div>
<div class="cube__side cube__side--top"><!-- top --></div>
<div class="cube__side cube__side--bottom"><!-- bottom --></div>
<div class="cube__side cube__side--left"><!-- left --></div>
<div class="cube__side cube__side--right"><!-- right --></div>
</div>
</div>
</div>
</div>
<div class="mole mole-scene__mole" id="js-mole">
<div class="mole__inner" id="js-mole-inner">
<div id="js-mole-hat" class="mole__hat">
<div class="mole__hat-base">
<div class="mole__hat-shadow" id="js-mole-hat-shadow"></div>
</div>
<div class="mole__hat-cone-wrapper">
<div class="mole__hat-cone-rotator" id="js-mole-hat-cone">
<div class="mole__hat-cone"></div>
</div>
</div>
</div>
<div class="mole__head">
<div class="mole-mouth">
<div class="mole-mouth__inner" id="js-mole-tongue">
<svg viewBox="0 0 60 60" style="max-width: 20px;">
<path id="js-mole-tongue-path" d="M0 30 Q 20 10, 30 25 T 50 30" stroke="#C95549" fill="none" stroke-width="18" stroke-linecap="round">
</svg>
</div>
</div>
<div class="mole__mouth-wrapper" id="js-mole-mouth">
<div class="mole__mouth" id="js-mole-mouth-outer">
<div class="mole__mouth-inner" id="js-mole-mouth-inner"></div>
</div>
</div>
</div>
<div class="mole__eye" id="js-mole-eye">
<svg width="13px" height="6px" viewBox="0 0 13 6" version="1.1" xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink" xmlns:sketch="http://www.bohemiancoding.com/sketch/ns">
<g id="Page-1" stroke="none" stroke-width="1" fill="none" fill-rule="evenodd" sketch:type="MSPage">
<path d="M0,0 Q 6.5 10, 13 0" id="js-mole-eye-lash" stroke="#4C4040" stroke-width="2"></path>
</g>
</svg>
</div>
<div class="mole__glasses" id="js-mole-glasses"></div>
<div class="mole__glasses-left" id="js-mole-glasses-left"></div>
<div class="mole__body" id="js-mole-body"></div>
<div class="mole__hand" id="js-mole-hand">
<div class="mole__hand-circle" id="js-mole-hand-circle"></div>
</div>
<div class="mole__hand-left" id="js-mole-hand-left"></div>
</div>
</div>
<div class="mole-scene__door">
<div class="door-shadow">
<div class="door-shadow__el" id="js-door-shadow"></div>
</div>
<div class="mole-scene__door-rotation" id="js-door">
<div class="shape cuboid-1 cub-1 door">
<div class="face ft"></div>
<div class="face bk"></div>
<div class="face rt"></div>
<div class="face lt"></div>
<div class="face bm"></div>
<div class="face tp">
<div class="door-handle">
<div class="door-handle__shadow">
<div class="door-handle__shadow-inner" id="js-door-handle-shadow"></div>
</div>
<div class="door-handle__part door-handle__part--bottom"></div>
<div class="door-handle__part door-handle__part--top"></div>
</div>
</div>
<div class="cr cr-0">
<div class="face side s0"></div>
<div class="face side s1"></div>
<div class="face side s2"></div>
</div>
<div class="cr cr-1">
<div class="face side s0"></div>
<div class="face side s1"></div>
<div class="face side s2"></div>
</div>
<div class="cr cr-3">
<div class="face side s0"></div>
<div class="face side s1"></div>
<div class="face side s2"></div>
</div>
</div>
</div>
</div>
<div class="mole-scene__ground"></div>
<div class="mole-scene__door-wave-wrapper">
<div class="mole-scene__door-wave" id="js-door-wave"></div>
</div>
<div class="mole-scene__mask"></div>
</div>
<div class="spinner" id="js-spinner">
<div class="dot1"></div>
<div class="dot2"></div>
</div>
<a href="http://mojs.io/tutorials/easing/path-easing/" class="tutorial-link" id="js-tutorials-link" style="opacity: 0;">
tutorial
<span class="tutorial-link__logo">
<svg width="16px" height="16px" viewBox="0 0 16 16" version="1.1" xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink" xmlns:sketch="http://www.bohemiancoding.com/sketch/ns">
<g id="Page-1" stroke="none" stroke-width="1" fill="none" fill-rule="evenodd" sketch:type="MSPage">
<path d="M8,0 C12.418278,0 16,3.581722 16,8 C16,12.418278 12.418278,16 8,16 C3.581722,16 0,12.418278 0,8 C0,3.581722 3.581722,0 8,0 L8,0 Z M7.99952276,4.06943864 C10.1705754,4.06943864 11.9305614,5.82942457 11.9305614,8.00047724 C11.9305614,10.1715299 10.1705754,11.9315158 7.99952276,11.9315158 C5.82847009,11.9315158 4.06848416,10.1715299 4.06848416,8.00047724 C4.06848416,5.82942457 5.82847009,4.06943864 7.99952276,4.06943864 L7.99952276,4.06943864 Z" id="Oval-22" fill="#FFFFFF" sketch:type="MSShapeGroup"></path>
</g>
</svg>
</span>
</a>
<style>
.spinner {
width: 40px;
height: 40px;
/*margin-left: -20px;*/
margin-top: -20px;
position: absolute;
z-index: 20;
top: 50%;
left: 50%;
text-align: center;
-webkit-animation: sk-rotate 2.0s infinite linear;
animation: sk-rotate 2.0s infinite linear;
}
.dot1, .dot2 {
width: 60%;
height: 60%;
display: inline-block;
position: absolute;
top: 0;
background-color: white;
border-radius: 100%;
-webkit-animation: sk-bounce 2.0s infinite ease-in-out;
animation: sk-bounce 2.0s infinite ease-in-out;
}
.dot2 {
top: auto;
bottom: 0;
-webkit-animation-delay: -1.0s;
animation-delay: -1.0s;
}
@-webkit-keyframes sk-rotate { 100% { -webkit-transform: rotate(360deg) }}
@keyframes sk-rotate { 100% { transform: rotate(360deg); -webkit-transform: rotate(360deg) }}
@-webkit-keyframes sk-bounce {
0%, 100% { -webkit-transform: scale(0.0) }
50% { -webkit-transform: scale(1.0) }
}
@keyframes sk-bounce {
0%, 100% {
transform: scale(0.0);
-webkit-transform: scale(0.0);
} 50% {
transform: scale(1.0);
-webkit-transform: scale(1.0);
}
}
</style>
// SCENES
// - CUBE
// -- CUBE FALL
// --- CUBE FALL EFFECTS
var effects = {
init: function (proto) {
// set prototype to cube object
this.proto = proto;
Object.setPrototypeOf(this, proto);
this.vars();
this.createTween();
},
vars: function () {
this.burstOption = {
parent: this.cubeSceneEl,
x: '100%', y: 100,
shiftX: {0: 300},
shiftY: {0: '-50'},
type: ['circle', 'rect', 'polygon'],
fill: ['white', 'yellow', 'pink'],
delay: (this.delay+265)*this.s,
duration: 1400*this.s,
radius: {50: 150},
degree: 200,
count: 5,
angle: {0:'-25'},
easing: 'expo.out',
isSwirl: true,
randomRadius: .7,
randomAngle: .1,
swirlFrequency: 5,
isRunLess: true,
opacity: .75
};
},
createTween: function () {
this.cubeMainTween.add([ this.createFall1(), this.createFall2(),
this.createFall3(), this.createFall4(),
this.createFall5()
] );
},
createFall1: function () {
if (this.isMobile()) { return new mojs.Timeline; }
var timeline = new mojs.Timeline;
var burst2Option = {
x: '-20%', shiftX: {0: -300},
angle: {0:'25'},
onStart: ()=> { this.isSound && this.fall1Sound.play(); }
}
mojs.h.extend(burst2Option, this.burstOption);
var burst1 = new mojs.Burst(this.burstOption),
burst2 = new mojs.Burst(burst2Option);
timeline.add(burst1, burst2);
return timeline;
},
createFall2: function () {
if (this.isMobile()) { return new mojs.Timeline; }
var timeline = new mojs.Timeline;
var burst1Option = {delay: (this.delay+850)*this.s, radius: {30: 60}, count: 3}
var burst2Option = {
x: '-20%', shiftX: {0: -300}, angle: {0:'25'},
onStart: ()=> { this.isSound && this.fall2Sound.play(); }
}
mojs.h.extend(burst1Option, this.burstOption);
mojs.h.extend(burst2Option, burst1Option);
var burst1 = new mojs.Burst(burst1Option),
burst2 = new mojs.Burst(burst2Option);
timeline.add(burst1, burst2);
return timeline;
},
createFall3: function () {
if (this.isMobile()) { return new mojs.Timeline; }
var timeline = new mojs.Timeline;
var burst1Option = {delay: (this.delay+1275)*this.s, radius: {15: 30}, count: 2, shiftX: {0: 150}, shiftY: {0: '-25'}}
var burst2Option = {
x: '-20%', shiftX: {0: -150}, angle: {0:'25'},
onStart: () => { this.isSound && this.fall3Sound.play(); }
}
mojs.h.extend(burst1Option, this.burstOption);
mojs.h.extend(burst2Option, burst1Option);
var burst1 = new mojs.Burst(burst1Option),
burst2 = new mojs.Burst(burst2Option);
timeline.add(burst1, burst2);
return timeline;
},
createFall4: function () {
if (this.isMobile()) { return new mojs.Timeline; }
var timeline = new mojs.Timeline;
var burst1Option = {delay: (this.delay+1550)*this.s, radius: {5: 12}, count: 1, shiftX: {0: 80}, shiftY: {0: '-15'}}
var burst2Option = {
x: '-20%', shiftX: {0: -80}, angle: {0:'15'},
onStart: () => { this.isSound && this.fall4Sound.play(); }
}
mojs.h.extend(burst1Option, this.burstOption);
mojs.h.extend(burst2Option, burst1Option);
var burst1 = new mojs.Burst(burst1Option),
burst2 = new mojs.Burst(burst2Option);
timeline.add(burst1, burst2);
return timeline;
},
createFall5: function () {
if (this.isMobile()) { return new mojs.Timeline; }
var timeline = new mojs.Timeline;
var burst1Option = {delay: (this.delay+1725)*this.s, radius: {5: 12}, count: 1, shiftX: {0: 60}, shiftY: {0: '-10'}, childOptions: {radius: {3:0}} }
var burst2Option = {
x: '-20%', shiftX: {0: -60}, angle: {0:'10'},
onStart: () => { this.isSound && this.fall5Sound.play(); }
}
mojs.h.extend(burst1Option, this.burstOption);
mojs.h.extend(burst2Option, burst1Option);
var burst1 = new mojs.Burst(burst1Option),
burst2 = new mojs.Burst(burst2Option);
timeline.add(burst1, burst2);
return timeline;
}
}
var cubeFall = {
init: function (proto) {
// set prototype to cube object
this.proto = proto;
Object.setPrototypeOf(this, proto);
this.vars();
this.createTween();
effects.init(this);
},
vars: function () {
this.bouncyEasing = mojs.easing.path('M0,100 C4.00577744,92.3519448 8.46993511,63.9895504 13.1512887,0.0901667719 L21.3497674,0 C21.3497674,-1.77229627 30.0509472,116.705669 42.9949846,0 L48.1345723,0 C48.1345723,-0.774700647 55,56.7834546 63.0607938,0 L66.17434,0 C66.17434,-0.960124778 70.5072591,29.23993 76.7835754,0 L78.6555388,0 C78.6555388,0.000360393587 81.8632425,16.4914595 86.0928122,0 L87.2894428,0 C87.2894428,-0.761743229 89.7692184,9.63462033 92.2144672,0 L93.1382971,0 C93.1382971,-0.227841855 94.7579743,4.40567189 96.9144218,0 L97.5682773,0 C97.5682773,-0.227841855 98.9774879,1.86613741 100,0', { precompute: 5500, eps: .00001 });
this.scaleEasing = mojs.easing.path('M0,0 C4.00577744,7.64805524 8.46993511,36.0104496 13.1512887,99.9098332 L21.3497674,100 C21.3497674,101.772296 30.5883328,-15.0576272 42.9949846,100 L48.1345723,100 C48.1345723,100.774701 54.5357691,43.5875572 63.0607938,100 L66.17434,100 C66.17434,100.960125 70.5072591,70.76007 76.7835754,100 L78.6555388,100 C78.6555388,99.9996396 81.8632425,83.5085405 86.0928122,100 L87.2894428,100 C87.2894428,100.761743 89.1622181,90.3428525 92.2144672,100 L93.1382971,100 C93.1382971,100.227842 94.7579743,95.5943281 96.9144218,100 L97.5682773,100 C97.5682773,100.227842 98.9774879,98.1338626 100,100', { precompute: 5500, eps: .00001 });
this.squashEasing = mojs.easing.path('M0,100 C0,100 4.50292969,98.5458979 13.1655083,129.599609 C13.1655083,125.550292 14.5922587,111.423982 14.9775391,100 C18.3436489,0.118817967 21.3763133,100 21.3763133,100 C21.3763133,100 24.1020114,143.589313 31.182035,100.498105 C31.328125,99.3914616 32.96875,99.9925683 32.96875,99.9925683 C32.96875,99.9925683 37.7038574,101.822997 43.1033936,119.37915 C43.4711914,114.650634 44.145598,101.943658 44.3303223,99.9925683 C46.303074,64.0298992 48.1256605,100 48.1256605,100 C48.1199951,99.9868613 49.9071233,128.571455 54.5492038,100.31832 C54.644989,99.5927399 55.7206794,99.9868608 55.7206794,99.9868608 C55.7206794,99.9868608 59.6297405,101.239014 63.1699944,112.749862 C63.4111443,109.649569 64.0730787,101.271818 64.1941948,99.9925683 C65.7125677,79.1142212 66.3750221,100 66.3750221,100 C66.3750221,100 75.6449112,100 76.9499613,100 C77.9891495,90.3360533 78.7952818,100 78.7952818,100 C78.7952818,100 85.3866104,100 86.163329,100 C86.7355255,95.6422743 87.4229688,100 87.4229688,100 C87.4229688,100 91.4811997,100 92.0937284,100 C92.6703705,97.8777651 93.2507552,100 93.2507552,100 C93.2507552,100 96.5008682,100 97.0045401,100 C97.4574799,98.8978552 97.8392386,100 97.8392386,100 L100,100', { precompute: 5500, eps: .00001 });
},
createTween: function () {
// var tween = new mojs.Timeline;
this.cubeFallTween = new mojs.Tween({
duration: this.fallDuration*this.s,
delay: this.delay*this.s,
onStart: () => { this.cubeEl.style.opacity = 1; },
onUpdate: (progress) => {
var bounceProgress = this.bouncyEasing(progress),
scaleProgress = this.scaleEasing(progress),
squashProgress = this.squashEasing(progress);
mojs.h.setPrefixedStyle(this.cubeEl, 'transform', `translate3d(0, ${- this.translateY + this.translateY*bounceProgress}px, 0)`);
mojs.h.setPrefixedStyle(this.cubeSquashEl, 'transform', `scaleX(${1+squashProgress}) scaleY(${1-squashProgress})`);
mojs.h.setPrefixedStyle(this.shadowEl, 'transform', `scale(${1+(scaleProgress)+squashProgress}) rotateX(${-28*squashProgress}deg) rotateY(${28*squashProgress}deg) translateZ(${-4*squashProgress}px)`);
this.shadowEl.style.opacity = Math.max((bounceProgress)/2, .1 );
}
});
this.cubeMainTween.add(this.cubeFallTween);
}
}
// -- CUBE ANTICIPATION
var cubeAnticipation = {
init: function (proto) {
this.proto = proto;
// set prototype to cube object
Object.setPrototypeOf(this, proto);
this.vars();
this.createTween();
},
vars: function () {
this.anticipationEasing = mojs.easing.path('M0,0 C0,0 17.1742287,-107.268176 19.3167114,-0.633646433 C19.3167114,55.7683836 100,100 100,100');
this.anticipatingYEasing = mojs.easing.path('M0,100 C4.21746922,99.7372437 14.4689363,99.8708599 19.3294067,99.8708626 C26.5066376,7.56216386 46.8866348,19.6362701 46.8866348,19.6362701 L100,19.6362701');
},
createTween: function () {
this.cubeAnticipationTween = new mojs.Tween({
delay: (this.fallDuration + 200)*this.s,
duration: (1*this.fallDuration)*this.s,
// onComplete: ()=> { mojs.h.style(this.cubeEl, 'transform', ''); },
onUpdate: (p)=> {
var anticipationProgress = this.anticipationEasing(p),
anticipationYProgress = 1-this.anticipatingYEasing(p);
mojs.h.style(this.cubeEl, 'transform', `translate3d(0, ${-this.translateY*(1-anticipationYProgress)}px, 0)`);
var nAnticipationProgress = 1+(1-anticipationProgress);
mojs.h.style(this.cubeSquashEl, 'transform', `scaleX(${anticipationProgress}) scaleY(${nAnticipationProgress})`);
if (anticipationProgress > 1) {
var scale = anticipationProgress, rotateX = 1-anticipationProgress;
} else {
var scale = nAnticipationProgress, rotateX = .2*mojs.easing.cubic.out(p);
}
mojs.h.style(this.shadowEl, 'transform', `scale(${scale})
translateX(${-.5*anticipationProgress}px)
translateY(${-.5*anticipationProgress}px)
rotateX(${30*rotateX}deg)
rotateY(${-30*rotateX}deg)`
);
this.shadowEl.style.opacity = (anticipationYProgress/2) - .3*(1-anticipationProgress);
}
});
this.cubeMainTween.add(this.cubeAnticipationTween);
}
}
var cube = {
init: function (proto) {
Object.setPrototypeOf(this, proto);
this.vars();
this.createTween();
this.initChildScenes();
// this.cubeMainTween.start();
},
vars: function () {
this.cubeEl = document.querySelector('#js-cube');
this.cubeSquashEl = document.querySelector('#js-cube-squash');
this.shadowEl = document.querySelector('#js-shadow');
this.cubeSceneEl = document.querySelector('#js-cube-scene');
this.translateY = window.innerHeight;
this.fallDuration = 2000;
this.delay = 0;
window.addEventListener('resize', ()=> { this.translateY = window.innerHeight; });
},
createTween: function () { this.cubeMainTween = new mojs.Timeline; },
initChildScenes: function () {
cubeFall.init(this);
cubeAnticipation.init(this);
this.mainTween.add(this.cubeMainTween);
}
}
// - MOLE
// -- MOLE DOOR OPEN
var doorOpen = {
init: function (proto) {
Object.setPrototypeOf(this, proto);
this.vars();
this.createTween();
// this.cubeMainTween.start();
},
vars: function () {
},
createTween: function () {
var tween = new mojs.Tween({
duration: 1000*this.s,
delay: this.delay*this.s,
onStart: () => {
this.isSound && this.doorOpenSound.play();
},
onUpdate: (p) => {
// return;
var bounce = mojs.easing.bounce.out(p);
var pp = mojs.easing.cubic.out(mojs.easing.cubic.out(p));
mojs.h.setPrefixedStyle(this.doorEl, 'transform', `rotateY(${-125*bounce}deg) translateX(${8*(1-pp)}px) translateY(${8*(1-pp)}px) scaleX(${1-(.25*bounce)})`);
var shadowBounce = mojs.easing.cubic.in(bounce);
mojs.h.setPrefixedStyle(this.doorShadowEl, 'transform', `scaleX(${shadowBounce}) translateZ(0)`);
this.doorShadowEl.style.opacity = shadowBounce;
mojs.h.setPrefixedStyle(this.doorHandleShadowEl, 'transform', `rotateZ(${-75*(1-bounce)}deg) scaleY(${bounce}) translateZ(0)`);
this.doorHandleShadowEl.style.opacity = bounce;
}
});
this.moleTimeline.add(tween);
}
}
// -- MOLE OPEN
var moleOpen = {
init: function (proto) {
Object.setPrototypeOf(this, proto);
this.vars();
this.createTween();
this.initChildScenes();
},
vars: function () {
this.moleMouthEl = document.querySelector('#js-mole-mouth');
this.moleBodyEl = document.querySelector('#js-mole-body');
this.moleInnerEl = document.querySelector('#js-mole-inner');
mojs.h.style(this.moleMouthEl, 'transform', 'scale(0.25)');
},
createTween: function () {
var motionPathStagger = mojs.Stagger(mojs.MotionPath);
var s = this.s;
var moleOpenMotionPath = new motionPathStagger({
// motionBlur: [.2, null, null, null, null],
delay: [(this.delay+100)*s, (this.delay+250)*s, (this.delay+250)*s, (this.delay+225)*s, (this.delay+225)*s],
duration: [500*s, 450*s, 450*s, 300*s, 300*s],
path: [{x: 25, y: -240}, {x: 0, y: -1}, {x: 0, y: -1}, {x: 0, y: -1}, {x: 0, y: -1}],
curvature: [{x: '140%', y: '-15%'}, {x: '8000%', y: '-15%'}, {x: '4000%', y: '-15%'}, {x: '6000%'}, {x: '6000%'}],
el: [this.moleEl, this.moleHandEl, this.moleHandLeftEl, this.moleGlassesEl, this.moleGlassesLeftEl],
easing: ['expo.out', 'expo.out', 'expo.out', 'bounce.out', 'bounce.out'],
onStaggerStart: () => { this.isSound && this.whooshSound1.play(); }
});
var coneEasing = mojs.easing.path('M0,100 C0,100 19.2604909,99.9551166 20.5142238,99.9551166 C22.4949103,-13.4780187 30.6324028,0.551751812 30.6324028,0.551751812 C34.4304749,8.15161955 38.3387131,36.3731334 42.4370999,100 C42.4370999,101.784879 50.525191,-14.4647311 61.3868482,100 C61.3868482,100.758318 66.9909069,43.8552324 74.4543142,100 C74.4543142,100.959118 78.2476568,70.9090718 83.7423864,100 C83.7423864,100 86.5506362,83.5459334 90.2534996,100 C90.2534996,100.758318 91.893059,90.3911797 94.5652129,100 C94.5652129,100.155918 95.9831925,95.5454201 97.8710986,100 C97.8710986,100.155918 99.1048209,98.0723403 100,100');
var coneTween = new mojs.Tween({
delay: (this.delay+0)*this.s,
duration: 1200*this.s,
onUpdate: (p) => {
var coneP = coneEasing(p);
mojs.h.style(this.moleConeEl, 'transform', `rotateX(${140*coneP}deg) rotateY(${-20*coneP}deg) translateY(${-6*coneP}px)`);
mojs.h.style(this.moleConeShadowEl, {
opacity: 1 - coneP,
transform: `scaleX(${1-mojs.easing.cubic.in(coneP)}) translateZ(0)`
});
}
});
var stretchCurve = mojs.easing.path('M0,0 C0,0 31.4848633,29.7739254 55.2021484,-4.28613761e-07 C74.9160156,-20.18457 100,0 100,0');
var stretchTween = new mojs.Tween({
delay: (this.delay+0)*this.s,
duration: 500*this.s,
onUpdate: (p) => {
var stretchP = stretchCurve(p);
var inv = 1+(1-stretchP);
mojs.h.setPrefixedStyle(this.moleInnerEl, 'transform', `scaleX(${stretchP}) scaleY(${inv}) translateZ(0)`);
}
});
this.moleTimeline.add( moleOpenMotionPath, coneTween, stretchTween );
},
initChildScenes: function () {
}
}
// -- MOLE RANTING
// --- MOLE RANTING TONGUE
var tongue = {
init: function (proto) {
proto && Object.setPrototypeOf(this, proto);
this.vars();
this.createTween();
// this.initChildScenes();
},
vars: function () {
this.delay = this.handRantingDuration+275; this.duration = 1800;
},
createTween: function () {
var skewCurve = mojs.easing.path('M0,100 C0,100 18.1450901,69.0663515 24.0949898,99.9609384 C30.0448895,130.855525 100,100 100,100');
var handCurve = mojs.easing.path('M0,-3.55271368e-14 C10.9545898,-40.8999024 23.9307575,-0.575683661 23.930758,0.136022468 C23.9307575,99.5087928 23.9307575,123.533199 42.6040039,123.533196 C47.594178,123.533196 54.2372213,123.00636 61.2202377,122.247035 C61.5346348,122.212848 63.3167217,121.96483 65.9540934,121.59172 C76.2346029,120.13733 99.5107422,116.78222 99.5107422,116.78222');
var mouthCurve = mojs.easing.path('M0,0.300003052 C0,-118.289845 23.9999996,0.30000305 23.9999996,0.30000305 C23.9999996,0.30000305 28.9929691,57.0874986 31.8132816,63.7992219 C86.0328155,57.0874986 100,72.5585908 100,72.5585908');
var noizeCurve = mojs.easing.path('M0,99.05 L24.2114672,99.1070023 L27.0786839,106.049107 L29.2555809,92.7589286 L32.0340385,103.220982 L35.3459816,94.0055804 L38.3783493,102.496652 L41.0513382,95.3588169 L43.7739944,106.049107 L45.6729927,96.3013392 L50,104.487165 L53.3504448,92.7589286 L57.7360497,103.220982 L60.8616066,95.3588169 L65.0345993,102.496652 L68.6997757,96.9146207 L71.6646194,101.435268 L75.0262299,95.3588169 L78.0089264,104.487165 L81.2276764,92.7589286 L84.390625,102.496652 L85.7360458,95.3588169 L88.4709854,101.435268 L90.9453125,96.3013392 L94.2198639,103.220982 L96.1110458,94.0055804 L100,99.05');
var saliva = new mojs.Burst({
parent: this.moleEl,
type: 'circle',
fill: 'white',
duration: (this.duration/1.3)*this.s,
x: 145, y: 105,
delay: `stagger(${(this.duration/4)*this.s}, rand(50, 100))`,
degree: 0,
angle: {75: 150},
isSwirl: true,
randomRadius: .75,
radius: {0:150},
count: 16,
isRunLess: true,
childOptions: {
radius: { 'rand(.5,2)' : 0},
duration: 300*this.s,
}
});
saliva.el.style['z-index'] = 10;
var salivaLauncher = new mojs.Tween({
delay: 435*this.s,
onStart: () => {
this.isSound && this[`salivaSound${Math.round(mojs.h.rand(1,2))}`].play();
}
});
var squintCurve = mojs.easing.mix({ to: .25, value: 1 }, { to: 1, value: 'cubic.in' });
mojs.h.style(this.moleMouthEl, 'transform-origin', `right center`);
var tween = new mojs.Tween({
delay: this.delay*this.s,
duration: this.duration*this.s,
onStart: ()=> { if (!this.isMobile()) { saliva.run(); }; salivaLauncher.run(); this.isSound && this.sighSound1.play(); },
onUpdate: (p)=> {
var skewP = skewCurve(p);
var handP = handCurve(p);
var mouthP = mouthCurve(p);
var noizeP = noizeCurve(p);
mojs.h.style(this.moleEl, 'transform', `skewX(${(75*skewP)-(5*noizeP)}deg) skewY(${15*noizeP}deg) ${this.zHack}`);
mojs.h.style(this.moleHandEl, 'transform', `rotate(${(this.handAngle*handP)+(30*noizeP)}deg) ${this.zHack}`);
mojs.h.style(this.moleHandLeftEl, 'transform', `rotate(${(100*skewP)-(15*noizeP)}deg) translateY(${(-100*skewP)}px) ${this.zHack}`);
mojs.h.style(this.moleMouthEl, 'transform', `scale(${mouthP+(3*noizeP)}) translate(${-30*skewP}px, 0) ${this.zHack}`);
mojs.h.style(this.moleGlassesEl, 'transform', `translateY(${20*noizeP}px) ${this.zHack}`);
mojs.h.style(this.moleGlassesLeftEl,'transform', `translateY(${10*noizeP}px) ${this.zHack}`);
mojs.h.style(this.moleEyeEl, 'transform', ``);
mojs.h.style(this.moleConeEl, 'transform', `rotateZ(${20*noizeP}deg) ${this.zHack}`);
mojs.h.style(this.moleTongueEl, 'transform', `translate(${-140*skewP}px, 0) ${this.zHack}`);
this.moleTonguePath.setAttribute('d', `M0 30 Q 20 ${10+(550*noizeP)}, 30 25 T 50 30`);
// SQUINT
var squintP = squintCurve(p);
var n_squintP = mojs.easing.inverse(squintP);
this.moleEyeLashEl.setAttribute('d', `M0,0 Q 6.5 ${10*squintP}, 13 0`);
this.moleEyeLashEl.setAttribute('stroke-width', 2 + 1.5*n_squintP);
mojs.h.style(this.moleEyeEl, 'transform', `rotate(${37*n_squintP}deg) translate(${7*n_squintP}px, ${-4*n_squintP}px) scaleX(${1-.4*n_squintP}) ${this.zHack}`);
}
});
// tween.start();
this.moleRantingTween.add(tween);
}
}
// --- MOLE RANTING HAND
// SCENES
var moleRantingHand = {
init: function (proto) {
Object.setPrototypeOf(this, proto);
this.vars();
this.createTween();
this.initChildScenes();
},
vars: function () {
},
createTween: function () {
var handAngleCurve = mojs.easing.path('M0,100 L3.13085938,99.9660558 C11.128418,-42.5141612 24.7357688,10.3389432 24.7357688,10.3389432 C24.7357688,10.3389432 35.4207115,6.43611673 35.420711,19.551763 C35.420711,19.551763 35.4207115,28.5204487 38.4679491,20.1010452 C45.9122391,-2.41706848 48.2480469,19.3280379 49.4205542,19.3280385 C49.4205546,6.88000841 55.0592461,-3.51334643 59,15.8785806 C60.6251608,22.5931723 56.8918457,-3.3408203 65.4951172,-3.3408203 C68.7340668,-3.54252346 69.730594,6.60260412 70.328125,14.0234368 C70.9301836,21.5004985 74.0961573,27.0302603 74.7888322,18.8316301 C77.5927734,-0.603027419 100,0 100,0');
var handStretchCurve = mojs.easing.path('M1.13686838e-13,100.140658 C1.13686838e-13,100.140658 5.01160836,100.097038 8.74856937,100.270866 C15.1440434,57.219434 23.7860103,98.447299 23.7860103,100.097037 C30.2913574,71.1380541 36.1603623,98.3939125 36.160361,100.162142 C41.9325738,44.182975 49.1344299,98.9199542 49.1344299,100.053418 C53.6287224,80.2298508 59.2720971,99.9303714 59.2720971,99.9303714 C59.2720971,99.9303714 63.6972656,56.5605469 70.2742418,100.003578 C72.7851563,131.47461 74.5979385,101.614397 75,100.097038 C78.8691406,68.734375 82.3889542,100.577847 94.1109085,100.097038 L99.9962311,100.097038');
var tween = new mojs.Tween({
delay: 500*this.s,
duration: this.handRantingDuration*this.s,
onStart: () => {
this.isSound && this[`rantSound${Math.round(mojs.h.rand(1,3))}`].play();
},
onUpdate: (p)=> {
var handP = handAngleCurve(p);
var handStretchP = handStretchCurve(p);
var inv = mojs.easing.inverse(handStretchP);
var shiftP = mojs.easing.quad.out(p);
var handStretchShiftP = handStretchCurve(shiftP);
mojs.h.style(this.moleHandEl, 'transform', `rotate(${this.handAngle*handP}deg) scaleX(${1-(.4*handStretchP)}) scaleY(${1+handStretchP}) ${this.zHack}`);
mojs.h.style(this.moleHandLeftEl, 'transform', `translateY(${-75*handStretchP}px) ${this.zHack}`);
mojs.h.style(this.moleGlassesEl, 'transform', `translateY(${-45*handStretchShiftP}px) ${this.zHack}`);
mojs.h.style(this.moleGlassesLeftEl, 'transform', `translateY(${-45*handStretchShiftP}px) ${this.zHack}`);
var bodyScale = .25*handStretchP;
mojs.h.style(this.moleEl, 'transform', `scaleY(${1+bodyScale}) scaleX(${1-bodyScale}) ${this.zHack}`);
mojs.h.style(this.moleMouthEl, 'transform', `scale(${Math.min(1-(5*handStretchP), 1.2)}) translateX(${Math.min(-50*handStretchShiftP, 10)}px) ${this.zHack}`);
mojs.h.style(this.moleMouthInnerEl, 'transform', `scale(${1-(4*handStretchP)}) translateX(${Math.min(-150*handStretchP, 10)}px) translateY(${(-20*handStretchShiftP)}px) ${this.zHack}`);
mojs.h.style(this.moleMouthOuterEl, 'border-top-right-radius', `${200*(handStretchShiftP)}%`);
}
});
this.moleRantingTween.add(tween);
},
initChildScenes: function () { }
}
// --- MOLE RANTING SEARCH
var moleRantingSearch = {
init: function (proto) {
Object.setPrototypeOf(this, proto);
this.vars();
this.createTween();
this.initChildScenes();
},
vars: function () {
this.doorEl = document.querySelector('#js-door');
this.doorShadowEl = document.querySelector('#js-door-shadow');
this.doorHandleShadowEl = document.querySelector('#js-door-handle-shadow');
},
createTween: function () {
var timeLine = new mojs.Timeline;
var duration = 1000;
var doorSound1Tween = new mojs.Tween({
delay: 510*this.s,
onStart: () => { this.isSound && this.doorOpenSoundSmall.play(); }
});
var wehSound1Tween = new mojs.Tween({
delay: 120*this.s,
onStart: () => { this.isSound && this.wehSound1.play(); }
});
var wehSound2Tween = new mojs.Tween({
delay: 400*this.s,
onStart: () => { this.isSound && this.wehSound2.play(); }
});
var e = mojs.easing;
var bodySkewC = e.path('M0.506500786,100 C0.506500786,100 5.85142524,99.4107621 7.9810887,99.4107621 C7.9810887,66.899765 14.0576168,-39.8300779 32.375588,23.1162121 C34.150559,29.6685115 40.0307601,29.7045647 40.8105474,23.116212 C49.0488287,-46.488282 57.7949224,0 66.8462524,0.141452063 C79.10852,0.14145202 100.481854,0 100.481854,0');
var riseC = e.path('M0.504882812,100 L8.29748693,100 C19.3574219,34.4345703 32.1187229,99.4550794 32.1187235,100 C32.1187235,100 37.9296875,122.487303 43.1708984,99.4550794 C51.9283709,10.3408208 63.429554,94.8232407 63.4295529,100 C67.7822266,127.167966 76.9882812,99.4550793 76.9882812,99.4550793 L100.110353,100');
var doorAngleC = e.mix({ to: .45, value: 1 }, { to: 1, value: bodySkewC });
var tween = new mojs.Tween({
duration: duration*this.s,
onUpdate: (p)=> {
var riseP = riseC(p);
var bodySkewP = bodySkewC(p);
mojs.h.style(this.moleEl, 'transform', `skewX(${9*bodySkewP}deg) scale(${1-.15*riseP}, ${1+.15*riseP}) translate(0, ${-17*riseP}px) ${this.zHack}`);
mojs.h.style(this.moleHandEl, 'transform', `rotate(${29.5 + 65*bodySkewP}deg) scaleY(${1+.1*bodySkewP}) translateY(${-15*riseP}px) ${this.zHack}`);
mojs.h.style(this.moleHandLeftEl, 'transform', `rotate(${20*bodySkewP}deg) translate(${30*bodySkewP}px, ${-10*bodySkewP - 10*riseP}px) ${this.zHack}`);
this.moleEyeLashEl.setAttribute('d', `M0,0 Q ${6.5 - 13*riseP} ${10-30*Math.max(riseP, 0)}, 13 0`);
this.moleEyeLashEl.setAttribute('stroke-width', 2 + 2.5*riseP);
mojs.h.style(this.moleEyeEl, 'transform', `rotate(${60*riseP}deg) translate(${7*riseP}px, ${-4*riseP}px) scaleX(${1-.9*riseP}) ${this.zHack}`);
mojs.h.style(this.moleMouthEl, 'transform', `scale(${.3 + 2.4*riseP}) ${this.zHack}`);
}
});
var tween2 = new mojs.Tween({
duration: duration*this.s,
onUpdate: (p) => {
var riseP = riseC(p);
mojs.h.setPrefixedStyle(this.moleConeEl, 'transform', `rotateX(${210*riseP}deg) ${this.zHack}` );
mojs.h.setPrefixedStyle(this.moleGlassesEl, 'transform', `translateY(${-25*riseP}px) ${this.zHack}` );
mojs.h.setPrefixedStyle(this.moleGlassesLeftEl, 'transform', `translateY(${-25*riseP}px) ${this.zHack}` );
}
});
var tween3 = new mojs.Tween({
delay: 50*this.s,
duration: duration*this.s,
onUpdate: (p) => {
var doorAngleP = doorAngleC(p);
mojs.h.setPrefixedStyle(this.doorEl, 'transform', `rotateY(${-125 + 90*e.inverse(doorAngleP)}deg) scaleX(.75) ${this.zHack}`);
mojs.h.setPrefixedStyle(this.doorShadowEl, 'transform', `scaleX(${1-.45*e.inverse(doorAngleP)}) ${this.zHack}`);
}
});
timeLine.add(tween, wehSound1Tween, wehSound2Tween, tween2, tween3, doorSound1Tween);
this.moleRantingTween.append(timeLine);
},
initChildScenes: function () {}
}
var moleRanting = {
init: function (proto) {
Object.setPrototypeOf(this, proto);
this.vars();
this.createTween();
this.initChildScenes();
},
vars: function () {
this.scene = document.querySelector('#js-mole-scene');
this.moleEl = document.querySelector('#js-mole-inner');
this.moleTongueEl = document.querySelector('#js-mole-tongue');
this.moleTonguePath = document.querySelector('#js-mole-tongue-path');
this.handAngle = -175;
this.handRantingDuration = 1500;
},
createTween: function () {
this.moleRantingTween = new mojs.Timeline;
},
initChildScenes: function () {
moleRantingHand.init(this);
tongue.init(this);
moleRantingSearch.init(this);
this.moleTimeline.add(this.moleRantingTween);
}
}
// -- MOLE CLOSE
var close = {
init: function (proto) {
Object.setPrototypeOf(this, proto);
this.vars();
this.createTween();
},
vars() {
this.moleInnerEl = document.querySelector('#js-mole-inner');
},
resetParts() {},
createTween() {
var delay = 4400;
var e = mojs.easing, h = mojs.h;
this.closeTimeline = new mojs.Timeline({ delay: delay*this.s });
var closeSoundLauncher = new mojs.Tween({
duration: 50,
delay: 150*this.s,
onStart: ()=> { this.isSound && this.doorCloseSound.play(); this.isSound && this.fallingSound.play(); }
});
var moveDownTween = new mojs.Tween({
duration: 600*this.s,
onStart: () => { this.moleHandCircleEl.style.opacity = 1; },
onComplete: () => {
this.resetParts();
this.moleHandCircleEl.style.opacity = 0;
h.style( this.moleHandEl, 'transform', '' );
h.style( this.moleHatEl, 'transform', '' );
this.moleHatEl.style['z-index'] = 4;
this.moleEyeLashEl.setAttribute('d', `M0,0 Q 6.5 10, 13 0`);
this.moleEyeLashEl.setAttribute('stroke-width', 2);
mojs.h.style(this.moleEyeEl, 'transform', '');
h.style( this.moleGlassesEl, 'transform', '' );
h.style( this.moleGlassesLeftEl, 'transform', '' );
},
onUpdate: (p) => {
var cubicInP = e.cubic.in(p);
var quadInP = e.quad.in(p);
var expoInP = e.expo.in(p);
h.style( this.moleEl, 'transform', `translate(${25}px, ${-240 + 360*cubicInP}px) ${this.zHack}` );
// (p === 1) && (this.moleEl.style['z-index'] = 0);
h.style( this.moleInnerEl, 'transform', `skewX(${9*(1-p)}deg) scale(${ 1 - .2*cubicInP }, ${ 1 + .2*cubicInP }) ${this.zHack}` );
h.style( this.moleHandEl, 'transform', `rotate(${94.5 + 100.5*quadInP}deg) scaleY(${1.1 - .1*quadInP}) translateY(${70*quadInP}px) ${this.zHack}` );
h.style( this.moleHandLeftEl, 'transform', `rotate(${20 - 20*quadInP}deg) translate(${30 - 35*quadInP}px, ${-10 - 70*quadInP}px) ${this.zHack}` );
h.style( this.doorEl, 'transform', `rotateY(${ -125 + 125*cubicInP }deg) scaleX(${.75 + .25*expoInP}) translate(${8*expoInP}px, ${8*expoInP}px) ${this.zHack}` );
h.style( this.doorShadowEl, 'transform', `scaleX(${1 - 1.65*cubicInP}) ${this.zHack}` );
h.style( this.moleConeEl, 'transform', `rotateX(${150*quadInP}deg) rotateY(${-14*quadInP}deg) translateY(${-5*quadInP}px) ${this.zHack}` );
this.moleConeShadowEl.style.opacity = 1-p;
h.style( this.moleHatEl, 'transform', `translateY(${-35*expoInP}px) ${this.zHack}` );
this.moleHatEl.style['z-index'] = Math.round(12 - 12*p);
h.style( this.moleGlassesEl, 'transform', `translateY(${-85*expoInP}px) ${this.zHack}` );
h.style( this.moleGlassesLeftEl, 'transform', `translateY(${-85*expoInP}px) ${this.zHack}` );
this.moleEyeLashEl.setAttribute('d', `M0,0 Q 6.5 ${10*p}, 13 0`);
this.moleEyeLashEl.setAttribute('stroke-width', 2 + 1.5*p);
mojs.h.style(this.moleEyeEl, 'transform', `translate(${7*p}px, ${-5*p}px) scaleX(${1-.4*p}) ${this.zHack}`);
mojs.h.style(this.moleMouthInnerEl, 'transform', `scale(${.3 - .3*p}) ${this.zHack}`);
}
});
var burstStagger = new mojs.Stagger(mojs.Burst)({
quantifier: 4,
parent: this.moleSceneEl,
x: [145, 295, 50, 175],
y: [75, 25, 25, 0],
shiftY: [{0: -65}, {0: -50}, {0: -50}, {0: -35}],
degree: 50,
randomRadius: 1,
randomAngle: .2,
angle: -25,
isRunLess: true,
fill: 'white',
count: 'rand(3,5)',
childOptions: { radius: {'rand(2, 5)': 0} }
});
for (var module of burstStagger.childModules) { module.el.style['z-index'] = 3; }
var doorWaveTween = new mojs.Tween({
duration: 400*this.s,
onUpdate: (p) => {
mojs.h.style(this.doorWaveEl, 'transform', `scale(${1.1 + 2*e.cubic.out(p)}) ${this.zHack}`);
this.doorWaveEl.style.opacity = 1 - e.expo.out(p);
}
});
var noiseCurve = mojs.easing.path('M0.259486607,100.071429 C0.259486607,100.071429 4.27680653,83.4402907 6.90123802,100.071429 C9.52566951,116.702566 13.5373987,100.071429 13.5373987,100.071429 C13.5373987,100.071429 16.7628232,87.9112723 21.6735437,100.071429 C26.5842642,112.231585 30.9212118,100.071429 30.9212118,100.071429 C30.9212118,100.071429 37.4556606,76.8219874 36.8193484,100.071429 C36.1830363,123.32087 44.2583534,100.071429 44.2583534,100.071429 C44.2583534,100.071429 52.7238326,76.230468 58.7731881,100.071429 C64.8225436,123.912389 71.8496108,100.071429 71.8496108,100.071429 C71.8496108,100.071429 76.8389838,84.6718743 77.5101727,100.071429 C78.1813616,115.470983 86.7695435,100.071429 86.7695435,100.071429 C86.7695435,100.071429 90.9161334,91.365514 92.5121951,100.071429 C94.1082567,108.777343 97.4553275,100.071429 97.4553275,100.071429 C97.4553275,100.071429 98.5630678,96.4871648 100.000003,100.071429');
var noiseTween = new mojs.Tween({
duration: 200*this.s,
onStart: () => { this.isSound && this.boomSound.play(); },
onUpdate: (p)=> {
mojs.h.style(this.sceneEl, 'transform', `translate(${noiseCurve(p)*40}px, ${-noiseCurve(p)*20}px) ${this.zHack}`);
}
});
var staggerAddTween = (this.isMobile() ? new mojs.Timeline : burstStagger.timeline);
var doorWaveAddTween = (this.isMobile() ? new mojs.Timeline : doorWaveTween);
this.closeTimeline
.add(moveDownTween, closeSoundLauncher)
.append([ staggerAddTween, doorWaveAddTween, noiseTween]);
this.moleTimeline.add(this.closeTimeline);
},
initChildScenes: function () {
}
}
var mole = {
init(proto) {
Object.setPrototypeOf(this, proto);
this.vars();
this.createTween();
this.initChildScenes();
this.initChildParts();
this.mainTween.add(this.moleTimeline);
},
vars() {
this.scene = document.querySelector('#js-mole-scene');
},
createTween() {
this.moleTimeline = new mojs.Timeline({ delay: (this.cubeDuration-1200)*this.s }); },
initChildScenes() {
doorOpen.init(this);
moleOpen.init(this);
},
initChildParts() {
moleRanting.init(this);
close.init(this);
}
}
var main = {
s: 1, // global time coefficient
zHack: ' translateZ(0) ',
mainTween: new mojs.Timeline({ repeat: 999999, delay: 0 }),
delay: 0,
cubeDuration: 3900,
isSound: true,
init() {
this.vars();
this.showHiddenParts();
this.loadSounds();
},
showHiddenParts () {
this.sceneEl.style.opacity = 1;
this.tutorialsLinkEl.style.opacity = 1;
},
loadSounds() {
var soundBase = 'https://s3-us-west-2.amazonaws.com/s.cdpn.io/6859/';
var soundUrl = `${soundBase}fall-kick-1.${this.soundFileType}`;
this.fall1Sound = new Howl({ urls: [ soundUrl ], onload: this.tryToLaunch.bind(this) });
this.fall2Sound = new Howl({ urls: [ soundUrl ], rate: .9, volume: .8, onload: this.tryToLaunch.bind(this) });
this.fall3Sound = new Howl({ urls: [ soundUrl ], rate: .8, volume: .5, onload: this.tryToLaunch.bind(this) });
this.fall4Sound = new Howl({ urls: [ soundUrl ], rate: .7, volume: .4, onload: this.tryToLaunch.bind(this) });
this.fall5Sound = new Howl({ urls: [ soundUrl ], rate: .6, volume: .3, onload: this.tryToLaunch.bind(this) });
this.whooshSound1 = new Howl({ urls: [`${soundBase}whoosh-1.${this.soundFileType}`], volume: .4, rate: 1.4, onload: this.tryToLaunch.bind(this) });
this.doorOpenSound = new Howl({ urls: [`${soundBase}door-open-1.${this.soundFileType}`], rate: 2.5, onload: this.tryToLaunch.bind(this) });
this.salivaSound1 = new Howl({ urls: [ `${soundBase}saliva-1.${this.soundFileType}` ], onload: this.tryToLaunch.bind(this) });
this.salivaSound2 = new Howl({ urls: [ `${soundBase}saliva-2.${this.soundFileType}` ], onload: this.tryToLaunch.bind(this) });
this.sighSound1 = new Howl({ urls: [ `${soundBase}sigh-1.${this.soundFileType}` ], rate: 1.8, onload: this.tryToLaunch.bind(this) });
this.doorOpenSoundSmall = new Howl({ urls: [`${soundBase}door-open-small-1.${this.soundFileType}`], rate: 1.9, volume: .6, onload: this.tryToLaunch.bind(this) });
this.wehSound1 = new Howl({ urls: [`${soundBase}ugh-2.${this.soundFileType}`], volume: .35, rate: 1.25, onload: this.tryToLaunch.bind(this) });
this.wehSound2 = new Howl({ urls: [`${soundBase}ugh-1.${this.soundFileType}`], volume: .35, rate: 1.35, onload: this.tryToLaunch.bind(this) });
this.rantSound1 = new Howl({ urls: [`${soundBase}rant-1-1.${this.soundFileType}`], rate: 1.25, volume: .65, onload: this.tryToLaunch.bind(this) });
this.rantSound2 = new Howl({ urls: [`${soundBase}rant-1-2.${this.soundFileType}`], rate: 1.25, volume: .65, onload: this.tryToLaunch.bind(this) });
this.rantSound3 = new Howl({ urls: [`${soundBase}rant-1-3.${this.soundFileType}`], rate: 1.25, volume: .65, onload: this.tryToLaunch.bind(this) });
this.doorCloseSound = new Howl({ urls: [`${soundBase}door-close-1.${this.soundFileType}`], rate: 1.5, volume: .65, onload: this.tryToLaunch.bind(this) });
this.boomSound = new Howl({ urls: [ `${soundBase}fall-kick-1.${this.soundFileType}` ], rate: .5, onload: this.tryToLaunch.bind(this) });
this.fallingSound = new Howl({ urls: [ `${soundBase}falling-1.${this.soundFileType}` ], rate: 4.5, volume: .05, onload: this.tryToLaunch.bind(this) });
},
tryToLaunch() {
this.soundsLoadedCnt++;
if (this.soundsLoadedCnt >= 19 && !this.isLaunched ) { this.isLaunched = true; this.onSoundsLoaded(); }
},
onSoundsLoaded() {
this.spinnerEl.style.opacity = 0;
cube.init(this)
mole.init(this);
this.mainTween.start();
},
vars() {
this.sceneEl = document.querySelector('#js-mole-scene');
this.moleEl = document.querySelector('#js-mole');
this.moleHatEl = document.querySelector('#js-mole-hat');
this.moleConeEl = document.querySelector('#js-mole-hat-cone');
this.moleConeShadowEl = document.querySelector('#js-mole-hat-shadow');
this.moleGlassesEl = document.querySelector('#js-mole-glasses');
this.moleGlassesLeftEl = document.querySelector('#js-mole-glasses-left');
this.moleMouthEl = document.querySelector('#js-mole-mouth');
this.moleMouthInnerEl = document.querySelector('#js-mole-mouth-inner');
this.moleMouthOuterEl = document.querySelector('#js-mole-mouth-outer');
this.moleHandEl = document.querySelector('#js-mole-hand');
this.moleHandLeftEl = document.querySelector('#js-mole-hand-left');
this.moleHandCircleEl = document.querySelector('#js-mole-hand-circle');
this.doorEl = document.querySelector('#js-door');
this.doorShadowEl = document.querySelector('#js-door-shadow');
this.doorHandleShadowEl = document.querySelector('#js-door-handle-shadow');
this.moleEyeEl = document.querySelector('#js-mole-eye');
this.moleEyeLashEl = document.querySelector('#js-mole-eye-lash');
this.moleSceneEl = document.querySelector('#js-mole-scene');
this.doorWaveEl = document.querySelector('#js-door-wave');
this.tutorialsLinkEl = document.querySelector('#js-tutorials-link');
this.spinnerEl = document.querySelector('#js-spinner');
this.soundFileType = (this.isOpera()) ? 'wav' : 'mp3';
this.soundsLoadedCnt = 0;
},
isMobile: function () {
return !!(navigator.userAgent.match(/Android/i) || navigator.userAgent.match(/webOS/i) || navigator.userAgent.match(/iPhone/i) || navigator.userAgent.match(/iPad/i) || navigator.userAgent.match(/iPod/i) || navigator.userAgent.match(/BlackBerry/i) || navigator.userAgent.match(/Windows Phone/i));
},
isOpera: function () {
var userAgent = navigator.userAgent;
return /^Opera\//.test(userAgent) || /\x20OPR\//.test(userAgent);
}
}
main.init();
<script src="//cdn.jsdelivr.net/mojs/0.147.3/mo.min.js"></script>
<script src="//cdn.jsdelivr.net/howler.js/1.1.27/howler.min.js"></script>
PX = (1/16)rem
GS = 10*PX
BRADIUS = 8*PX
c-main-background = #50E3C2
rect()
width arguments
height arguments
circle()
border-radius 50%
rect arguments
body
paddding 0
margin 0
background c-main-background
font-size 16px
height 100%
overflow hidden
// MOLE
.mole
width 204*PX
height 274*PX
&__head
width 172*PX
height 116*PX
background url('data:image/svg+xml;base64,PD94bWwgdmVyc2lvbj0iMS4wIiBlbmNvZGluZz0iVVRGLTgiIHN0YW5kYWxvbmU9Im5vIj8+PHN2ZyB3aWR0aD0iMTcycHgiIGhlaWdodD0iMTE2cHgiIHZpZXdCb3g9IjAgMCAxNzIgMTE2IiB2ZXJzaW9uPSIxLjEiIHhtbG5zPSJodHRwOi8vd3d3LnczLm9yZy8yMDAwL3N2ZyIgeG1sbnM6eGxpbms9Imh0dHA6Ly93d3cudzMub3JnLzE5OTkveGxpbmsiIHhtbG5zOnNrZXRjaD0iaHR0cDovL3d3dy5ib2hlbWlhbmNvZGluZy5jb20vc2tldGNoL25zIj4gICAgICAgIDx0aXRsZT5VbnRpdGxlZCA3IENvcHk8L3RpdGxlPiAgICA8ZGVzYz5DcmVhdGVkIHdpdGggU2tldGNoLjwvZGVzYz4gICAgPGRlZnM+PC9kZWZzPiAgICA8ZyBpZD0iUGFnZS0xIiBzdHJva2U9Im5vbmUiIHN0cm9rZS13aWR0aD0iMSIgZmlsbD0ibm9uZSIgZmlsbC1ydWxlPSJldmVub2RkIiBza2V0Y2g6dHlwZT0iTVNQYWdlIj4gICAgICAgIDxnIGlkPSJoZWFkLSstbm9zZS1jb3B5IiBza2V0Y2g6dHlwZT0iTVNMYXllckdyb3VwIj4gICAgICAgICAgICA8cGF0aCBkPSJNMC44MDQ5OTkzMDQsOTMuODc3MTM2NSBDMC44MDQ5OTkzMDQsOTMuODc3MTM2NSAxNC45NjM5NzU4LC0xOS42NTU4MTU5IDEwNS40MTE0NDUsMy4zNDQ5MDk5IEMxMTguOTQ4NTU0LDcuMTAyNzIyNDEgMTQwLjA5Nzk2OCwxNy42Mzg4NTQ3IDE2My42ODQ4ODIsMjAuNDUxMzU1NyBDMTY2LjkwNzUzOCwyNC45NTUyNjIgMTYxLjgwMjA3LDM1LjY1MjUyNzEgMTYxLjgwMjA3LDM1LjY1MjUyNzEgQzE2MS44MDIwNywzNS42NTI1MjcxIDE1My4zMTg2NzEsNjEuNTY1NjEzNSAxNDMuMzY1NTQ2LDc4LjkyMzAzNDkgQzExNS44Mzg4NjYsMTI1Ljg2MzI4MiA0LjA4MDA3ODA1LDEyNC44NTU0NjUgMC44MDQ5OTkzMDQsOTMuODc3MTM2NSBaIiBpZD0iaGVhZCIgZmlsbD0iIzRDNDA0MCIgc2tldGNoOnR5cGU9Ik1TU2hhcGVHcm91cCI+PC9wYXRoPiAgICAgICAgICAgIDxwYXRoIGQ9Ik0xNjYuNDI4MTMsMjguNDAxMjA2NCBDMTY0Ljk2OTgwNCwyOS4xNzQxNzAyIDE2Mi44MjM3MDEsMjguODcxODcwOSAxNjEuNjMzMTM4LDI3LjcyNDUyMDUgTDE1OS4yOTQ0MzQsMjUuNDcwNzAzMSBDMTU5LjI5NDQzNCwyNS40NzA3MDMxIDE1Ni43MzE5MzQsMjcuMTgyNjE3MiAxNTQuNjkyODcxLDI0LjQzOTQ1MzEgQzE1Ny45ODE5MzQsMTIuNTczMjQyMiAxNzEuMzA3MTI5LDE5LjEzNjcxODcgMTcxLjMwNzEyOSwyMi4wMDc4MTI1IEMxNzEuMzA3MTI5LDI2LjY1OTE3OTcgMTY2LjQyODEzLDI4LjQwMTIwNjQgMTY2LjQyODEzLDI4LjQwMTIwNjQgWiIgaWQ9Im5vc2UiIGZpbGw9IiNDOTU0NEEiIHNrZXRjaDp0eXBlPSJNU1NoYXBlR3JvdXAiPjwvcGF0aD4gICAgICAgIDwvZz4gICAgPC9nPjwvc3ZnPg==')
position absolute
top 2*GS
left .4*GS
z-index 1
&__glasses
width 118*PX
height 55*PX
position absolute
top 2.3*GS
left 2.6*GS
background url('data:image/svg+xml;base64,PD94bWwgdmVyc2lvbj0iMS4wIiBlbmNvZGluZz0iVVRGLTgiIHN0YW5kYWxvbmU9Im5vIj8+PHN2ZyB3aWR0aD0iMTE4cHgiIGhlaWdodD0iNTVweCIgdmlld0JveD0iMCAwIDExOCA1NSIgdmVyc2lvbj0iMS4xIiB4bWxucz0iaHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmciIHhtbG5zOnhsaW5rPSJodHRwOi8vd3d3LnczLm9yZy8xOTk5L3hsaW5rIiB4bWxuczpza2V0Y2g9Imh0dHA6Ly93d3cuYm9oZW1pYW5jb2RpbmcuY29tL3NrZXRjaC9ucyI+ICAgICAgICA8dGl0bGU+Z2xhc3NlczwvdGl0bGU+ICAgIDxkZXNjPkNyZWF0ZWQgd2l0aCBTa2V0Y2guPC9kZXNjPiAgICA8ZGVmcz48L2RlZnM+ICAgIDxnIGlkPSJQYWdlLTEiIHN0cm9rZT0ibm9uZSIgc3Ryb2tlLXdpZHRoPSIxIiBmaWxsPSJub25lIiBmaWxsLXJ1bGU9ImV2ZW5vZGQiIHNrZXRjaDp0eXBlPSJNU1BhZ2UiPiAgICAgICAgPGcgaWQ9ImdsYXNzLXJpZ2h0LWNvcHkiIHNrZXRjaDp0eXBlPSJNU0xheWVyR3JvdXAiIHRyYW5zZm9ybT0idHJhbnNsYXRlKDEuOTc5ODA0LCAyLjUwMDAwMCkiIHN0cm9rZT0iI0YzNUQ1QyIgc3Ryb2tlLXdpZHRoPSIzIj4gICAgICAgICAgICA8Y2lyY2xlIGlkPSJPdmFsLTMiIGZpbGwtb3BhY2l0eT0iMC4yNSIgZmlsbD0iI0ZGRkZGRiIgc2tldGNoOnR5cGU9Ik1TU2hhcGVHcm91cCIgY3g9IjYyIiBjeT0iMjkiIHI9IjIyIj48L2NpcmNsZT4gICAgICAgICAgICA8cGF0aCBkPSJNMC44NTE1NjI1LDIxLjM5MDYyNSBMNi4yNTQ0MTQxOSwxMy4xNDM3IEM3LjE2MTg1MTgzLDExLjc1ODU4NTIgOS4xMzU4NDc0NCwxMS4xMzM1NzIgMTAuNjg5MjcxLDExLjc1ODA3MTggTDM5Ljk4OTI1NzgsMjMuNTM3MTA5NCIgaWQ9IlBhdGgtNiIgc2tldGNoOnR5cGU9Ik1TU2hhcGVHcm91cCI+PC9wYXRoPiAgICAgICAgICAgIDxwYXRoIGQ9Ik03Ny44ODI4MTI1LDEyLjY2OTc2NjMgQzkyLjM0Mzc1LC05Ljc5Mjk2ODMzIDExNS4xMTEzMjgsNC43MDg5ODQ0IDExNS4xMTEzMjgsNC43MDg5ODQ0IiBpZD0iUGF0aC03IiBza2V0Y2g6dHlwZT0iTVNTaGFwZUdyb3VwIj48L3BhdGg+ICAgICAgICA8L2c+ICAgIDwvZz48L3N2Zz4=')
z-index 3
&__glasses-left
width 17*PX
height 27*PX
background url('data:image/svg+xml;base64,PD94bWwgdmVyc2lvbj0iMS4wIiBlbmNvZGluZz0iVVRGLTgiIHN0YW5kYWxvbmU9Im5vIj8+PHN2ZyB3aWR0aD0iMTdweCIgaGVpZ2h0PSIyN3B4IiB2aWV3Qm94PSIwIDAgMTcgMjciIHZlcnNpb249IjEuMSIgeG1sbnM9Imh0dHA6Ly93d3cudzMub3JnLzIwMDAvc3ZnIiB4bWxuczp4bGluaz0iaHR0cDovL3d3dy53My5vcmcvMTk5OS94bGluayIgeG1sbnM6c2tldGNoPSJodHRwOi8vd3d3LmJvaGVtaWFuY29kaW5nLmNvbS9za2V0Y2gvbnMiPiAgICAgICAgPHRpdGxlPmdsYXNzZXMgY29weTwvdGl0bGU+ICAgIDxkZXNjPkNyZWF0ZWQgd2l0aCBTa2V0Y2guPC9kZXNjPiAgICA8ZGVmcz48L2RlZnM+ICAgIDxnIGlkPSJQYWdlLTEiIHN0cm9rZT0ibm9uZSIgc3Ryb2tlLXdpZHRoPSIxIiBmaWxsPSJub25lIiBmaWxsLXJ1bGU9ImV2ZW5vZGQiIHNrZXRjaDp0eXBlPSJNU1BhZ2UiPiAgICAgICAgPGVsbGlwc2UgaWQ9Ik92YWwtMy1Db3B5LTIiIHN0cm9rZT0iI0YzNUQ1QyIgc3Ryb2tlLXdpZHRoPSIzIiBmaWxsLW9wYWNpdHk9IjAuMjUiIGZpbGw9IiNGRkZGRkYiIHNrZXRjaDp0eXBlPSJNU1NoYXBlR3JvdXAiIHRyYW5zZm9ybT0idHJhbnNsYXRlKDguMTM2NTIzLCAxNC4wMDAwMDApIHJvdGF0ZSgtOTIuMDAwMDAwKSB0cmFuc2xhdGUoLTguMTM2NTIzLCAtMTQuMDAwMDAwKSAiIGN4PSI4LjEzNjUyMzQ4IiBjeT0iMTQiIHJ4PSIxMSIgcnk9IjYiPjwvZWxsaXBzZT4gICAgPC9nPjwvc3ZnPg==')
position absolute
z-index -1
right 4.7*GS
top 2.4*GS
&__eye
width 11*PX
height 4.5*PX
position absolute
left 8.6*GS
top 4.7*GS
z-index 4
// outline 1px solid deeppink
&__body
width 164*PX
height 182*PX
position absolute
bottom 0
background url('data:image/svg+xml;base64,PD94bWwgdmVyc2lvbj0iMS4wIiBlbmNvZGluZz0iVVRGLTgiIHN0YW5kYWxvbmU9Im5vIj8+PHN2ZyB3aWR0aD0iMTY1cHgiIGhlaWdodD0iMTgzcHgiIHZpZXdCb3g9IjAgMCAxNjUgMTgzIiB2ZXJzaW9uPSIxLjEiIHhtbG5zPSJodHRwOi8vd3d3LnczLm9yZy8yMDAwL3N2ZyIgeG1sbnM6eGxpbms9Imh0dHA6Ly93d3cudzMub3JnLzE5OTkveGxpbmsiIHhtbG5zOnNrZXRjaD0iaHR0cDovL3d3dy5ib2hlbWlhbmNvZGluZy5jb20vc2tldGNoL25zIj4gICAgICAgIDx0aXRsZT5VbnRpdGxlZCA3PC90aXRsZT4gICAgPGRlc2M+Q3JlYXRlZCB3aXRoIFNrZXRjaC48L2Rlc2M+ICAgIDxkZWZzPjwvZGVmcz4gICAgPGcgaWQ9IlBhZ2UtMSIgc3Ryb2tlPSJub25lIiBzdHJva2Utd2lkdGg9IjEiIGZpbGw9Im5vbmUiIGZpbGwtcnVsZT0iZXZlbm9kZCIgc2tldGNoOnR5cGU9Ik1TUGFnZSI+ICAgICAgICA8ZyBpZD0iYm9keS1jb3B5LTMiIHNrZXRjaDp0eXBlPSJNU0xheWVyR3JvdXAiIHRyYW5zZm9ybT0idHJhbnNsYXRlKDAuNzUxODAxLCAwLjk4NDk0NykiPiAgICAgICAgICAgIDxwYXRoIGQ9Ik00LjE2Nzk2ODc1LDIwLjk5MjE4NzUgQzQuMTY3OTY4NzUsMjAuOTkyMTg3NSAxNTYuNjgxNjQxLC0xMS4zMTkzMzU0IDE0Ni43Mjg1MTYsNi4wMzgwODU5NCBDMTQ2LjcyODUxNiw2LjAzODA4NTk0IDIxNC41MTE3MTgsMTMzLjA3MDMwNSA3NC4zMTczODI4LDE4MS41MTk1MzEgTDEyLjMzNDk2MDksMTY5LjM2MzI3NCBDMTIuMzM0OTYwOSwxNjkuMzYzMjc0IC04LjMyODEyNDkzLDEwMS45NDkyMTIgNC4xNjc5Njg3NSwyMC45OTIxODc1IFoiIGlkPSJQYXRoLTMiIGZpbGw9IiM0QzQwNDAiIHNrZXRjaDp0eXBlPSJNU1NoYXBlR3JvdXAiPjwvcGF0aD4gICAgICAgICAgICA8ZWxsaXBzZSBpZD0iT3ZhbC0xMSIgZmlsbD0iIzNGMzMzMyIgc2tldGNoOnR5cGU9Ik1TU2hhcGVHcm91cCIgdHJhbnNmb3JtPSJ0cmFuc2xhdGUoMTQ3LjUwMDAwMCwgOTUuNTAwMDAwKSByb3RhdGUoNy4wMDAwMDApIHRyYW5zbGF0ZSgtMTQ3LjUwMDAwMCwgLTk1LjUwMDAwMCkgIiBjeD0iMTQ3LjUiIGN5PSI5NS41IiByeD0iMi41IiByeT0iNi41Ij48L2VsbGlwc2U+ICAgICAgICA8L2c+ICAgIDwvZz48L3N2Zz4=')
transform-origin left top
&__inner
position absolute
rect 100%
transform-origin center bottom
&__mouth-wrapper
position absolute
right 3.2*GS
top 7.4*GS
circle 20*PX
&__mouth
position absolute
background #3A3535
circle 20*PX
border-top-right-radius 0
overflow hidden
transform rotate(20deg)
&__mouth-inner
background #C9544A
position absolute
left -.3*GS
top GS
circle 15*PX
&__hat
position absolute
z-index 4
&__hat-base
width 36*PX
height 25*PX
position absolute
z-index 2
left 5.8*GS
top .1*GS
background url('data:image/svg+xml;base64,PD94bWwgdmVyc2lvbj0iMS4wIiBlbmNvZGluZz0iVVRGLTgiIHN0YW5kYWxvbmU9Im5vIj8+PHN2ZyB3aWR0aD0iMzdweCIgaGVpZ2h0PSIyNXB4IiB2aWV3Qm94PSIwIDAgMzcgMjUiIHZlcnNpb249IjEuMSIgeG1sbnM9Imh0dHA6Ly93d3cudzMub3JnLzIwMDAvc3ZnIiB4bWxuczp4bGluaz0iaHR0cDovL3d3dy53My5vcmcvMTk5OS94bGluayIgeG1sbnM6c2tldGNoPSJodHRwOi8vd3d3LmJvaGVtaWFuY29kaW5nLmNvbS9za2V0Y2gvbnMiPiAgICAgICAgPHRpdGxlPmxlZnQgaGFuZCBjb3B5IDM8L3RpdGxlPiAgICA8ZGVzYz5DcmVhdGVkIHdpdGggU2tldGNoLjwvZGVzYz4gICAgPGRlZnM+PC9kZWZzPiAgICA8ZyBpZD0iUGFnZS0xIiBzdHJva2U9Im5vbmUiIHN0cm9rZS13aWR0aD0iMSIgZmlsbD0ibm9uZSIgZmlsbC1ydWxlPSJldmVub2RkIiBza2V0Y2g6dHlwZT0iTVNQYWdlIj4gICAgICAgIDxwYXRoIGQ9Ik0yLjUxMDYxNDYyLDIzLjM2MzcyMDIgQzIuNTEwNjE0NjIsMjMuMzYzNzIwMiAxNy43ODY4NDkzLDIzLjc1NzU2MjkgMzQuODQyNTc4MiwxOS40NjczNjkzIEwyMy4wMjUxOTU0LDAuNzgwODQ1ODczIEw1LjQ5Nzg1MTYsMy43MzIwMTc3NSBMMi41MTA2MTQ2MiwyMy4zNjM3MjAyIFoiIGlkPSJQYXRoLTExIiBmaWxsPSIjRURERUNCIiBza2V0Y2g6dHlwZT0iTVNTaGFwZUdyb3VwIj48L3BhdGg+ICAgIDwvZz48L3N2Zz4=')
&__hat-cone
width 27*PX
height 79*PX
position absolute
z-index 2
left -1.2*GS
top -.4*GS
background url('data:image/svg+xml;base64,PD94bWwgdmVyc2lvbj0iMS4wIiBlbmNvZGluZz0iVVRGLTgiIHN0YW5kYWxvbmU9Im5vIj8+PHN2ZyB3aWR0aD0iMjdweCIgaGVpZ2h0PSI3OXB4IiB2aWV3Qm94PSIwIDAgMjcgNzkiIHZlcnNpb249IjEuMSIgeG1sbnM9Imh0dHA6Ly93d3cudzMub3JnLzIwMDAvc3ZnIiB4bWxuczp4bGluaz0iaHR0cDovL3d3dy53My5vcmcvMTk5OS94bGluayIgeG1sbnM6c2tldGNoPSJodHRwOi8vd3d3LmJvaGVtaWFuY29kaW5nLmNvbS9za2V0Y2gvbnMiPiAgICAgICAgPHRpdGxlPmxlZnQgaGFuZCBjb3B5IDI8L3RpdGxlPiAgICA8ZGVzYz5DcmVhdGVkIHdpdGggU2tldGNoLjwvZGVzYz4gICAgPGRlZnM+PC9kZWZzPiAgICA8ZyBpZD0iUGFnZS0xIiBzdHJva2U9Im5vbmUiIHN0cm9rZS13aWR0aD0iMSIgZmlsbD0ibm9uZSIgZmlsbC1ydWxlPSJldmVub2RkIiBza2V0Y2g6dHlwZT0iTVNQYWdlIj4gICAgICAgIDxnIGlkPSJoYXQtY29weS0yIiBza2V0Y2g6dHlwZT0iTVNMYXllckdyb3VwIiB0cmFuc2Zvcm09InRyYW5zbGF0ZSgyLjAwMDAwMCwgMC4wMDAwMDApIj4gICAgICAgICAgICA8cGF0aCBkPSJNMjIuOTAyNjAwNiwwLjA1NDE0ODg0NTcgTDExLjcyNTk4NTUsNzMuMjU1MjMyIEwwLjczNzM4MDY5NiwwLjA1NDE0ODg0NTcgTDIyLjkwMjYwMDYsMC4wNTQxNDg4NDU3IFoiIGlkPSJQYXRoLTEyIiBmaWxsPSIjRTdEOUM4IiBza2V0Y2g6dHlwZT0iTVNTaGFwZUdyb3VwIj48L3BhdGg+ICAgICAgICAgICAgPGcgaWQ9ImJydXNoIiB0cmFuc2Zvcm09InRyYW5zbGF0ZSgxMS45MzI4NzAsIDc0LjQ4NDk0Nykgcm90YXRlKC05LjAwMDAwMCkgdHJhbnNsYXRlKC0xMS45MzI4NzAsIC03NC40ODQ5NDcpIHRyYW5zbGF0ZSg5LjkzMjg3MCwgNzAuOTg0OTQ3KSIgc2tldGNoOnR5cGU9Ik1TU2hhcGVHcm91cCI+ICAgICAgICAgICAgICAgIDxlbGxpcHNlIGlkPSJPdmFsLTEyIiBmaWxsPSIjRURERUNCIiBjeD0iMiIgY3k9IjIiIHJ4PSIyIiByeT0iMiI+PC9lbGxpcHNlPiAgICAgICAgICAgICAgICA8cGF0aCBkPSJNMS42MzI1MzAxMSwyLjMxNTY3NzI3IEwwLjU2ODc0OTAzMyw1LjQxNDc3MjgxIiBpZD0iUGF0aC0xMyIgc3Ryb2tlPSIjRURERUNCIj48L3BhdGg+ICAgICAgICAgICAgICAgIDxwYXRoIGQ9Ik0yLjczMDU3MzExLDIuMjY5Mjc0OTYgTDMuNDcwNzA2MDMsNS40NjExNzUxMiIgaWQ9IlBhdGgtMTMtQ29weSIgc3Ryb2tlPSIjRURERUNCIj48L3BhdGg+ICAgICAgICAgICAgICAgIDxwYXRoIGQ9Ik0yLjEyNjUyNTkzLDIuODE2NjUwMzkgTDIuMTI2NTI1OTUsNi4zOTc5MDU4MyIgaWQ9IlBhdGgtMTMtQ29weS0yIiBzdHJva2U9IiNFRERFQ0IiPjwvcGF0aD4gICAgICAgICAgICA8L2c+ICAgICAgICA8L2c+ICAgIDwvZz48L3N2Zz4=') no-repeat
transform rotateX(40deg) rotateY(-28deg) rotateZ(16deg) translateX(4px)
&__hat-cone-wrapper
position absolute
z-index 5
width 36*PX
height 25*PX
left 5.8*GS
top .1*GS
&__hat-cone-rotator
transform-origin center top 2px
&__hat-shadow
width 22*PX
height 23*PX
position absolute
z-index 0
left .1*GS
top .2*GS
opacity 1
background url('data:image/svg+xml;base64,PD94bWwgdmVyc2lvbj0iMS4wIiBlbmNvZGluZz0iVVRGLTgiIHN0YW5kYWxvbmU9Im5vIj8+PHN2ZyB3aWR0aD0iMjJweCIgaGVpZ2h0PSIyM3B4IiB2aWV3Qm94PSIwIDAgMjIgMjMiIHZlcnNpb249IjEuMSIgeG1sbnM9Imh0dHA6Ly93d3cudzMub3JnLzIwMDAvc3ZnIiB4bWxuczp4bGluaz0iaHR0cDovL3d3dy53My5vcmcvMTk5OS94bGluayIgeG1sbnM6c2tldGNoPSJodHRwOi8vd3d3LmJvaGVtaWFuY29kaW5nLmNvbS9za2V0Y2gvbnMiPiAgICAgICAgPHRpdGxlPmhhdCBzaGFkb3c8L3RpdGxlPiAgICA8ZGVzYz5DcmVhdGVkIHdpdGggU2tldGNoLjwvZGVzYz4gICAgPGRlZnM+PC9kZWZzPiAgICA8ZyBpZD0iUGFnZS0xIiBzdHJva2U9Im5vbmUiIHN0cm9rZS13aWR0aD0iMSIgZmlsbD0ibm9uZSIgZmlsbC1ydWxlPSJldmVub2RkIiBza2V0Y2g6dHlwZT0iTVNQYWdlIj4gICAgICAgIDxwYXRoIGQ9Ik0yMS40NzMxNDQ1LDAgTDQuMDQwNzcxNDgsMi45MzIxMjg5MSBMMSwyMi42NzQ4MDQ3IEMxLDIyLjY3NDgwNDcgMTEuNTUyNDkwMiwyMi42NzQ4MDQ3IDE4LjQ3MzE0NDUsMjEuNDM2NzY3NiBMMjEuNDczMTQ0NSwwIFoiIGlkPSJQYXRoLTE3NiIgb3BhY2l0eT0iMC4xIiBmaWxsPSIjMDAwMDAwIiBza2V0Y2g6dHlwZT0iTVNTaGFwZUdyb3VwIj48L3BhdGg+ICAgIDwvZz48L3N2Zz4=')
transform-origin left center
transform translateX(4px) translateY(4px)
&__hand
width 54*PX
height 102*PX
background url('data:image/svg+xml;base64,PD94bWwgdmVyc2lvbj0iMS4wIiBlbmNvZGluZz0iVVRGLTgiIHN0YW5kYWxvbmU9Im5vIj8+PHN2ZyB3aWR0aD0iNTRweCIgaGVpZ2h0PSIxMDJweCIgdmlld0JveD0iMCAwIDU0IDEwMiIgdmVyc2lvbj0iMS4xIiB4bWxucz0iaHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmciIHhtbG5zOnhsaW5rPSJodHRwOi8vd3d3LnczLm9yZy8xOTk5L3hsaW5rIiB4bWxuczpza2V0Y2g9Imh0dHA6Ly93d3cuYm9oZW1pYW5jb2RpbmcuY29tL3NrZXRjaC9ucyI+ICAgICAgICA8dGl0bGU+aGFuZDwvdGl0bGU+ICAgIDxkZXNjPkNyZWF0ZWQgd2l0aCBTa2V0Y2guPC9kZXNjPiAgICA8ZGVmcz4gICAgICAgIDxsaW5lYXJHcmFkaWVudCB4MT0iNTAlIiB5MT0iMCUiIHgyPSI1MCUiIHkyPSIxMDAlIiBpZD0ibGluZWFyR3JhZGllbnQtMSI+ICAgICAgICAgICAgPHN0b3Agc3RvcC1jb2xvcj0iIzRDNDA0MCIgb2Zmc2V0PSIwJSI+PC9zdG9wPiAgICAgICAgICAgIDxzdG9wIHN0b3AtY29sb3I9IiMzQTJGMkYiIG9mZnNldD0iMTAwJSI+PC9zdG9wPiAgICAgICAgPC9saW5lYXJHcmFkaWVudD4gICAgPC9kZWZzPiAgICA8ZyBpZD0iUGFnZS0xIiBzdHJva2U9Im5vbmUiIHN0cm9rZS13aWR0aD0iMSIgZmlsbD0ibm9uZSIgZmlsbC1ydWxlPSJldmVub2RkIiBza2V0Y2g6dHlwZT0iTVNQYWdlIj4gICAgICAgIDxnIGlkPSJyaWdodC1oYW5kLWNvcHkiIHNrZXRjaDp0eXBlPSJNU0xheWVyR3JvdXAiIHRyYW5zZm9ybT0idHJhbnNsYXRlKDIuMDAwMDAwLCAyLjc5NzMwNCkiPiAgICAgICAgICAgIDxwYXRoIGQ9Ik0wLjIyMjY1NjI1LDAuMTIxMDkzNzUgTDExLjI0MTYyODIsNzUuNTI4NTI5MyBDMTIuNjc4NzQwNCw4NS4zNjMyODkzIDIxLjg5ODIwNDUsOTMuMzM1OTM3NSAzMS44NDMzMDI5LDkzLjMzNTkzNzUgTDI1LjkzMDM3MjQsOTMuMzM1OTM3NSBDMzguMDc1OTQzOSw5My4zMzU5Mzc1IDQ3LjkyMTg3NSw4My40ODI3NTk4IDQ3LjkyMTg3NSw3MS4zNDM5NDc2IEw0Ny45MjE4NzUsNS45NjA5Mzc1IiBpZD0iUGF0aC04IiBmaWxsPSJ1cmwoI2xpbmVhckdyYWRpZW50LTEpIiBza2V0Y2g6dHlwZT0iTVNTaGFwZUdyb3VwIj48L3BhdGg+ICAgICAgICAgICAgPGcgaWQ9ImZpbmdlcnMiIHRyYW5zZm9ybT0idHJhbnNsYXRlKDIzLjAwMDAwMCwgODYuMDAwMDAwKSIgZmlsbD0iIzAwMDAwMCIgc2tldGNoOnR5cGU9Ik1TU2hhcGVHcm91cCI+ICAgICAgICAgICAgICAgIDxlbGxpcHNlIGlkPSJPdmFsLTgiIGN4PSIxNyIgY3k9IjMiIHJ4PSIyIiByeT0iMyI+PC9lbGxpcHNlPiAgICAgICAgICAgICAgICA8ZWxsaXBzZSBpZD0iT3ZhbC04LUNvcHkiIGN4PSI5LjUiIGN5PSI3IiByeD0iMi41IiByeT0iNCI+PC9lbGxpcHNlPiAgICAgICAgICAgICAgICA8ZWxsaXBzZSBpZD0iT3ZhbC04LUNvcHktMiIgY3g9IjIiIGN5PSI1IiByeD0iMiIgcnk9IjMiPjwvZWxsaXBzZT4gICAgICAgICAgICA8L2c+ICAgICAgICA8L2c+ICAgIDwvZz48L3N2Zz4=')
position absolute
z-index 5
top 10.6*GS
left 1.6*GS
transform-origin top center
&__hand-circle
content ''
width 40*PX
height 60*PX
background #4B4040
border-radius 50%
border-bottom-right-radius 0
position absolute
right 4*PX
top -50*PX
opacity 0
z-index -1
&__hand-left
width 120*PX
height 107*PX
background url('data:image/svg+xml;base64,<?xml version="1.0" encoding="UTF-8" standalone="no"?><svg width="120px" height="107px" viewBox="0 0 120 107" version="1.1" xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink" xmlns:sketch="http://www.bohemiancoding.com/sketch/ns">        <title>mole-hand-left</title>    <desc>Created with Sketch.</desc>    <defs></defs>    <g id="Page-1" stroke="none" stroke-width="1" fill="none" fill-rule="evenodd" sketch:type="MSPage">        <g id="left-hand" sketch:type="MSLayerGroup" transform="translate(0.979804, 52.297304)" fill="#3F3333">            <path d="M75.9319724,11.1421587 L0.916164302,0.893125721 L0.916164302,52.4741804 C0.916164302,52.4741804 70.4551801,42.5189004 77.208454,41.0759546 C83.1193901,39.621198 88.3709387,11.7635342 75.9319724,11.1421587 Z" id="left-arm" sketch:type="MSShapeGroup"></path>        </g>        <path d="M79.6897536,65.8670372 C79.7160883,65.869593 79.7423129,65.872182 79.7684279,65.8748039 C90.4868402,66.95093 84.7824517,73.2064304 82.739333,73.5836839" id="Path-74" fill="#3F3333" sketch:type="MSShapeGroup"></path>        <path d="M79.4471274,74.624399 C79.4734621,74.6269548 79.4996867,74.6295438 79.5258017,74.6321657 C90.244214,75.7082918 84.3368507,82.0342549 82.293732,82.4115084" id="Path-74-Copy-2" fill="#3F3333" sketch:type="MSShapeGroup" transform="translate(82.605350, 78.517954) rotate(26.000000) translate(-82.605350, -78.517954) "></path>        <path d="M77.2998919,82.7002704 C77.3262265,82.7028262 77.3524511,82.7054152 77.3785661,82.7080371 C88.0969784,83.7841632 82.1896152,90.1101263 80.1464964,90.4873798" id="Path-74-Copy-3" fill="#3F3333" sketch:type="MSShapeGroup" transform="translate(80.458114, 86.593825) rotate(42.000000) translate(-80.458114, -86.593825) "></path>        <g id="candle" sketch:type="MSLayerGroup" transform="translate(41.979804, 4.297304)">            <g id="Path-168-+-Path-169" transform="translate(38.020196, 15.702696)" sketch:type="MSShapeGroup">                <path d="M4.5047433,33.125279 L0.298828125,31.2512556 L3.12555804,11.8233817 L11.2501395,18.0040458 L5.64648438,33.2773438 L4.5047433,33.125279 L4.5047433,33.125279 Z" id="Path-168" fill="#FCF1D5"></path>                <path d="M4.32435826,2.75251116 L4.04199219,4.25418527 L15.5671038,8.63225446 L16.6965681,0.284179687 L5.83691406,0.234514509 L4.32435826,2.75251116 L4.32435826,2.75251116 Z" id="Path-169" fill="#FCF5E3"></path>            </g>            <g transform="translate(39.720856, 52.728624) rotate(14.000000) translate(-39.720856, -52.728624) translate(11.220856, 5.728624)" id="Shape" sketch:type="MSShapeGroup">                <path d="M27.5588709,1.98202551 C27.5096045,1.41356695 27.4375998,0.841318667 27.543712,0.272860108 C27.6422449,0.405500439 27.8355208,0.666991376 27.9340536,0.799631706 C28.7109469,1.99339468 29.5029992,3.20610627 29.8478641,4.60830405 C29.999453,5.4950994 30.0979858,6.49558647 28.9004331,5.99155321 C28.3774513,5.01380449 28.0666939,3.94889212 27.7521468,2.89534893 C27.7180393,2.73997025 27.6498243,2.42921291 27.6157168,2.27004451 L27.5588709,1.98202551 L27.5588709,1.98202551 Z" fill="#070401"></path>                <path d="M33.7512795,4.29754671 C33.9256068,4.26343919 34.2742614,4.19522416 34.4485887,4.15732693 C35.2936971,4.20659334 36.3396608,3.97163046 36.8778016,4.80915941 C38.1094618,5.6391089 37.105185,7.10952171 37.0293905,8.2426491 C35.8394173,10.0465576 37.3590965,10.5846984 38.586967,11.11147 C38.0564057,12.2787049 37.03697,13.0328599 35.9417398,13.6316362 C34.5092242,13.8741786 33.2737743,13.085916 32.09896,12.3961863 C31.8829457,12.0247934 31.6404034,11.6685594 31.4243891,11.3009562 C31.2273235,10.4179505 31.0188887,9.53494489 30.8824586,8.64435982 C31.2311132,7.78788226 31.5267117,6.90866635 31.7654643,6.01050183 C32.3490817,5.3510899 33.0691292,4.84326692 33.7512795,4.29754671 L33.7512795,4.29754671 L33.7512795,4.29754671 Z" fill="#FCF5E3"></path>                <path d="M22.2608372,7.49228381 C22.3555803,6.76465685 22.7193937,5.82101564 23.5228152,5.69974448 C26.2400471,6.04460934 29.067181,6.95035331 31.7654643,6.01050183 C31.5267117,6.90866635 31.2311132,7.78788226 30.8824586,8.64435982 C31.0188887,9.53494489 31.2273235,10.4179505 31.4243891,11.3009562 C30.643706,11.2327411 30.6778136,11.9262606 30.6361266,12.5022986 C29.9653455,11.8694147 30.1813598,11.0243063 30.2988412,10.2170952 C29.5977423,10.095824 29.5636348,10.7628154 29.3855178,11.2516897 C28.4418766,12.0210037 27.2708519,11.0887316 26.2248882,11.0091474 C26.5887017,12.0285831 26.0467712,13.6088979 24.7468959,12.976014 C24.8984849,14.4956933 23.4924974,13.7225896 22.5829637,14.0030292 C22.3101036,11.8428866 22.3555803,9.66000578 22.2608372,7.49228381 L22.2608372,7.49228381 L22.2608372,7.49228381 Z" fill="#F7EBDA"></path>                <path d="M29.3855178,11.2516897 C29.5636348,10.7628154 29.5977423,10.095824 30.2988412,10.2170952 C30.1813598,11.0243063 29.9653455,11.8694147 30.6361266,12.5022986 C30.9241456,13.8855477 31.4926042,15.4582831 32.9933348,15.8599938 C33.8498123,15.7387226 34.6987104,15.5530262 35.5665572,15.4848111 C35.6082441,16.18591 35.6916181,17.5805284 35.733305,18.2778375 C35.5627674,19.9907927 35.4604449,21.7113272 35.2216923,23.4129132 C35.0094678,24.4664564 34.8654583,25.5389482 34.9488322,26.6152297 C34.513014,29.7682799 34.0279293,32.9137506 33.7929665,36.0933288 C32.6484699,36.9649652 31.4471275,36.4836703 30.2761028,35.9796371 C30.9620428,37.3818348 32.2543386,37.8138633 33.7550692,37.2643534 C33.0122834,39.7125149 37.3439376,36.460932 36.7641099,38.655182 C36.8740119,40.7622684 33.7702281,39.8375758 33.2358771,41.2435633 C33.0539703,41.9598211 32.7811102,42.619233 31.9208429,42.5964947 C31.6896698,42.3160551 31.4584966,42.0356156 31.2235338,41.7627555 C31.041627,42.7821911 29.1050782,42.7405042 29.3893075,41.5732693 C29.5295273,40.2013893 28.339554,39.2766967 27.9075255,38.079144 C27.2253752,38.1587282 26.0884581,38.5680184 26.9032487,37.5826902 C27.3883334,37.2908815 27.8772077,37.0028625 28.3585026,36.7034743 C28.8397976,37.0976056 29.1429755,37.6243772 29.3248822,38.2193638 C29.7038546,38.0260879 30.1358831,37.8782886 30.4163226,37.5372135 C29.9426072,37.0672878 29.4309945,36.639049 28.9004331,36.2373383 L28.9838071,35.9417398 C29.0558118,35.3012765 28.6427319,34.0999341 27.7748852,34.5660701 C27.0851555,34.827561 27.6043476,35.486973 27.6687729,35.9796371 C26.9714638,36.4268245 26.1339348,36.4419833 25.3380928,36.3169225 C25.8193877,35.9076323 26.3385799,35.5438188 26.8236645,35.1345287 C26.8122954,34.3955325 26.4067949,33.7285412 26.2400471,33.0160731 C26.9449357,32.674998 27.6687729,32.2316003 28.4797738,32.4438248 C28.381241,31.522922 27.1382116,31.9587402 26.5735428,31.4509172 C27.0283096,30.4845377 27.6232962,29.5674245 27.7597263,28.4873532 C28.1349089,28.6995778 28.491143,28.9421201 28.8701153,29.1581343 C28.6199936,28.5214608 28.2751287,27.9302639 27.9454228,27.3352772 C27.3087492,27.8658386 26.7061831,28.6124141 25.8307569,28.0287967 C26.077089,27.5588709 26.365108,27.1116835 26.5962811,26.6341783 C26.0619301,26.7402906 25.5351585,26.8539823 25.0008074,26.9373562 C25.2547189,26.6872345 25.5124201,26.4371127 25.7663316,26.1869909 C25.4896818,26.1680423 24.9363821,26.1301451 24.6597323,26.1111965 C24.9022746,25.7322241 25.1751347,25.3797798 25.3987284,24.9894382 C25.1637655,24.1822271 24.1367504,24.1102223 23.469759,23.8335725 C22.977095,21.4005699 23.1590017,18.7705016 22.7345526,16.2768634 C22.7193937,15.5151289 22.6663376,14.7571842 22.5829637,14.0030292 C23.4924974,13.7225896 24.8984849,14.4956933 24.7468959,12.976014 C26.0467712,13.6088979 26.5887017,12.0285831 26.2248882,11.0091474 C27.2708519,11.0887316 28.4418766,12.0210037 29.3855178,11.2516897 L29.3855178,11.2516897 L29.3855178,11.2516897 Z M28.889064,32.2240208 C29.0747604,33.2017696 28.0477453,33.2434565 27.9984789,34.0506677 C28.3585026,34.0809855 29.313513,33.2851435 29.1619241,34.0999341 C28.9307509,35.1762156 29.6962751,34.6646029 30.2723131,34.403112 C30.5679116,33.5428447 29.2831952,33.7247514 29.177083,33.0463909 C30.4352712,33.251036 29.6735368,31.9928477 28.889064,32.2240208 L28.889064,32.2240208 L28.889064,32.2240208 Z" fill="#FCF1D5"></path>                <path d="M30.6361266,12.5022986 C30.6778136,11.9262606 30.643706,11.2327411 31.4243891,11.3009562 C31.6404034,11.6685594 31.8829457,12.0247934 32.09896,12.3961863 C31.6404034,14.4540063 34.7631357,15.6250309 35.953109,13.9802908 C35.9682679,14.2569407 36.0023754,14.8026609 36.0175343,15.0793107 C35.9038426,15.1816332 35.6802489,15.3824886 35.5665572,15.4848111 C34.6987104,15.5530262 33.8498123,15.7387226 32.9933348,15.8599938 C31.4926042,15.4582831 30.9241456,13.8855477 30.6361266,12.5022986 L30.6361266,12.5022986 L30.6361266,12.5022986 Z" fill="#EBDDC2"></path>                <path d="M35.953109,13.9802908 C34.7631357,15.6250309 31.6404034,14.4540063 32.09896,12.3961863 C33.2737743,13.085916 34.5092242,13.8741786 35.9417398,13.6316362 L35.953109,13.9802908 L35.953109,13.9802908 Z" fill="#D8C6A8"></path>                <path fill="#CAB487" d="M35.5665572,15.4848111 C35.6802489,15.3824886 35.9038426,15.1816332 36.0175343,15.0793107 L36.063011,15.4393345 C35.9720576,16.3867654 35.8621556,17.3341963 35.733305,18.2778375 C35.6916181,17.5805284 35.6082441,16.18591 35.5665572,15.4848111 L35.5665572,15.4848111 L35.5665572,15.4848111 Z"></path>                <path fill="#9C7B4D" d="M34.9488322,26.6152297 C34.8654583,25.5389482 35.0094678,24.4664564 35.2216923,23.4129132 C35.1951642,24.485405 35.0738931,25.5465276 34.9488322,26.6152297 L34.9488322,26.6152297 L34.9488322,26.6152297 Z"></path>                <path d="M23.469759,23.5116384 C24.1367504,23.7882882 25.3545341,23.9959535 25.5894969,24.8031646 C25.3659032,25.1935062 25.2433497,25.6188279 25.0008074,25.9978002 C25.2774572,26.0167489 25.5541072,25.9788515 25.830757,25.9978001 C25.5768455,26.2479219 25.5920043,26.6057561 25.3380928,26.8558779 C25.8724438,26.772504 26.2893135,26.7662506 26.8236645,26.6601384 C26.5924914,27.1376436 26.4863791,27.4659928 26.2400471,27.9359186 C27.1154732,28.519536 27.3441715,27.6392599 27.9808451,27.1086986 C28.310551,27.7036852 28.8041729,28.6027747 29.0542947,29.2394483 C28.6753223,29.0234341 28.156109,28.8978537 27.7809263,28.6856291 C27.6444963,29.7657004 27.2784314,30.3583997 26.8236645,31.3247793 C27.3883334,31.8326023 28.5302481,31.7313567 28.6287809,32.6522596 C27.8177801,32.4400351 27.2551502,32.6549421 26.5502616,32.9960172 C26.7170094,33.7084853 27.001321,34.5672895 27.0126902,35.3062856 C26.5276055,35.7155758 26.0707919,36.0439777 25.5894969,36.4532678 C25.1213604,36.3704717 24.7506857,35.9872165 24.5839378,35.6196133 C24.5005639,34.6267057 24.6673117,33.5580036 24.2011757,32.6522596 C24.2011757,31.4547069 24.3830825,30.2344159 24.0116895,29.0785501 C23.6592452,27.3504361 23.3295393,25.6147427 23.469759,23.8335725 L23.469759,23.5116384 L23.469759,23.5116384 Z" fill="#F3E3C0"></path>                <path d="M4.53250958,25.3684106 C5.23739819,25.2433497 5.54815553,25.8686542 5.87407178,26.3613182 C7.0602553,27.8165721 6.15830105,29.7682799 6.06734769,31.4584966 L5.71111365,31.4660761 C5.74143144,29.3627794 4.63862184,27.4527587 4.53250958,25.3684106 L4.53250958,25.3684106 L4.53250958,25.3684106 Z" fill="#0C0702"></path>                <path d="M49.3384132,27.5929784 C51.0210505,27.9302639 51.3280181,30.0790372 51.1877984,31.4736555 L50.4146947,31.4736555 C49.6529603,30.3140001 49.4824227,28.9421201 49.3384132,27.5929784 L49.3384132,27.5929784 L49.3384132,27.5929784 Z" fill="#110401"></path>                <path fill="#937547" d="M24.0116895,29.0785501 C24.3830825,30.2344159 24.2011757,31.4547069 24.2011757,32.6522596 C23.5758713,31.5608192 23.9927409,30.2647337 24.0116895,29.0785501 L24.0116895,29.0785501 L24.0116895,29.0785501 Z"></path>                <path d="M1.58410452,31.5570295 C2.55806352,30.4542199 4.46808427,32.0269552 5.71111365,31.4660761 L6.06734769,31.4584966 C7.15499839,31.6404034 8.60646258,30.4921171 9.40988401,31.5418706 C9.69411329,34.0279293 9.25450534,36.5405162 9.11807528,39.0303647 C8.53066811,39.272907 7.92052259,39.4396548 7.29142845,39.5268185 C5.96502514,39.4737623 4.64241156,39.409337 3.31979798,39.5116596 L2.99767147,39.451024 C2.21319866,38.3216863 3.37664384,38.8636168 4.09669135,38.9773085 C4.47566372,38.298948 4.89632305,37.1923486 3.80867234,36.9232783 C4.28996726,36.4760909 4.97969698,36.5329367 5.57089388,36.35103 C4.99485587,34.9753603 5.18434206,33.3306202 4.30133643,32.0875908 C4.2482803,32.8076383 4.14216803,34.2401539 4.0891119,34.9602014 C3.53960196,34.2818408 3.42591025,33.4177838 3.30463909,32.5878343 C2.61869909,32.8265869 2.12603501,33.4026249 1.52346894,33.7891767 C1.53862783,33.2282976 1.56894562,32.1141189 1.58410452,31.5570295 L1.58410452,31.5570295 L1.58410452,31.5570295 Z" fill="#F4E9D2"></path>                <path d="M46.91299,31.3372255 C47.2730138,30.8104539 48.0120099,31.2121646 48.5198329,31.2652207 C48.6638424,32.6105727 47.3147007,32.2960256 46.91299,31.3372255 L46.91299,31.3372255 L46.91299,31.3372255 Z" fill="#E2C2A2"></path>                <path d="M54.6516059,31.7503054 C54.6137086,33.0653395 54.5758114,34.3917428 54.6553956,35.7067769 C54.59476,36.419245 54.5417039,37.1279233 54.4772786,37.8403914 C54.2612643,38.9166729 53.5563757,39.6556691 52.4042997,39.5571363 C51.0566906,40.2644548 49.8263544,39.6854286 48.7889032,39.5154493 C48.6259451,39.4851315 48.2962392,39.4282856 48.133281,39.3979679 C47.064579,37.901027 49.2323009,39.6329307 49.5809555,38.5642286 C49.7628622,37.8934475 49.4255768,37.2340356 49.3232543,36.5784134 C49.7856006,36.5253573 50.2479469,36.4647217 50.7027137,36.3434505 C50.5966015,35.3164354 50.5776528,34.2553128 50.0774093,33.3230407 C49.7969698,32.4172968 48.4175103,30.4011637 49.2701982,34.0885649 C48.5463609,34.183308 49.039025,33.0084937 48.8154313,32.5802549 C48.1257016,32.4703529 47.6974628,33.0501806 47.1782707,33.3760969 C47.1214248,32.6901569 47.0153125,32.0117963 46.91299,31.3372255 C47.3147007,32.2960256 48.6638424,32.6105727 48.5198329,31.2652207 C49.1451373,31.3789125 49.7780211,31.4547069 50.4146947,31.4736555 L51.1877984,31.4736555 C52.3360847,31.7351465 53.9315583,30.4314815 54.6516059,31.7503054 L54.6516059,31.7503054 Z" fill="#F8E8CF"></path>                <path d="M46.6856066,34.3841634 C46.7765599,33.4102044 46.1360966,32.0913805 46.91299,31.3372255 C47.0153125,32.0117963 47.1214248,32.6901569 47.1782707,33.3760969 C47.6974628,33.0501806 48.1257016,32.4703529 48.8154313,32.5802549 C49.039025,33.0084937 48.5463609,34.183308 49.2701982,34.0885649 C48.4175103,30.4011637 49.7969698,32.4172968 50.0774093,33.3230407 C50.5776528,34.2553128 50.5966015,35.3164354 50.7027137,36.3434505 C50.2479469,36.4647217 49.7856006,36.5253573 49.3232543,36.5784134 C49.4255768,37.2340356 49.7628622,37.8934475 49.5809555,38.5642286 C49.2323009,39.6329307 47.064579,37.901027 48.133281,39.3979679 C47.7391498,39.299435 47.352598,39.1781639 46.9736256,39.0341544 C46.9433078,38.8711963 46.8864619,38.5414903 46.8561441,38.3785322 C46.8750928,37.0521289 47.269224,35.6423516 46.6856066,34.3841634 L46.6856066,34.3841634 L46.6856066,34.3841634 Z" fill="#EAD0B6"></path>                <path fill="#926841" d="M54.6516059,31.7503054 C55.0343679,33.0236525 55.0343679,34.3424764 54.6553956,35.7067769 C54.5758114,34.3917428 54.6137086,33.0653395 54.6516059,31.7503054 L54.6516059,31.7503054 L54.6516059,31.7503054 Z"></path>                <path d="M4.30133643,32.0875908 C5.18434206,33.3306202 4.99485587,34.9753603 5.57089388,36.35103 C4.97969698,36.5329367 4.28996726,36.4760909 3.80867234,36.9232783 C4.89632305,37.1923486 4.47566372,38.298948 4.09669135,38.9773085 C3.37664384,38.8636168 2.21319866,38.3216863 2.99767147,39.451024 C2.57701213,39.3676501 2.16393225,39.2577481 1.76222153,39.121318 C1.31503413,37.3818348 1.57273535,35.555188 1.52346894,33.7891767 C2.12603501,33.4026249 2.61869909,32.8265869 3.30463909,32.5878343 C3.42591025,33.4177838 3.53960196,34.2818408 4.0891119,34.9602014 C4.14216803,34.2401539 4.2482803,32.8076383 4.30133643,32.0875908 L4.30133643,32.0875908 L4.30133643,32.0875908 Z" fill="#E2D3C0"></path>                <path d="M28.889064,32.2240208 C29.6735368,31.9928477 30.4352712,33.251036 29.177083,33.0463909 C29.2831952,33.7247514 30.5679116,33.5428447 30.2723131,34.403112 C29.6962751,34.6646029 28.9307509,35.1762156 29.1619241,34.0999341 C29.313513,33.2851435 28.3585026,34.0809855 27.9984789,34.0506677 C28.0477453,33.2434565 29.0747604,33.2017696 28.889064,32.2240208 L28.889064,32.2240208 L28.889064,32.2240208 Z" fill="#F4E0BF"></path>                <path d="M27.7748852,34.5660701 C28.6427319,34.0999341 29.0558118,35.3012765 28.9838071,35.9417398 C28.5631477,35.6082441 28.1008014,35.7787817 27.6687729,35.9796371 C27.6043476,35.486973 27.0851555,34.827561 27.7748852,34.5660701 L27.7748852,34.5660701 L27.7748852,34.5660701 Z" fill="#F2DEBD"></path>                <path fill="#AD8663" d="M46.6856066,34.3841634 C47.269224,35.6423516 46.8750928,37.0521289 46.8561441,38.3785322 C46.446854,37.0862364 46.6552888,35.7105667 46.6856066,34.3841634 L46.6856066,34.3841634 L46.6856066,34.3841634 Z"></path>                <path d="M24.993228,37.1847692 C24.6445734,36.6769462 23.1362633,35.4263374 24.5839378,35.6196133 C24.7506857,35.9872165 25.0008074,36.2183896 25.3380928,36.3169225 C26.1339348,36.4419833 26.9714638,36.4268245 27.6687729,35.9796371 C28.1008014,35.7787817 28.5631477,35.6082441 28.9838071,35.9417398 L28.9004331,36.2373383 C28.7640031,36.35103 28.491143,36.5859929 28.3585026,36.7034743 C27.8772077,37.0028625 27.3883334,37.2908815 26.9032487,37.5826902 C26.2514162,37.5182649 25.6071632,37.4121526 24.993228,37.1847692 L24.993228,37.1847692 L24.993228,37.1847692 Z" fill="#F3E3C0"></path>                <path d="M33.7929665,36.0933288 C34.1719388,35.9417398 34.5547009,35.80152 34.9412528,35.66509 C34.8389302,36.3737683 34.224995,36.7944277 33.7550692,37.2643534 C32.2543386,37.8138633 30.9620428,37.3818348 30.2761028,35.9796371 C31.4471275,36.4836703 32.6484699,36.9649652 33.7929665,36.0933288 L33.7929665,36.0933288 L33.7929665,36.0933288 Z" fill="#FCF1D5"></path>                <path d="M28.3585026,36.7034743 C28.491143,36.5859929 28.7640031,36.35103 28.9004331,36.2373383 C29.4309945,36.639049 29.9426072,37.0672878 30.4163226,37.5372135 C30.1358831,37.8782886 29.7038546,38.0260879 29.3248822,38.2193638 C29.1429755,37.6243772 28.8397976,37.0976056 28.3585026,36.7034743 L28.3585026,36.7034743 L28.3585026,36.7034743 Z" fill="#F4E0C0"></path>                <path d="M24.993228,37.1847692 C25.6071632,37.4121526 26.2514162,37.5182649 26.9032487,37.5826902 C26.0884581,38.5680184 27.2253752,38.1587282 27.9075255,38.079144 C28.339554,39.2766967 29.5295273,40.2013893 29.3893075,41.5732693 C29.1050782,42.7405042 31.041627,42.7821911 31.2235338,41.7627555 C31.4584966,42.0356156 31.6896698,42.3160551 31.9208429,42.5964947 C29.7682799,43.0436821 27.5475018,42.9262006 25.4442051,42.331214 C25.1561861,40.6296281 24.9780691,38.9128832 24.993228,37.1847692 L24.993228,37.1847692 L24.993228,37.1847692 Z" fill="#F1DAB8"></path>                <path d="M52.4042997,39.5571363 C53.5563757,39.6556691 54.2612643,38.9166729 54.4772786,37.8403914 C54.4507505,38.6059156 54.7956154,39.1099489 55.5649293,39.2274303 C56.542678,39.4131267 56.0803317,40.7471095 55.322387,40.9555443 C52.3398744,41.8764472 49.1565064,41.8385499 46.158835,40.9934415 C45.6244839,40.7584787 44.8210625,40.5879411 45.1052918,39.8148375 C45.1242404,38.8598271 46.3180034,39.0644722 46.9736256,39.0341544 C47.352598,39.1781639 47.7391498,39.299435 48.133281,39.3979679 C48.2962392,39.4282856 48.6259451,39.4851315 48.7889032,39.5154493 C49.9750868,39.7617813 51.2294853,39.9626367 52.4042997,39.5571363 L52.4042997,39.5571363 L52.4042997,39.5571363 Z" fill="#F39D14"></path>                <path d="M0.685939994,40.9820724 C-0.757944745,40.2203379 0.363813478,38.4391678 1.76222153,39.121318 C2.16393225,39.2577481 2.57701213,39.3676501 2.99767147,39.451024 L3.31979798,39.5116596 C4.64241156,39.8451553 5.96502514,39.848945 7.29142845,39.5268185 C7.92052259,39.4396548 8.53066811,39.272907 9.11807528,39.0303647 C9.76990777,39.0644722 10.9636707,38.8598271 10.9826194,39.8148375 C11.2403206,40.561413 10.4672169,40.7622684 9.96318368,41.042708 C6.92761497,41.8916061 3.71013953,41.8840266 0.685939994,40.9820724 L0.685939994,40.9820724 L0.685939994,40.9820724 Z" fill="#F2AF15"></path>                <path fill="#FAD87A" d="M3.31979798,39.5116596 C4.64241156,39.409337 5.96502514,39.4737623 7.29142845,39.5268185 C5.96502514,39.848945 4.64241156,39.8451553 3.31979798,39.5116596 L3.31979798,39.5116596 L3.31979798,39.5116596 Z"></path>                <path fill="#FBD276" d="M48.7889032,39.5154493 C49.9978251,39.4472343 51.1915881,39.5116596 52.4042997,39.5571363 C51.2294853,39.9626367 49.9750868,39.7617813 48.7889032,39.5154493 L48.7889032,39.5154493 L48.7889032,39.5154493 Z"></path>                <path d="M0.685939994,40.9820724 C3.71013953,41.8840266 6.92761497,41.8916061 9.96318368,41.042708 C9.85707141,41.535372 9.77748721,42.0356156 9.61073937,42.5131208 C9.75853859,41.3041989 8.72394402,42.0583539 8.09106015,42.2137326 C5.85891288,43.1194766 3.21368572,42.8617753 1.15586574,41.6301151 C1.0383843,41.467157 0.80342143,41.1450305 0.685939994,40.9820724 L0.685939994,40.9820724 L0.685939994,40.9820724 Z" fill="#C18A20"></path>                <path d="M46.158835,40.9934415 C49.1565064,41.8385499 52.3398744,41.8764472 55.322387,40.9555443 C54.9851015,41.5315823 54.9623632,42.1909942 54.9775221,42.8428267 L54.6970825,42.9034623 C54.6516059,42.7063967 54.5568628,42.3122654 54.5075964,42.1151998 C52.2413416,42.5472283 49.8538156,43.2445374 47.6444067,42.1379381 C47.2502754,42.1038306 46.7538216,41.6793815 46.4241156,42.0773025 C46.3255828,41.7172788 46.2346295,41.357255 46.158835,40.9934415 L46.158835,40.9934415 L46.158835,40.9934415 Z" fill="#CC751D"></path>                <path d="M31.9208429,42.5964947 C32.7811102,42.619233 33.0539703,41.9598211 33.2358771,41.2435633 C33.2661949,41.5126337 33.3306202,42.0469847 33.360938,42.3160551 C34.0355088,42.1796251 35.198954,41.7892835 35.2406409,42.8504062 C35.7143564,44.2184964 34.0392985,44.1730197 33.4935783,45.0522357 C32.1709647,44.3852443 30.6209677,45.1356096 29.2149802,45.1204507 C27.7483571,45.4804744 26.3954258,44.7717961 24.9477513,44.7376886 C24.2618113,44.2601834 22.6663376,43.7675193 23.3219598,42.687448 C23.4849179,41.6111665 24.7393165,42.2440504 25.4442051,42.331214 C27.5475018,42.9262006 29.7682799,43.0436821 31.9208429,42.5964947 L31.9208429,42.5964947 L31.9208429,42.5964947 Z" fill="#F3A814"></path>                <path d="M1.15586574,41.6301151 C3.21368572,42.8617753 5.85891288,43.1194766 8.09106015,42.2137326 C8.72394402,42.0583539 9.75853859,41.3041989 9.61073937,42.5131208 C9.231767,44.6505249 5.93470735,45.1318199 7.55670911,47.777047 C7.15878812,47.5117664 6.77602602,47.2275371 6.3894742,46.9508872 C6.24167498,45.9655591 5.78690813,44.279132 4.48324317,44.9878104 C4.21417278,45.0257076 3.67603201,45.1052918 3.40696163,45.1469787 C3.02798926,44.8854878 2.65659633,44.6239969 2.27004451,44.3814546 C1.64095037,43.5856126 1.34914165,42.6116536 1.15586574,41.6301151 L1.15586574,41.6301151 L1.15586574,41.6301151 Z" fill="#E7B526"></path>                <path d="M46.4241156,42.0773025 C46.7538216,41.6793815 47.2502754,42.1038306 47.6444067,42.1379381 C49.8538156,43.2445374 52.2413416,42.5472283 54.5075964,42.1151998 C54.5568628,42.3122654 54.6516059,42.7063967 54.6970825,42.9034623 C54.265054,43.9266877 53.2266697,44.5065154 52.4535661,45.2493013 C52.3929305,46.1057788 52.4497764,46.9660461 52.6241037,47.8301031 C52.3322949,47.557243 52.0480657,47.269224 51.7789953,46.9774153 C51.4985557,46.5226485 51.2446442,46.0527227 50.9907327,45.5865867 C50.012984,45.0484459 49.6794883,46.2346295 49.2815673,46.871303 C48.572889,47.4056541 47.0380509,49.190614 48.3682439,46.0148255 C48.394772,45.5790073 48.6373143,44.9802309 48.1181221,44.7338989 C47.1555323,44.1502814 46.6401299,43.1535841 46.4241156,42.0773025 L46.4241156,42.0773025 L46.4241156,42.0773025 Z" fill="#ECA423"></path>                <path d="M4.48324317,44.9878104 C5.78690813,44.279132 6.24167498,45.9655591 6.3894742,46.9508872 L6.38189475,47.2616446 C5.8134362,47.6444067 5.35866935,48.1635988 4.86600526,48.6373143 C4.60451433,48.0499071 4.35439256,47.4549205 3.93752295,46.9622564 C4.52493013,46.446854 4.6007246,45.7230168 4.48324317,44.9878104 L4.48324317,44.9878104 L4.48324317,44.9878104 Z" fill="#DF9817"></path>                <path d="M24.9477513,44.7376886 C26.3954258,44.7717961 27.7483571,45.4804744 29.2149802,45.1204507 C29.1884521,45.760914 28.1955445,46.3975876 28.8739051,46.9470975 C29.7228032,47.1744809 29.8592332,45.8821851 30.6550752,45.7950215 C30.5565424,46.4127465 30.3935843,47.0191023 30.329159,47.640617 C30.8559306,47.6519861 31.3864919,47.6481964 31.9094738,47.7429395 C30.7232902,48.3113981 30.4314815,49.5695863 30.2533645,50.7633493 C29.6659573,50.767139 29.0785501,50.767139 28.4949327,50.7633493 C28.5707272,48.0423277 25.0121766,47.3980746 24.9477513,44.7376886 L24.9477513,44.7376886 L24.9477513,44.7376886 Z" fill="#EEB529"></path>                <path d="M29.2149802,45.1204507 C30.6209677,45.1356096 32.1709647,44.3852443 33.4935783,45.0522357 C33.2889332,46.1057788 32.8948019,47.1858501 31.9094738,47.7429395 C31.3864919,47.6481964 30.8559306,47.6519861 30.329159,47.640617 C30.3935843,47.0191023 30.5565424,46.4127465 30.6550752,45.7950215 C29.8592332,45.8821851 29.7228032,47.1744809 28.8739051,46.9470975 C28.1955445,46.3975876 29.1884521,45.760914 29.2149802,45.1204507 L29.2149802,45.1204507 L29.2149802,45.1204507 Z" fill="#F4C12B"></path>                <path d="M3.40696163,45.1469787 C3.67603201,45.1052918 4.21417278,45.0257076 4.48324317,44.9878104 C4.6007246,45.7230168 4.52493013,46.446854 3.93752295,46.9622564 C3.64950395,47.2616446 3.3539055,47.5496636 3.04693788,47.8301031 C3.12652207,46.9281489 3.24400351,46.0337741 3.40696163,45.1469787 L3.40696163,45.1469787 L3.40696163,45.1469787 Z" fill="#F1B412"></path>                <path d="M49.2815673,46.871303 C49.6794883,46.2346295 50.012984,45.0484459 50.9907327,45.5865867 C51.2446442,46.0527227 51.4985557,46.5226485 51.7789953,46.9774153 C51.6160371,47.5079766 51.4796071,48.0536968 51.274962,48.5766787 C51.4758174,46.844775 49.8917129,49.3459926 49.7173856,47.6785142 C49.6074836,47.4776588 49.3914693,47.0721584 49.2815673,46.871303 L49.2815673,46.871303 L49.2815673,46.871303 Z" fill="#E08318"></path>                <path d="M4.86600526,48.6373143 C5.35866935,48.1635988 5.8134362,47.6444067 6.38189475,47.2616446 C6.66612403,48.3189775 6.85939994,49.4293666 7.48470436,50.3540591 C6.82529243,50.5094378 6.3894742,51.0437889 5.96502514,51.5288735 C5.69974448,51.1802189 5.46478161,50.808826 5.21844957,50.4488022 C5.05549145,49.8538156 4.95316891,49.2436701 4.86600526,48.6373143 L4.86600526,48.6373143 L4.86600526,48.6373143 Z" fill="#E2B639"></path>                <path d="M49.7173856,47.6785142 C49.8917129,49.3459926 51.4758174,46.844775 51.274962,48.5766787 C51.0741067,49.1034503 50.8012465,49.5999041 50.5359659,50.0963579 C49.903082,50.0660401 49.0882914,49.8651848 49.2247215,50.7936671 C49.2891468,51.5099249 48.4857253,50.8315643 48.1446502,50.8543027 C48.6183657,49.7704417 49.1565064,48.7168985 49.7173856,47.6785142 L49.7173856,47.6785142 L49.7173856,47.6785142 Z" fill="#E9AD3D"></path>                <path d="M49.2247215,50.7936671 C49.0882914,49.8651848 49.903082,50.0660401 50.5359659,50.0963579 C49.8841334,53.0599219 46.8258264,54.7690873 44.0669075,55.4663965 C42.1189895,55.4929245 40.0839078,54.9737324 38.1852563,55.5876676 C38.037457,55.5914573 37.7418586,55.6028265 37.5940594,55.610406 C36.1880719,55.4247095 34.7782946,55.3299664 33.3647277,55.3337561 C33.360938,54.8183537 33.360938,54.306741 33.3647277,53.7951283 C34.7707152,53.8140769 36.1880719,53.8330255 37.5940594,53.7193338 C37.7456483,53.7155441 38.0488262,53.7079646 38.2004152,53.7079646 C39.5116596,53.7496516 40.8380629,53.8330255 42.1568867,53.7572311 C44.4761976,53.7534413 46.8106675,52.8022207 48.1446502,50.8543027 C48.4857253,50.8315643 49.2891468,51.5099249 49.2247215,50.7936671 L49.2247215,50.7936671 L49.2247215,50.7936671 Z" fill="#F3CF4A"></path>                <path d="M5.96502514,51.5288735 C6.3894742,51.0437889 6.82529243,50.5094378 7.48470436,50.3540591 C9.98592202,54.2726335 15.1475257,54.2915821 19.2442171,53.7231235 C20.5592512,53.7534413 21.8818648,53.8102872 23.2006887,53.7496516 C23.9017875,53.7837591 24.6028864,53.7951283 25.307775,53.7723899 C25.3456723,54.416643 25.3722003,55.0646857 25.3949387,55.7127285 C24.663522,55.6975696 23.9321053,55.678621 23.2006887,55.636934 C21.8856545,55.3413356 20.5706204,55.3299664 19.2517965,55.6028265 C19.1002076,55.6066162 18.7970297,55.6141957 18.6454407,55.6179854 C17.3266169,55.3261767 16.0115827,55.3337561 14.6965486,55.636934 C11.3274842,55.9476914 7.71966723,54.5000169 5.96502514,51.5288735 L5.96502514,51.5288735 L5.96502514,51.5288735 Z" fill="#EFD348"></path>                <path d="M28.4949327,50.7633493 C29.0785501,50.767139 29.6659573,50.767139 30.2533645,50.7633493 C30.4201123,51.096845 30.5868602,51.4303407 30.7498183,51.7638364 C29.9615558,52.8893843 28.9648584,52.1049115 27.9795303,51.7638364 C28.1462781,51.4303407 28.3206054,51.096845 28.4949327,50.7633493 L28.4949327,50.7633493 L28.4949327,50.7633493 Z" fill="#F2A714"></path>                <path d="M27.1950575,52.6582112 C27.4527587,52.358823 27.7142496,52.0594348 27.9795303,51.7638364 C28.9648584,52.1049115 29.9615558,52.8893843 30.7498183,51.7638364 C31.1325804,52.1693368 31.5191322,52.5748372 31.8905252,52.9879171 C32.0496936,54.0452501 32.0496936,55.1063727 31.8981046,56.1637056 C31.6366137,56.4138274 31.3789125,56.6639492 31.1174215,56.9140709 C30.8256128,55.8718969 30.219257,54.8676201 30.6323369,53.7648105 C30.2723131,54.1437829 29.9539763,54.5568628 29.5939526,54.9320454 C28.7981106,54.0452501 26.9108282,54.2802129 27.1950575,52.6582112 L27.1950575,52.6582112 L27.1950575,52.6582112 Z" fill="#F3BA29"></path>                <path d="M25.307775,53.7723899 C25.815598,53.2153006 26.5318558,52.9727582 27.1950575,52.6582112 C26.9108282,54.2802129 28.7981106,54.0452501 29.5939526,54.9320454 C29.9539763,54.5568628 30.2723131,54.1437829 30.6323369,53.7648105 C30.219257,54.8676201 30.8256128,55.8718969 31.1174215,56.9140709 C31.6025062,57.7932868 31.0188887,58.312479 30.2495748,58.6952411 C29.6735368,58.5626007 29.0899193,58.4526987 28.5025121,58.4072221 C28.4229279,58.9832601 28.2637595,60.1391258 28.1841753,60.7189535 C28.0325864,59.422868 27.5740298,58.2063667 27.4262306,56.9178606 C27.1003144,56.1106495 26.0884581,56.0500139 25.3949387,55.7127285 C25.3722003,55.0646857 25.3456723,54.416643 25.307775,53.7723899 L25.307775,53.7723899 L25.307775,53.7723899 Z" fill="#EB9E1E"></path>                <path d="M31.8905252,52.9879171 C32.3831892,53.112978 32.8720636,53.2494081 33.360938,53.400997 L33.3647277,53.7951283 C33.360938,54.306741 33.360938,54.8183537 33.3647277,55.3337561 L33.360938,55.7278874 C32.8758533,55.8870558 32.386979,56.0310653 31.8981046,56.1637056 C32.0496936,55.1063727 32.0496936,54.0452501 31.8905252,52.9879171 L31.8905252,52.9879171 L31.8905252,52.9879171 Z" fill="#F3A315"></path>                <path fill="#814B15" d="M19.2442171,53.7231235 C20.5630409,53.4275251 21.8818648,53.4351045 23.2006887,53.7496516 C21.8818648,53.8102872 20.5592512,53.7534413 19.2442171,53.7231235 L19.2442171,53.7231235 L19.2442171,53.7231235 Z"></path>                <path fill="#8C4C18" d="M33.360938,53.400997 C34.7745049,53.442684 36.1842821,53.5487962 37.5940594,53.7193338 C36.1880719,53.8330255 34.7707152,53.8140769 33.3647277,53.7951283 L33.360938,53.400997 L33.360938,53.400997 Z"></path>                <path fill="#884716" d="M38.2004152,53.7079646 C39.5230287,53.4275251 40.8380629,53.442684 42.1568867,53.7572311 C40.8380629,53.8330255 39.5116596,53.7496516 38.2004152,53.7079646 L38.2004152,53.7079646 L38.2004152,53.7079646 Z"></path>                <path fill="#D7B94D" d="M14.6965486,55.636934 C16.0115827,55.3337561 17.3266169,55.3261767 18.6454407,55.6179854 C17.3341963,55.7203079 16.007793,55.6558826 14.6965486,55.636934 L14.6965486,55.636934 L14.6965486,55.636934 Z"></path>                <path fill="#D4B54C" d="M19.2517965,55.6028265 C20.5706204,55.3299664 21.8856545,55.3413356 23.2006887,55.636934 C21.8856545,55.7089388 20.5630409,55.6445135 19.2517965,55.6028265 L19.2517965,55.6028265 L19.2517965,55.6028265 Z"></path>                <path fill="#CBA848" d="M33.3647277,55.3337561 C34.7782946,55.3299664 36.1880719,55.4247095 37.5940594,55.610406 C36.1880719,55.7278874 34.7669255,55.7127285 33.360938,55.7278874 L33.3647277,55.3337561 L33.3647277,55.3337561 Z"></path>                <path fill="#CEAC4A" d="M38.1852563,55.5876676 C40.0839078,54.9737324 42.1189895,55.4929245 44.0669075,55.4663965 C42.1644662,56.0538036 40.1255948,55.5459807 38.1852563,55.5876676 L38.1852563,55.5876676 L38.1852563,55.5876676 Z"></path>                <path d="M28.5025121,58.4072221 C29.0899193,58.4526987 29.6735368,58.5626007 30.2495748,58.6952411 C30.3897946,60.3892476 30.8104539,62.0415671 30.9544634,63.7393633 C31.3675433,66.1382585 31.6290342,68.5598919 32.1141189,70.9474179 C32.3756098,72.9521817 32.989545,75.1047448 31.810941,76.9427608 C31.6479828,77.0564525 31.3258563,77.2838359 31.1666879,77.3975277 C30.6247574,77.5112194 29.9084996,77.9432479 29.6204806,77.2194106 C29.49163,76.0104888 30.1699906,74.9114689 30.7422389,73.8996127 C29.9463969,73.9791969 29.1732932,74.1762625 28.381241,74.2861645 C28.7526339,73.9867763 29.1429755,73.7177059 29.5143684,73.4183177 C28.2372315,72.2662417 27.6005579,70.7427728 26.7781878,69.2875189 C26.8501926,68.7001117 26.9335665,68.1164943 27.0207302,67.5366665 C27.1268424,66.968208 27.339067,65.8350806 27.4451792,65.266622 C27.7597263,63.7621017 27.9454228,62.234843 28.1841753,60.7189535 C28.2637595,60.1391258 28.4229279,58.9832601 28.5025121,58.4072221 L28.5025121,58.4072221 L28.5025121,58.4072221 Z" fill="#F2B92E"></path>                <path d="M26.4901688,71.9289563 C26.569753,71.0459507 26.6682859,70.1629451 26.7781878,69.2875189 C27.6005579,70.7427728 28.2372315,72.2662417 29.5143684,73.4183177 C29.1429755,73.7177059 28.7526339,73.9867763 28.381241,74.2861645 C29.1732932,74.1762625 29.9463969,73.9791969 30.7422389,73.8996127 C30.1699906,74.9114689 29.49163,76.0104888 29.6204806,77.2194106 C29.9084996,77.9432479 30.6247574,77.5112194 31.1666879,77.3975277 C31.0946832,78.0114629 30.8597203,78.5571831 30.3177898,78.8944685 C29.6773265,78.8755199 29.0406529,78.8793096 28.4039793,78.9058377 C27.6725626,78.0758882 27.255693,77.0261347 26.4825894,76.226503 C26.4977483,74.7901977 26.5280661,73.3614719 26.4901688,71.9289563 L26.4901688,71.9289563 L26.4901688,71.9289563 Z" fill="#EC9F29"></path>                <path fill="#C07322" d="M26.103617,72.3913026 C26.1983601,72.2738212 26.391636,72.042648 26.4901688,71.9289563 C26.5280661,73.3614719 26.4977483,74.7901977 26.4825894,76.226503 C25.7398035,75.1312729 26.3385799,73.6040142 26.103617,72.3913026 L26.103617,72.3913026 L26.103617,72.3913026 Z"></path>                <path d="M28.4039793,78.9058377 C29.0406529,78.8793096 29.6773265,78.8755199 30.3177898,78.8944685 C30.2344159,79.8305303 30.6058088,80.6907976 31.0871037,81.4714807 C29.931238,81.4639012 28.7905311,81.4601115 27.6384551,81.4373731 C27.8468899,81.1076672 28.0325864,80.7628023 28.1955445,80.410358 C28.4380868,79.944222 28.381241,79.4060812 28.4039793,78.9058377 L28.4039793,78.9058377 L28.4039793,78.9058377 Z" fill="#E28217"></path>                <path d="M26.5166969,81.8883503 C26.8805104,81.714023 27.255693,81.5662238 27.6384551,81.4373731 C28.7905311,81.4601115 29.931238,81.4639012 31.0871037,81.4714807 C31.2690105,81.4752704 31.6290342,81.4752704 31.810941,81.4752704 C31.7389362,81.9755139 31.6441931,82.4757574 31.5153425,82.9684215 C30.1396728,82.976001 28.7715825,82.9722113 27.3997025,83.0517955 C27.1003144,82.6652436 26.7857673,82.290061 26.5166969,81.8883503 L26.5166969,81.8883503 L26.5166969,81.8883503 Z" fill="#F19C19"></path>                <path d="M27.3997025,83.0517955 C28.7715825,82.9722113 30.1396728,82.976001 31.5153425,82.9684215 C33.9710835,85.3445783 37.0180214,87.2811271 40.4969877,87.5653564 C41.4406289,87.8988521 42.5169105,89.4677977 40.9290162,89.8240318 C34.759346,92.2835625 27.8241516,91.7264731 21.3475137,90.9836872 C22.1698838,90.5137615 21.2376118,89.8732982 21.495313,89.3578957 C23.9965306,89.6193867 27.4034923,88.3422498 27.3125389,85.3635269 C25.9747664,85.2460455 25.0652327,86.2503223 23.9662128,86.8112014 C23.8222033,86.5951871 23.5303946,86.1631586 23.3863851,85.9471444 C24.2314935,85.4279522 24.9970177,84.8026478 25.7663316,84.1811331 C26.3310004,83.8324785 26.8956693,83.483824 27.3997025,83.0517955 L27.3997025,83.0517955 L27.3997025,83.0517955 Z M28.8814845,84.5638952 C27.805203,85.2915222 28.915592,87.0120567 28.4229279,87.9253802 C28.6427319,88.3990956 28.161437,90.8927338 29.5295273,90.5819765 C29.6318498,89.6307558 29.8327052,87.7321043 29.9350277,86.7846733 C30.5906499,86.1328408 29.9426072,84.1735537 28.8814845,84.5638952 L28.8814845,84.5638952 L28.8814845,84.5638952 Z M31.0643654,85.6439665 C30.9014073,86.69372 31.5987164,87.584305 32.5044604,88.0087541 C34.4940654,89.4867463 37.0976056,89.4374799 39.4358651,89.0054514 C38.943201,88.3157217 37.8517606,88.3460395 37.1127644,87.9594877 C35.0132575,87.4289264 33.2927229,85.5416439 31.0643654,85.6439665 L31.0643654,85.6439665 L31.0643654,85.6439665 Z" fill="#F4BC40"></path>                <path d="M28.8814845,84.5638952 C29.9426072,84.1735537 30.5906499,86.1328408 29.9350277,86.7846733 C29.8327052,87.7321043 29.6318498,89.6307558 29.5295273,90.5819765 C28.161437,90.8927338 28.6427319,88.3990956 28.4229279,87.9253802 C28.915592,87.0120567 27.805203,85.2915222 28.8814845,84.5638952 L28.8814845,84.5638952 L28.8814845,84.5638952 Z" fill="#EA8A1E"></path>                <path d="M23.9662128,86.8112014 C25.0652327,86.2503223 25.9747664,85.2460455 27.3125389,85.3635269 C27.4034923,88.3422498 23.9965306,89.6193867 21.495313,89.3578957 C21.7492245,88.8273344 22.757291,88.3195114 21.9500798,87.804109 C22.2722063,87.0764821 22.9429874,86.7467761 23.9662128,86.8112014 L23.9662128,86.8112014 L23.9662128,86.8112014 Z" fill="#ED9F22"></path>                <path d="M31.0643654,85.6439665 C33.2927229,85.5416439 35.0132575,87.4289264 37.1127644,87.9594877 C37.8517606,88.3460395 38.943201,88.3157217 39.4358651,89.0054514 C37.0976056,89.4374799 34.4940654,89.4867463 32.5044604,88.0087541 C31.5987164,87.584305 30.9014073,86.69372 31.0643654,85.6439665 L31.0643654,85.6439665 L31.0643654,85.6439665 Z" fill="#EEA226"></path>                <path d="M21.2376118,86.7657247 C21.9273415,86.4208598 22.6360198,86.1176819 23.3863851,85.9471444 C23.5303946,86.1631586 23.8222033,86.5951871 23.9662128,86.8112014 C22.9429874,86.7467761 22.2722063,87.0764821 21.9500798,87.804109 C21.343724,88.0580205 20.7222093,88.2854039 20.0627974,88.3422498 C20.4228212,87.7927398 20.8396908,87.2849169 21.2376118,86.7657247 L21.2376118,86.7657247 L21.2376118,86.7657247 Z" fill="#ECA831"></path>                <path d="M18.5469079,87.4706133 C19.4337033,87.2167018 20.343237,87.008267 21.2376118,86.7657247 C20.8396908,87.2849169 20.4228212,87.7927398 20.0627974,88.3422498 C20.7222093,88.2854039 21.343724,88.0580205 21.9500798,87.804109 C22.757291,88.3195114 21.7492245,88.8273344 21.495313,89.3578957 C21.2376118,89.8732982 22.1698838,90.5137615 21.3475137,90.9836872 C21.0329667,91.590043 20.7563168,92.2191371 20.4531389,92.8330724 C20.191648,92.8141238 19.6610867,92.7724368 19.3995958,92.7496985 C19.285904,92.6928526 19.0547309,92.5715815 18.9410392,92.5147356 C19.1835815,91.9614359 19.4867594,91.3475007 19.2404274,90.7373552 C18.1414075,90.4834437 17.269771,88.9220775 16.337499,90.286378 C16.4549804,88.9410261 17.3758833,88.0201233 18.5469079,87.4706133 L18.5469079,87.4706133 L18.5469079,87.4706133 Z" fill="#E78725"></path>                <path d="M15.0641518,88.2399272 C16.2313867,87.9973849 17.3645141,87.6297817 18.5469079,87.4706133 C17.3758833,88.0201233 16.4549804,88.9410261 16.337499,90.286378 C17.269771,88.9220775 18.1414075,90.4834437 19.2404274,90.7373552 C19.4867594,91.3475007 19.1835815,91.9614359 18.9410392,92.5147356 C17.4782058,92.0637585 15.8372555,92.0523893 14.5222213,91.2072809 C13.8287019,90.6880888 12.8130559,89.9074057 13.6430054,89.0244 C14.1129312,88.7515399 14.5790672,88.4748901 15.0641518,88.2399272 L15.0641518,88.2399272 L15.0641518,88.2399272 Z" fill="#E4781A"></path>                <path d="M40.4969877,87.5653564 C41.2549325,87.6487303 42.0052978,87.8116885 42.7518734,87.9784363 C42.9375698,88.0769691 43.3089627,88.270245 43.4946592,88.3687778 C44.2488142,88.8083858 45.0219179,89.3389471 45.2644602,90.2371116 C44.4648285,91.3588699 43.0891588,91.6430991 41.8802369,92.1054454 C34.8654583,93.6251246 27.5664504,93.8373492 20.4531389,92.8330724 C20.7563168,92.2191371 21.0329667,91.590043 21.3475137,90.9836872 C27.8241516,91.7264731 34.759346,92.2835625 40.9290162,89.8240318 C42.5169105,89.4677977 41.4406289,87.8988521 40.4969877,87.5653564 L40.4969877,87.5653564 L40.4969877,87.5653564 Z" fill="#F19C1F"></path>            </g>        </g>        <g id="Oval-4-+-Oval-8-Copy-2-Copy" sketch:type="MSLayerGroup" transform="translate(70.103142, 72.141573) rotate(-10.000000) translate(-70.103142, -72.141573) translate(60.103142, 65.641573)">            <path d="M6.85967026,10.1761652 C7.85027642,10.2131284 16.3812648,12.026637 16.3812648,12.026637 C16.3812648,12.026637 18.8246953,3.4389116 16.3812648,1.17860114 C15.3670849,0.240427771 8.81942274,1.29472968 6.85967026,1.17860114 C-0.713525734,0.729838281 -1.5518752,9.86229885 6.85967026,10.1761652 Z" id="Oval-4" fill="#3F3333" sketch:type="MSShapeGroup" transform="translate(9.164255, 6.406454) rotate(185.000000) translate(-9.164255, -6.406454) "></path>            <path d="M16.5841511,10.5943197 C17.9532113,10.5943197 19.0630538,9.2511739 19.0630538,7.59431965 C19.0630538,5.9374654 14.1052484,5.9374654 14.1052484,7.59431965 C14.1052484,9.2511739 15.215091,10.5943197 16.5841511,10.5943197 Z" id="Oval-8-Copy-2-Copy" fill="#000000" sketch:type="MSShapeGroup" transform="translate(16.584151, 8.472999) rotate(-77.000000) translate(-16.584151, -8.472999) "></path>        </g>        <g id="fingers-copy" sketch:type="MSLayerGroup" transform="translate(81.459803, 78.348963) rotate(-87.000000) translate(-81.459803, -78.348963) translate(70.459803, 73.348963)" fill="#000000">            <ellipse id="Oval-8" sketch:type="MSShapeGroup" cx="19.9462936" cy="5.94903451" rx="2" ry="3"></ellipse>            <ellipse id="Oval-8-Copy" sketch:type="MSShapeGroup" cx="11.1859842" cy="5.0082228" rx="2.5" ry="4"></ellipse>            <ellipse id="Oval-8-Copy-2" sketch:type="MSShapeGroup" cx="2.68735473" cy="3.06055875" rx="2" ry="3"></ellipse>        </g>    </g></svg>')
position absolute
z-index -1
left 8.5*GS
top 7*GS
.mole-mouth
position absolute
width 25*PX
height 25*PX
// left 200%
right 15*PX
top 68*PX
z-index 2
border-radius 50%
overflow hidden
// border 1px solid cyan
&__inner
position absolute
width 15*PX
left -16*PX
top 10*PX
.mole-scene
position absolute
left 50%
top 50%
margin-left -106*PX
&__ground
background #664001
position absolute
z-index 0
width 214*PX
height 211*PX
border-top-right-radius BRADIUS + .3
border-bottom-right-radius BRADIUS
transform rotateX(68deg) rotateZ(48deg) translateX(-8.5*GS) translateY(-13.6*GS) translateZ(-2px)
top -4*GS
&__door
top -3.56*GS
transform rotateX(68deg) rotateZ(48deg) translateX(-12.2*GS) translateY(-11.6*GS)
transform-origin 0% 50%
position absolute
z-index 1
transform-style preserve-3d
rect 209*PX
&__door-wave
// border 5px solid white
width 120px
height 120px
position absolute
z-index 12
left 0
top 0
border-radius 20px
opacity 0
background white
transform scale(0) translateZ(0)
&__door-wave-wrapper
position absolute
transform rotateX(70deg) rotateZ(48deg) translate(35px, -180px)
z-index 6
opacity .75
&__door-rotation
// display none
// transition all 1s linear
transform translateX(8px) translateY(8px)
transform-origin 0% 50%
transform-style preserve-3d
&__mask
position absolute
top 0*PX
left -6*PX
// outline 1px solid
width 306*PX
height 673*PX
background url('data:image/svg+xml;base64,PD94bWwgdmVyc2lvbj0iMS4wIiBlbmNvZGluZz0iVVRGLTgiIHN0YW5kYWxvbmU9Im5vIj8+PHN2ZyB3aWR0aD0iMzA2cHgiIGhlaWdodD0iNjczcHgiIHZpZXdCb3g9IjAgMCAzMDYgNjczIiB2ZXJzaW9uPSIxLjEiIHhtbG5zPSJodHRwOi8vd3d3LnczLm9yZy8yMDAwL3N2ZyIgeG1sbnM6eGxpbms9Imh0dHA6Ly93d3cudzMub3JnLzE5OTkveGxpbmsiIHhtbG5zOnNrZXRjaD0iaHR0cDovL3d3dy5ib2hlbWlhbmNvZGluZy5jb20vc2tldGNoL25zIj4gICAgICAgIDx0aXRsZT5VbnRpdGxlZCAxNDwvdGl0bGU+ICAgIDxkZXNjPkNyZWF0ZWQgd2l0aCBTa2V0Y2guPC9kZXNjPiAgICA8ZGVmcz48L2RlZnM+ICAgIDxnIGlkPSJQYWdlLTEiIHN0cm9rZT0ibm9uZSIgc3Ryb2tlLXdpZHRoPSIxIiBmaWxsPSJub25lIiBmaWxsLXJ1bGU9ImV2ZW5vZGQiIHNrZXRjaDp0eXBlPSJNU1BhZ2UiPiAgICAgICAgPGcgaWQ9Im1vbGUtbWFzayIgc2tldGNoOnR5cGU9Ik1TTGF5ZXJHcm91cCI+ICAgICAgICAgICAgPGcgaWQ9IlBhZ2UtMSIgc2tldGNoOnR5cGU9Ik1TU2hhcGVHcm91cCI+ICAgICAgICAgICAgICAgIDxnIGlkPSJtb2xlLW1hc2siIHRyYW5zZm9ybT0idHJhbnNsYXRlKDQuMDAwMDAwLCAyLjAwMDAwMCkiIGZpbGw9IiM1MEUzQzIiPiAgICAgICAgICAgICAgICAgICAgPGcgaWQ9IlBhZ2UtMSI+ICAgICAgICAgICAgICAgICAgICAgICAgPGcgaWQ9Im1vbGUtbWFzayI+ICAgICAgICAgICAgICAgICAgICAgICAgICAgIDxnIGlkPSJQYWdlLTEiPiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgPHBhdGggZD0iTTI5NC44ODgyMDIsMTEuMTY1NzQ1MiBDMjk1LjkzNzIwMSwxMC44MTgxMDk2IDI5Ni45MjE5NjcsOS42NjA5MDY2IDI5Ny4wOTE4NjgsOC41NTQxNTM4NyBMMjk3LjQ2Nzc3Myw2LjEwNTQ2ODc1IEwzMDEuMjA4NDk2LDYuMTA1NDY4NzUgTDMwMS4yMDg0ODYsNjcwLjEzNjcxOSBMMC45NjU2NDc0NjMsNjcwLjEzNjcxOSBMMC45NjU2NTc1NDcsMC43MjQxMjEwOTQgTDE0MS45NDE5NDYsNTguNDI5MjE1NSBDMTQ0LjQ5NDYxNyw1OS40NzM0NjA1IDE0OC42ODc1NzMsNTkuNjE2MjMwMyAxNTEuMzA3OTcyLDU4Ljc0NzgzNzQgTDI5NC44ODgyMDIsMTEuMTY1NzQ1MiBaIiBpZD0iUGF0aC0xIj48L3BhdGg+ICAgICAgICAgICAgICAgICAgICAgICAgICAgIDwvZz4gICAgICAgICAgICAgICAgICAgICAgICA8L2c+ICAgICAgICAgICAgICAgICAgICA8L2c+ICAgICAgICAgICAgICAgIDwvZz4gICAgICAgICAgICAgICAgPHBhdGggZD0iTTAuNzgzMjAzMTMsMC45ODY2NTM2NSBMNDguOTgzNzIzOSwyMC42OTMzNTk0IiBpZD0iUGF0aC0yIiBzdHJva2U9IiM5Nzk3OTciIHN0cm9rZS13aWR0aD0iMC4xIj48L3BhdGg+ICAgICAgICAgICAgPC9nPiAgICAgICAgPC9nPiAgICA8L2c+PC9zdmc+')
z-index 2
&__mole
position absolute
z-index 2
top 6*GS
// top -17*GS
left 5*GS
// DOOR
bgColor = #F5A623
bgColorDark = darken(#F5A623, 8)
.scene, .shape, .face, .face-wrapper, .cr
position absolute;
transform-style preserve-3d;
.shape
top 50%;
left 50%;
width 0;
height 0;
transform rotateZ(90deg);
transform-origin 50%;
.face, .face-wrapper
overflow hidden;
transform-origin 0 0;
backface-visibility hidden;
/* hidden by default, prevent blinking and other weird rendering glitchs */
.face
background-size 100% 100%;
background-position center;
.face-wrapper .face
left 100%;
width 100%;
height 100%
.photon-shader
position absolute;
left 0;
top 0;
width 100%;
height 100%
.side
left 50%;
.cr, .cr .side
height 100%;
[class*="cuboid"] .ft, [class*="cuboid"] .bk
width 100%;
height 100%;
[class*="cuboid"] .bk
left 100%;
[class*="cuboid"] .rt
transform rotateY(-90deg) translateX(-50%);
[class*="cuboid"] .lt
transform rotateY(90deg) translateX(-50%);
[class*="cuboid"] .tp
transform rotateX(90deg) translateY(-50%);
[class*="cuboid"] .bm
transform rotateX(-90deg) translateY(-50%);
[class*="cuboid"] .lt
left 100%;
[class*="cuboid"] .bm
top 100%;
coverSize = 20;
.door .bm
overflow visible;
&:before,
&:after
content '';
position absolute;
background inherit;
&:before
height (coverSize)px;
width 110%;
top -(.8*coverSize)px;
left -(coverSize)px;
&:after
width (coverSize)px;
height 100%;
left -(coverSize)px;
top 0;
transform translateX(1px)
/* .cub-1 styles */
.cub-1
transform translate3D(0em, 0em, 0em) rotateX(90deg) rotateY(0deg) rotateZ(0deg);
opacity 1;
width 13em;
height .3em;
margin -0.15em 0 0 -6.5em;
.cub-1 .ft
transform translateZ(6.5em);
.cub-1 .bk
transform translateZ(-6.5em) rotateY(180deg);
.cub-1 .rt, .cub-1 .lt
width 13em;
height .3em;
.cub-1 .tp, .cub-1 .bm
width 13em;
height 13em;
.cub-1 .face
background-color bgColor;
.cub-1 .bm
background-color c-main-background;
.cub-1 .tp
background bgColor url('data:image/png;base64,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');
.cub-1 .ft
width 12em;
margin-left 0.5em;
.cub-1 .bk
width 12.5em;
margin-left -0.5em;
background-color bgColorDark;
.cub-1 .rt, .cub-1 .lt
width 12em;
background-color bgColorDark;
.cub-1 .rt
width 13em;
.cub-1 .tp, .cub-1 .bm, .cub-1 .tp .photon-shader, .cub-1 .bm .photon-shader
border-radius 0.5em;
border-top-left-radius 0;
border-bottom-left-radius 0;
.cub-1 .cr
width 0.5em;
left 0.25em;
.cub-1 .cr-0
transform translate3D(12em, 0, 6em);
.cub-1 .cr-1
transform translate3D(12em, 0, -6em);
.cub-1 .cr-2
transform translate3D(0, 0, -6em);
.cub-1 .cr-3
transform translate3D(0, 0, 6em);
.cub-1 .cr-0 .s0
transform rotateY(15deg) translate3D(-50%, 0, 0.475em);
.cub-1 .cr-0 .s1
transform rotateY(45deg) translate3D(-50%, 0, 0.475em);
.cub-1 .cr-0 .s2
transform rotateY(75deg) translate3D(-50%, 0, 0.475em);
.cub-1 .cr-1 .s0
transform rotateY(105deg) translate3D(-50%, 0, 0.475em);
.cub-1 .cr-1 .s1
transform rotateY(135deg) translate3D(-50%, 0, 0.475em);
.cub-1 .cr-1 .s2
transform rotateY(165deg) translate3D(-50%, 0, 0.475em);
.cub-1 .cr-2 .s0
transform rotateY(195deg) translate3D(-50%, 0, 0.475em);
.cub-1 .cr-2 .s1
transform rotateY(225deg) translate3D(-50%, 0, 0.475em);
.cub-1 .cr-2 .s2
transform rotateY(255deg) translate3D(-50%, 0, 0.475em);
.cub-1 .cr-3 .s0
transform rotateY(285deg) translate3D(-50%, 0, 0.475em);
.cub-1 .cr-3 .s1
transform rotateY(315deg) translate3D(-50%, 0, 0.475em);
.cub-1 .cr-3 .s2
transform rotateY(345deg) translate3D(-50%, 0, 0.475em);
.cub-1 .side
width 0.2929491924311227em;
background-color bgColorDark;
// DOOR SHADOW
.door-shadow
width 7.5*GS
height 99.5%
position absolute
transform translateX(-7.4*GS) translateY(-50%)
&__el
background rgba(0,0,0,.15)
position absolute
transform scaleX(0)
transform-origin 100% center
rect 100%
border-bottom-left-radius BRADIUS
// DOOR HANDLE
.door-handle
position absolute
top 7%
right 50%
margin-right -1*GS
rect 13*PX
&__part
position absolute
z-index 1
circle 100%
&--bottom
background-color #EDEDED
&--top
background-color white
left 1*PX
top 2*PX
&__shadow
position absolute
left GS
top 0
width 100%
height 4*GS
opacity .1
z-index 0
transform rotate(105deg)
transform-origin 0% 0%
&__shadow-inner
position absolute
z-index 0
left 0
top 0
background linear-gradient(to bottom, rgba(0,0,0,0.65) 0%,rgba(0,0,0,0) 100%)
transform-origin inherit
rect 100%
// CUBE
squareSize = 100
.square
width (squareSize)px
height (squareSize)px
background cyan
position absolute
left 50%
margin-left -(squareSize/2)px
top 50px
z-index 1
.shadow-wrapper
transform rotateX(70deg)
width (squareSize)px
height (squareSize)px
position absolute
z-index 0
// top (500+squareSize)px
// left 50%
margin-left (squareSize)px
.shadow
width 100%
height 100%
background rgba(0,0,0,0.5)
.cube-wrapper
z-index 10
position absolute
width (squareSize)px
height (squareSize)px
left 50%
margin-left (squareSize)px
top -(squareSize)px
.cube
transform-style preserve-3d
transform rotateY(45deg) rotateX(-15deg) rotateZ(-15deg)
z-index 1
font-size 0
&__squash
transform-origin center (squareSize)px
.cube__side
position absolute
width (squareSize)px
height (squareSize)px
background white
border-radius 10px
&:after
content ''
position absolute
left 0
top 0
width 100%
height 100%
border-radius inherit
&--back
transform translateZ(-(squareSize/2)px) rotateY(180deg)
&--right
transform rotateY(-270deg) translateX((squareSize/2)px)
transform-origin top right
&--left
transform rotateY(270deg) translateX(-(squareSize/2)px)
transform-origin center left
&--top
transform rotateX(-90deg) translateY(-(squareSize/2)px)
transform-origin top center
&:after
background rgba(0,0,0,.02)
&--bottom
transform rotateX(90deg) translateY((squareSize/2)px)
transform-origin bottom center
&--front
transform translateZ((squareSize/2)px)
&:after
background rgba(0,0,0,.05)
shadowSize = squareSize+7
.cube-shadow-wrapper
transform-style preserve-3d
width (shadowSize)px
height (shadowSize)px
position absolute
left 50%
margin-left -(shadowSize/2)px
top (.42*squareSize)px
z-index 0
transform rotateX(112deg) rotateZ(45deg)
.transit
transform rotateX(127.5deg) rotateZ(46deg) !important
.cube-shadow
background rgba(0,0,0,.25)
width 100%
height 100%
border-radius 10px
opacity 0
// TUTORIAL LINK
{el = '.tutorial-link'}
position fixed
color white
bottom 20*PX
right 20*PX
font-size 10*PX
font-family sans-serif
text-decoration none
padding-left 30*PX
letter-spacing 1.5*PX
&:hover
opacity .85
{el}__logo
path
fill #F34246
&__logo
width 24*PX
height 24*PX
position absolute
right 10*PX
top -32*PX
// display none
svg
width 100%
height 100%
path
fill #F35D5C
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment