@charset "UTF-8";
*, *::before, *::after { margin: 0; padding: 0; }

*, *::before, *::after { -webkit-box-sizing: border-box; box-sizing: border-box; }

/*! normalize.css v8.0.1 | MIT License | github.com/necolas/normalize.css */
/* Document ========================================================================== */
/** 1. Correct the line height in all browsers. 2. Prevent adjustments of font size after orientation changes in iOS. */
html { line-height: 1.15; /* 1 */ -webkit-text-size-adjust: 100%; /* 2 */ }

/* Sections ========================================================================== */
/** Remove the margin in all browsers. */
body { margin: 0; background-color: white; }

/** Render the `main` element consistently in IE. */
main { display: block; }

/** Correct the font size and margin on `h1` elements within `section` and `article` contexts in Chrome, Firefox, and Safari. */
h1 { font-size: 2em; margin: 0.67em 0; }

/* Grouping content ========================================================================== */
/** 1. Add the correct box sizing in Firefox. 2. Show the overflow in Edge and IE. */
hr { -webkit-box-sizing: content-box; box-sizing: content-box; /* 1 */ height: 0; /* 1 */ overflow: visible; /* 2 */ }

/** 1. Correct the inheritance and scaling of font size in all browsers. 2. Correct the odd `em` font sizing in all browsers. */
pre { font-family: monospace, monospace; /* 1 */ font-size: 1em; /* 2 */ }

/* Text-level semantics ========================================================================== */
/** Remove the gray background on active links in IE 10. */
a { background-color: transparent; }

/** 1. Remove the bottom border in Chrome 57- 2. Add the correct text decoration in Chrome, Edge, IE, Opera, and Safari. */
abbr[title] { border-bottom: none; /* 1 */ text-decoration: underline; /* 2 */ -webkit-text-decoration: underline dotted; text-decoration: underline dotted; /* 2 */ }

/** Add the correct font weight in Chrome, Edge, and Safari. */
b, strong { font-weight: bolder; }

/** 1. Correct the inheritance and scaling of font size in all browsers. 2. Correct the odd `em` font sizing in all browsers. */
code, kbd, samp { font-family: monospace, monospace; /* 1 */ font-size: 1em; /* 2 */ }

/** Add the correct font size in all browsers. */
small { font-size: 80%; }

/** Prevent `sub` and `sup` elements from affecting the line height in all browsers. */
sub, sup { font-size: 75%; line-height: 0; position: relative; vertical-align: baseline; }

sub { bottom: -0.25em; }

sup { top: -0.5em; }

/* Embedded content ========================================================================== */
/** Remove the border on images inside links in IE 10. */
img { border-style: none; }

/* Forms ========================================================================== */
/** 1. Change the font styles in all browsers. 2. Remove the margin in Firefox and Safari. */
button, input, optgroup, select, textarea { font-family: inherit; /* 1 */ font-size: 100%; /* 1 */ line-height: 1.15; /* 1 */ margin: 0; /* 2 */ }

/** Show the overflow in IE. 1. Show the overflow in Edge. */
button, input { /* 1 */ overflow: visible; }

/** Remove the inheritance of text transform in Edge, Firefox, and IE. 1. Remove the inheritance of text transform in Firefox. */
button, select { /* 1 */ text-transform: none; }

/** Correct the inability to style clickable types in iOS and Safari. */
button, [type="button"], [type="reset"], [type="submit"] { -webkit-appearance: button; }

/** Remove the inner border and padding in Firefox. */
button::-moz-focus-inner, [type="button"]::-moz-focus-inner, [type="reset"]::-moz-focus-inner, [type="submit"]::-moz-focus-inner { border-style: none; padding: 0; }

/** Restore the focus styles unset by the previous rule. */
button:-moz-focusring, [type="button"]:-moz-focusring, [type="reset"]:-moz-focusring, [type="submit"]:-moz-focusring { outline: 1px dotted ButtonText; }

/** Correct the padding in Firefox. */
fieldset { padding: 0.35em 0.75em 0.625em; }

/** 1. Correct the text wrapping in Edge and IE. 2. Correct the color inheritance from `fieldset` elements in IE. 3. Remove the padding so developers are not caught out when they zero out `fieldset` elements in all browsers. */
legend { -webkit-box-sizing: border-box; box-sizing: border-box; /* 1 */ color: inherit; /* 2 */ display: table; /* 1 */ max-width: 100%; /* 1 */ padding: 0; /* 3 */ white-space: normal; /* 1 */ }

/** Add the correct vertical alignment in Chrome, Firefox, and Opera. */
progress { vertical-align: baseline; }

/** Remove the default vertical scrollbar in IE 10+. */
textarea { overflow: auto; }

/** 1. Add the correct box sizing in IE 10. 2. Remove the padding in IE 10. */
[type="checkbox"], [type="radio"] { -webkit-box-sizing: border-box; box-sizing: border-box; /* 1 */ padding: 0; /* 2 */ }

/** Correct the cursor style of increment and decrement buttons in Chrome. */
[type="number"]::-webkit-inner-spin-button, [type="number"]::-webkit-outer-spin-button { height: auto; }

/** 1. Correct the odd appearance in Chrome and Safari. 2. Correct the outline style in Safari. */
[type="search"] { -webkit-appearance: textfield; /* 1 */ outline-offset: -2px; /* 2 */ }

/** Remove the inner padding in Chrome and Safari on macOS. */
[type="search"]::-webkit-search-decoration { -webkit-appearance: none; }

/** 1. Correct the inability to style clickable types in iOS and Safari. 2. Change font properties to `inherit` in Safari. */
::-webkit-file-upload-button { -webkit-appearance: button; /* 1 */ font: inherit; /* 2 */ }

/* Interactive ========================================================================== */
/* Add the correct display in Edge, IE 10+, and Firefox. */
details { display: block; }

/* Add the correct display in all browsers. */
summary { display: list-item; }

/* Misc ========================================================================== */
/** Add the correct display in IE 10+. */
template { display: none; }

/** Add the correct display in IE 10. */
[hidden] { display: none; }

@font-face { font-family: 'GT-Walsheim-Pro'; src: url("fonts/GT-Walsheim-Pro-Light.eot"); src: local("☺"), url("fonts/GT-Walsheim-Pro-Light.woff") format("woff"), url("fonts/GT-Walsheim-Pro-Light.ttf") format("truetype"), url("fonts/GT-Walsheim-Pro-Light.svg") format("svg"); font-weight: 100; font-style: normal; }

@font-face { font-family: 'GT-Walsheim-Pro'; src: url("fonts/GT-Walsheim-Pro-Regular.eot"); src: local("☺"), url("fonts/GT-Walsheim-Pro-Regular.woff") format("woff"), url("fonts/GT-Walsheim-Pro-Regular.ttf") format("truetype"), url("fonts/GT-Walsheim-Pro-Regular.svg") format("svg"); font-weight: 400; font-style: normal; }

@font-face { font-family: 'GT-Walsheim-Pro'; src: url("fonts/GT-Walsheim-Pro-Medium.eot"); src: local("☺"), url("fonts/GT-Walsheim-Pro-Medium.woff") format("woff"), url("fonts/GT-Walsheim-Pro-Medium.ttf") format("truetype"), url("fonts/GT-Walsheim-Pro-Medium.svg") format("svg"); font-weight: 600; font-style: normal; }

@font-face { font-family: "scramble"; src: url("fonts/scramble.eot?v2"); src: local("☺"), url("fonts/scramble.woff2?v2") format("woff2"), url("fonts/scramble.woff?v2") format("woff"), url("fonts/scramble.ttf?v2") format("truetype"), url("fonts/scramble.otf?v2") format("opentype"), url("fonts/scramble.svg?v2#scramble") format("svg"); font-weight: normal; font-style: normal; font-display: block; }

.scramble { /* use !important to prevent issues with browser extensions that change fonts */ font-family: "scramble" !important; speak: none; font-style: normal; font-weight: normal; font-variant: normal; text-transform: none; /* Better Font Rendering =========== */ -webkit-font-smoothing: antialiased; -moz-osx-font-smoothing: grayscale; }

.scramble-logo:before { content: "" !important; }

.scramble-dot:before { content: "" !important; }

.scramble-plus:before { content: "" !important; font-weight: bold; }

.scramble-cross:before { content: "" !important; font-weight: bold; }

.scramble-smile:before { content: "" !important; }

.scramble-shield:before { content: "" !important; }

.scramble-notebook:before { content: "" !important; }

.scramble-graph:before { content: "" !important; }

.scramble-feather:before { content: "" !important; }

.scramble-wallet:before { content: "" !important; }

.scramble-money:before { content: "" !important; }

.scramble-coins:before { content: "" !important; }

.scramble-arrow-left:before { content: "" !important; }

