Created
March 6, 2017 03:48
-
-
Save 0b01/47605a25fdb72f3e541fff4f80b3c603 to your computer and use it in GitHub Desktop.
parallax.html
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
<html> | |
<head> | |
<script type="text/javascript" src="https://ajax.googleapis.com/ajax/libs/jquery/2.1.4/jquery.min.js"></script> | |
<script> | |
(function ($) { | |
var maxfps = 25, | |
delay = 1 / maxfps * 1000, | |
lastRender = new Date().getTime(), | |
layers = [], | |
plaxActivityTarget = {}, | |
motionDegrees = 30, | |
motionMax = 1, | |
motionMin = -1, | |
motionStartX = null, | |
motionStartY = null, | |
ignoreMoveable = false, | |
options = null; | |
var defaults = { | |
useTransform : true | |
}; | |
// Public Methods | |
$.fn.plaxify = function (params){ | |
options = $.extend({}, defaults, params); | |
options.useTransform = (options.useTransform ? supports3dTransform() : false); | |
return this.each(function () { | |
var layerExistsAt = -1; | |
var layer = { | |
"xRange": $(this).data('xrange') || 0, | |
"yRange": $(this).data('yrange') || 0, | |
"zRange": $(this).data('zrange') || 0, | |
"invert": $(this).data('invert') || false, | |
"background": $(this).data('background') || false | |
}; | |
for (var i=0;i<layers.length;i++){ | |
if (this === layers[i].obj.get(0)){ | |
layerExistsAt = i; | |
} | |
} | |
for (var param in params) { | |
if (layer[param] == 0) { | |
layer[param] = params[param]; | |
} | |
} | |
layer.inversionFactor = (layer.invert ? -1 : 1); // inversion factor for calculations | |
// Add an object to the list of things to parallax | |
layer.obj = $(this); | |
if(layer.background) { | |
// animate using the element's background | |
pos = (layer.obj.css('background-position') || "0px 0px").split(/ /); | |
if(pos.length != 2) { | |
return; | |
} | |
x = pos[0].match(/^((-?\d+)\s*px|0+\s*%|left)$/); | |
y = pos[1].match(/^((-?\d+)\s*px|0+\s*%|top)$/); | |
if(!x || !y) { | |
// no can-doesville, babydoll, we need pixels or top/left as initial values (it mightbe possible to construct a temporary image from the background-image property and get the dimensions and run some numbers, but that'll almost definitely be slow) | |
return; | |
} | |
layer.originX = layer.startX = x[2] || 0; | |
layer.originY = layer.startY = y[2] || 0; | |
layer.transformOriginX = layer.transformStartX = 0; | |
layer.transformOriginY = layer.transformStartY = 0; | |
layer.transformOriginZ = layer.transformStartZ = 0; | |
} else { | |
// Figure out where the element is positioned, then reposition it from the top/left, same for transform if using translate3d | |
var position = layer.obj.position(), | |
transformTranslate = get3dTranslation(layer.obj); | |
layer.obj.css({ | |
'transform' : transformTranslate.join() + 'px', | |
'top' : position.top, | |
'left' : position.left, | |
'right' :'', | |
'bottom':'' | |
}); | |
layer.originX = layer.startX = position.left; | |
layer.originY = layer.startY = position.top; | |
layer.transformOriginX = layer.transformStartX = transformTranslate[0]; | |
layer.transformOriginY = layer.transformStartY = transformTranslate[1]; | |
layer.transformOriginZ = layer.transformStartZ = transformTranslate[2]; | |
} | |
layer.startX -= layer.inversionFactor * Math.floor(layer.xRange/2); | |
layer.startY -= layer.inversionFactor * Math.floor(layer.yRange/2); | |
layer.transformStartX -= layer.inversionFactor * Math.floor(layer.xRange/2); | |
layer.transformStartY -= layer.inversionFactor * Math.floor(layer.yRange/2); | |
layer.transformStartZ -= layer.inversionFactor * Math.floor(layer.zRange/2); | |
if(layerExistsAt >= 0){ | |
layers.splice(layerExistsAt,1,layer); | |
} else { | |
layers.push(layer); | |
} | |
}); | |
}; | |
// Get the translate position of the element | |
// | |
// return 3 element array for translate3d | |
function get3dTranslation(obj) { | |
var translate = [0,0,0], | |
matrix = obj.css("-webkit-transform") || | |
obj.css("-moz-transform") || | |
obj.css("-ms-transform") || | |
obj.css("-o-transform") || | |
obj.css("transform"); | |
if(matrix !== 'none') { | |
var values = matrix.split('(')[1].split(')')[0].split(','); | |
var x = 0, | |
y = 0, | |
z = 0; | |
if(values.length == 16){ | |
// 3d matrix | |
x = (parseFloat(values[values.length - 4])); | |
y = (parseFloat(values[values.length - 3])); | |
z = (parseFloat(values[values.length - 2])); | |
}else{ | |
// z is not transformed as is not a 3d matrix | |
x = (parseFloat(values[values.length - 2])); | |
y = (parseFloat(values[values.length - 1])); | |
z = 0; | |
} | |
translate = [x,y,z]; | |
} | |
return translate; | |
} | |
// Check if element is in viewport area | |
// | |
// Returns boolean | |
function inViewport(element) { | |
if (element.offsetWidth === 0 || element.offsetHeight === 0) return false; | |
var height = document.documentElement.clientHeight, | |
rects = element.getClientRects(); | |
for (var i = 0, l = rects.length; i < l; i++) { | |
var r = rects[i], | |
in_viewport = r.top > 0 ? r.top <= height : (r.bottom > 0 && r.bottom <= height); | |
if (in_viewport) return true; | |
} | |
return false; | |
} | |
// Check support for 3dTransform | |
// | |
// Returns boolean | |
function supports3dTransform() { | |
var el = document.createElement('p'), | |
has3d, | |
transforms = { | |
'webkitTransform':'-webkit-transform', | |
'OTransform':'-o-transform', | |
'msTransform':'-ms-transform', | |
'MozTransform':'-moz-transform', | |
'transform':'transform' | |
}; | |
document.body.insertBefore(el, null); | |
for (var t in transforms) { | |
if (el.style[t] !== undefined) { | |
el.style[t] = "translate3d(1px,1px,1px)"; | |
has3d = window.getComputedStyle(el).getPropertyValue(transforms[t]); | |
} | |
} | |
document.body.removeChild(el); | |
return (has3d !== undefined && has3d.length > 0 && has3d !== "none"); | |
} | |
// Determine if the device has an accelerometer | |
// | |
// returns true if the browser has window.DeviceMotionEvent (mobile) | |
function moveable(){ | |
return (ignoreMoveable===true) ? false : window.DeviceOrientationEvent !== undefined; | |
} | |
// The values pulled from the gyroscope of a motion device. | |
// | |
// Returns an object literal with x and y as options. | |
function valuesFromMotion(e) { | |
x = e.gamma; | |
y = e.beta; | |
// Swap x and y in Landscape orientation | |
if (Math.abs(window.orientation) === 90) { | |
var a = x; | |
x = y; | |
y = a; | |
} | |
// Invert x and y in upsidedown orientations | |
if (window.orientation < 0) { | |
x = -x; | |
y = -y; | |
} | |
motionStartX = (motionStartX === null) ? x : motionStartX; | |
motionStartY = (motionStartY === null) ? y : motionStartY; | |
return { | |
x: x - motionStartX, | |
y: y - motionStartY | |
}; | |
} | |
// Move the elements in the `layers` array within their ranges, | |
// based on mouse or motion input | |
// | |
// Parameters | |
// | |
// e - mousemove or devicemotion event | |
// | |
// returns nothing | |
function plaxifier(e) { | |
if (new Date().getTime() < lastRender + delay) return; | |
lastRender = new Date().getTime(); | |
var leftOffset = (plaxActivityTarget.offset() != null) ? plaxActivityTarget.offset().left : 0, | |
topOffset = (plaxActivityTarget.offset() != null) ? plaxActivityTarget.offset().top : 0, | |
x = e.pageX-leftOffset, | |
y = e.pageY-topOffset; | |
if (!inViewport(layers[0].obj[0].parentNode)) return; | |
if(moveable()){ | |
if(e.gamma === undefined){ | |
ignoreMoveable = true; | |
return; | |
} | |
values = valuesFromMotion(e); | |
// Admittedly fuzzy measurements | |
x = values.x / motionDegrees; | |
y = values.y / motionDegrees; | |
// Ensure not outside of expected range, -1 to 1 | |
x = x < motionMin ? motionMin : (x > motionMax ? motionMax : x); | |
y = y < motionMin ? motionMin : (y > motionMax ? motionMax : y); | |
// Normalize from -1 to 1 => 0 to 1 | |
x = (x + 1) / 2; | |
y = (y + 1) / 2; | |
} | |
var hRatio = x/((moveable() === true) ? motionMax : plaxActivityTarget.width()), | |
vRatio = y/((moveable() === true) ? motionMax : plaxActivityTarget.height()), | |
layer, i; | |
for (i = layers.length; i--;) { | |
layer = layers[i]; | |
if(options.useTransform && !layer.background){ | |
newX = layer.transformStartX + layer.inversionFactor*(layer.xRange*hRatio); | |
newY = layer.transformStartY + layer.inversionFactor*(layer.yRange*vRatio); | |
newZ = layer.transformStartZ; | |
layer.obj | |
.css({'transform':'translate3d('+newX+'px,'+newY+'px,'+newZ+'px)'}); | |
}else{ | |
newX = layer.startX + layer.inversionFactor*(layer.xRange*hRatio); | |
newY = layer.startY + layer.inversionFactor*(layer.yRange*vRatio); | |
if(layer.background) { | |
layer.obj | |
.css('background-position', newX+'px '+newY+'px'); | |
} else { | |
layer.obj | |
.css('left', newX) | |
.css('top', newY); | |
} | |
} | |
} | |
} | |
$.plax = { | |
// Begin parallaxing | |
// | |
// Parameters | |
// | |
// opts - options for plax | |
// activityTarget - optional; plax will only work within the bounds of this element, if supplied. | |
// | |
// Examples | |
// | |
// $.plax.enable({ "activityTarget": $('#myPlaxDiv')}) | |
// # plax only happens when the mouse is over #myPlaxDiv | |
// | |
// returns nothing | |
enable: function(opts){ | |
if (opts) { | |
if (opts.activityTarget) plaxActivityTarget = opts.activityTarget || $(document.body); | |
if (typeof opts.gyroRange === 'number' && opts.gyroRange > 0) motionDegrees = opts.gyroRange; | |
} else { | |
plaxActivityTarget = $(document.body); | |
} | |
plaxActivityTarget.bind('mousemove.plax', function (e) { | |
plaxifier(e); | |
}); | |
if(moveable()){ | |
window.ondeviceorientation = function(e){plaxifier(e);}; | |
} | |
}, | |
// Stop parallaxing | |
// | |
// Examples | |
// | |
// $.plax.disable() | |
// # plax no longer runs | |
// | |
// $.plax.disable({ "clearLayers": true }) | |
// # plax no longer runs and all layers are forgotten | |
// | |
// returns nothing | |
disable: function(opts){ | |
$(document).unbind('mousemove.plax'); | |
window.ondeviceorientation = undefined; | |
if (opts && typeof opts.restorePositions === 'boolean' && opts.restorePositions) { | |
for(var i = layers.length; i--;) { | |
layer = layers[i]; | |
if(options.useTransform && !layer.background){ | |
layer.obj | |
.css('transform', 'translate3d('+layer.transformOriginX+'px,'+layer.transformOriginY+'px,'+layer.transformOriginZ+'px)') | |
.css('top', layer.originY); | |
}else{ | |
if(layers[i].background) { | |
layer.obj.css('background-position', layer.originX+'px '+layer.originY+'px'); | |
} else { | |
layer.obj | |
.css('left', layer.originX) | |
.css('top', layer.originY); | |
} | |
} | |
} | |
} | |
if (opts && typeof opts.clearLayers === 'boolean' && opts.clearLayers) layers = []; | |
} | |
}; | |
if (typeof ender !== 'undefined') { | |
$.ender($.fn, true); | |
} | |
})(function () { | |
return typeof jQuery !== 'undefined' ? jQuery : ender; | |
}()); | |
</script> | |
<style> | |
#shell{ | |
display: block; | |
position: relative; | |
margin: 100px auto; | |
width: 860px; | |
height: 770px; | |
z-index: 0; | |
} | |
#base_parallax { | |
overflow: hidden; | |
position: absolute; | |
left: 0; | |
top: 0; | |
width: 100%; | |
} | |
#logo_parallax { | |
top:5%; | |
left:7%; | |
display: block; | |
margin: 0 auto; | |
position: relative; | |
width:10%; | |
float:left; | |
} | |
#bubble_parallax{ | |
z-index: 1000; | |
top:43%; | |
left:10%; | |
display: block; | |
margin: 0 auto; | |
position: relative; | |
width:20%; | |
float:left; | |
} | |
#text_parallax{ | |
z-index: 1; | |
top:40%; | |
left:-23%; | |
display: block; | |
margin: 0 auto; | |
position: relative; | |
width:70%; | |
float:left; | |
} | |
#texthl_parallax{ | |
z-index: 1; | |
top: 28%; | |
left: 7%; | |
display: block; | |
margin: 0 auto; | |
position: relative; | |
width: 35%; | |
float: left; | |
} | |
#title_parallax{ | |
z-index: 1; | |
top: -2%; | |
left: -29%; | |
display: block; | |
margin: 0 auto; | |
position: relative; | |
width: 60%; | |
float: left; | |
} | |
</style> | |
</head> | |
<body> | |
<div id="shell"> | |
<div id="base_parallax"> | |
<img id="base" src="data:image/svg+xml;base64,PHN2ZyB4bWxucz0iaHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmciIHhtbG5zOnhsaW5rPSJodHRwOi8vd3d3LnczLm9yZy8xOTk5L3hsaW5rIiB2aWV3Qm94PSIwIDAgMzQ1LjkgMjMzLjA4Ij48ZGVmcz48c3R5bGU+LmNscy0xe2ZpbGw6dXJsKCNsaW5lYXItZ3JhZGllbnQpO30uY2xzLTJ7ZmlsbDojM2JhYWI2O30uY2xzLTN7ZmlsbDojMmY4NmJjO30uY2xzLTR7ZmlsbDojMmU4MmIxO30uY2xzLTEyLC5jbHMtNXtmaWxsOiNmZmY7fS5jbHMtNntmaWxsOiNhMmEyYTE7fS5jbHMtN3tmaWxsOiNiMGIxYjI7fS5jbHMtOHtmaWxsOiNjMmMzYzE7fS5jbHMtOXtmaWxsOiNmZGZlZmU7fS5jbHMtMTB7ZmlsbDojYzdjOWM3O30uY2xzLTExe2ZpbGw6IzgyODM4Mjt9LmNscy0xMntzdHJva2U6IzIzMWYyMDt9PC9zdHlsZT48bGluZWFyR3JhZGllbnQgaWQ9ImxpbmVhci1ncmFkaWVudCIgeDE9IjE3Mi45NSIgeTE9IjIwOC42OCIgeDI9IjE3Mi45NSIgeTI9IjIyMi41NiIgZ3JhZGllbnRVbml0cz0idXNlclNwYWNlT25Vc2UiPjxzdG9wIG9mZnNldD0iMCIgc3RvcC1jb2xvcj0iI2Q4ZjBmNyIvPjxzdG9wIG9mZnNldD0iMC45OSIgc3RvcC1jb2xvcj0iI2FlZTFmNyIvPjwvbGluZWFyR3JhZGllbnQ+PC9kZWZzPjx0aXRsZT5iZzwvdGl0bGU+PGcgaWQ9IkxheWVyXzIiIGRhdGEtbmFtZT0iTGF5ZXIgMiI+PGcgaWQ9IkxheWVyXzEtMiIgZGF0YS1uYW1lPSJMYXllciAxIj48cmVjdCBjbGFzcz0iY2xzLTEiIHdpZHRoPSIzNDUuOSIgaGVpZ2h0PSIyMzMuMDgiLz48cmVjdCBjbGFzcz0iY2xzLTIiIHg9IjIyLjMxIiB5PSI1NS45OSIgd2lkdGg9IjIyOC42NyIgaGVpZ2h0PSIxOC41Ii8+PHJlY3QgY2xhc3M9ImNscy0zIiB4PSIyMi45MyIgeT0iNzkuNTgiIHdpZHRoPSIzMS4wMSIgaGVpZ2h0PSI1LjI1Ii8+PHJlY3QgY2xhc3M9ImNscy00IiB4PSIyMi4zMSIgeT0iMzIuMiIgd2lkdGg9IjM1Ljg2IiBoZWlnaHQ9IjUuMjUiLz48cmVjdCBjbGFzcz0iY2xzLTQiIHg9IjY5LjY4IiB5PSIzMi4yIiB3aWR0aD0iMzUuODYiIGhlaWdodD0iNS4yNSIvPjxyZWN0IGNsYXNzPSJjbHMtNCIgeD0iMTE4LjMxIiB5PSIzMi4yIiB3aWR0aD0iMzAuNCIgaGVpZ2h0PSI1LjI1Ii8+PHJlY3QgY2xhc3M9ImNscy00IiB4PSIxNjkuMDciIHk9IjMyLjIiIHdpZHRoPSIyMy45OCIgaGVpZ2h0PSI1LjI1Ii8+PHJlY3QgY2xhc3M9ImNscy00IiB4PSIyMTAuMzgiIHk9IjMyLjIiIHdpZHRoPSIzNC44MyIgaGVpZ2h0PSI1LjI1Ii8+PHJlY3QgY2xhc3M9ImNscy01IiB4PSIyNzEuMTEiIHk9IjMyLjIiIHdpZHRoPSIzOS43OSIgaGVpZ2h0PSI1LjI1Ii8+PHJlY3QgY2xhc3M9ImNscy02IiB4PSIzMTAuOSIgeT0iMzIuMiIgd2lkdGg9IjUuMjUiIGhlaWdodD0iNS4yNSIvPjxyZWN0IGNsYXNzPSJjbHMtNyIgd2lkdGg9IjM0NS45IiBoZWlnaHQ9IjkuMDYiLz48cmVjdCBjbGFzcz0iY2xzLTQiIHg9IjE5Ni4xMSIgeT0iMTUuMDUiIHdpZHRoPSI5LjY5IiBoZWlnaHQ9IjIuNjIiLz48cmVjdCBjbGFzcz0iY2xzLTQiIHg9IjE4MS42NCIgeT0iMTUuMDUiIHdpZHRoPSI5LjY5IiBoZWlnaHQ9IjIuNjIiLz48cmVjdCBjbGFzcz0iY2xzLTQiIHg9IjIxMC4zOCIgeT0iMTUuMDUiIHdpZHRoPSI5LjY5IiBoZWlnaHQ9IjIuNjIiLz48cmVjdCBjbGFzcz0iY2xzLTQiIHg9IjIyNi43NCIgeT0iMTUuMDUiIHdpZHRoPSI5LjY5IiBoZWlnaHQ9IjIuNjIiLz48cmVjdCBjbGFzcz0iY2xzLTQiIHg9IjEzNi45NSIgeT0iMTUuMDUiIHdpZHRoPSI5LjY5IiBoZWlnaHQ9IjIuNjIiLz48cmVjdCBjbGFzcz0iY2xzLTQiIHg9IjEyMi40OSIgeT0iMTUuMDUiIHdpZHRoPSI5LjY5IiBoZWlnaHQ9IjIuNjIiLz48cmVjdCBjbGFzcz0iY2xzLTQiIHg9IjE1MS4yMiIgeT0iMTUuMDUiIHdpZHRoPSI5LjY5IiBoZWlnaHQ9IjIuNjIiLz48cmVjdCBjbGFzcz0iY2xzLTQiIHg9IjE2Ny41OCIgeT0iMTUuMDUiIHdpZHRoPSI5LjY5IiBoZWlnaHQ9IjIuNjIiLz48cmVjdCBjbGFzcz0iY2xzLTgiIHg9IjI3MS4xMSIgeT0iMTUuMDUiIHdpZHRoPSI5Ljg2IiBoZWlnaHQ9IjIuNjIiLz48cmVjdCBjbGFzcz0iY2xzLTgiIHg9IjI0NS4wNiIgeT0iMTUuMDUiIHdpZHRoPSIyMC4yNCIgaGVpZ2h0PSIyLjYyIi8+PHJlY3QgY2xhc3M9ImNscy05IiB4PSIzMzkuNiIgeT0iMi4yNiIgd2lkdGg9IjQuNTUiIGhlaWdodD0iNC41NSIvPjxyZWN0IGNsYXNzPSJjbHMtMTAiIHg9IjM0MC41NiIgeT0iOS4wNiIgd2lkdGg9IjUuMzQiIGhlaWdodD0iMjI0LjAyIi8+PHJlY3QgY2xhc3M9ImNscy0xMSIgeD0iMzQwLjU2IiB5PSIzMi4yIiB3aWR0aD0iNS4zNCIgaGVpZ2h0PSIyMi4wNSIvPjxwYXRoIGNsYXNzPSJjbHMtMTIiIGQ9Ik0wLDE0MyIgdHJhbnNmb3JtPSJ0cmFuc2xhdGUoLTQuMzUpIi8+PC9nPjwvZz48L3N2Zz4=" /> | |
</div> | |
<div id="logo_parallax"> | |
<img id="logo" src="data:image/svg+xml;base64,PHN2ZyB4bWxucz0iaHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmciIHhtbG5zOnhsaW5rPSJodHRwOi8vd3d3LnczLm9yZy8xOTk5L3hsaW5rIiB2aWV3Qm94PSIwIDAgMTcuMTIgNC4yNyI+PGRlZnM+PHN0eWxlPi5jbHMtMXtmaWxsOiM2MzEwMTE7fS5jbHMtMntmaWxsOiNmMDYxMjg7fS5jbHMtM3tmaWxsOnVybCgjcmFkaWFsLWdyYWRpZW50KTt9LmNscy00e2ZpbGw6dXJsKCNyYWRpYWwtZ3JhZGllbnQtNSk7fS5jbHMtNXtmaWxsOiNmNjg3MjI7fS5jbHMtNntmaWxsOiNmNGFjMWU7fTwvc3R5bGU+PHJhZGlhbEdyYWRpZW50IGlkPSJyYWRpYWwtZ3JhZGllbnQiIGN4PSItMTc0OC42MyIgY3k9Ii0xMjEuNDEiIHI9IjAiIGdyYWRpZW50VHJhbnNmb3JtPSJ0cmFuc2xhdGUoLTIyNjEuNzEgLTE1NC4xNykgcm90YXRlKDE4MCkgc2NhbGUoMS4zIDEuMykiIGdyYWRpZW50VW5pdHM9InVzZXJTcGFjZU9uVXNlIj48c3RvcCBvZmZzZXQ9IjAuMzYiIHN0b3AtY29sb3I9IiNmNDgwMjAiLz48c3RvcCBvZmZzZXQ9IjAuMzgiIHN0b3AtY29sb3I9IiNmNzhmMjMiLz48c3RvcCBvZmZzZXQ9IjAuNDEiIHN0b3AtY29sb3I9IiNmYWEyMjAiLz48c3RvcCBvZmZzZXQ9IjAuNDQiIHN0b3AtY29sb3I9IiNmYWIwMWQiLz48c3RvcCBvZmZzZXQ9IjAuNDgiIHN0b3AtY29sb3I9IiNmY2JjMWYiLz48c3RvcCBvZmZzZXQ9IjAuNTMiIHN0b3AtY29sb3I9IiNmZmM4MWQiLz48c3RvcCBvZmZzZXQ9IjAuNiIgc3RvcC1jb2xvcj0iI2ZmY2UxYiIvPjxzdG9wIG9mZnNldD0iMC43OCIgc3RvcC1jb2xvcj0iI2ZmY2UxYyIvPjwvcmFkaWFsR3JhZGllbnQ+PHJhZGlhbEdyYWRpZW50IGlkPSJyYWRpYWwtZ3JhZGllbnQtNSIgY3g9Ii0xNzQ4LjYxIiBjeT0iLTEyMS40IiB4bGluazpocmVmPSIjcmFkaWFsLWdyYWRpZW50Ii8+PHN5bWJvbCBpZD0idGhpbmtfMiIgZGF0YS1uYW1lPSJ0aGluayAyIiB2aWV3Qm94PSIwIDAgMjUwLjgyIDcwLjg0Ij48cGF0aCBjbGFzcz0iY2xzLTEiIGQ9Ik0wLDExSDguNTZWMy4xOUwxNi4yNiwwVjExSDI2Ljc4djUuNjJIMTYuMjZWNDEuOTRsLjEzLDIuNjguMywxLjQxcS43MiwyLjM0LDQuNDcsMi4yNmEzMS42OCwzMS42OCwwLDAsMCw1LjYyLS42NHY1Ljc1QTYyLDYyLDAsMCwxLDE5LDU0UTkuMDcsNTQsOC42LDQ2bDAtNC4zNHYtMjVIMFoiLz48cGF0aCBjbGFzcz0iY2xzLTEiIGQ9Ik00OS44MSwzMS4zNCwzNC4xLDExSDQ0LjMyTDU1LjE0LDI2LjI3LDY2LjEyLDExaDguOTRMNTkuMzUsMzAuOTEsNzYsNTIuODRINjYuMTJMNTQsMzYuMTksNDIsNTIuODRIMzNaIi8+PHBhdGggY2xhc3M9ImNscy0xIiBkPSJNODAuMzksMTFoOC41NlYzLjE5TDk2LjY1LDBWMTFoMTAuNTJ2NS42Mkg5Ni42NVY0MS45NGwuMTMsMi42OC4zLDEuNDFxLjcyLDIuMzQsNC40NywyLjI2YTMxLjY4LDMxLjY4LDAsMCwwLDUuNjItLjY0djUuNzVhNjIsNjIsMCwwLDEtNy43OS42NFE4OS40Niw1NCw4OSw0NmwwLTQuMzR2LTI1SDgwLjM5WiIvPjxwYXRoIGNsYXNzPSJjbHMtMSIgZD0iTTEyNi4yNCwxNC42cTQuNDMtNC43MywxMi00Ljc3YTE4LjA1LDE4LjA1LDAsMCwxLDcsMS40MSwxNS4xOCwxNS4xOCwwLDAsMSw1LjExLDMuNDVxNS42Miw1Ljg4LDUuNTgsMTd0LTUuNTMsMTdhMTUuNzksMTUuNzksMCwwLDEtNS42OCwzLjk0QTE4LjM2LDE4LjM2LDAsMCwxLDEzNy42MSw1NHEtNy41OCwwLTExLjkyLTQuNmwtMS4wNi0xLjE5djIwLjFsLTcuNzEsMi41MVYxMWg3LjcxdjUuNTRabS0xLjgzLDE3LjhhMjQuMTIsMjQuMTIsMCwwLDAsMS40MSw4Ljc3cTIuNDcsNy4xMSwxMC4wOSw3LjExYTEwLjYyLDEwLjYyLDAsMCwwLDQuNTYtLjg1cTcuNDEtMyw3LjQ1LTE1Ljg0YTIzLjkxLDIzLjkxLDAsMCwwLTEuNTgtOC44NnEtMi42LTcuMTUtMTAtNy4xNWExMC4yMiwxMC4yMiwwLDAsMC05LjYyLDUuNTRRMTI0LjQ1LDI1LjE2LDEyNC40MSwzMi40WiIvPjxwYXRoIGNsYXNzPSJjbHMtMSIgZD0iTTE3NCw0MS4zNGE5LjUxLDkuNTEsMCwwLDAsNS41Myw2LDExLjIsMTEuMiwwLDAsMCw0LjY4Ljg5cTguNjQtLjA4LDEwLTguODFoOHEtLjk0LDUuNTQtMi44MSw4YTE1LjA2LDE1LjA2LDAsMCwxLTYuNzMsNS4xMUEyMywyMywwLDAsMSwxODQuMjMsNTRxLTkuNzksMC0xNC43Ny02LTQuODEtNS43OS00LjczLTE1LjVhMzIuMjIsMzIuMjIsMCwwLDEsMi4wOS0xMi4xOCwxNS42NSwxNS42NSwwLDAsMSw3LTgsMTkuNSwxOS41LDAsMCwxLDEwLjM5LTIuNnExNywuMTMsMTguMjIsMTcuMmwuMTMsNmgtMjkuOEEzMS42NCwzMS42NCwwLDAsMCwxNzQsNDEuMzRabS0xLjI0LTE0aDIxLjhxLS4yMS02LjE3LTIuMy04LjYtMi42OC0zLjE1LTguMTctMy4xOS04LjY5LDAtMTAuNjQsOC40M1oiLz48cGF0aCBjbGFzcz0iY2xzLTEiIGQ9Ik0yMTMuMzEsMTFoNy4ydjUuNzFxNC45LTYuODEsMTQuNDMtNi45YTIwLjU2LDIwLjU2LDAsMCwxLDcuNDksMS4zMnE3Ljc5LDIuOTQsOC4zNSwxNC44MmwwLDJWNTIuODRoLTcuNzFWMjcuNzZxMC05LjA3LTUuNjItMTEuMzNhMTIuMzEsMTIuMzEsMCwwLDAtNC42OC0uODVxLTExLjY3LDAtMTEuNzksMTIuMThWNTIuODRoLTcuNzFaIi8+PC9zeW1ib2w+PC9kZWZzPjx0aXRsZT5sb2dvPC90aXRsZT48ZyBpZD0iTGF5ZXJfMiIgZGF0YS1uYW1lPSJMYXllciAyIj48ZyBpZD0iTGF5ZXJfMS0yIiBkYXRhLW5hbWU9IkxheWVyIDEiPjxwYXRoIGlkPSJfUGF0aF8iIGRhdGEtbmFtZT0iJmx0O1BhdGgmZ3Q7IiBjbGFzcz0iY2xzLTIiIGQ9Ik02LjIzLDMuMDciLz48cGF0aCBpZD0iX1BhdGhfMiIgZGF0YS1uYW1lPSImbHQ7UGF0aCZndDsiIGNsYXNzPSJjbHMtMyIgZD0iTTMuMjUsMy4xMVoiLz48cGF0aCBpZD0iX1BhdGhfMyIgZGF0YS1uYW1lPSImbHQ7UGF0aCZndDsiIGNsYXNzPSJjbHMtMyIgZD0iTTMuMjUsMy4xMVoiLz48cGF0aCBpZD0iX1BhdGhfNCIgZGF0YS1uYW1lPSImbHQ7UGF0aCZndDsiIGNsYXNzPSJjbHMtMyIgZD0iTTMuMjUsMy4xMVoiLz48cGF0aCBpZD0iX1BhdGhfNSIgZGF0YS1uYW1lPSImbHQ7UGF0aCZndDsiIGNsYXNzPSJjbHMtMyIgZD0iTTMuMjUsMy4xMVoiLz48cGF0aCBpZD0iX1BhdGhfNiIgZGF0YS1uYW1lPSImbHQ7UGF0aCZndDsiIGNsYXNzPSJjbHMtNCIgZD0iTTMuMjMsMy4wOVoiLz48cGF0aCBpZD0iX1BhdGhfNyIgZGF0YS1uYW1lPSImbHQ7UGF0aCZndDsiIGNsYXNzPSJjbHMtMiIgZD0iTTAsMy4wN2MwLC42OCwxLjM3LDEuMiwzLjA3LDEuMnMzLjA3LS41LDMuMDctMS4yaDBBMy4wNywzLjA3LDAsMSwwLDAsMy4wN1oiLz48cGF0aCBpZD0iX1BhdGhfOCIgZGF0YS1uYW1lPSImbHQ7UGF0aCZndDsiIGNsYXNzPSJjbHMtNSIgZD0iTTEuMDksM2MwLC40NC44OS43NiwyLC43NnMyLS4zMywyLS43NmEyLDIsMCwwLDAtMi0yLDIsMiwwLDAsMC0yLDJaIi8+PHBhdGggaWQ9Il9QYXRoXzkiIGRhdGEtbmFtZT0iJmx0O1BhdGgmZ3Q7IiBjbGFzcz0iY2xzLTYiIGQ9Ik0zLjc1LDMuMDdjMCwuMTUtLjI2LjI2LS42NS4yNnMtLjY4LS4xMS0uNjUtLjI2aDBhLjY4LjY4LDAsMCwxLC42NS0uNy43MS43MSwwLDAsMSwuNjUuN1oiLz48cGF0aCBpZD0iX1BhdGhfMTAiIGRhdGEtbmFtZT0iJmx0O1BhdGgmZ3Q7IiBjbGFzcz0iY2xzLTYiIGQ9Ik0yLjM3LDMuMDlaIi8+PHBhdGggaWQ9Il9QYXRoXzExIiBkYXRhLW5hbWU9IiZsdDtQYXRoJmd0OyIgY2xhc3M9ImNscy02IiBkPSJNMy43NywzLjA5WiIvPjxwYXRoIGlkPSJfUGF0aF8xMiIgZGF0YS1uYW1lPSImbHQ7UGF0aCZndDsiIGNsYXNzPSJjbHMtNiIgZD0iTTIuMzcsMy4wOVoiLz48cGF0aCBpZD0iX1BhdGhfMTMiIGRhdGEtbmFtZT0iJmx0O1BhdGgmZ3Q7IiBjbGFzcz0iY2xzLTYiIGQ9Ik0zLjc3LDMuMDlaIi8+PHBhdGggaWQ9Il9QYXRoXzE0IiBkYXRhLW5hbWU9IiZsdDtQYXRoJmd0OyIgY2xhc3M9ImNscy02IiBkPSJNMi4zNywzLjA5WiIvPjx1c2UgaWQ9InRoaW5rXzItMyIgZGF0YS1uYW1lPSJ0aGluayAyIiB3aWR0aD0iMjUwLjgyIiBoZWlnaHQ9IjcwLjg1IiB0cmFuc2Zvcm09InRyYW5zbGF0ZSg2LjUyIDEuMjgpIHNjYWxlKDAuMDQpIiB4bGluazpocmVmPSIjdGhpbmtfMiIvPjwvZz48L2c+PC9zdmc+" /> | |
</div> | |
<div id="bubble_parallax"> | |
<img id="bubble" src="data:image/svg+xml;base64,PHN2ZyB4bWxucz0iaHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmciIHhtbG5zOnhsaW5rPSJodHRwOi8vd3d3LnczLm9yZy8xOTk5L3hsaW5rIiB2aWV3Qm94PSIwIDAgNzAuMTQgNTUuMzkiPjxkZWZzPjxzdHlsZT4uY2xzLTF7ZmlsbDojZmZmO3N0cm9rZTojMjMxZjIwO30uY2xzLTJ7ZmlsbDojYTBkY2YxO30uY2xzLTN7ZmlsbDojZWNlNzBlO30uY2xzLTR7ZmlsbDojZjE1ZjI2O30uY2xzLTV7ZmlsbDojZjY4OTIyO30uY2xzLTZ7ZmlsbDp1cmwoI3JhZGlhbC1ncmFkaWVudCk7fS5jbHMtN3tmaWxsOnVybCgjcmFkaWFsLWdyYWRpZW50LTMpO30uY2xzLTh7ZmlsbDp1cmwoI3JhZGlhbC1ncmFkaWVudC01KTt9LmNscy05e2ZpbGw6I2Y4YWMxYzt9PC9zdHlsZT48cmFkaWFsR3JhZGllbnQgaWQ9InJhZGlhbC1ncmFkaWVudCIgY3g9Ii0xMDI4LjcxIiBjeT0iMjI0LjQ2IiByPSIwIiBncmFkaWVudFRyYW5zZm9ybT0ibWF0cml4KC0wLjkyLCAtMC45MiwgLTAuOTIsIDAuOTIsIC02NzQuNTEsIC0xMTM5LjQ5KSIgZ3JhZGllbnRVbml0cz0idXNlclNwYWNlT25Vc2UiPjxzdG9wIG9mZnNldD0iMC4zNiIgc3RvcC1jb2xvcj0iI2Y1ODAyMCIvPjxzdG9wIG9mZnNldD0iMC4zOCIgc3RvcC1jb2xvcj0iI2Y3OGYyMiIvPjxzdG9wIG9mZnNldD0iMC40MSIgc3RvcC1jb2xvcj0iI2ZhYTIyMCIvPjxzdG9wIG9mZnNldD0iMC40NCIgc3RvcC1jb2xvcj0iI2ZjYjExZCIvPjxzdG9wIG9mZnNldD0iMC40OCIgc3RvcC1jb2xvcj0iI2ZlYmQxZSIvPjxzdG9wIG9mZnNldD0iMC41MyIgc3RvcC1jb2xvcj0iI2ZmYzcxYyIvPjxzdG9wIG9mZnNldD0iMC42IiBzdG9wLWNvbG9yPSIjZmZjYzFhIi8+PHN0b3Agb2Zmc2V0PSIwLjc4IiBzdG9wLWNvbG9yPSIjZmZjZTE5Ii8+PC9yYWRpYWxHcmFkaWVudD48cmFkaWFsR3JhZGllbnQgaWQ9InJhZGlhbC1ncmFkaWVudC0zIiBjeD0iLTEwMjguNzEiIGN5PSIyMjQuNDYiIHI9IjAuMDEiIHhsaW5rOmhyZWY9IiNyYWRpYWwtZ3JhZGllbnQiLz48cmFkaWFsR3JhZGllbnQgaWQ9InJhZGlhbC1ncmFkaWVudC01IiBjeD0iLTEwMjguNjgiIGN5PSIyMjQuNDYiIHI9IjAiIHhsaW5rOmhyZWY9IiNyYWRpYWwtZ3JhZGllbnQiLz48L2RlZnM+PHRpdGxlPmJ1YmJsZTwvdGl0bGU+PGcgaWQ9IkxheWVyXzIiIGRhdGEtbmFtZT0iTGF5ZXIgMiI+PGcgaWQ9IkxheWVyXzEtMiIgZGF0YS1uYW1lPSJMYXllciAxIj48cG9seWdvbiBjbGFzcz0iY2xzLTEiIHBvaW50cz0iMjQuNTggNDMgMC41IDQzIDAuNSAwLjUgNjkuNjQgMC41IDY5LjY0IDQzIDQ1LjU2IDQzIDM1LjA3IDU0LjY0IDI0LjU4IDQzIi8+PHJlY3QgY2xhc3M9ImNscy0yIiB4PSIxMC45MiIgeT0iNy4xMSIgd2lkdGg9IjQ1LjI5IiBoZWlnaHQ9IjIuNDEiLz48cmVjdCBjbGFzcz0iY2xzLTIiIHg9IjUuMzMiIHk9IjExLjM1IiB3aWR0aD0iNTAuODgiIGhlaWdodD0iMi40MSIvPjxyZWN0IGNsYXNzPSJjbHMtMiIgeD0iNS4zMyIgeT0iMTUuMzkiIHdpZHRoPSI0My41OSIgaGVpZ2h0PSIyLjQxIi8+PHJlY3QgY2xhc3M9ImNscy0yIiB4PSIxMC45MiIgeT0iMTkuODUiIHdpZHRoPSI0NS4yOSIgaGVpZ2h0PSIyLjQxIi8+PHJlY3QgY2xhc3M9ImNscy0yIiB4PSI1LjMzIiB5PSIyNC4zMSIgd2lkdGg9IjUwLjg4IiBoZWlnaHQ9IjIuNDEiLz48cmVjdCBjbGFzcz0iY2xzLTIiIHg9IjUuMzMiIHk9IjI4Ljc3IiB3aWR0aD0iNTAuODgiIGhlaWdodD0iMi40MSIvPjxyZWN0IGNsYXNzPSJjbHMtMiIgeD0iNS4zMyIgeT0iMzMuMDgiIHdpZHRoPSIzOS44IiBoZWlnaHQ9IjIuNDEiLz48cG9seWxpbmUgY2xhc3M9ImNscy0zIiBwb2ludHM9IjU0LjgzIDAuOTkgNjkuMTQgMC45OSA2OS4xNCAxNS4zIi8+PHBhdGggaWQ9Il9QYXRoXyIgZGF0YS1uYW1lPSImbHQ7UGF0aCZndDsiIGNsYXNzPSJjbHMtNCIgZD0iTTU5LjQ0LDUuNjNjLS41NS41Ni4xNiwyLjEyLDEuNTUsMy41MnMyLjk1LDIuMTEsMy41LDEuNTVoMGEzLjU4LDMuNTgsMCwwLDAtNS4wNS01LjA2WiIvPjxwYXRoIGlkPSJfUGF0aF8yIiBkYXRhLW5hbWU9IiZsdDtQYXRoJmd0OyIgY2xhc3M9ImNscy00IiBkPSJNNjQuNDgsMTAuNjYiLz48cGF0aCBpZD0iX1BhdGhfMyIgZGF0YS1uYW1lPSImbHQ7UGF0aCZndDsiIGNsYXNzPSJjbHMtNSIgZD0iTTYwLjM4LDYuNDljLS4zNS4zNi4wOSwxLjM1LDEsMi4yNXMxLjksMS4zNiwyLjI2LDFhMi4zMiwyLjMyLDAsMCwwLDAtMy4yNiwyLjI5LDIuMjksMCwwLDAtMy4yNCwwWiIvPjxwYXRoIGlkPSJfUGF0aF80IiBkYXRhLW5hbWU9IiZsdDtQYXRoJmd0OyIgY2xhc3M9ImNscy02IiBkPSJNNjIuMSw4LjMyWiIvPjxwYXRoIGlkPSJfUGF0aF81IiBkYXRhLW5hbWU9IiZsdDtQYXRoJmd0OyIgY2xhc3M9ImNscy02IiBkPSJNNjIuMSw4LjMyWiIvPjxwYXRoIGlkPSJfUGF0aF82IiBkYXRhLW5hbWU9IiZsdDtQYXRoJmd0OyIgY2xhc3M9ImNscy03IiBkPSJNNjIuMTEsOC4zMmgwWiIvPjxwYXRoIGlkPSJfUGF0aF83IiBkYXRhLW5hbWU9IiZsdDtQYXRoJmd0OyIgY2xhc3M9ImNscy03IiBkPSJNNjIuMTEsOC4zMloiLz48cGF0aCBpZD0iX1BhdGhfOCIgZGF0YS1uYW1lPSImbHQ7UGF0aCZndDsiIGNsYXNzPSJjbHMtOCIgZD0iTTYyLjA4LDguMjlaIi8+PHBhdGggaWQ9Il9QYXRoXzkiIGRhdGEtbmFtZT0iJmx0O1BhdGgmZ3Q7IiBjbGFzcz0iY2xzLTkiIGQ9Ik02Mi41MSw4LjcxYy0uMTMuMTItLjQ0LDAtLjc1LS4zMnMtLjQ1LS42NS0uMzMtLjc3aDBhLjc3Ljc3LDAsMCwxLDEuMSwwLC43OC43OCwwLDAsMSwwLDEuMTFoMFoiLz48cGF0aCBpZD0iX1BhdGhfMTAiIGRhdGEtbmFtZT0iJmx0O1BhdGgmZ3Q7IiBjbGFzcz0iY2xzLTkiIGQ9Ik02MS40LDcuNloiLz48cGF0aCBpZD0iX1BhdGhfMTEiIGRhdGEtbmFtZT0iJmx0O1BhdGgmZ3Q7IiBjbGFzcz0iY2xzLTkiIGQ9Ik02Mi41Miw4LjcyWiIvPjxwYXRoIGlkPSJfUGF0aF8xMiIgZGF0YS1uYW1lPSImbHQ7UGF0aCZndDsiIGNsYXNzPSJjbHMtOSIgZD0iTTYxLjQsNy42WiIvPjxwYXRoIGlkPSJfUGF0aF8xMyIgZGF0YS1uYW1lPSImbHQ7UGF0aCZndDsiIGNsYXNzPSJjbHMtOSIgZD0iTTYyLjUyLDguNzJaIi8+PHBhdGggaWQ9Il9QYXRoXzE0IiBkYXRhLW5hbWU9IiZsdDtQYXRoJmd0OyIgY2xhc3M9ImNscy05IiBkPSJNNjEuMzksNy41OVoiLz48L2c+PC9nPjwvc3ZnPg==" /> | |
</div> | |
<div id="text_parallax"> | |
<img id="text" src="data:image/svg+xml;base64,PHN2ZyB4bWxucz0iaHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmciIHZpZXdCb3g9IjAgMCAyMjguMDUgOTUuNTEiPjxkZWZzPjxzdHlsZT4uY2xzLTF7ZmlsbDojZmZmO308L3N0eWxlPjwvZGVmcz48dGl0bGU+dGV4dDwvdGl0bGU+PGcgaWQ9IkxheWVyXzIiIGRhdGEtbmFtZT0iTGF5ZXIgMiI+PGcgaWQ9IkxheWVyXzEtMiIgZGF0YS1uYW1lPSJMYXllciAxIj48cmVjdCBjbGFzcz0iY2xzLTEiIHk9IjE0LjE3IiB3aWR0aD0iMTk0LjA2IiBoZWlnaHQ9IjUuMjUiLz48cmVjdCBjbGFzcz0iY2xzLTEiIHk9IjcuMDgiIHdpZHRoPSIyMjguMDUiIGhlaWdodD0iNS4yNSIvPjxyZWN0IGNsYXNzPSJjbHMtMSIgd2lkdGg9IjIxMC41NiIgaGVpZ2h0PSI1LjI1Ii8+PHJlY3QgY2xhc3M9ImNscy0xIiB5PSIzNS40MiIgd2lkdGg9IjE2MS4zIiBoZWlnaHQ9IjUuMjUiLz48cmVjdCBjbGFzcz0iY2xzLTEiIHk9IjI4LjMzIiB3aWR0aD0iMjI4LjA1IiBoZWlnaHQ9IjUuMjUiLz48cmVjdCBjbGFzcz0iY2xzLTEiIHk9IjIxLjI1IiB3aWR0aD0iMjEwLjU2IiBoZWlnaHQ9IjUuMjUiLz48cmVjdCBjbGFzcz0iY2xzLTEiIHk9IjQ5LjU4IiB3aWR0aD0iMjI4LjA1IiBoZWlnaHQ9IjUuMjUiLz48cmVjdCBjbGFzcz0iY2xzLTEiIHk9IjQyLjUiIHdpZHRoPSIyMTAuNTYiIGhlaWdodD0iNS4yNSIvPjxyZWN0IGNsYXNzPSJjbHMtMSIgeD0iMTE2LjczIiB5PSI2MS41OCIgd2lkdGg9IjExMS4zMiIgaGVpZ2h0PSI1Ljk1Ii8+PHJlY3QgY2xhc3M9ImNscy0xIiB5PSI4My4xOCIgd2lkdGg9IjE5OS40OCIgaGVpZ2h0PSI1LjI1Ii8+PHJlY3QgY2xhc3M9ImNscy0xIiB5PSI3Ni4xIiB3aWR0aD0iMjI4LjA1IiBoZWlnaHQ9IjUuMjUiLz48cmVjdCBjbGFzcz0iY2xzLTEiIHk9IjY5LjAxIiB3aWR0aD0iMjEwLjU2IiBoZWlnaHQ9IjUuMjUiLz48cmVjdCBjbGFzcz0iY2xzLTEiIHk9IjkwLjI2IiB3aWR0aD0iMjEwLjU2IiBoZWlnaHQ9IjUuMjUiLz48L2c+PC9nPjwvc3ZnPg==" /> | |
</div> | |
<div id="texthl_parallax"> | |
<img id="texthl" src="data:image/svg+xml;base64,PHN2ZyB4bWxucz0iaHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmciIHZpZXdCb3g9IjAgMCAxMTEuMzIgNS45NSI+PGRlZnM+PHN0eWxlPi5jbHMtMXtmaWxsOiNlY2U3MGU7fTwvc3R5bGU+PC9kZWZzPjx0aXRsZT50ZXh0LWhsPC90aXRsZT48ZyBpZD0iTGF5ZXJfMiIgZGF0YS1uYW1lPSJMYXllciAyIj48ZyBpZD0iTGF5ZXJfMS0yIiBkYXRhLW5hbWU9IkxheWVyIDEiPjxyZWN0IGNsYXNzPSJjbHMtMSIgd2lkdGg9IjExMS4zMiIgaGVpZ2h0PSI1Ljk1Ii8+PC9nPjwvZz48L3N2Zz4=" /> | |
</div> | |
<div id="title_parallax"> | |
<img id="title" src="data:image/svg+xml;base64,<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 236.86 18.79"><defs><style>.cls-1{fill:#231f20;}</style></defs><title>title</title><g id="Layer_2" data-name="Layer 2"><g id="Layer_1-2" data-name="Layer 1"><path class="cls-1" d="M3.21,2V4.73H5.72V6.06H3.21v5.21c0,1.2.34,1.88,1.32,1.88a3.92,3.92,0,0,0,1-.12l.08,1.32a4.3,4.3,0,0,1-1.56.24,2.43,2.43,0,0,1-1.89-.74,3.57,3.57,0,0,1-.68-2.51V6.06H0V4.73H1.5V2.41Z"/><path class="cls-1" d="M8.51,4.73,9.89,6.8c.36.54.66,1,1,1.58h.06c.32-.58.64-1.08,1-1.6l1.36-2.05h1.89L11.84,9.39l3.39,5h-2l-1.42-2.17c-.38-.56-.7-1.1-1-1.68h0c-.32.58-.66,1.1-1,1.68l-1.4,2.17H6.4L9.83,9.45,6.56,4.73Z"/><path class="cls-1" d="M19.3,2V4.73h2.51V6.06H19.3v5.21c0,1.2.34,1.88,1.32,1.88a3.92,3.92,0,0,0,1-.12l.08,1.32a4.3,4.3,0,0,1-1.56.24,2.43,2.43,0,0,1-1.89-.74,3.57,3.57,0,0,1-.68-2.51V6.06h-1.5V4.73h1.5V2.41Z"/><path class="cls-1" d="M23.78,7.88c0-1.24,0-2.23-.08-3.15h1.58l.08,1.66h0a3.79,3.79,0,0,1,3.43-1.87c2.33,0,4.09,2,4.09,4.91,0,3.47-2.11,5.19-4.39,5.19a3.39,3.39,0,0,1-3-1.52h0v5.25H23.78Zm1.73,2.57a3.93,3.93,0,0,0,.08.72,2.71,2.71,0,0,0,2.63,2.05c1.85,0,2.93-1.52,2.93-3.73,0-1.93-1-3.59-2.87-3.59a2.8,2.8,0,0,0-2.65,2.17,2.86,2.86,0,0,0-.12.72Z"/><path class="cls-1" d="M36.1,9.87a3.09,3.09,0,0,0,3.31,3.35,6.35,6.35,0,0,0,2.67-.5l.3,1.26a7.82,7.82,0,0,1-3.21.6c-3,0-4.75-2-4.75-4.87S36.14,4.51,39,4.51c3.15,0,4,2.77,4,4.55a6.7,6.7,0,0,1-.06.82Zm5.15-1.26c0-1.12-.46-2.85-2.43-2.85-1.78,0-2.55,1.64-2.69,2.85Z"/><path class="cls-1" d="M45.12,7.34c0-1,0-1.81-.08-2.61h1.56l.1,1.6h0a3.55,3.55,0,0,1,3.19-1.81c1.34,0,3.41.8,3.41,4.11v5.76H51.58V8.81C51.58,7.26,51,6,49.34,6A2.49,2.49,0,0,0,47,7.76a2.54,2.54,0,0,0-.12.82v5.8H45.12Z"/><path class="cls-1" d="M60.33,14.38c0-.66.08-1.64.08-2.49V.22h1.74V6.28h0a3.6,3.6,0,0,1,3.29-1.77c2.39,0,4.09,2,4.07,4.93,0,3.45-2.17,5.17-4.33,5.17A3.44,3.44,0,0,1,62,12.78h-.06l-.08,1.6Zm1.82-3.87a3.27,3.27,0,0,0,.08.64,2.71,2.71,0,0,0,2.63,2.05c1.83,0,2.93-1.5,2.93-3.71,0-1.93-1-3.59-2.87-3.59a2.8,2.8,0,0,0-2.67,2.15,3.44,3.44,0,0,0-.1.72Z"/><path class="cls-1" d="M71.75,7.74c0-1.14,0-2.11-.08-3h1.54l.06,1.89h.08A2.9,2.9,0,0,1,76,4.51a1.9,1.9,0,0,1,.5.06V6.22a2.63,2.63,0,0,0-.6-.06,2.46,2.46,0,0,0-2.35,2.25,4.93,4.93,0,0,0-.08.82v5.15H71.75Z"/><path class="cls-1" d="M80.3,2a1.09,1.09,0,0,1-2.17,0,1.07,1.07,0,0,1,1.1-1.1A1,1,0,0,1,80.3,2Zm-2,12.36V4.73H80.1v9.65Z"/><path class="cls-1" d="M83,7.34c0-1,0-1.81-.08-2.61h1.56l.1,1.6h0a3.55,3.55,0,0,1,3.19-1.81c1.34,0,3.41.8,3.41,4.11v5.76H89.47V8.81C89.47,7.26,88.9,6,87.24,6a2.49,2.49,0,0,0-2.35,1.79,2.54,2.54,0,0,0-.12.82v5.8H83Z"/><path class="cls-1" d="M102.39,4.73c0,.7-.08,1.48-.08,2.65V13c0,2.21-.44,3.57-1.38,4.41a5.12,5.12,0,0,1-3.51,1.16,6.23,6.23,0,0,1-3.21-.8l.44-1.34a5.45,5.45,0,0,0,2.83.76c1.79,0,3.11-.94,3.11-3.37V12.72h0a3.44,3.44,0,0,1-3.07,1.62c-2.39,0-4.11-2-4.11-4.71,0-3.27,2.13-5.13,4.35-5.13a3.21,3.21,0,0,1,3,1.68h0l.08-1.46Zm-1.82,3.81a2.49,2.49,0,0,0-.1-.8A2.53,2.53,0,0,0,98,5.88c-1.67,0-2.87,1.42-2.87,3.65,0,1.89,1,3.47,2.85,3.47a2.57,2.57,0,0,0,2.43-1.79,3.06,3.06,0,0,0,.14-.94Z"/><path class="cls-1" d="M105,12.58a4.6,4.6,0,0,0,2.31.7c1.28,0,1.87-.64,1.87-1.44s-.5-1.3-1.79-1.77c-1.73-.62-2.55-1.58-2.55-2.73,0-1.56,1.26-2.83,3.33-2.83a4.81,4.81,0,0,1,2.37.6l-.44,1.28a3.76,3.76,0,0,0-2-.56c-1,0-1.62.6-1.62,1.32s.58,1.16,1.83,1.64c1.67.64,2.53,1.48,2.53,2.91,0,1.7-1.32,2.89-3.61,2.89a5.51,5.51,0,0,1-2.71-.66Z"/><path class="cls-1" d="M118,4.73l2.11,5.7c.22.64.46,1.4.62,2h0c.18-.58.38-1.32.62-2l1.92-5.66h1.85l-2.63,6.88c-1.26,3.31-2.11,5-3.31,6A4.75,4.75,0,0,1,117,18.79l-.44-1.48a4.65,4.65,0,0,0,1.54-.86,5.33,5.33,0,0,0,1.48-2,1.25,1.25,0,0,0,.14-.42,1.52,1.52,0,0,0-.12-.46l-3.57-8.89Z"/><path class="cls-1" d="M135.27,9.47c0,3.57-2.47,5.13-4.81,5.13-2.61,0-4.63-1.91-4.63-5,0-3.23,2.11-5.13,4.79-5.13S135.27,6.52,135.27,9.47Zm-7.66.1c0,2.11,1.22,3.71,2.93,3.71s2.93-1.58,2.93-3.75c0-1.64-.82-3.71-2.89-3.71S127.61,7.74,127.61,9.57Z"/><path class="cls-1" d="M145.55,11.75c0,1,0,1.87.08,2.63h-1.56L144,12.8h0a3.63,3.63,0,0,1-3.19,1.79c-1.52,0-3.33-.84-3.33-4.23V4.73h1.75v5.34c0,1.83.56,3.07,2.15,3.07a2.54,2.54,0,0,0,2.31-1.6,2.57,2.57,0,0,0,.16-.9V4.73h1.75Z"/><path class="cls-1" d="M148.46,7.74c0-1.14,0-2.11-.08-3h1.54L150,6.62h.08a2.9,2.9,0,0,1,2.67-2.11,1.9,1.9,0,0,1,.5.06V6.22a2.63,2.63,0,0,0-.6-.06,2.46,2.46,0,0,0-2.35,2.25,4.92,4.92,0,0,0-.08.82v5.15h-1.73Z"/><path class="cls-1" d="M159,12.58a4.6,4.6,0,0,0,2.31.7c1.28,0,1.87-.64,1.87-1.44s-.5-1.3-1.79-1.77c-1.73-.62-2.55-1.58-2.55-2.73,0-1.56,1.26-2.83,3.33-2.83a4.81,4.81,0,0,1,2.37.6l-.44,1.28a3.76,3.76,0,0,0-2-.56c-1,0-1.62.6-1.62,1.32s.58,1.16,1.83,1.64c1.67.64,2.53,1.48,2.53,2.91,0,1.7-1.32,2.89-3.61,2.89a5.51,5.51,0,0,1-2.71-.66Z"/><path class="cls-1" d="M169.06,2a1.09,1.09,0,0,1-2.17,0A1.07,1.07,0,0,1,168,.92,1,1,0,0,1,169.06,2Zm-2,12.36V4.73h1.75v9.65Z"/><path class="cls-1" d="M173.88,2V4.73h2.51V6.06h-2.51v5.21c0,1.2.34,1.88,1.32,1.88a3.92,3.92,0,0,0,1-.12l.08,1.32a4.3,4.3,0,0,1-1.56.24,2.43,2.43,0,0,1-1.89-.74,3.57,3.57,0,0,1-.68-2.51V6.06h-1.5V4.73h1.5V2.41Z"/><path class="cls-1" d="M179.22,9.87a3.09,3.09,0,0,0,3.31,3.35,6.34,6.34,0,0,0,2.67-.5l.3,1.26a7.82,7.82,0,0,1-3.21.6c-3,0-4.75-2-4.75-4.87s1.71-5.21,4.53-5.21c3.15,0,4,2.77,4,4.55a6.7,6.7,0,0,1-.06.82Zm5.15-1.26c0-1.12-.46-2.85-2.43-2.85-1.78,0-2.55,1.64-2.69,2.85Z"/><path class="cls-1" d="M194.58,2V4.73h2.51V6.06h-2.51v5.21c0,1.2.34,1.88,1.32,1.88a3.92,3.92,0,0,0,1-.12l.08,1.32a4.3,4.3,0,0,1-1.56.24,2.43,2.43,0,0,1-1.89-.74,3.57,3.57,0,0,1-.68-2.51V6.06h-1.5V4.73h1.5V2.41Z"/><path class="cls-1" d="M207.68,9.47c0,3.57-2.47,5.13-4.81,5.13-2.61,0-4.63-1.91-4.63-5,0-3.23,2.11-5.13,4.79-5.13S207.68,6.52,207.68,9.47Zm-7.66.1c0,2.11,1.22,3.71,2.93,3.71s2.93-1.58,2.93-3.75c0-1.64-.82-3.71-2.89-3.71S200,7.74,200,9.57Z"/><path class="cls-1" d="M214.11.22h1.75V14.38h-1.75Z"/><path class="cls-1" d="M220.77,2a1.09,1.09,0,0,1-2.17,0,1.07,1.07,0,0,1,1.1-1.1A1,1,0,0,1,220.77,2Zm-2,12.36V4.73h1.75v9.65Z"/><path class="cls-1" d="M223.66,14.38V6.06H222.3V4.73h1.36V4.27A4.55,4.55,0,0,1,224.78.9a3.36,3.36,0,0,1,2.35-.9,4.09,4.09,0,0,1,1.5.28l-.24,1.36a2.62,2.62,0,0,0-1.12-.22c-1.5,0-1.87,1.32-1.87,2.79v.52h2.33V6.06H225.4v8.32Z"/><path class="cls-1" d="M230,9.87a3.09,3.09,0,0,0,3.31,3.35,6.34,6.34,0,0,0,2.67-.5l.3,1.26a7.82,7.82,0,0,1-3.21.6c-3,0-4.75-2-4.75-4.87s1.71-5.21,4.53-5.21c3.15,0,4,2.77,4,4.55a6.7,6.7,0,0,1-.06.82Zm5.15-1.26c0-1.12-.46-2.85-2.43-2.85-1.78,0-2.55,1.64-2.69,2.85Z"/></g></g></svg>" /> | |
</div> | |
</div> | |
<script type="text/javascript"> | |
$(document).ready(function () { | |
$('#base').plaxify() | |
$('#logo').plaxify({"xRange":10,"yRange":10}) | |
$('#text').plaxify({"xRange":20,"yRange":20}) | |
$('#bubble').plaxify({"xRange":50,"yRange":50}) | |
$('#texthl').plaxify({"xRange":30,"yRange":30}) | |
$('#title').plaxify({"xRange":30,"yRange":30}) | |
$.plax.enable() | |
}) | |
</script> | |
</body> | |
</html> |
Sign up for free
to join this conversation on GitHub.
Already have an account?
Sign in to comment