Skip to content

Instantly share code, notes, and snippets.

@0b01
Created March 6, 2017 03:48
Show Gist options
  • Save 0b01/47605a25fdb72f3e541fff4f80b3c603 to your computer and use it in GitHub Desktop.
Save 0b01/47605a25fdb72f3e541fff4f80b3c603 to your computer and use it in GitHub Desktop.
parallax.html
<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