.scramble-arrow-up:before { content: "" !important; }

.scramble-arrow-right:before { content: "" !important; }

.scramble-arrow-down:before { content: "" !important; }

.scramble-facebook:before { content: "" !important; }

.scramble-linkedin:before { content: "" !important; }

div#loader { position: fixed; z-index: 100000; width: 100%; height: 100%; display: -webkit-box; display: -ms-flexbox; display: flex; margin: 0; top: 0; font-size: 10.25rem; overflow: hidden; scroll-behavior: smooth; -webkit-transition: all 1s ease-in-out 1s; transition: all 1s ease-in-out 1s; }

div#loader:before { content: ""; position: absolute; top: calc(50vh - 15rem); top: calc(var(--vh, 1vh) * 50 - 15rem); left: calc(50vw - 15rem); width: 0; height: 0; padding: 15rem; border-radius: 50%; background-color: #fcd11b; -webkit-transform: scale(0); transform: scale(0); -webkit-transition: -webkit-transform ease-in-out 1s; transition: -webkit-transform ease-in-out 1s; transition: transform ease-in-out 1s; transition: transform ease-in-out 1s, -webkit-transform ease-in-out 1s; }

div#loader div { opacity: 0; display: block; position: relative; max-height: 13rem; top: calc(50vh - 1em); top: calc(var(--vh, 1vh) * 50 - 1em); margin: 0 auto; -webkit-transition: all .1s ease-in-out 1s; transition: all .1s ease-in-out 1s; }

div#loader div i { position: relative; display: block; white-space: nowrap; overflow: hidden; color: #fff; -webkit-transition: all ease-in-out 1s; transition: all ease-in-out 1s; }

div#loader div i + i { position: absolute; left: 0; top: 0; color: #000; max-width: 0; }

body.loading div#loader:before { background-color: #fcd11b; -webkit-transform: scale(8); transform: scale(8); }

body.loading div#loader div { opacity: 1; }

#login { position: fixed; top: 0; left: 0; right: 0; width: 100vw; height: 100vh; overflow: hidden; z-index: 100000; opacity: 1; -webkit-transition: opacity .3s ease-in-out, z-index .3s ease-in-out; transition: opacity .3s ease-in-out, z-index .3s ease-in-out; }

#login div.login-wrapper { position: absolute; min-height: 200vmax; min-width: 200vmax; border-radius: 100%; padding: calc(100vmax - 50vh) calc(100vmax - 50vw); bottom: calc(-100vmax + 50vh); left: calc(-100vmax + 50vw); display: -webkit-box; display: -ms-flexbox; display: flex; -webkit-box-orient: vertical; -webkit-box-direction: normal; -ms-flex-direction: column; flex-direction: column; -webkit-box-pack: justify; -ms-flex-pack: justify; justify-content: space-between; background-color: #000; color: #fff; -webkit-transform: scale(1); transform: scale(1); -webkit-transition: all ease-in-out .4s; transition: all ease-in-out .4s; }

#login div.header { min-width: 100%; display: -webkit-box; display: -ms-flexbox; display: flex; -webkit-box-align: center; -ms-flex-align: center; align-items: center; -ms-flex-line-pack: center; align-content: center; padding: 1rem 4rem 1rem 4rem; opacity: 1; -webkit-transition: all .25s ease-in-out .3s; transition: all .25s ease-in-out .3s; }

#login div.header .logo { display: block; -webkit-box-flex: 0; -ms-flex: 0 0; flex: 0 0; margin-right: auto; padding: 1em; width: 8rem; text-align: center; }

#login div.header .logo a { text-decoration: none; text-transform: uppercase; color: black; white-space: nowrap; }

#login div.header a.dot { position: relative; padding: 1em; text-decoration: none; text-transform: uppercase; color: black; white-space: nowrap; }

#login div.header a.dot::before { content: ""; display: block; position: absolute; width: 0; height: 0; padding: 1em; margin-top: 0rem; top: 0.6125em; right: 0.25em; z-index: -1; border-radius: 100%; background-color: #fcd11b; -webkit-transition: all .25s ease-in-out; transition: all .25s ease-in-out; }

#login div.header a.dot:hover::before { -webkit-transform: scale(1.2); transform: scale(1.2); }

#login div.slide { width: 100%; height: 100%; opacity: 1; -webkit-transition: all .25s ease-in-out .3s; transition: all .25s ease-in-out .3s; }

#login input { margin-bottom: 2rem; border-bottom-color: #fff; color: #fff; font-size: 1.2em; font-weight: 600; }

#login input:focus, #login input:active, #login input:hover { outline: none; border: none; border-bottom: 2px #fcd11b solid; }

#login .btn-outline-circle { color: #fff; -webkit-transform: scale(1); transform: scale(1); }

#login.hidden { z-index: -1; -webkit-transition: opacity .25s ease-in-out .3s, z-index .3s ease-in-out .3s; transition: opacity .25s ease-in-out .3s, z-index .3s ease-in-out .3s; }

#login.hidden div.login-wrapper { bottom: calc(-100vmax + 100vh - 2em); left: calc(-100vmax + 100vw - 2em); -webkit-transform: scale(0); transform: scale(0); -webkit-transition: all .4s ease-in-out .2s; transition: all .4s ease-in-out .2s; }

#login.hidden div.header, #login.hidden div.slide { opacity: 0; -webkit-transition: all .25s ease-in-out; transition: all .25s ease-in-out; }

@media (max-width: 479.8px) { #login { font-size: 3rem; }
  #login div.header { padding: .5em 1em; } }

html { font-family: "GT-Walsheim-Pro"; font-weight: 400; font-size: 1.1111111111vw; line-height: 1.45; }

p.headline { font-size: 2.5rem; font-weight: 600; }

p.lead { font-size: 1.5em; }

.slide p, .slide span { margin-bottom: 1em; opacity: 0; -webkit-transition: all 0.35s ease-in-out; transition: all 0.35s ease-in-out; }

.slide ul, .slide ol, .slide svg { opacity: 0; -webkit-transition: all 0.35s ease-in-out; transition: all 0.35s ease-in-out; }

.scrolled-in .slide p.headline { -webkit-transition: all 0.35s ease-in-out; transition: all 0.35s ease-in-out; }

.scrolled-in .slide p.lead { -webkit-transition: all 0.35s ease-in-out .1s; transition: all 0.35s ease-in-out .1s; }

.scrolled-in p, .scrolled-in span, .scrolled-in ul, .scrolled-in ol, .scrolled-in svg { opacity: 1; -webkit-transform: translateY(0rem); transform: translateY(0rem); -webkit-transition: all 0.35s ease-in-out .2s; transition: all 0.35s ease-in-out .2s; }

form { margin-bottom: 2em; }

form input, form small, form label, form .small { font-size: .75em; margin-bottom: 2em; }

@media (max-width: 479.8px) { html { font-size: 1.4vw; line-height: 1.35; }
  p.headline { font-size: 5rem; }
  p.lead { font-size: 1.5em; }
  p { font-size: 3rem; } }

header { position: fixed; top: 0; left: 0; right: 0; background: #fff; z-index: 1000; }

header a { text-decoration: none; text-transform: uppercase; white-space: nowrap; }

header.about { background: transparent; }

header.scrolled-in, header.header { background: transparent; }

header.scrolled-in nav#main .logo, header.header nav#main .logo { position: fixed; width: 100%; top: calc(50vh - 1em); top: calc(var(--vh, 1vh) * 50 - 1em); left: 0; font-size: 10.25rem; text-align: center; }

header.scrolled-in nav#main .logo p.title, header.header nav#main .logo p.title { font-size: 2.7rem; margin-top: -2rem; opacity: 1; }

header.scrolled-in nav#main #menu .dots span, header.header nav#main #menu .dots span { opacity: 0; font-size: 0; }

header.scrolled-in nav#main #menu .dots span:nth-child(-n+3), header.header nav#main #menu .dots span:nth-child(-n+3) { opacity: 1; font-size: 1em; }

header.scrolled-in nav#main #menu:hover > div .dots span, header.header nav#main #menu:hover > div .dots span { display: inline-block; opacity: 1; font-size: 1em; }

header nav#main { margin-left: 0rem; width: 100%; display: -webkit-box; display: -ms-flexbox; display: flex; -webkit-box-align: center; -ms-flex-align: center; align-items: center; -ms-flex-line-pack: center; align-content: center; padding: 1rem 3rem 1rem 4rem; }

header nav#main .logo { position: fixed; display: block; -webkit-box-flex: 0; -ms-flex: 0 0; flex: 0 0; top: 1.75em; left: 4em; width: 8rem; text-align: center; -webkit-transition: all 0.5s ease-out; transition: all 0.5s ease-out; }

header nav#main .logo a { padding: 0; color: black; }

header nav#main .logo p.title { font-size: 0; font-weight: 600; -webkit-transition: all 0.5s ease-out; transition: all 0.5s ease-out; }

header nav#main #menu-c { opacity: 0; font-size: 1.5em; position: fixed; left: calc(50vw - 0.5em); -webkit-transform: scale(0); transform: scale(0); -webkit-transition: all 0.25s ease-out; transition: all 0.25s ease-out; }

header nav#main #menu { margin-left: 10.9rem; display: -webkit-box; display: -ms-flexbox; display: flex; -webkit-box-align: center; -ms-flex-align: center; align-items: center; -webkit-box-flex: 1; -ms-flex: 1 1; flex: 1 1; min-height: 3em; }

header nav#main #menu > div { border-radius: 2em; -webkit-transition: all 0.25s ease-in-out; transition: all 0.25s ease-in-out; cursor: default; display: -webkit-box; display: -ms-flexbox; display: flex; -webkit-box-align: center; -ms-flex-align: center; align-items: center; padding: 0 1em; }

header nav#main #menu > div .dots { cursor: default; display: -webkit-box; display: -ms-flexbox; display: flex; -webkit-box-align: center; -ms-flex-align: center; align-items: center; -ms-flex-line-pack: center; align-content: center; -webkit-box-pack: stretch; -ms-flex-pack: stretch; justify-content: stretch; margin-right: .4em; font-size: 2.5em; line-height: 0; }

header nav#main #menu > div .dots span { cursor: default; margin-bottom: 0; margin-left: .125em; margin-right: .125em; display: inline-block; opacity: 1; -webkit-transition: all 0.25s ease-in-out; transition: all 0.25s ease-in-out; }

header nav#main #menu > div .dots span.active { opacity: 1; color: #fcd11b; }

header nav#main #menu > div .links { display: -webkit-box; display: -ms-flexbox; display: flex; -webkit-box-align: center; -ms-flex-align: center; align-items: center; -ms-flex-line-pack: center; align-content: center; -webkit-box-pack: stretch; -ms-flex-pack: stretch; justify-content: stretch; }

header nav#main #menu > div .links a.active { font-size: 1em; opacity: 1; -webkit-transition: all 0.25s ease-in-out; transition: all 0.25s ease-in-out; }

header nav#main #menu > div .links a { font-size: 0; opacity: 0; padding: 1em .5em; margin-right: 0; -webkit-transition: all 0.25s ease-in-out; transition: all 0.25s ease-in-out; }

header nav#main #menu > div a { font-weight: bold; color: black; margin: 0; -webkit-transition: all 0.25s ease-in-out; transition: all 0.25s ease-in-out; }

header nav#main #menu:hover > div { background-color: #fcd11b; border-radius: 2em; color: white; -webkit-transition: all 0.25s ease-in-out; transition: all 0.25s ease-in-out; }

header nav#main #menu:hover > div a { display: inline-block; opacity: 1; min-width: initial; }

header nav#main #menu:hover > div .dots span, header nav#main #menu:hover > div .dots span.active { display: inline-block; color: white; }

header nav#main #menu:hover > div .links a { font-size: 1em; }

header nav#main #menu:hover > div .links a.active { display: inline-block; color: white; font-size: 1em; }

header nav#main a { font-size: 1em; display: inline-block; position: relative; font-weight: bold; color: black; }

header nav#main a#login-o { padding: 1em; }

header nav#main a#login-o::before { content: ""; display: block; position: absolute; width: 0; height: 0; padding: 1em; margin-top: 0rem; top: 0.5em; right: 0.25em; z-index: -1; border-radius: 100%; background-color: #fcd11b; -webkit-transition: all .25s ease-in-out; transition: all .25s ease-in-out; }

header nav#main a.dot:hover::before { -webkit-transform: scale(1.2); transform: scale(1.2); }

@media (max-width: 479.8px) { header nav#main { padding: .5em 0; font-size: 3rem; -webkit-box-align: start; -ms-flex-align: start; align-items: flex-start; }
  header nav#main #menu { margin-left: 0; }
  header nav#main #menu > div { width: 100%; }
  header nav#main #menu > div .dots { font-size: 2.75em; padding: 3.5rem 0; }
  header nav#main #menu > div .dots span { font-size: 0; }
  header nav#main #menu > div .dots span.active { font-size: 1em; }
  header nav#main #menu > div .links { -webkit-box-orient: vertical; -webkit-box-direction: normal; -ms-flex-direction: column; flex-direction: column; -webkit-box-align: start; -ms-flex-align: start; align-items: flex-start; }
  header nav#main #menu > div .links a.active { color: black; }
  header nav#main #menu:hover > div { background-color: transparent; border-radius: 2em; }
  header nav#main #menu:hover > div .dots span.active { opacity: 1; color: #fcd11b; }
  header nav#main #menu:hover > div .links a { opacity: 0; font-size: 0; color: black; }
  header nav#main #menu:hover > div .links a.active { color: black; font-size: 1em; opacity: 1; }
  header nav#main #login-o { position: fixed; top: .5em; right: 1em; }
  header nav#main .logo { opacity: 0; /* z-index: -1000; */ position: fixed; top: 1.5em; left: 2em; width: 0; }
  header nav#main.open { width: 100vw; height: 100vh; height: calc(var(--vh, 1vh) * 100); background-color: #fcd11b; -webkit-box-pack: justify; -ms-flex-pack: justify; justify-content: space-between; }
  header nav#main.open #menu-c { opacity: 1; padding: .5em; -webkit-transform: scale(1); transform: scale(1); }
  header nav#main.open #menu { position: absolute; top: 5em; left: 1em; }
  header nav#main.open #menu > div .dots span { font-size: 0 !important; opacity: 0 !important; }
  header nav#main.open #menu > div .links a { font-size: 2em; opacity: 1; }
  header nav#main.open #menu > div .links a.active { color: white; }
  header nav#main.open #menu:hover > div { background-color: transparent; border-radius: 0; }
  header nav#main.open #menu:hover > div .links a { opacity: 1; font-size: 1.5em; }
  header nav#main.open #menu:hover > div .links a.active { color: white; }
  header nav#main.open .logo { position: fixed; opacity: 1; z-index: 1000; top: 1.5em; left: 2em; width: 8rem; font-size: 1em; }
  header nav#main.open .logo p.title { opacity: 0; font-size: 0; -webkit-transform: scale(0); transform: scale(0); }
  header.about { background: white; }
  header.scrolled-in nav#main .logo, header.header nav#main .logo { opacity: 1; z-index: 1000; }
  header.scrolled-in nav#main .logo p.title, header.header nav#main .logo p.title { font-size: 4.7rem; margin-top: 1rem; }
  header.scrolled-in nav#main #menu:hover > div, header.header nav#main #menu:hover > div { width: 100%; }
  header.scrolled-in nav#main #menu:hover > div .dots span, header.header nav#main #menu:hover > div .dots span { font-size: 0; }
  header.scrolled-in nav#main #menu:hover > div .dots span.active, header.header nav#main #menu:hover > div .dots span.active { font-size: 1em; }
  header.scrolled-in nav#main.open .logo p.title, header.header nav#main.open .logo p.title { opacity: 0; font-size: 0; -webkit-transform: scale(0); transform: scale(0); } }

nav#side { z-index: 999; -webkit-transition: all .25s ease-in-out; transition: all .25s ease-in-out; position: -webkit-sticky; position: sticky; left: 4rem; bottom: 2rem; width: 8rem; font-size: 1rem; }

nav#side a.btn-outline-circle { -webkit-transform: scale(1); transform: scale(1); -webkit-transition: all .25s ease-in-out; transition: all .25s ease-in-out; }

nav#side a.btn-outline-circle i { font-size: 2rem; }

nav#side a.btn-outline-circle.hover-caption:hover i { opacity: 0; font-size: 0; }

nav#side.header { left: 12rem; }

nav#side.header > div a#up { opacity: 0; }

nav#side.header > div a#down { margin-top: 8rem; background-color: transparent; background-size: 0 0; }

nav#side.header > div a#down, nav#side.header > div a#down::before { border: 2px solid transparent; border-radius: 100%; }

nav#side.header > div a#down:hover { font-size: 2rem; }

nav#side.header > div a#down:hover::before { background-color: transparent; border: none; }

nav#side.header > div a#down:hover::after { content: ""; -webkit-transform: rotate(0deg); transform: rotate(0deg); }

nav#side.header > div a#down:hover i { display: block; font-size: 1em; opacity: 1; -webkit-animation: bounce 1s cubic-bezier(0.5, -0.5, 0.7, 1) infinite; animation: bounce 1s cubic-bezier(0.5, -0.5, 0.7, 1) infinite; }

nav#side.contact > div a#down { background-size: 200% 200%; border-color: #fcd11b; }

nav#side.contact > div a#down i { font-size: 0; opacity: 0; }

nav#side.contact > div a#down::after, nav#side.contact > div a#down:hover::after { content: ""; -webkit-transform: rotate(0deg); transform: rotate(0deg); }

nav#side > div { position: absolute; bottom: 0; width: 8rem; padding: 2.5rem 1rem; }

nav#side > div a.btn-outline-circle { position: relative; display: block; color: black; }

nav#side > div a.btn-outline-circle:hover i { opacity: 0; }

@media (max-width: 479.8px) { nav#side { left: -100%; display: none; }
  nav#side.header { display: block; left: calc(50vw - 4rem); }
  nav#side.header > div a#down i, nav#side.header > div a#down:hover i { font-size: 7rem; } }

@-webkit-keyframes bounce { 0% { -webkit-transform: translateY(0); transform: translateY(0); }
  50% { -webkit-transform: translateY(1rem); transform: translateY(1rem); }
  100% { -webkit-transform: translateY(0); transform: translateY(0); } }

@keyframes bounce { 0% { -webkit-transform: translateY(0); transform: translateY(0); }
  50% { -webkit-transform: translateY(1rem); transform: translateY(1rem); }
  100% { -webkit-transform: translateY(0); transform: translateY(0); } }

main { padding: 0 2rem 0 4rem; }

canvas { position: absolute; top: 0; left: 0; }

section { min-height: 75vh; display: -webkit-box; display: -ms-flexbox; display: flex; -webkit-box-align: center; -ms-flex-align: center; align-items: center; }

section div.slide { display: block; margin-left: 10rem; padding-left: 2rem; padding-right: 1rem; padding-top: 2rem; margin-top: 4rem; min-width: calc(100% - 10rem); z-index: 100; }

section:not(.scrolled-in) div.slide p, section:not(.scrolled-in) div.slide span { -webkit-transform: translateY(2rem); transform: translateY(2rem); }

.row { display: -webkit-box; display: -ms-flexbox; display: flex; -ms-flex-wrap: wrap; flex-wrap: wrap; margin-left: -1rem; margin-right: -1rem; }

.row .col-10 { display: block; padding-left: 1rem; padding-right: 1rem; max-width: 10%; -webkit-box-flex: 0; -ms-flex: 0 0 10%; flex: 0 0 10%; }

.row .col-15 { display: block; padding-left: 1rem; padding-right: 1rem; max-width: 15%; -webkit-box-flex: 0; -ms-flex: 0 0 15%; flex: 0 0 15%; }

.row .col-20 { display: block; padding-left: 1rem; padding-right: 1rem; max-width: 20%; -webkit-box-flex: 0; -ms-flex: 0 0 20%; flex: 0 0 20%; }

.row .col-25 { display: block; padding-left: 1rem; padding-right: 1rem; max-width: 25%; -webkit-box-flex: 0; -ms-flex: 0 0 25%; flex: 0 0 25%; }

.row .col-30 { display: block; padding-left: 1rem; padding-right: 1rem; max-width: 30%; -webkit-box-flex: 0; -ms-flex: 0 0 30%; flex: 0 0 30%; }

.row .col-33 { display: block; padding-left: 1rem; padding-right: 1rem; max-width: 33%; -webkit-box-flex: 0; -ms-flex: 0 0 33%; flex: 0 0 33%; }

.row .col-40 { display: block; padding-left: 1rem; padding-right: 1rem; max-width: 40%; -webkit-box-flex: 0; -ms-flex: 0 0 40%; flex: 0 0 40%; }

.row .col-50 { display: block; padding-left: 1rem; padding-right: 1rem; max-width: 50%; -webkit-box-flex: 0; -ms-flex: 0 0 50%; flex: 0 0 50%; }

.row .col-55 { display: block; padding-left: 1rem; padding-right: 1rem; max-width: 55%; -webkit-box-flex: 0; -ms-flex: 0 0 55%; flex: 0 0 55%; }

.row .col-60 { display: block; padding-left: 1rem; padding-right: 1rem; max-width: 60%; -webkit-box-flex: 0; -ms-flex: 0 0 60%; flex: 0 0 60%; }

.row .col-66 { display: block; padding-left: 1rem; padding-right: 1rem; max-width: 66%; -webkit-box-flex: 0; -ms-flex: 0 0 66%; flex: 0 0 66%; }

.row .col-70 { display: block; padding-left: 1rem; padding-right: 1rem; max-width: 70%; -webkit-box-flex: 0; -ms-flex: 0 0 70%; flex: 0 0 70%; }

.row .col-75 { display: block; padding-left: 1rem; padding-right: 1rem; max-width: 75%; -webkit-box-flex: 0; -ms-flex: 0 0 75%; flex: 0 0 75%; }

.row .col-80 { display: block; padding-left: 1rem; padding-right: 1rem; max-width: 80%; -webkit-box-flex: 0; -ms-flex: 0 0 80%; flex: 0 0 80%; }

.row .col-90 { display: block; padding-left: 1rem; padding-right: 1rem; max-width: 90%; -webkit-box-flex: 0; -ms-flex: 0 0 90%; flex: 0 0 90%; }

.row .col-100 { display: block; padding-left: 1rem; padding-right: 1rem; max-width: 100%; -webkit-box-flex: 0; -ms-flex: 0 0 100%; flex: 0 0 100%; }

@media (max-width: 479.8px) { section { padding-top: 10rem; min-height: 0; }
  section div.slide { font-size: 3rem; margin: 0; height: auto; }
  .row { margin-left: -2rem; margin-right: -2rem; }
  .row .mcol-10 { display: block; padding-left: 2rem; padding-right: 2rem; max-width: 10%; -webkit-box-flex: 0; -ms-flex: 0 0 10%; flex: 0 0 10%; }
  .row .mcol-15 { display: block; padding-left: 2rem; padding-right: 2rem; max-width: 15%; -webkit-box-flex: 0; -ms-flex: 0 0 15%; flex: 0 0 15%; }
  .row .mcol-20 { display: block; padding-left: 2rem; padding-right: 2rem; max-width: 20%; -webkit-box-flex: 0; -ms-flex: 0 0 20%; flex: 0 0 20%; }
  .row .mcol-25 { display: block; padding-left: 2rem; padding-right: 2rem; max-width: 25%; -webkit-box-flex: 0; -ms-flex: 0 0 25%; flex: 0 0 25%; }
  .row .mcol-30 { display: block; padding-left: 2rem; padding-right: 2rem; max-width: 30%; -webkit-box-flex: 0; -ms-flex: 0 0 30%; flex: 0 0 30%; }
  .row .mcol-33 { display: block; padding-left: 2rem; padding-right: 2rem; max-width: 33%; -webkit-box-flex: 0; -ms-flex: 0 0 33%; flex: 0 0 33%; }
  .row .mcol-40 { display: block; padding-left: 2rem; padding-right: 2rem; max-width: 40%; -webkit-box-flex: 0; -ms-flex: 0 0 40%; flex: 0 0 40%; }
  .row .mcol-50 { display: block; padding-left: 2rem; padding-right: 2rem; max-width: 50%; -webkit-box-flex: 0; -ms-flex: 0 0 50%; flex: 0 0 50%; }
  .row .mcol-55 { display: block; padding-left: 2rem; padding-right: 2rem; max-width: 55%; -webkit-box-flex: 0; -ms-flex: 0 0 55%; flex: 0 0 55%; }
  .row .mcol-60 { display: block; padding-left: 2rem; padding-right: 2rem; max-width: 60%; -webkit-box-flex: 0; -ms-flex: 0 0 60%; flex: 0 0 60%; }
  .row .mcol-66 { display: block; padding-left: 2rem; padding-right: 2rem; max-width: 66%; -webkit-box-flex: 0; -ms-flex: 0 0 66%; flex: 0 0 66%; }
  .row .mcol-70 { display: block; padding-left: 2rem; padding-right: 2rem; max-width: 70%; -webkit-box-flex: 0; -ms-flex: 0 0 70%; flex: 0 0 70%; }
  .row .mcol-75 { display: block; padding-left: 2rem; padding-right: 2rem; max-width: 75%; -webkit-box-flex: 0; -ms-flex: 0 0 75%; flex: 0 0 75%; }
  .row .mcol-80 { display: block; padding-left: 2rem; padding-right: 2rem; max-width: 80%; -webkit-box-flex: 0; -ms-flex: 0 0 80%; flex: 0 0 80%; }
  .row .mcol-90 { display: block; padding-left: 2rem; padding-right: 2rem; max-width: 90%; -webkit-box-flex: 0; -ms-flex: 0 0 90%; flex: 0 0 90%; }
  .row .mcol-100 { display: block; padding-left: 2rem; padding-right: 2rem; max-width: 100%; -webkit-box-flex: 0; -ms-flex: 0 0 100%; flex: 0 0 100%; } }

footer { padding: 2em 2rem 2em 5rem; background-color: black; display: -webkit-box; display: -ms-flexbox; display: flex; -webkit-box-pack: justify; -ms-flex-pack: justify; justify-content: space-between; -webkit-box-align: center; -ms-flex-align: center; align-items: center; font-size: 1rem; font-weight: 600; color: white; }

footer a { text-decoration: none; text-transform: uppercase; white-space: nowrap; color: white; }

footer .copyright { padding-right: 1rem; margin-right: auto; }

footer .logo { width: 8rem; margin-right: 3rem; }

footer ul.social { padding-right: 1rem; }

footer ul.social li { display: inline-block; list-style: none; text-transform: uppercase; margin: .5rem; font-size: 2em; }

footer .address { padding-right: 1rem; margin-right: auto; }

footer .muted { color: #4d4d4d; }

footer .credits { display: none; }

@media (max-width: 479.8px) { footer { font-size: 3em; -webkit-box-orient: vertical; -webkit-box-direction: normal; -ms-flex-direction: column; flex-direction: column; -webkit-box-align: start; -ms-flex-align: start; align-items: flex-start; }
  footer ul.social { position: absolute; right: 0; }
  footer .logo { margin-bottom: 3em; -webkit-box-ordinal-group: 2; -ms-flex-order: 1; order: 1; }
  footer .address { margin-bottom: .5em; -webkit-box-ordinal-group: 3; -ms-flex-order: 2; order: 2; }
  footer .copyright { margin-bottom: .5em; -webkit-box-ordinal-group: 4; -ms-flex-order: 3; order: 3; } }

#bg-animations { position: fixed; z-index: -1; display: block; left: 0; top: 0; width: 100vw; height: 100vh; height: calc(var(--vh, 1vh) * 100); overflow: hidden; -webkit-transition: all .25s ease-in-out; transition: all .25s ease-in-out; }

#bg-animations canvas { display: block; opacity: 0; -webkit-transform: scale(0); transform: scale(0); -webkit-transition: all .25s ease-in-out; transition: all .25s ease-in-out; }

#bg-animations .dot { -webkit-transform: scale(0); transform: scale(0); opacity: 0; -webkit-transition: all .25s ease-in-out; transition: all .25s ease-in-out; }

#bg-animations.top canvas { opacity: 1; -webkit-transform: scale(1); transform: scale(1); }

#bg-animations.header canvas { opacity: 1; -webkit-transform: scale(1); transform: scale(1); }

#bg-animations.header .dot { display: none; margin: 17vmin calc(50% - 32vmin); padding: 33vmin; -webkit-transform: scale(1); transform: scale(1); opacity: 1; }

#bg-animations.about canvas { opacity: 1; -webkit-transform: scale(1); transform: scale(1); }

#bg-animations.about .dot { display: none; margin: 17vmin calc(50% - 32vmin); padding: 33vmin; -webkit-transform: scale(1); transform: scale(1); opacity: 1; }

div.dot { position: relative; display: block; width: 0; height: 0; padding: 50%; border-radius: 100%; background-color: #fcd11b; border: 2px solid #fcd11b; -webkit-transition: all .25s ease-in-out; transition: all .25s ease-in-out; -webkit-transform: scale(0); transform: scale(0); }

span.tooltip { position: absolute; display: block; top: 0; left: 0; opacity: 0; font-size: 1rem; text-transform: none; line-height: 1; padding: 1.5rem; background-color: white; border-radius: 2rem; border: 1px solid black; white-space: nowrap; -webkit-transition: all 0.25s ease-in-out; transition: all 0.25s ease-in-out; }

span.tooltip::after, span.tooltip::before { position: absolute; display: block; content: ""; border-color: transparent; border-style: solid; }

span.tooltip::before { bottom: calc(-1.5rem - 2px); border-width: calc(1.5rem + 2px) calc(1rem + 2px) 0 0; border-top-color: black; }

span.tooltip::after { bottom: calc(-1.5rem + 2px); left: calc(1.5rem + 2px); border-width: 1.5rem 1rem 0 0; border-top-color: #fff; }

.spoiler { font-size: 1em; opacity: 0 !important; line-height: 0; }

.spoiler.more { opacity: 1 !important; font-size: 1em; line-height: 1.45; }

.spoiler.more + .toggle::before { content: "less"; }

.spoiler + .toggle { display: -webkit-box; display: -ms-flexbox; display: flex; -webkit-box-align: center; -ms-flex-align: center; align-items: center; cursor: pointer; color: #fcd11b; font-size: 2.5em; line-height: 0; padding: 1rem 0; }

.spoiler + .toggle i { -webkit-transition: all 0.25s ease-in-out; transition: all 0.25s ease-in-out; margin-right: .2em; }

.spoiler + .toggle:hover i { margin-right: .3em; }

.spoiler + .toggle::before { display: inline-block; content: "more"; cursor: pointer; text-transform: uppercase; color: black; font-size: .4em; font-weight: 600; margin-right: .5em; }

ul.dot > li { position: relative; margin-bottom: 2.5rem; }

ul.dot > li::before { content: ""; display: block; position: absolute; top: 0; left: 0; width: 0; height: 0; padding: 3.5rem; margin: 1.5rem 0 0 2.2rem; border-radius: 100%; border: 2px #fcd11b solid; background-color: #fcd11b; z-index: -1; -webkit-transition: all .25s ease-in-out .05s; transition: all .25s ease-in-out .05s; -webkit-transform: scale(0); transform: scale(0); }

ul.dot > li:hover::before { -webkit-transform: scale(1.2); transform: scale(1.2); }

ul.sm-dot { display: -webkit-box; display: -ms-flexbox; display: flex; -ms-flex-wrap: wrap; flex-wrap: wrap; margin-left: -1rem; width: 0; height: 0; opacity: 0; -webkit-transition: width 0.1s ease-in-out .25s, opacity 0.25s ease-in-out; transition: width 0.1s ease-in-out .25s, opacity 0.25s ease-in-out; }

ul.sm-dot > li { width: 0; position: relative; display: -webkit-box !important; display: -ms-flexbox !important; display: flex !important; margin-bottom: 2.5rem; padding-right: 2rem; }

ul.sm-dot > li::before { content: ""; font-family: "scramble" !important; font-size: 2em; line-height: .5; color: #fcd11b; display: block; min-width: .5em; margin-left: -.5em; }

.scrolled-in ul.sm-dot.sm-dot.hidden { opacity: 0; -webkit-transition: width 0.1s ease-in-out .25s, opacity 0.25s ease-in-out; transition: width 0.1s ease-in-out .25s, opacity 0.25s ease-in-out; }

.scrolled-in ul.sm-dot.sm-dot.visible { opacity: 1; width: 100%; height: auto; -webkit-transition: width .1s ease-in-out, opacity 0.25s ease-in-out .1s; transition: width .1s ease-in-out, opacity 0.25s ease-in-out .1s; }

ol.dot { position: relative; display: -webkit-box; display: -ms-flexbox; display: flex; -ms-flex-wrap: wrap; flex-wrap: wrap; margin-left: 0em; margin-right: -2em; counter-reset: li; list-style: none; }

ol.dot li { position: relative; display: block; counter-increment: li; opacity: 0; -webkit-transform: scale(0); transform: scale(0); -webkit-transition: all 0.25s ease-in-out .05s; transition: all 0.25s ease-in-out .05s; font-size: 1em; }

ol.dot li p { padding: 2em 4em 7em 4em !important; }

ol.dot li p::before { content: counters(li, ".") ""; font-weight: 600; display: block; font-size: 2.5em; opacity: 1; margin-bottom: .5em; }

ol.dot li::after { content: ""; display: block; position: absolute; top: 0; left: 0; right: 0; bottom: 0; width: 0; height: 0; padding: calc(50% - 1em); border-radius: 100%; border: 2px #fcd11b solid; background-image: radial-gradient(#fcd11b 50%, transparent 50%, transparent 100%); background-position: center; background-repeat: no-repeat; background-size: 0 0; -webkit-transition: background-size .25s ease-in-out; transition: background-size .25s ease-in-out; z-index: -1; }

ol.dot li:hover::after { background-size: 200% 200%; }

ul.radio { position: relative; display: -webkit-box; display: -ms-flexbox; display: flex; -ms-flex-wrap: wrap; flex-wrap: wrap; width: 50%; }

ul.radio > li { display: -webkit-box; display: -ms-flexbox; display: flex; -webkit-box-flex: 0; -ms-flex: 0 0 50%; flex: 0 0 50%; -webkit-box-align: center; -ms-flex-align: center; align-items: center; font-weight: 600; margin-bottom: 3rem; text-transform: uppercase; cursor: pointer; }

ul.radio > li::before { content: ""; -webkit-box-flex: 0; -ms-flex: 0 0 2em; flex: 0 0 2em; display: block; width: 3em; height: 2em; margin-right: 3em; border-radius: 100%; border: 2px solid #fcd11b; background-image: radial-gradient(#fcd11b 50%, transparent 50%, transparent 100%); background-position: center; background-repeat: no-repeat; background-size: 0 0; -webkit-transition: background-size .25s ease-in-out; transition: background-size .25s ease-in-out; }

ul.radio > li:hover::before, ul.radio > li:focus::before { background-size: 66% 66%; }

ul.radio > li.active::before { background-size: 200% 200%; }

ul.radio > li.active > ul { display: block; z-index: 10; }

ul.radio > li.active > ul > li { -webkit-transform: translateY(0); transform: translateY(0); opacity: 1; }

ul.radio > li > ul { position: absolute; display: block; width: 75%; top: 0; left: 100%; padding-left: 5rem; margin-left: 3rem; font-weight: 400; text-transform: none; z-index: 9; }

ul.radio > li > ul > li { display: -webkit-box; display: -ms-flexbox; display: flex; -webkit-box-align: start; -ms-flex-align: start; align-items: start; margin-bottom: 2rem; -webkit-transform: translateY(2rem); transform: translateY(2rem); opacity: 0; -webkit-transition: all .25s ease-in-out; transition: all .25s ease-in-out; }

ul.radio > li > ul > li::before { -webkit-box-flex: 0; -ms-flex: 0 0 2rem; flex: 0 0 2rem; display: block; margin-right: 1.65rem; content: ""; font-family: "scramble" !important; font-size: 2.25rem; font-weight: 400; line-height: 1; color: #fcd11b; speak: none; text-transform: none; margin-left: -4rem; }

ul.dot, ul.radio, ol.dot, ol.radio { opacity: 0; -webkit-transform: translateY(2rem); transform: translateY(2rem); -webkit-transition: all 0.35s ease-in-out; transition: all 0.35s ease-in-out; }

.scrolled-in .spoiler { font-size: 1em; opacity: 0 !important; line-height: 0; }

.scrolled-in .spoiler.more { opacity: 1 !important; font-size: 1em; line-height: 1.45; }

.scrolled-in .spoiler.more + .toggle::before { content: "less"; }

.scrolled-in .spoiler + .toggle { display: -webkit-box; display: -ms-flexbox; display: flex; -webkit-box-align: center; -ms-flex-align: center; align-items: center; cursor: pointer; color: #fcd11b; font-size: 2.5em; line-height: 0; padding: 1rem 0; }

.scrolled-in .spoiler + .toggle i { -webkit-transition: all 0.25s ease-in-out; transition: all 0.25s ease-in-out; margin-right: .2em; }

.scrolled-in .spoiler + .toggle:hover i { margin-right: .3em; }

.scrolled-in .spoiler + .toggle::before { display: inline-block; content: "more"; cursor: pointer; text-transform: uppercase; color: black; font-size: .4em; font-weight: 600; margin-right: .5em; }

.scrolled-in div.dot { -webkit-transform: scale(1); transform: scale(1); }

.scrolled-in ul.dot, .scrolled-in ol.dot { opacity: 1; -webkit-transform: translateY(0); transform: translateY(0); -webkit-transition: all 0.25s ease-in-out .04s; transition: all 0.25s ease-in-out .04s; }

.scrolled-in ul.dot li:before, .scrolled-in ul.dot li, .scrolled-in ol.dot li:before, .scrolled-in ol.dot li { -webkit-transform: scale(1); transform: scale(1); opacity: 1; }

.scrolled-in ul.radio, .scrolled-in ol.radio { opacity: 1; -webkit-transform: translateY(0); transform: translateY(0); -webkit-transition: all 0.25s ease-in-out .04s; transition: all 0.25s ease-in-out .04s; }

.scrolled-in ul.dot > li:hover::before { -webkit-transform: scale(1.2); transform: scale(1.2); -webkit-transition: all 0.25s ease-in-out; transition: all 0.25s ease-in-out; }

.scrolled-in span.tooltip { top: -6rem; left: 3rem; opacity: 1; -webkit-transform: scale(1); transform: scale(1); }

.scrolled-in span.tooltip.hide { top: 0; left: 0; opacity: 0; -webkit-transform: scale(0); transform: scale(0); }

@media (max-width: 479.8px) { ol.dot { -ms-flex-wrap: nowrap; flex-wrap: nowrap; overflow-x: scroll; }
  ol.dot li p { padding: 2em 0em 0 0em !important; }
  ol.dot li::after { padding: 33%; border: none; }
  ol.dot li.active::after { background-size: 200% 200%; }
  ul.radio { width: 100%; }
  ul.radio > li { -webkit-box-flex: 0; -ms-flex: 0 0 80%; flex: 0 0 80%; }
  ul.radio > li::before { margin-right: 1em; }
  ul.radio > li > ul { width: 100%; top: 120%; left: 0; padding-left: 0; margin-left: 0; }
  ul.radio > li > ul > li::before { content: none !important; } }

.btn-outline-circle { cursor: pointer; position: relative; width: 100%; height: 1rem; font-size: 1rem; font-weight: 600; line-height: 0; text-decoration: none; text-transform: uppercase; text-align: center; color: black; display: block; padding: calc(50%  - 2px) 0; margin-bottom: 1rem; border: 2px solid #fcd11b; border-radius: 100%; background-color: transparent; background-image: radial-gradient(#fcd11b 50%, transparent 50%, transparent 100%); background-position: center; background-repeat: no-repeat; background-size: 0 0; -webkit-transition: all .25s ease-in-out; transition: all .25s ease-in-out; -webkit-transform: scale(0) rotate(0deg); transform: scale(0) rotate(0deg); }

.btn-outline-circle::after { position: relative; display: inline-block; font-size: 1rem; color: black; -webkit-transform: rotate(-90deg); transform: rotate(-90deg); }

.btn-outline-circle:focus { outline: 0; }

.btn-outline-circle:hover, .btn-outline-circle.sending { border-color: #fcd11b; background-size: 200% 200%; color: black; height: 1rem; -webkit-transform: rotate(0deg); transform: rotate(0deg); }

.btn-outline-circle:hover.hover-caption, .btn-outline-circle.sending.hover-caption { font-size: 0; height: 1rem; }

.btn-outline-circle:hover.hover-caption::after, .btn-outline-circle.sending.hover-caption::after { content: attr(data-caption); }

.btn-outline-circle.sending.error { border-color: red; }

.btn-outline-image { cursor: pointer; position: relative; height: 1rem; max-width: 100%; font-family: sans-serif; font-size: 1rem; font-weight: 600; line-height: 0; text-decoration: none; text-transform: uppercase; text-align: center; color: black; background-color: #fcd11b; display: block; padding: calc(50% - 2px) 0; margin-bottom: 1rem; border: 2px solid #fcd11b; border-radius: 100%; -webkit-transform: scale(0) rotate(0deg); transform: scale(0) rotate(0deg); -webkit-transition: all 0.35s ease-in-out; transition: all 0.35s ease-in-out; }

.btn-outline-image.add span { position: absolute; display: block; top: -6rem; left: 50%; font-size: 1rem; text-transform: none; line-height: 1; padding: 1.5rem; opacity: 0; background-color: white; border-radius: 2rem; border: 1px solid black; white-space: nowrap; }

.btn-outline-image.add span::after, .btn-outline-image.add span::before { position: absolute; display: block; content: ""; border-color: transparent; border-style: solid; }

.btn-outline-image.add span::before { bottom: calc(-1.5rem - .2em); border-width: calc(1.5rem + .2em) calc(1rem + .2em) 0 0; border-top-color: black; }

.btn-outline-image.add span::after { bottom: calc(-1.5rem + .1em); left: calc(1.5rem + .13em); border-width: 1.5rem 1rem 0 0; border-top-color: #fff; }

.btn-outline-image.add::after { content: ""; font-family: "scramble" !important; font-weight: 400; position: relative; display: block; font-size: 1rem; padding: 1rem; margin: calc(50% + 1em) auto 0; border: 2px solid #fcd11b; border-radius: 100%; line-height: .9; height: 2em; width: 2em; text-align: center; color: black; background-color: #fcd11b; -webkit-transform: rotate(0deg); transform: rotate(0deg); }

.btn-outline-image.add:hover span { opacity: 1; }

.btn-outline-image.add:hover::after { -webkit-transform: rotate(405deg); transform: rotate(405deg); }

.btn-outline-image.coin { background-image: url(/assets/img/coin.png); background-size: 66%; background-position: center; background-repeat: no-repeat; }

.btn-outline-image.coin:hover { background-image: url(/assets/img/coin.png); -webkit-animation: bounce-bg 1s cubic-bezier(0.5, -0.5, 0.7, 1) infinite; animation: bounce-bg 1s cubic-bezier(0.5, -0.5, 0.7, 1) infinite; }

.btn-outline-image.coin:active, .btn-outline-image.coin:focus { background-image: url(/assets/img/coin.png); -webkit-animation: bounce-bg 1s cubic-bezier(0.5, -0.5, 0.7, 1) 1; animation: bounce-bg 1s cubic-bezier(0.5, -0.5, 0.7, 1) 1; }

.btn-outline-image.face-1 { background-image: url(/assets/img/face1.png); background-size: 75%; background-position: center; background-repeat: no-repeat; }

.btn-outline-image.face-1:hover { background-image: url(/assets/img/face1.png); }

.btn-outline-image.face-2 { background-image: url(/assets/img/face2.png); background-size: 75%; background-position: center; background-repeat: no-repeat; }

.btn-outline-image.face-2:hover { background-image: url(/assets/img/face2.png); }

.btn-outline-image.face-3 { background-image: url(/assets/img/face3.png); background-size: 75%; background-position: center; background-repeat: no-repeat; }

.btn-outline-image.face-3:hover { background-image: url(/assets/img/face3.png); }

.btn-outline-image.face-4 { background-image: url(/assets/img/face4.png); background-size: 75%; background-position: center; background-repeat: no-repeat; }

.btn-outline-image.face-4:hover { background-image: url(/assets/img/face4.png); }

.btn-outline-image.face-5 { background-image: url(/assets/img/face5.png); background-size: 75%; background-position: center; background-repeat: no-repeat; }

.btn-outline-image.face-5:hover { background-image: url(/assets/img/face5.png); }

.btn-outline-image.face-6 { background-image: url(/assets/img/face6.png); background-size: 75%; background-position: center; background-repeat: no-repeat; }

.btn-outline-image.face-6:hover { background-image: url(/assets/img/face6.png); }

.btn-outline-image.face-7 { background-image: url(/assets/img/face7.png); background-size: 75%; background-position: center; background-repeat: no-repeat; }

.btn-outline-image.face-7:hover { background-image: url(/assets/img/face7.png); }

.btn-add { position: relative; display: block; padding-bottom: 4em; padding-left: 2em; -webkit-transform: scale(0); transform: scale(0); -webkit-transition: all 0.35s ease-in-out; transition: all 0.35s ease-in-out; }

.btn-add::after { cursor: pointer; position: absolute; content: ""; font-family: "scramble" !important; font-weight: 400; font-size: 2rem; line-height: 1.5em; text-align: center; left: calc(50% - .75em); bottom: .5em; width: 1.5em; height: 1.5em; border-radius: 100%; border: 2px solid #fcd11b; color: black; background-color: #fcd11b; -webkit-transition: all 0.35s ease-in-out; transition: all 0.35s ease-in-out; }

.btn-add::after:hover { -webkit-transform: scale(1.2); transform: scale(1.2); }

.btn-add.visible::after { -webkit-transform: rotate(45deg); transform: rotate(45deg); }

.btn-add.visible:hover::after { -webkit-transform: rotate(45deg) scale(1.2); transform: rotate(45deg) scale(1.2); }

.btn-face { position: relative; -webkit-transform: scale(0); transform: scale(0); -webkit-transition: all 0.35s ease-in-out; transition: all 0.35s ease-in-out; }

.btn-face.playing .tooltip { opacity: 1; }

.btn-face.selected .add::after { -webkit-transform: rotate(45deg); transform: rotate(45deg); }

.btn-face.selected .add:hover::after { -webkit-transform: rotate(45deg) scale(1.2); transform: rotate(45deg) scale(1.2); }

.btn-face .bg { display: block; position: absolute; width: 0; height: 0; padding: 40%; margin: 10%; background-color: #f1f1f2; border-radius: 100%; background-position: center; background-repeat: no-repeat; background-size: 100%; }

.btn-face .bg.face-1 { background-image: url(/assets/img/face1.png); }

.btn-face .bg.face-2 { background-image: url(/assets/img/face2.png); }

.btn-face .bg.face-3 { background-image: url(/assets/img/face3.png); }

.btn-face .bg.face-4 { background-image: url(/assets/img/face4.png); }

.btn-face .bg.face-5 { background-image: url(/assets/img/face5.png); }

.btn-face .bg.face-6 { background-image: url(/assets/img/face6.png); }

.btn-face .bg.face-7 { background-image: url(/assets/img/face7.png); }

.btn-face video { position: relative; border-radius: 100%; width: 100%; height: 100%; opacity: 100%; border-radius: 100%; background-color: #fcd11b; -webkit-transform: scale(1); transform: scale(1); -webkit-transition: opacity 0.25s ease-in-out, -webkit-transform 0.25s ease-in-out .25s; transition: opacity 0.25s ease-in-out, -webkit-transform 0.25s ease-in-out .25s; transition: transform 0.25s ease-in-out .25s, opacity 0.25s ease-in-out; transition: transform 0.25s ease-in-out .25s, opacity 0.25s ease-in-out, -webkit-transform 0.25s ease-in-out .25s; }

.btn-face .add { padding-bottom: 5em; }

.btn-face .add::after { cursor: pointer; position: absolute; content: ""; font-family: "scramble" !important; font-weight: 400; font-size: 2rem; line-height: 1.5em; text-align: center; left: calc(50% - .75em); bottom: .5em; width: 1.5em; height: 1.5em; border-radius: 100%; background-color: #fcd11b; -webkit-transform: scale(1); transform: scale(1); -webkit-transition: all 0.35s ease-in-out; transition: all 0.35s ease-in-out; }

.btn-face .add:hover::after { -webkit-transform: scale(1.2); transform: scale(1.2); }

.btn-face .tooltip { opacity: 0; left: 50%; }

.btn-face, .btn-face:hover, .btn-add, .btn-add:hover, .btn-outline-circle, .btn-outline-circle:hover, .btn-outline-image, .btn-outline-image:hover { -webkit-transform: scale(0); transform: scale(0); }

.scrolled-in .btn-face, .scrolled-in .btn-face:hover, .scrolled-in .btn-add, .scrolled-in .btn-add:hover, .scrolled-in .btn-outline-circle, .scrolled-in .btn-outline-circle:hover, .scrolled-in .btn-outline-image, .scrolled-in .btn-outline-image:hover { -webkit-transform: scale(1); transform: scale(1); }

@media (max-width: 479.8px) { .btn-outline-circle { font-size: 1em; }
  .btn-face .add::after, .btn-add::after { font-size: 2em; } }

@-webkit-keyframes bounce-bg { 0% { background-position-y: 50%; }
  50% { background-position-y: 0%; }
  100% { background-position-y: 50%; } }

@keyframes bounce-bg { 0% { background-position-y: 50%; }
  50% { background-position-y: 0%; }
  100% { background-position-y: 50%; } }

input { display: block; width: 100%; padding: .5rem 0; border: none; border-radius: 0; border-bottom: 2px gray solid; background: transparent; }

input:focus, input:active, input:hover { outline: none; border: none; border-bottom: 2px #fcd11b solid; }

.d-none { display: none; }

@media (max-width: 479.8px) { .md-none { display: none !important; } }

body.loading { overflow: hidden; }

header .logo { width: 58rem; }

section#header { padding-top: 6rem; min-height: 70vh; }

section#header .slide { padding-right: 8rem; }

#about { padding-top: 30vh; min-height: 50vh; }

#about .slide { padding-right: 8rem; padding-top: 4rem; padding-bottom: 4rem; margin-top: 2rem; min-height: 30vh; }

#problem .slide .dot { margin: 1em 0; }

#problem .slide #fundrising-time { padding: 0; }

#problem .slide #fundrising-time > p { display: -webkit-box; display: -ms-flexbox; display: flex; -webkit-box-flex: 0; -ms-flex: 0 0 50%; flex: 0 0 50%; -webkit-box-align: start; -ms-flex-align: start; align-items: flex-start; margin-top: 1em; margin-bottom: 1em; }

#problem .slide #fundrising-time > p > span { font-size: 5em; font-weight: 400; line-height: 0.8; margin-bottom: 1rem; }

#problem .slide #fundrising-time > p > span + span { font-size: 2em; font-weight: 600; line-height: 1; }

#problem .slide #fundrising-time > p + p { margin-left: .75em; }

#problem .slide div.dot::after { position: absolute; content: "Click"; font-weight: 600; display: block; text-transform: uppercase; text-align: center; -webkit-transform: translate(-50%, -50%); transform: translate(-50%, -50%); opacity: 0; background-position: center; background-size: contain; background-repeat: no-repeat; -webkit-transition: all .25s ease-in-out; transition: all .25s ease-in-out; }

#problem .slide div.dot:hover, #problem .slide div.dot:focus { cursor: pointer; -webkit-transform: scale(1.05); transform: scale(1.05); }

#problem .slide div.dot:hover::after, #problem .slide div.dot:focus::after { opacity: 1; }

#problem .slide div.dot.clicked:hover, #problem .slide div.dot.clicked:focus { -webkit-transform: scale(1.05); transform: scale(1.05); }

#problem .slide div.dot.clicked:hover::after, #problem .slide div.dot.clicked:focus::after { position: absolute; display: block; }

#problem .slide div.dot.clicked::after { position: absolute; content: ""; display: block; width: 75%; height: 75%; text-transform: uppercase; text-align: center; -webkit-transform: translate(-50%, -50%); transform: translate(-50%, -50%); border-radius: 100%; background-image: url("/assets/img/coin.png"); background-position: center; background-size: contain; background-repeat: no-repeat; opacity: 1; -webkit-transition: all .25s ease-in-out; transition: all .25s ease-in-out; }

#problem .slide div.dot.clicked.coin { background-color: #fcd11b; }

#problem .slide div.dot.clicked.coin::after { background-image: url("/assets/img/coin.png"); }

#problem .slide div.dot.clicked.watch { background-color: #f1f1f2; border-color: #f1f1f2; }

#problem .slide div.dot.clicked.watch::after { background-image: url("/assets/img/watch.png"); }

#problem1 .slide { padding-top: 3rem; margin-top: 4rem; }

#problem1 .slide div > .dot { margin-bottom: 3rem; }

#problem1 .slide div > .dot:nth-of-type(1)::after { content: ""; position: absolute; display: block; height: 100%; width: 80%; background-image: url(/assets/img/coin_shadow_yellow.png), url(/assets/img/coin.png); background-position: center 105%, center top; background-repeat: no-repeat; background-size: 70%; -webkit-transform: translate(-50%, -50%); transform: translate(-50%, -50%); -webkit-transition: all .25s ease-in-out; transition: all .25s ease-in-out; opacity: 0; }

#problem1 .slide div > .dot:nth-of-type(2) { background-color: transparent; background-image: radial-gradient(#fcd11b 50%, transparent 50%, transparent 100%); background-position: center; background-repeat: no-repeat; background-size: 200% 200%; -webkit-transition: all .25s ease-in-out; transition: all .25s ease-in-out; }

#problem1 .slide div > .dot:nth-of-type(2)::after { position: absolute; content: "Now, it's easy"; font-weight: 600; display: block; text-transform: uppercase; text-align: center; -webkit-transform: translate(-50%, -50%); transform: translate(-50%, -50%); opacity: 0; -webkit-transition: all .25s ease-in-out; transition: all .25s ease-in-out; }

#problem1 .slide div > .tooltip { top: auto; left: auto; bottom: 45%; right: -50%; line-height: 1.47; border-radius: 3rem; padding: 0.75rem 1.75rem; }

#problem1 .slide div > .tooltip::before { left: 25%; }

#problem1 .slide div > .tooltip::after { left: calc(25% + 2px); }

#problem1 .slide div:hover > .dot:nth-of-type(1)::after { content: ""; position: absolute; display: block; height: 100%; width: 80%; background-image: url(/assets/img/coin_shadow_yellow.png), url(/assets/img/coin.png); background-position: center 105%, center top; background-repeat: no-repeat; background-size: 80%; -webkit-transform: translate(-50%, -60%); transform: translate(-50%, -60%); opacity: 1; }

#problem1 .slide div:hover > .dot:nth-of-type(2) { border: 2px solid #fcd11b; background-size: 0 0; }

#problem1 .slide div:hover > .dot:nth-of-type(2)::after { opacity: 1; }

#solution1 .slide #s1_faces.selected .btn-face:not(.selected) video { opacity: 0; -webkit-transform: scale(0.8); transform: scale(0.8); -webkit-transition: opacity 0.25s ease-in-out .25s, -webkit-transform 0.25s ease-in-out; transition: opacity 0.25s ease-in-out .25s, -webkit-transform 0.25s ease-in-out; transition: transform 0.25s ease-in-out, opacity 0.25s ease-in-out .25s; transition: transform 0.25s ease-in-out, opacity 0.25s ease-in-out .25s, -webkit-transform 0.25s ease-in-out; }

#solution3 .slide .s3_targets { position: absolute; opacity: 0; -webkit-transition: all 0.35s ease-in-out; transition: all 0.35s ease-in-out; -webkit-transform: translateY(2rem); transform: translateY(2rem); }

#solution3 .slide .s3_targets.active { opacity: 1; -webkit-transform: translateY(0); transform: translateY(0); -webkit-transition: all 0.35s ease-in-out .25s; transition: all 0.35s ease-in-out .25s; }

#solution3 .slide [id^='s3-arrow'] { position: absolute; }

#solution3 .slide [id^='s3-arrow'].left { margin-left: 7rem; margin-top: 3.5rem; }

#solution3 .slide [id^='s3-arrow'].right { margin-right: 7rem; margin-top: 3.5rem; }

#solution3 .slide svg, #solution3 .slide video { -webkit-transition: all 0.25s ease-in-out; transition: all 0.25s ease-in-out; }

#solution3 .slide .btn-face .bg { margin: 0; padding: 50%; background-size: 100%; -webkit-transition: all 0.25s ease-in-out; transition: all 0.25s ease-in-out; }

#solution3 .slide .success .btn-face .bg { background-color: #f1f1f2; border-color: #f1f1f2; }

#solution3 .slide .success .btn-face .bg.face-1 { background-color: #fcd11b; border-color: #fcd11b; }

#solution3 .slide .success .btn-face .bg.face-1 + video { opacity: 1; }

#solution3 .slide .success .btn-face video { opacity: 0; }

#solution3 .slide .failure .btn-face .bg { background-color: #fcd11b; border-color: #fcd11b; }

#solution3 .slide .failure .btn-face .bg.face-1 { background-color: #f1f1f2; border-color: #f1f1f2; }

#solution3 .slide .failure .btn-face .bg.face-1 + video { opacity: 0; }

#solution3 .slide .failure .btn-face video { opacity: 1; }

#features .slide ul.dot { padding-left: 4rem; padding-right: 7rem; }

#features .slide ul.dot li { padding-top: 2.5rem; padding-left: 5rem; padding-right: 5rem; }

#features .slide ul.dot li p { margin-bottom: 0; }

#contact .slide p.lead { margin: 0.7rem 3rem 1em 3rem; }

.row:hover .btn-outline-image.add { background-color: #f1f1f2; border-color: #f1f1f2; max-width: 80%; margin: 10% 10% calc(10% + 1rem); padding: 40% 0; }

.row:hover .btn-outline-image.add:hover { max-width: 100%; margin: 0; padding: calc(50% - 2px) 0; background-color: #fcd11b; border-color: #fcd11b; margin-bottom: 1rem; }

.row:hover .btn-outline-image.add:hover::after { margin: calc(50% + 1em) auto 0; }

.row:hover .btn-outline-image.add::after { margin: calc(50% + 1em + 1rem) auto 0; }

@media (max-width: 479.8px) { #about .slide { height: auto; }
  #problem .slide { height: auto; }
  #problem .slide #fundrising-time { display: -webkit-box; display: -ms-flexbox; display: flex; margin-top: 8rem; }
  #problem .slide #fundrising-time > p { display: -webkit-box; display: -ms-flexbox; display: flex; -webkit-box-flex: 0; -ms-flex: 0 0 50%; flex: 0 0 50%; -webkit-box-align: start; -ms-flex-align: start; align-items: flex-start; margin-top: 1em; margin-bottom: 1em; }
  #problem .slide #fundrising-time > p > span { font-size: 3em; font-weight: 400; line-height: 0.8; }
  #problem .slide #fundrising-time > p > span + span { font-size: 2em; font-weight: 600; line-height: 1; }
  #problem .slide #fundrising-time > p + p { margin-left: 0; margin-top: .5em; }
  #solution .slide .btn-outline-circle { font-size: 2em; }
  #solution .slide .info { text-align: center; -ms-flex-line-pack: stretch; align-content: stretch; -ms-flex-item-align: center; align-self: center; }
  #solution .slide .controls { display: -webkit-box; display: -ms-flexbox; display: flex; }
  #features .slide ul.dot { padding-left: 0; padding-right: 0; margin-left: -1em; margin-right: -1em; margin-top: 1em; }
  #features .slide ul.dot li { padding-top: .25em; padding-left: 1em; padding-right: 1em; margin-bottom: 1.5em; }
  #features .slide ul.dot li::before { margin: 0; }
  #contact .slide p.lead { margin: 0 0 1em 0; } }