diff --git a/package.json b/package.json index 757aaa0..0024a9f 100644 --- a/package.json +++ b/package.json @@ -2,9 +2,9 @@ "name": "video-chat2", "version": "1.0.0", "description": "", - "main": "index.js", + "main": "server.js", "scripts": { - "start": "node index.js", + "start": "node server.js", "test": "echo \"Error: no test specified\" && exit 1" }, "author": "", diff --git a/public/chat.html b/public/chat.html index a7032c0..752c45c 100644 --- a/public/chat.html +++ b/public/chat.html @@ -40,7 +40,6 @@ color: red; } - @@ -60,6 +59,6 @@ - + \ No newline at end of file diff --git a/public/app.js b/public/chat.js similarity index 100% rename from public/app.js rename to public/chat.js diff --git a/public/landing.html b/public/landing.html deleted file mode 100644 index 1cb9d98..0000000 --- a/public/landing.html +++ /dev/null @@ -1,13 +0,0 @@ - - - - - Landing - - -

Welcome to videochat

-

Click the button to get a disposable video chat room

-Link - - - \ No newline at end of file diff --git a/public/landing/css/style.css b/public/landing/css/style.css new file mode 100755 index 0000000..43b3c90 --- /dev/null +++ b/public/landing/css/style.css @@ -0,0 +1,3228 @@ +@import url("https://fonts.googleapis.com/css?family=Fira+Sans:600|Heebo:400,500,700&display=swap"); + +html { + line-height: 1.15; + -ms-text-size-adjust: 100%; + -webkit-text-size-adjust: 100% +} + +body { + margin: 0 +} + +article, aside, footer, header, nav, section { + display: block +} + +h1 { + font-size: 2em; + margin: 0.67em 0 +} + +figcaption, figure, main { + display: block +} + +figure { + margin: 1em 40px +} + +hr { + box-sizing: content-box; + height: 0; + overflow: visible +} + +pre { + font-family: monospace, monospace; + font-size: 1em +} + +a { + background-color: transparent; + -webkit-text-decoration-skip: objects +} + +abbr[title] { + border-bottom: none; + text-decoration: underline; + -webkit-text-decoration: underline dotted; + text-decoration: underline dotted +} + +b, strong { + font-weight: inherit +} + +b, strong { + font-weight: bolder +} + +code, kbd, samp { + font-family: monospace, monospace; + font-size: 1em +} + +dfn { + font-style: italic +} + +mark { + background-color: #ff0; + color: #000 +} + +small { + font-size: 80% +} + +sub, sup { + font-size: 75%; + line-height: 0; + position: relative; + vertical-align: baseline +} + +sub { + bottom: -0.25em +} + +sup { + top: -0.5em +} + +audio, video { + display: inline-block +} + +audio:not([controls]) { + display: none; + height: 0 +} + +img { + border-style: none +} + +svg:not(:root) { + overflow: hidden +} + +button, input, optgroup, select, textarea { + font-family: sans-serif; + font-size: 100%; + line-height: 1.15; + margin: 0 +} + +button, input { + overflow: visible +} + +button, select { + text-transform: none +} + +button, html [type="button"], [type="reset"], [type="submit"] { + -webkit-appearance: button +} + +button::-moz-focus-inner, [type="button"]::-moz-focus-inner, [type="reset"]::-moz-focus-inner, [type="submit"]::-moz-focus-inner { + border-style: none; + padding: 0 +} + +button:-moz-focusring, [type="button"]:-moz-focusring, [type="reset"]:-moz-focusring, [type="submit"]:-moz-focusring { + outline: 1px dotted ButtonText +} + +fieldset { + padding: 0.35em 0.75em 0.625em +} + +legend { + box-sizing: border-box; + color: inherit; + display: table; + max-width: 100%; + padding: 0; + white-space: normal +} + +progress { + display: inline-block; + vertical-align: baseline +} + +textarea { + overflow: auto +} + +[type="checkbox"], [type="radio"] { + box-sizing: border-box; + padding: 0 +} + +[type="number"]::-webkit-inner-spin-button, [type="number"]::-webkit-outer-spin-button { + height: auto +} + +[type="search"] { + -webkit-appearance: textfield; + outline-offset: -2px +} + +[type="search"]::-webkit-search-cancel-button, [type="search"]::-webkit-search-decoration { + -webkit-appearance: none +} + +::-webkit-file-upload-button { + -webkit-appearance: button; + font: inherit +} + +details, menu { + display: block +} + +summary { + display: list-item +} + +canvas { + display: inline-block +} + +template { + display: none +} + +[hidden] { + display: none +} + +@media (min-width: 641px) { + .has-animations [class*=reveal-] { + opacity: 0; + will-change: opacity, transform + } + + .has-animations .reveal-from-top { + transform: translateY(-10px) + } + + .has-animations .reveal-from-bottom { + transform: translateY(10px) + } + + .has-animations .reveal-from-left { + transform: translateX(-10px) + } + + .has-animations .reveal-from-right { + transform: translateX(10px) + } + + .has-animations .reveal-scale-up { + transform: scale(.95) + } + + .has-animations .reveal-scale-down { + transform: scale(1.05) + } + + .has-animations .reveal-rotate-from-left { + transform: perspective(1000px) rotateY(-45deg) + } + + .has-animations .reveal-rotate-from-right { + transform: perspective(1000px) rotateY(45deg) + } + + .has-animations.is-loaded [class*=reveal-] { + transition: opacity 1s cubic-bezier(0.39, 0.575, 0.565, 1), transform 1s cubic-bezier(0.39, 0.575, 0.565, 1) + } + + .has-animations.is-loaded [class*=reveal-].is-revealed { + opacity: 1; + transform: translate(0) + } +} + +html { + box-sizing: border-box +} + +*, *:before, *:after { + box-sizing: inherit +} + +body { + background: #16171B; + -moz-osx-font-smoothing: grayscale; + -webkit-font-smoothing: antialiased +} + +hr { + border: 0; + display: block; + height: 1px; + background: #292B32; + margin-top: 24px; + margin-bottom: 24px +} + +ul, ol { + margin-top: 0; + padding-left: 24px +} + +ul:not(:last-child), ol:not(:last-child) { + margin-bottom: 24px +} + +ul { + list-style: disc +} + +ol { + list-style: decimal +} + +li:not(:last-child) { + margin-bottom: 12px +} + +li > ul, li > ol { + margin-top: 12px; + margin-bottom: 0 +} + +dl { + margin-top: 0; + margin-bottom: 24px +} + +dt { + font-weight: 700 +} + +dd { + margin-left: 24px; + margin-bottom: 24px +} + +img { + border-radius: 2px +} + +img, svg, video { + display: block; + height: auto; + max-width: 100% +} + +figure { + margin: 48px 0 +} + +figcaption { + padding: 8px 0 +} + +table { + font-size: 16px; + line-height: 24px; + letter-spacing: -0.1px; + border-collapse: collapse; + margin-bottom: 24px; + width: 100% +} + +tr { + border-bottom: 1px solid #292B32 +} + +th { + font-weight: 700; + text-align: left +} + +th, td { + padding: 8px 16px +} + +th:first-child, td:first-child { + padding-left: 0 +} + +th:last-child, td:last-child { + padding-right: 0 +} + +.invert-color hr { + display: block; + height: 1px; + background: #e5e9ff +} + +.invert-color tr { + border-bottom: 1px solid #e5e9ff +} + +html { + font-size: 20px; + line-height: 32px; + letter-spacing: -0.1px +} + +body { + color: #959CB1; + font-size: 1rem +} + +body, button, input, select, textarea { + font-family: "Heebo", sans-serif; + font-weight: 400 +} + +h1, h2, h3, h4, h5, h6, .h1, .h2, .h3, .h4, .h5, .h6 { + font-family: "Fira Sans", sans-serif; + font-weight: 600; + clear: both; + color: #F9FAFF; + word-wrap: break-word; + overflow-wrap: break-word +} + +h1, .h1 { + font-size: 38px; + line-height: 48px +} + +h2, .h2 { + font-size: 32px; + line-height: 42px +} + +h3, .h3 { + font-size: 24px; + line-height: 34px; + letter-spacing: -0.1px +} + +h4, .h4 { + font-size: 24px; + line-height: 34px; + letter-spacing: -0.1px +} + +h5, .h5 { + font-size: 20px; + line-height: 32px; + letter-spacing: -0.1px +} + +h6, .h6, small, .text-sm { + font-size: 18px; + line-height: 30px; + letter-spacing: -0.1px +} + +.text-xs { + font-size: 16px; + line-height: 24px; + letter-spacing: -0.1px +} + +.text-xxs { + font-size: 14px; + line-height: 22px +} + +figcaption { + font-size: 14px; + line-height: 22px +} + +a:not(.button) { + color: inherit +} + +a:not(.button):hover, a:not(.button):active { + color: #F9FAFF; + outline: 0 +} + +a.button-link { + color: #6A6F82 +} + +a.button-link:hover, a.button-link:active { + color: #959CB1 +} + +a.func-link { + color: #376DF9 +} + +a.func-link:hover, a.func-link:active { + color: #6991FA +} + +h1, .h1 { + margin-top: 48px; + margin-bottom: 32px +} + +h2, .h2 { + margin-top: 48px; + margin-bottom: 32px +} + +h3, .h3 { + margin-top: 36px; + margin-bottom: 24px +} + +h4, h5, h6, .h4, .h5, .h6 { + margin-top: 24px; + margin-bottom: 24px +} + +p { + margin-top: 0; + margin-bottom: 24px +} + +dfn, cite, em, i { + font-style: italic +} + +blockquote { + font-size: 20px; + line-height: 32px; + letter-spacing: -0.1px; + margin-top: 24px; + margin-bottom: 24px; + margin-left: 24px +} + +blockquote::before { + content: "\201C" +} + +blockquote::after { + content: "\201D" +} + +blockquote p { + display: inline +} + +address { + border-width: 1px 0; + border-style: solid; + border-color: #292B32; + padding: 24px 0; + margin: 0 0 24px +} + +pre, pre h1, pre h2, pre h3, pre h4, pre h5, pre h6, pre .h1, pre .h2, pre .h3, pre .h4, pre .h5, pre .h6 { + font-family: "Courier 10 Pitch", Courier, monospace +} + +pre, code, kbd, tt, var { + background: #0d0d10 +} + +pre { + font-size: 16px; + line-height: 24px; + letter-spacing: -0.1px; + max-width: 100%; + overflow: auto; + padding: 24px 24px; + margin-top: 24px; + margin-bottom: 24px +} + +code, kbd, tt, var { + font-family: Monaco, Consolas, "Andale Mono", "DejaVu Sans Mono", monospace; + font-size: 16px; + line-height: 24px; + letter-spacing: -0.1px; + padding: 2px 4px +} + +abbr, acronym { + cursor: help +} + +mark, ins { + text-decoration: none +} + +b, strong { + font-weight: 700 +} + +.invert-color { + color: #6A6F82 +} + +.invert-color a:not(.button):hover, .invert-color a:not(.button):active { + color: #1C1D22; + outline: 0 +} + +.invert-color a.button-link:hover, .invert-color a.button-link:active { + color: #376DF9 +} + +.invert-color a.func-link:hover, .invert-color a.func-link:active { + color: #6991FA +} + +.invert-color h1, .invert-color h2, .invert-color h3, .invert-color h4, .invert-color h5, .invert-color h6, .invert-color .h1, .invert-color .h2, .invert-color .h3, .invert-color .h4, .invert-color .h5, .invert-color .h6 { + color: #16171B +} + +.invert-color address { + border-color: #e5e9ff +} + +.invert-color pre, .invert-color code, .invert-color kbd, .invert-color tt, .invert-color var { + background: #0d0d10 +} + +@media (max-width: 640px) { + .h1-mobile { + font-size: 38px; + line-height: 48px + } + + .h2-mobile { + font-size: 32px; + line-height: 42px + } + + .h3-mobile { + font-size: 24px; + line-height: 34px; + letter-spacing: -0.1px + } + + .h4-mobile { + font-size: 24px; + line-height: 34px; + letter-spacing: -0.1px + } + + .h5-mobile { + font-size: 20px; + line-height: 32px; + letter-spacing: -0.1px + } + + .h6-mobile { + font-size: 18px; + line-height: 30px; + letter-spacing: -0.1px + } +} + +@media (min-width: 641px) { + h1, .h1 { + font-size: 44px; + line-height: 54px + } + + h2, .h2 { + font-size: 38px; + line-height: 48px + } + + h3, .h3 { + font-size: 32px; + line-height: 42px + } +} + +.container, .container-sm, .container-xs { + width: 100%; + margin: 0 auto; + padding-left: 16px; + padding-right: 16px +} + +@media (min-width: 481px) { + .container, .container-sm, .container-xs { + padding-left: 24px; + padding-right: 24px + } +} + +.container { + max-width: 1128px +} + +.container-sm { + max-width: 944px +} + +.container-xs { + max-width: 668px +} + +[class*=container] [class*=container] { + padding-left: 0; + padding-right: 0 +} + +[class*=container] .container-sm { + max-width: 896px +} + +[class*=container] .container-xs { + max-width: 620px +} + +.button { + display: inline-flex; + font-size: 14px; + line-height: 22px; + font-weight: 700; + padding: 12px 31px; + height: 48px; + text-decoration: none !important; + text-transform: uppercase; + color: #6A6F82; + background-color: #F9FAFF; + border-width: 1px; + border-style: solid; + border-color: rgba(0, 0, 0, 0); + border-radius: 2px; + cursor: pointer; + justify-content: center; + text-align: center; + letter-spacing: inherit; + white-space: nowrap; + transition: background .15s ease +} + +.button:active { + outline: 0 +} + +.button:hover { + background-color: #fff +} + +.button.is-loading { + position: relative; + color: transparent !important; + pointer-events: none +} + +.button.is-loading::after { + content: ''; + display: block; + position: absolute; + width: 22px; + height: 22px; + margin-left: -11px; + margin-top: -11px; + top: 50%; + left: 50%; + border: 2px solid #6A6F82; + border-radius: 50%; + border-right-color: transparent !important; + border-top-color: transparent !important; + z-index: 1; + -webkit-animation: button-loading .6s infinite linear; + animation: button-loading .6s infinite linear +} + +.button[disabled] { + cursor: not-allowed; + color: #16171B; + background-color: #292B32 !important +} + +.button[disabled].is-loading::after { + border-color: #16171B +} + +.button-sm { + padding: 6px 23px; + height: 36px +} + +.button-dark { + color: #F9FAFF; + background-color: #292B32 +} + +.button-dark:hover { + background-color: #30323a +} + +.button-dark.is-loading::after { + border-color: #F9FAFF +} + +.button-primary { + color: #F9FAFF; + background-color: #376DF9 +} + +.button-primary:hover { + background-color: #4678f9 +} + +.button-primary.is-loading::after { + border-color: #F9FAFF +} + +.button-secondary { + color: #F9FAFF; + background-color: #FF5FA0 +} + +.button-secondary:hover { + background-color: #ff6ea9 +} + +.button-secondary.is-loading::after { + border-color: #F9FAFF +} + +.button-block { + display: flex; + width: 100% +} + +.button-group { + display: flex; + flex-wrap: wrap; + align-items: center; + margin-right: -8px; + margin-left: -8px; + margin-top: -8px +} + +.button-group:last-of-type { + margin-bottom: -8px +} + +.button-group:not(:last-of-type) { + margin-bottom: 8px +} + +.button-group > [class*=button] { + margin: 8px +} + +@media (max-width: 640px) { + .button-wide-mobile { + width: 100%; + max-width: 280px + } +} + +@-webkit-keyframes button-loading { + 0% { + transform: rotate(0) + } + 100% { + transform: rotate(360deg) + } +} + +@keyframes button-loading { + 0% { + transform: rotate(0) + } + 100% { + transform: rotate(360deg) + } +} + +fieldset { + padding: 0; + margin: 0; + border: 0 +} + +.form-label, .form-switch { + color: #6A6F82; + font-weight: 500 +} + +.form-label { + font-size: 14px; + line-height: 22px +} + +.form-input, .form-select, .form-checkbox input, .form-radio input { + -moz-appearance: none; + -webkit-appearance: none; + background-color: #F9FAFF; + border-width: 1px; + border-style: solid; + border-color: #16171B +} + +.form-input:hover, .form-select:hover, .form-checkbox input:hover, .form-radio input:hover { + border-color: #6A6F82 +} + +.form-input:active, .form-input:focus, .form-select:active, .form-select:focus, .form-checkbox input:active, .form-checkbox input:focus, .form-radio input:active, .form-radio input:focus { + outline: none; + border-color: #376DF9 +} + +.form-input[disabled], .form-select[disabled], .form-checkbox input[disabled], .form-radio input[disabled] { + cursor: not-allowed; + background-color: #292B32; + border-color: #1C1D22 +} + +.form-input.form-error, .form-select.form-error, .form-checkbox input.form-error, .form-radio input.form-error { + border-color: #FF5FA0 +} + +.form-input.form-warning, .form-select.form-warning, .form-checkbox input.form-warning, .form-radio input.form-warning { + border-color: #FFC55A +} + +.form-input.form-success, .form-select.form-success, .form-checkbox input.form-success, .form-radio input.form-success { + border-color: #1EC198 +} + +.form-input, .form-select { + display: block; + font-size: 16px; + line-height: 24px; + letter-spacing: -0.1px; + padding: 11px 15px; + height: 48px; + border-radius: 0; + color: #16171B; + box-shadow: none; + max-width: 100%; + width: 100% +} + +.form-input::-webkit-input-placeholder { + color: #959CB1 +} + +.form-input::-moz-placeholder { + color: #959CB1 +} + +.form-input:-ms-input-placeholder { + color: #959CB1 +} + +.form-input::-ms-input-placeholder { + color: #959CB1 +} + +.form-input::placeholder { + color: #959CB1 +} + +.form-input::-ms-input-placeholder { + color: #959CB1 +} + +textarea.form-input { + height: auto; + resize: vertical +} + +.form-select { + padding-right: 46px; + background-image: url("data:image/svg+xml;charset=US-ASCII,%3Csvg%20viewBox%3D%220%200%2016%2016%22%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%3E%3Cpath%20d%3D%22M8%2011.4L2.6%206%204%204.6l4%204%204-4L13.4%206%208%2011.4z%22%20fill%3D%22%23F9FAFF%22%20fill-rule%3D%22evenodd%22%2F%3E%3C%2Fsvg%3E"); + background-position: right 15px center; + background-repeat: no-repeat; + background-size: 16px 16px +} + +.form-select-sm { + padding-right: 38px; + background-position: right 11px center +} + +.form-select-sm, .form-input-sm { + padding: 5px 11px; + height: 36px +} + +.has-icon-left, .has-icon-right { + position: relative +} + +.has-icon-left svg, .has-icon-right svg { + pointer-events: none; + position: absolute; + top: 50%; + transform: translateY(-50%) +} + +.has-icon-left .form-input { + padding-left: 46px +} + +.has-icon-left .form-input + svg { + left: 15px +} + +.has-icon-left .form-input-sm { + padding-left: 38px +} + +.has-icon-left .form-input-sm + svg { + left: 11px +} + +.has-icon-right .form-input { + padding-right: 46px +} + +.has-icon-right .form-input + svg { + right: 15px +} + +.has-icon-right .form-input-sm { + padding-right: 38px +} + +.has-icon-right .form-input-sm + svg { + right: 11px +} + +.form-checkbox, .form-radio, .form-switch { + font-size: 16px; + line-height: 24px; + letter-spacing: -0.1px; + cursor: pointer +} + +.form-checkbox, .form-radio { + color: #959CB1 +} + +.form-checkbox, .form-radio { + position: relative; + padding-left: 24px +} + +.form-checkbox input, .form-radio input { + position: absolute; + left: 0; + top: 3px; + width: 16px; + height: 16px; + cursor: pointer +} + +.form-checkbox input:checked, .form-radio input:checked { + background-color: #376DF9 !important; + border-color: #376DF9 !important; + background-position: 50% +} + +.form-checkbox input { + border-radius: 2px +} + +.form-checkbox input:checked { + background-image: url(data:image/svg+xml;base64,PHN2ZyB3aWR0aD0iMTQiIGhlaWdodD0iMTQiIHhtbG5zPSJodHRwOi8vd3d3LnczLm9yZy8yMDAwL3N2ZyI+IDxwYXRoIGQ9Ik0xMS40IDVMMTAgMy42bC00IDQtMi0yTDIuNiA3IDYgMTAuNHoiIGZpbGw9IiNGRkYiIGZpbGwtcnVsZT0iZXZlbm9kZCIvPjwvc3ZnPg==) +} + +.form-radio input { + border-radius: 50% +} + +.form-radio input:checked { + background-image: url(data:image/svg+xml;base64,PHN2ZyB3aWR0aD0iMTQiIGhlaWdodD0iMTQiIHhtbG5zPSJodHRwOi8vd3d3LnczLm9yZy8yMDAwL3N2ZyI+PGNpcmNsZSBmaWxsPSIjRkZGIiBjeD0iNyIgY3k9IjciIHI9IjMiIGZpbGwtcnVsZT0iZXZlbm9kZCIvPjwvc3ZnPg==) +} + +.form-switch { + display: inline-flex; + align-items: center; + -webkit-user-select: none; + -moz-user-select: none; + -ms-user-select: none; + user-select: none +} + +.form-switch input { + clip: rect(0, 0, 0, 0); + height: 1px; + margin: -1px; + overflow: hidden; + position: absolute; + width: 1px +} + +.form-switch .form-switch-icon { + display: block; + position: relative; + min-width: 60px; + width: 60px; + height: 32px; + border-radius: 16px; + background: #292B32 +} + +.form-switch .form-switch-icon::before { + content: ''; + display: block; + position: absolute; + top: 2px; + left: 2px; + width: 28px; + height: 28px; + border-radius: 14px; + background: #F9FAFF; + transition: all .15s ease-out +} + +.form-switch input:checked + .form-switch-icon { + background: #376DF9 +} + +.form-switch input:checked + .form-switch-icon::before { + left: 30px +} + +.form-switch > span:not(.form-switch-icon) { + order: -1; + margin-right: 12px +} + +.form-switch > span:not(.form-switch-icon):last-child { + order: initial; + margin-left: 12px; + margin-right: 0 +} + +.invert-color .form-label, .invert-color .form-switch { + color: #292B32 +} + +.invert-color .form-input, .invert-color .form-select, .invert-color .form-checkbox input, .invert-color .form-radio input { + border-color: #e5e9ff +} + +.invert-color .form-input:active, .invert-color .form-input:focus, .invert-color .form-select:active, .invert-color .form-select:focus, .invert-color .form-checkbox input:active, .invert-color .form-checkbox input:focus, .invert-color .form-radio input:active, .invert-color .form-radio input:focus { + border-color: #376DF9 +} + +.invert-color .form-input[disabled], .invert-color .form-select[disabled], .invert-color .form-checkbox input[disabled], .invert-color .form-radio input[disabled] { + background-color: #e5e9ff +} + +.invert-color .form-input, .invert-color .form-select { + color: #292B32 +} + +.invert-color .form-select { + background-image: url("data:image/svg+xml;charset=US-ASCII,%3Csvg%20viewBox%3D%220%200%2016%2016%22%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%3E%3Cpath%20d%3D%22M8%2011.4L2.6%206%204%204.6l4%204%204-4L13.4%206%208%2011.4z%22%20fill%3D%22%23292B32%22%20fill-rule%3D%22evenodd%22%2F%3E%3C%2Fsvg%3E") +} + +.invert-color .form-checkbox, .invert-color .form-radio { + color: #292B32 +} + +.invert-color .form-checkbox input:checked, .invert-color .form-radio input:checked { + background-color: !important; + border-color: !important +} + +.form-group { + display: flex +} + +.form-group .form-input { + flex-grow: 1; + flex-shrink: 1; + margin-right: 12px +} + +.form-group .button { + padding-left: 24px; + padding-right: 24px; + flex-shrink: 0 +} + +.form-hint { + font-size: 14px; + line-height: 22px; + margin-top: 8px +} + +@media (max-width: 640px) { + .form-group-desktop .form-input { + margin-bottom: 12px + } + + .form-group-desktop .button { + width: 100% + } +} + +@media (min-width: 641px) { + .form-group-desktop { + display: flex + } + + .form-group-desktop .form-input { + flex-grow: 1; + flex-shrink: 1; + margin-right: 12px + } + + .form-group-desktop .button { + padding-left: 24px; + padding-right: 24px; + flex-shrink: 0 + } +} + +.header-nav-toggle { + background: transparent; + border: 0; + outline: 0; + padding: 0; + cursor: pointer +} + +.hamburger, .hamburger-inner { + display: block; + pointer-events: none +} + +.hamburger { + position: relative; + width: 24px; + height: 24px +} + +.hamburger-inner, .hamburger-inner::before, .hamburger-inner::after { + width: 24px; + height: 2px; + position: absolute; + background: #959CB1 +} + +.invert-color .hamburger-inner, .invert-color .hamburger-inner::before, .invert-color .hamburger-inner::after { + background: #1C1D22 +} + +.hamburger-inner { + top: 50%; + margin-top: -1px; + transition-duration: 0.22s; + transition-timing-function: cubic-bezier(0.55, 0.055, 0.675, 0.19) +} + +.hamburger-inner::before, .hamburger-inner::after { + content: ''; + display: block +} + +.hamburger-inner::before { + top: -7px; + transition: top 0.1s 0.25s ease-in, opacity 0.1s ease-in +} + +.hamburger-inner::after { + bottom: -7px; + transition: bottom 0.1s 0.25s ease-in, transform 0.22s cubic-bezier(0.55, 0.055, 0.675, 0.19), width 0.1s 0.25s ease-in +} + +.off-nav-is-active .hamburger-inner { + transform: rotate(225deg); + transition-delay: 0.12s; + transition-timing-function: cubic-bezier(0.215, 0.61, 0.355, 1) +} + +.off-nav-is-active .hamburger-inner::before { + top: 0; + opacity: 0; + transition: top 0.1s ease-out, opacity 0.1s 0.12s ease-out +} + +.off-nav-is-active .hamburger-inner::after { + width: 24px; + bottom: 0; + transform: rotate(-90deg); + transition: bottom 0.1s ease-out, transform 0.22s 0.12s cubic-bezier(0.215, 0.61, 0.355, 1), width 0.1s ease-out +} + +.accordion li { + position: relative +} + +.accordion li::before { + content: ''; + position: absolute; + top: 0; + left: 0; + width: 100%; + display: block; + height: 1px; + background: #292B32 +} + +.accordion li:last-of-type { + position: relative +} + +.accordion li:last-of-type::after { + content: ''; + position: absolute; + bottom: 0; + left: 0; + width: 100%; + display: block; + height: 1px; + background: #292B32 +} + +.invert-color .accordion li { + position: relative +} + +.invert-color .accordion li::before { + content: ''; + position: absolute; + top: 0; + left: 0; + width: 100%; + display: block; + height: 1px; + background: #e5e9ff +} + +.invert-color .accordion li:last-of-type { + position: relative +} + +.invert-color .accordion li:last-of-type::after { + content: ''; + position: absolute; + bottom: 0; + left: 0; + width: 100%; + display: block; + height: 1px; + background: #e5e9ff +} + +.accordion-header { + display: flex; + justify-content: space-between; + align-items: center; + padding-top: 24px; + padding-bottom: 24px; + cursor: pointer +} + +.accordion-header span { + width: calc(100% - (16px * 2)) +} + +.accordion-content { + max-height: 0; + opacity: 0; + overflow: hidden; + transition: max-height .15s ease-in-out, opacity .15s +} + +.is-active .accordion-content { + opacity: 1 +} + +.accordion-content p:last-child { + margin-bottom: 24px +} + +.accordion-icon { + position: relative; + width: 16px; + height: 16px +} + +.accordion-icon::before, .accordion-icon::after { + content: ''; + position: absolute; + background: #376DF9; + transition: transform .25s ease-out +} + +.accordion-icon::before { + top: 0; + left: 50%; + width: 2px; + height: 100%; + margin-left: -1px +} + +.accordion-icon::after { + top: 50%; + left: 0; + width: 100%; + height: 2px; + margin-top: -1px +} + +.is-active .accordion-icon { + cursor: pointer +} + +.is-active .accordion-icon::before { + transform: rotate(90deg) +} + +.is-active .accordion-icon::after { + transform: rotate(180deg) +} + +.modal, .modal::before { + bottom: 0; + left: 0; + right: 0; + top: 0 +} + +.modal { + display: none; + align-items: center; + flex-direction: column; + justify-content: center; + overflow: hidden; + position: fixed; + z-index: 40 +} + +.modal.modal-video .modal-inner { + padding: 0; + max-width: 1024px +} + +.modal::before, .modal .modal-inner { + display: none +} + +.modal::before { + content: ''; + position: absolute; + background-color: rgba(22, 23, 27, 0.88) +} + +.modal.is-active { + display: flex +} + +.modal.is-active::before, .modal.is-active .modal-inner { + display: block +} + +.modal.is-active .modal-inner { + -webkit-animation: slideUpInModal .15s ease-in-out both; + animation: slideUpInModal .15s ease-in-out both +} + +.modal.is-active::before { + -webkit-animation: slideUpInModalBg .15s ease-in-out both; + animation: slideUpInModalBg .15s ease-in-out both +} + +.modal-inner { + max-height: calc(100vh - 16px * 2); + overflow: auto; + position: relative; + width: calc(100% - (16px * 2)); + max-width: 480px; + margin-left: 16px; + margin-right: 16px; + background: #292B32 +} + +.modal-content { + padding: 48px 16px +} + +.modal-close { + background: transparent; + border: 0; + outline: 0; + padding: 0; + cursor: pointer; + position: absolute; + right: 24px; + top: 24px; + width: 16px; + height: 16px +} + +.modal-close::before, .modal-close::after { + content: ''; + display: block; + position: absolute; + top: 50%; + left: 50%; + margin-top: -1px; + margin-left: -8px; + width: 16px; + height: 2px; + background: #6A6F82 +} + +.modal-close::before { + transform: rotate(225deg) +} + +.modal-close::after { + transform: rotate(-45deg) +} + +.modal-close:hover::before, .modal-close:hover::after { + background: #959CB1 +} + +@media (min-width: 641px) { + .modal-inner { + margin: 0 auto; + max-height: calc(100vh - 48px * 2) + } + + .modal-content { + padding-top: 48px; + padding-bottom: 48px; + padding-left: 32px; + padding-right: 32px + } +} + +@-webkit-keyframes slideUpInModal { + 0% { + opacity: 0; + transform: translateY(-24px) + } + to { + opacity: 1; + transform: translateY(0) + } +} + +@keyframes slideUpInModal { + 0% { + opacity: 0; + transform: translateY(-24px) + } + to { + opacity: 1; + transform: translateY(0) + } +} + +@-webkit-keyframes slideUpInModalBg { + 0% { + opacity: 0 + } + to { + opacity: 1 + } +} + +@keyframes slideUpInModalBg { + 0% { + opacity: 0 + } + to { + opacity: 1 + } +} + +.carousel-item { + display: none +} + +.carousel-item.is-loading:not(.is-active) { + display: block; + position: absolute; + visibility: hidden; + opacity: 0 +} + +.carousel-item.is-active { + display: block +} + +.carousel-bullets { + display: inline-flex +} + +.carousel-bullet { + display: block; + position: relative; + width: 20px; + height: 20px; + padding: 0; + cursor: pointer; + line-height: 0; + border: none; + background: transparent +} + +.carousel-bullet::before { + content: ''; + position: absolute; + left: 6px; + top: 6px; + background: #292B32; + width: 8px; + height: 8px; + border-radius: 50%; + transition: background .25s ease +} + +.carousel-bullet:focus { + outline: none +} + +.carousel-bullet.is-active::before { + background: #6A6F82 +} + +.carousel-bullet:hover::before { + background: #959CB1 +} + +.invert-color .carousel-bullet::before { + background: #6A6F82 +} + +.invert-color .carousel-bullet.is-active::before { + background: #292B32 +} + +.invert-color .carousel-bullet:hover::before { + background: #376DF9 +} + +.split-wrap { + margin-top: -24px +} + +.split-wrap:last-of-type { + margin-bottom: -24px +} + +.split-wrap:not(:last-of-type) { + margin-bottom: 24px +} + +.split-wrap .split-item { + padding-top: 24px; + padding-bottom: 24px; + display: flex; + flex-direction: column +} + +.split-wrap .split-item .split-item-image { + position: relative; + width: 100% +} + +.split-wrap .split-item .split-item-image img, .split-wrap .split-item .split-item-image svg, .split-wrap .split-item .split-item-image video { + width: auto; + height: auto; + max-width: 100%; + overflow: visible +} + +.split-wrap .split-item .split-item-image.split-item-image-fill img, .split-wrap .split-item .split-item-image.split-item-image-fill svg, .split-wrap .split-item .split-item-image.split-item-image-fill video { + width: 100% +} + +@media (max-width: 640px) { + .split-wrap .split-item .split-item-content { + margin-bottom: 32px + } + + .split-wrap.invert-mobile .split-item .split-item-content { + order: 1; + margin-bottom: 0 !important + } + + .split-wrap.invert-mobile .split-item .split-item-image { + margin-bottom: 32px + } +} + +@media (min-width: 641px) { + .split-wrap { + margin-top: -40px + } + + .split-wrap:last-of-type { + margin-bottom: -40px + } + + .split-wrap:not(:last-of-type) { + margin-bottom: 40px + } + + .split-wrap .split-item { + padding-top: 40px; + padding-bottom: 40px; + flex-direction: row; + flex-wrap: nowrap; + align-items: center; + justify-content: flex-start + } + + .split-wrap .split-item .split-item-content { + flex-shrink: 0; + width: 396px; + margin-bottom: 0; + margin-right: 64px + } + + .split-wrap .split-item .split-item-image { + min-width: 436px + } + + .split-wrap:not(.invert-desktop) .split-item:nth-child(even), .split-wrap.invert-desktop .split-item:nth-child(odd) { + justify-content: flex-end + } + + .split-wrap:not(.invert-desktop) .split-item:nth-child(even) .split-item-content, .split-wrap.invert-desktop .split-item:nth-child(odd) .split-item-content { + order: 1; + margin-left: 64px; + margin-right: 0 + } + + .split-wrap:not(.invert-desktop) .split-item:nth-child(odd) .split-item-image img, .split-wrap:not(.invert-desktop) .split-item:nth-child(odd) .split-item-image svg, .split-wrap:not(.invert-desktop) .split-item:nth-child(odd) .split-item-image video, .split-wrap.invert-desktop .split-item:nth-child(even) .split-item-image img, .split-wrap.invert-desktop .split-item:nth-child(even) .split-item-image svg, .split-wrap.invert-desktop .split-item:nth-child(even) .split-item-image video { + margin-left: auto + } + + .split-wrap.align-top .split-item { + align-items: flex-start + } +} + +@media (min-width: 821px) { + .container .split-wrap .split-item .split-item-content { + width: 488px + } + + .container .split-wrap .split-item .split-item-image { + min-width: 528px + } +} + +.tiles-wrap { + display: flex; + flex-wrap: wrap; + justify-content: center; + margin-right: -12px; + margin-left: -12px; + margin-top: -12px +} + +.tiles-wrap:last-of-type { + margin-bottom: -12px +} + +.tiles-wrap:not(:last-of-type) { + margin-bottom: 12px +} + +.tiles-wrap.push-left::after { + content: ''; + flex-basis: 330px; + max-width: 330px; + box-sizing: content-box; + padding-left: 12px; + padding-right: 12px; + height: 0 +} + +.tiles-item { + flex-basis: 330px; + max-width: 330px; + box-sizing: content-box; + padding: 12px +} + +.tiles-item * { + box-sizing: border-box +} + +.tiles-item-inner { + display: flex; + flex-wrap: wrap; + flex-direction: column; + height: 100%; + padding: 32px 24px +} + +.site-header { + position: absolute !important; + top: 0; + width: 100%; + z-index: 10 !important +} + +.site-header + .site-content .section:first-of-type { + padding-top: 80px +} + +.site-header .brand { + margin-right: 32px +} + +.site-header-inner { + display: flex; + justify-content: space-between; + align-items: center; + height: 80px +} + +.header-nav { + flex-grow: 1 +} + +.header-nav .header-nav-inner { + display: flex; + flex-grow: 1 +} + +.header-nav ul { + display: flex; + align-items: center; + flex-grow: 1; + white-space: nowrap; + margin-bottom: 0 +} + +.header-nav ul:first-of-type { + flex-wrap: wrap +} + +.header-nav li + .header-button { + margin-left: 32px +} + +.header-nav a:not(.button) { + display: block; + text-decoration: none; + font-weight: 500; + text-transform: uppercase; + padding: 0 32px +} + +.invert-color .header-nav a:not(.button) { + text-decoration: none +} + +.header-nav a.button { + margin-left: 32px +} + +.header-nav-center:first-of-type { + flex-grow: 1; + justify-content: flex-end +} + +.header-nav-right { + justify-content: flex-end +} + +.header-nav-right + .header-nav-right { + flex-grow: 0 +} + +.header-nav-toggle { + display: none +} + +@media (max-width: 640px) { + .header-nav-toggle { + display: block + } + + .header-nav-toggle + .header-nav { + flex-direction: column; + position: absolute; + left: 0; + right: 0; + top: 100%; + z-index: 9999; + background: #292B32; + max-height: 0; + opacity: 0; + overflow: hidden; + transition: max-height .25s ease-in-out, opacity .15s + } + + .header-nav-toggle + .header-nav.is-active { + opacity: 1 + } + + .header-nav-toggle + .header-nav .header-nav-inner { + flex-direction: column; + padding: 24px + } + + .header-nav-toggle + .header-nav ul { + display: block; + text-align: center + } + + .header-nav-toggle + .header-nav ul a:not(.button) { + display: inline-flex; + padding-top: 12px; + padding-bottom: 12px + } + + .header-nav-toggle + .header-nav a.button { + margin-left: 0; + margin-top: 12px; + margin-bottom: 12px + } +} + +.is-boxed { + background: #1b1c21 +} + +.is-boxed .body-wrap { + max-width: 1440px; + margin: 0 auto; + box-shadow: 0 20px 48px rgba(22, 23, 27, 0.8) +} + +.is-boxed .body-wrap::before { + content: ''; + position: absolute; + top: 0; + left: 0; + width: 100%; + height: 100%; + background: #16171B; + z-index: -10 +} + +.body-wrap { + position: relative; + overflow: hidden; + display: flex; + flex-direction: column; + min-height: 100vh +} + +.site-content { + flex: 1 0 auto +} + +.site-footer { + position: relative +} + +.site-footer::before { + content: ''; + position: absolute; + bottom: 0; + left: 0; + width: 100%; + height: 100%; + background: #16171B; + z-index: -3 +} + +.site-footer-inner { + padding: 48px 0 +} + +.footer-top { + padding-bottom: 12px +} + +.footer-bottom { + padding-top: 12px +} + +.footer-blocks { + display: flex; + flex-wrap: wrap; + margin-right: -24px; + margin-left: -24px; + margin-top: -12px +} + +.footer-blocks:last-of-type { + margin-bottom: 28px +} + +.footer-blocks:not(:last-of-type) { + margin-bottom: 12px +} + +.footer-block { + flex-grow: 1; + flex-basis: 160px; + box-sizing: content-box; + padding: 12px 24px +} + +.footer-block * { + box-sizing: border-box +} + +.footer-block ul li:not(:last-child) { + margin-bottom: 4px +} + +.footer-block a { + color: #6A6F82; + text-decoration: none +} + +.footer-block a:hover, .footer-block a:active { + color: #959CB1 +} + +.invert-color .footer-block a { + text-decoration: none +} + +.footer-block-title { + font-size: 14px; + line-height: 22px; + font-weight: 700; + color: #F9FAFF; + text-transform: uppercase; + margin-bottom: 8px +} + +.invert-color .footer-block-title { + color: #16171B +} + +.footer-social a, .footer-nav a { + display: flex +} + +.footer-social ul, .footer-nav ul { + display: flex; + flex-wrap: wrap; + justify-content: center; + align-items: center; + white-space: nowrap; + margin-bottom: 0 +} + +.footer-social ul { + margin-right: -16px; + margin-left: -16px +} + +.footer-social li { + padding: 0 8px +} + +.footer-social a { + padding: 8px +} + +.footer-social a svg { + fill: #376DF9; + transition: fill .15s ease +} + +.footer-social a:hover svg { + fill: #6991FA +} + +.footer-nav { + margin-right: -12px; + margin-left: -12px +} + +.footer-nav a { + color: #6A6F82; + text-decoration: none; + padding: 0 12px +} + +.footer-nav a:hover, .footer-nav a:active { + color: #959CB1 +} + +.invert-color .footer-nav a { + text-decoration: none +} + +@media (max-width: 640px) { + .footer-top > *:not(:last-child), .footer-bottom > *:not(:last-child) { + margin-bottom: 24px + } +} + +@media (min-width: 641px) { + .site-footer-inner { + padding: 64px 0 + } + + .footer-top.space-between, .footer-bottom.space-between { + display: flex; + justify-content: space-between; + align-items: center + } + + .footer-top.invert-order-desktop > *:first-child, .footer-bottom.invert-order-desktop > *:first-child { + order: 1 + } +} + +.section-inner { + position: relative; + padding-top: 48px; + padding-bottom: 48px +} + +.section-header { + padding-bottom: 48px +} + +@media (min-width: 641px) { + .section-inner { + padding-top: 80px; + padding-bottom: 80px + } + + .section-header { + padding-bottom: 80px + } +} + +.hero-inner > .hero-content + .hero-figure, .hero-inner > .hero-figure + .hero-content { + margin-top: 48px +} + +.hero-inner > .hero-figure > a { + display: inline-flex; + align-items: center; + vertical-align: top +} + +@media (max-width: 640px) { + .hero .split-wrap .split-item .split-item-content { + margin-bottom: 48px + } + + .hero .split-wrap.invert-mobile .split-item .split-item-image { + margin-bottom: 48px + } +} + +@media (min-width: 641px) { + .hero-inner > .hero-content + .hero-figure, .hero-inner > .hero-figure + .hero-content { + margin-top: 64px + } +} + +@media (min-width: 641px) { + .features-split .section-header { + padding-bottom: 92px + } +} + +.features-tiles .tiles-wrap { + margin-right: -16px; + margin-left: -16px; + margin-top: -16px +} + +.features-tiles .tiles-wrap:last-of-type { + margin-bottom: -16px +} + +.features-tiles .tiles-wrap:not(:last-of-type) { + margin-bottom: 16px +} + +.features-tiles .tiles-wrap.push-left::after { + flex-basis: 360px; + max-width: 360px; + padding-left: 16px; + padding-right: 16px +} + +.features-tiles .tiles-item { + flex-basis: 360px; + max-width: 360px; + padding: 16px +} + +.features-tiles .tiles-item-inner { + padding-top: 0; + padding-bottom: 0; + padding-left: 0; + padding-right: 0 +} + +@media (min-width: 641px) { + .features-tiles .tiles-wrap { + margin-right: -32px; + margin-left: -32px; + margin-top: -32px + } + + .features-tiles .tiles-wrap:last-of-type { + margin-bottom: -32px + } + + .features-tiles .tiles-wrap:not(:last-of-type) { + margin-bottom: 32px + } + + .features-tiles .tiles-wrap.push-left::after { + padding-left: 32px; + padding-right: 32px + } + + .features-tiles .tiles-item { + padding: 32px + } +} + +.pricing .tiles-wrap.push-left::after { + flex-basis: 344px; + max-width: 344px +} + +.pricing .tiles-item { + flex-basis: 344px; + max-width: 344px +} + +.pricing .tiles-item-inner { + padding-top: 24px; + padding-bottom: 24px; + padding-left: 24px; + padding-right: 24px +} + +.pricing-item-content { + flex-grow: 1; + width: 100% +} + +ul.pricing-item-features-list li { + display: flex; + align-items: center; + margin-bottom: 12px +} + +.pricing-switcher { + margin-bottom: 48px +} + +@media (min-width: 641px) { + .pricing-switcher { + margin-bottom: 64px + } +} + +.testimonial .tiles-wrap.push-left::after { + flex-basis: 344px; + max-width: 344px +} + +.testimonial .tiles-item { + flex-basis: 344px; + max-width: 344px +} + +.testimonial .tiles-item-inner { + padding-top: 20px; + padding-bottom: 20px; + padding-left: 24px; + padding-right: 24px +} + +.testimonial-item-content { + flex-grow: 1 +} + +.testimonial-item-source { + display: inline-flex; + flex-wrap: wrap; + align-items: center +} + +.team .tiles-wrap { + margin-right: -16px; + margin-left: -16px; + margin-top: -16px +} + +.team .tiles-wrap:last-of-type { + margin-bottom: -16px +} + +.team .tiles-wrap:not(:last-of-type) { + margin-bottom: 16px +} + +.team .tiles-wrap.push-left::after { + flex-basis: 296px; + max-width: 296px; + padding-left: 16px; + padding-right: 16px +} + +.team .tiles-item { + flex-basis: 296px; + max-width: 296px; + padding: 16px +} + +.team .tiles-item-inner { + padding-top: 0; + padding-bottom: 0; + padding-left: 0; + padding-right: 0 +} + +@media (min-width: 641px) { + .team .section-header { + padding-bottom: 80px + } + + .team .tiles-wrap { + margin-right: -32px; + margin-left: -32px; + margin-top: -32px + } + + .team .tiles-wrap:last-of-type { + margin-bottom: -32px + } + + .team .tiles-wrap:not(:last-of-type) { + margin-bottom: 32px + } + + .team .tiles-wrap.push-left::after { + padding-left: 32px; + padding-right: 32px + } + + .team .tiles-item { + padding: 32px + } +} + +.cta .section-inner { + padding-top: 48px; + padding-bottom: 48px +} + +.cta-slogan { + margin-bottom: 40px +} + +@media (min-width: 641px) { + .cta .section-inner { + padding-top: 64px; + padding-bottom: 64px + } + + .cta-split { + display: flex; + justify-content: space-between; + align-items: center + } + + .cta-split .cta-slogan { + margin-bottom: 0; + margin-right: 48px + } +} + +.clients .section-inner { + padding-top: 26px; + padding-bottom: 26px +} + +.clients-inner ul { + display: flex; + flex-wrap: wrap; + flex-direction: column; + justify-content: center; + align-items: center; + margin: 0 +} + +.clients-inner li { + padding: 12px 28px +} + +@media (min-width: 641px) { + .clients .clients-inner ul { + flex-direction: row + } +} + +.signin .section-header { + padding-bottom: 32px +} + +.signin .tiles-item-inner { + padding-top: 0; + padding-bottom: 0; + padding-left: 0; + padding-right: 0 +} + +@media (min-width: 641px) { + .signin .section-header { + padding-bottom: 48px + } +} + +.signin-footer { + display: flex; + flex-wrap: wrap; + justify-content: space-between +} + +[class*=illustration-] { + position: relative +} + +[class*=illustration-]::after { + pointer-events: none +} + +[class*=illustration-element-]::after { + z-index: -1 +} + +[class*=illustration-section-]::after { + z-index: -2 +} + +.illustration-section-01::after { + content: ''; + position: absolute; + width: 100%; + max-width: 100%; + height: 612px; + background-image: url(../images/illustration-section-01.svg); + background-repeat: no-repeat; + background-size: auto; + left: 50%; + top: 0; + background-position: center top; + transform: translate(-50%) +} + +.illustration-section-02::after { + content: ''; + position: absolute; + width: 100%; + max-width: 100%; + height: 612px; + background-image: url(../images/illustration-section-02.svg); + background-repeat: no-repeat; + background-size: auto; + left: 50%; + top: 0; + background-position: center top; + transform: translate(-50%) +} + +.site-footer { + color: #6A6F82 +} + +.features-tiles-item-image { + display: inline-flex; + border-radius: 50%; + background: radial-gradient(circle at bottom, #376DF9 0%, #ff79af 50%, #FF8D74 100%) +} + +.pricing .tiles-item-inner { + background: #292B32 +} + +.pricing-item-header { + position: relative +} + +.pricing-item-header::after { + content: ''; + position: absolute; + bottom: 0; + left: 0; + width: 100%; + display: block; + height: 1px; + background: #292B32 +} + +.pricing-item-header::after { + background: rgba(106, 111, 130, 0.32); + max-width: 88px +} + +.pricing-item-price-currency { + color: #959CB1 +} + +ul.pricing-item-features-list { + position: relative +} + +ul.pricing-item-features-list::after { + content: ''; + position: absolute; + bottom: 0; + left: 0; + width: 100%; + display: block; + height: 1px; + background: #292B32 +} + +ul.pricing-item-features-list::after { + background: rgba(106, 111, 130, 0.32) +} + +ul.pricing-item-features-list li { + margin-bottom: 0; + padding: 14px 0; + position: relative +} + +ul.pricing-item-features-list li::before { + content: ''; + position: absolute; + top: 0; + left: 0; + width: 100%; + display: block; + height: 1px; + background: #292B32 +} + +ul.pricing-item-features-list li::before { + background: rgba(106, 111, 130, 0.32) +} + +ul.pricing-item-features-list li::after { + content: ''; + display: block; + width: 24px; + height: 24px; + margin-right: 12px; + background-image: url("data:image/svg+xml;charset=US-ASCII,%3Csvg%20width%3D%2224%22%20height%3D%2224%22%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%3E%3Cpath%20d%3D%22M5%2011h14v2H5z%22%20fill%3D%22%236A6F82%22%20fill-rule%3D%22nonzero%22%2F%3E%3C%2Fsvg%3E"); + background-repeat: no-repeat; + order: -1 +} + +ul.pricing-item-features-list li.is-checked::after { + background-image: url("data:image/svg+xml;charset=US-ASCII,%3Csvg%20width%3D%2224%22%20height%3D%2224%22%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%3E%3Cg%20fill-rule%3D%22nonzero%22%20fill%3D%22none%22%3E%3Ccircle%20fill%3D%22%231EC198%22%20cx%3D%2212%22%20cy%3D%2212%22%20r%3D%2212%22%2F%3E%3Cpath%20fill%3D%22%23292B32%22%20d%3D%22M10.5%2012.267l-2.5-1.6-1%201.066L10.5%2016%2017%209.067%2016%208z%22%2F%3E%3C%2Fg%3E%3C%2Fsvg%3E") +} + +.testimonial .tiles-item-inner { + background: #292B32 +} + +.testimonial-item-content { + position: relative +} + +.testimonial-item-content::before { + content: ''; + display: block; + width: 24px; + height: 18px; + margin-top: 12px; + margin-bottom: 16px; + background-image: url("data:image/svg+xml;charset=US-ASCII,%3Csvg%20width%3D%2224%22%20height%3D%2218%22%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%3E%3Cpath%20d%3D%22M0%2013.481c0-2.34.611-4.761%201.833-7.263C3.056%203.716%204.733%201.643%206.865%200L11%202.689C9.726%204.382%208.777%206.093%208.152%207.824c-.624%201.73-.936%203.578-.936%205.545V18H0v-4.519zm13%200c0-2.34.611-4.761%201.833-7.263%201.223-2.502%202.9-4.575%205.032-6.218L24%202.689c-1.274%201.693-2.223%203.404-2.848%205.135-.624%201.73-.936%203.578-.936%205.545V18H13v-4.519z%22%20fill%3D%22%23FF5FA0%22%20fill-rule%3D%22nonzero%22%2F%3E%3C%2Fsvg%3E"); + background-repeat: no-repeat +} + +.testimonial-item-footer { + font-family: "Fira Sans", sans-serif; + font-weight: 600; + padding-top: 20px +} + +.testimonial-item-footer.has-top-divider::before { + background: rgba(106, 111, 130, 0.32) +} + +.testimonial-item-link { + color: #376DF9 +} + +.testimonial-item-link a { + color: #376DF9; + text-decoration: none +} + +.testimonial-item-link a:hover { + color: #6991FA +} + +.cta .form-input { + border-color: transparent; + border-radius: 2px +} + +.cta-inner { + padding-left: 16px; + padding-right: 16px; + background-color: #376DF9; + background: linear-gradient(100deg, #376DF9 0, #FF5FA0 75%, #FFC55A 100%) +} + +@media (min-width: 641px) { + .cta .form-input { + min-width: 280px + } + + .cta-inner { + padding-left: 48px; + padding-right: 48px + } +} + +.screen-reader { + position: absolute; + width: 1px; + height: 1px; + padding: 0; + overflow: hidden; + clip: rect(0, 0, 0, 0); + white-space: nowrap; + border: 0 +} + +.list-reset { + list-style: none; + padding: 0 +} + +.list-reset li { + margin: 0 +} + +.ta-l { + text-align: left +} + +.ta-c { + text-align: center +} + +.ta-r { + text-align: right +} + +.fw-400 { + font-weight: 400 +} + +.fw-500 { + font-weight: 500 +} + +.fw-600 { + font-weight: 600 +} + +.fw-700 { + font-weight: 700 +} + +.text-color-high { + color: #F9FAFF +} + +.text-color-mid { + color: #959CB1 +} + +.text-color-low { + color: #6A6F82 +} + +.text-color-primary { + color: #376DF9 +} + +.text-color-secondary { + color: #FF5FA0 +} + +.text-color-error { + color: #FF5FA0 +} + +.text-color-warning { + color: #FFC55A +} + +.text-color-success { + color: #1EC198 +} + +.invert-color .text-color-high { + color: #16171B +} + +.invert-color .text-color-mid { + color: #1C1D22 +} + +.invert-color .text-color-low { + color: #6A6F82 +} + +.tt-u { + text-transform: uppercase +} + +.image-full { + width: 100% +} + +.image-larger { + position: relative; + left: 50%; + transform: translateX(-50%); + width: calc(100% + 96px); + max-width: 100vw +} + +.has-bg-color { + position: relative; + background-color: #fff; + z-index: 0 +} + +.has-shadow { + box-shadow: 0 24px 64px rgba(22, 23, 27, 0.64) +} + +img.has-shadow { + border-radius: 2px +} + +.has-top-divider { + position: relative +} + +.has-top-divider::before { + content: ''; + position: absolute; + top: 0; + left: 0; + width: 100%; + display: block; + height: 1px; + background: #292B32 +} + +.has-bottom-divider { + position: relative +} + +.has-bottom-divider::after { + content: ''; + position: absolute; + bottom: 0; + left: 0; + width: 100%; + display: block; + height: 1px; + background: #292B32 +} + +.invert-color .has-top-divider { + position: relative +} + +.invert-color .has-top-divider::before { + content: ''; + position: absolute; + top: 0; + left: 0; + width: 100%; + display: block; + height: 1px; + background: #e5e9ff +} + +.invert-color .has-bottom-divider { + position: relative +} + +.invert-color .has-bottom-divider::after { + content: ''; + position: absolute; + bottom: 0; + left: 0; + width: 100%; + display: block; + height: 1px; + background: #e5e9ff +} + +.center-content { + text-align: center +} + +.center-content img, .center-content svg, .center-content video { + margin-left: auto; + margin-right: auto +} + +.center-content .button-group { + justify-content: center +} + +.responsive-video { + position: relative; + padding-bottom: 56.25%; + height: 0 +} + +.responsive-video.is-4-3 { + padding-bottom: 75% +} + +.responsive-video iframe { + position: absolute; + top: 0; + left: 0; + width: 100%; + height: 100% +} + +.m-0 { + margin: 0 +} + +.mt-0 { + margin-top: 0 +} + +.mr-0 { + margin-right: 0 +} + +.mb-0 { + margin-bottom: 0 +} + +.ml-0 { + margin-left: 0 +} + +.m-4 { + margin: 4px +} + +.mt-4 { + margin-top: 4px +} + +.mr-4 { + margin-right: 4px +} + +.mb-4 { + margin-bottom: 4px +} + +.ml-4 { + margin-left: 4px +} + +.m-8 { + margin: 8px +} + +.mt-8 { + margin-top: 8px +} + +.mr-8 { + margin-right: 8px +} + +.mb-8 { + margin-bottom: 8px +} + +.ml-8 { + margin-left: 8px +} + +.m-12 { + margin: 12px +} + +.mt-12 { + margin-top: 12px +} + +.mr-12 { + margin-right: 12px +} + +.mb-12 { + margin-bottom: 12px +} + +.ml-12 { + margin-left: 12px +} + +.m-16 { + margin: 16px +} + +.mt-16 { + margin-top: 16px +} + +.mr-16 { + margin-right: 16px +} + +.mb-16 { + margin-bottom: 16px +} + +.ml-16 { + margin-left: 16px +} + +.m-24 { + margin: 24px +} + +.mt-24 { + margin-top: 24px +} + +.mr-24 { + margin-right: 24px +} + +.mb-24 { + margin-bottom: 24px +} + +.ml-24 { + margin-left: 24px +} + +.m-32 { + margin: 32px +} + +.mt-32 { + margin-top: 32px +} + +.mr-32 { + margin-right: 32px +} + +.mb-32 { + margin-bottom: 32px +} + +.ml-32 { + margin-left: 32px +} + +.p-0 { + padding: 0 +} + +.pt-0 { + padding-top: 0 +} + +.pr-0 { + padding-right: 0 +} + +.pb-0 { + padding-bottom: 0 +} + +.pl-0 { + padding-left: 0 +} + +.p-4 { + padding: 4px +} + +.pt-4 { + padding-top: 4px +} + +.pr-4 { + padding-right: 4px +} + +.pb-4 { + padding-bottom: 4px +} + +.pl-4 { + padding-left: 4px +} + +.p-8 { + padding: 8px +} + +.pt-8 { + padding-top: 8px +} + +.pr-8 { + padding-right: 8px +} + +.pb-8 { + padding-bottom: 8px +} + +.pl-8 { + padding-left: 8px +} + +.p-12 { + padding: 12px +} + +.pt-12 { + padding-top: 12px +} + +.pr-12 { + padding-right: 12px +} + +.pb-12 { + padding-bottom: 12px +} + +.pl-12 { + padding-left: 12px +} + +.p-16 { + padding: 16px +} + +.pt-16 { + padding-top: 16px +} + +.pr-16 { + padding-right: 16px +} + +.pb-16 { + padding-bottom: 16px +} + +.pl-16 { + padding-left: 16px +} + +.p-24 { + padding: 24px +} + +.pt-24 { + padding-top: 24px +} + +.pr-24 { + padding-right: 24px +} + +.pb-24 { + padding-bottom: 24px +} + +.pl-24 { + padding-left: 24px +} + +.p-32 { + padding: 32px +} + +.pt-32 { + padding-top: 32px +} + +.pr-32 { + padding-right: 32px +} + +.pb-32 { + padding-bottom: 32px +} + +.pl-32 { + padding-left: 32px +} + +.spacer-4 { + padding-top: 4px +} + +.spacer-8 { + padding-top: 8px +} + +.spacer-12 { + padding-top: 12px +} + +.spacer-16 { + padding-top: 16px +} + +.spacer-24 { + padding-top: 24px +} + +.spacer-32 { + padding-top: 32px +} + +.spacer-48 { + padding-top: 48px +} + +.spacer-64 { + padding-top: 64px +} + +@media (max-width: 640px) { + .ta-l-mobile { + text-align: left + } + + .ta-c-mobile { + text-align: center + } + + .ta-r-mobile { + text-align: right + } + + .center-content-mobile { + text-align: center + } + + .center-content-mobile img, .center-content-mobile svg, .center-content-mobile video { + margin-left: auto; + margin-right: auto + } + + .center-content-mobile .button-group { + justify-content: center + } + + .spacer-4-mobile { + padding-top: 4px + } + + .spacer-8-mobile { + padding-top: 8px + } + + .spacer-12-mobile { + padding-top: 12px + } + + .spacer-16-mobile { + padding-top: 16px + } + + .spacer-24-mobile { + padding-top: 24px + } + + .spacer-32-mobile { + padding-top: 32px + } + + .spacer-48-mobile { + padding-top: 48px + } + + .spacer-64-mobile { + padding-top: 64px + } +} + +@media (min-width: 641px) { + .ta-l-desktop { + text-align: left + } + + .ta-c-desktop { + text-align: center + } + + .ta-r-desktop { + text-align: right + } + + .center-content-desktop { + text-align: center + } + + .center-content-desktop img, .center-content-desktop svg, .center-content-desktop video { + margin-left: auto; + margin-right: auto + } + + .center-content-desktop .button-group { + justify-content: center + } +} + +/*# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["style.css"],"names":[],"mappings":"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","file":"style.css","sourcesContent":["@import url(\"https://fonts.googleapis.com/css?family=Fira+Sans:600|Heebo:400,500,700&display=swap\");html{line-height:1.15;-ms-text-size-adjust:100%;-webkit-text-size-adjust:100%}body{margin:0}article,aside,footer,header,nav,section{display:block}h1{font-size:2em;margin:0.67em 0}figcaption,figure,main{display:block}figure{margin:1em 40px}hr{box-sizing:content-box;height:0;overflow:visible}pre{font-family:monospace, monospace;font-size:1em}a{background-color:transparent;-webkit-text-decoration-skip:objects}abbr[title]{border-bottom:none;text-decoration:underline;text-decoration:underline dotted}b,strong{font-weight:inherit}b,strong{font-weight:bolder}code,kbd,samp{font-family:monospace, monospace;font-size:1em}dfn{font-style:italic}mark{background-color:#ff0;color:#000}small{font-size:80%}sub,sup{font-size:75%;line-height:0;position:relative;vertical-align:baseline}sub{bottom:-0.25em}sup{top:-0.5em}audio,video{display:inline-block}audio:not([controls]){display:none;height:0}img{border-style:none}svg:not(:root){overflow:hidden}button,input,optgroup,select,textarea{font-family:sans-serif;font-size:100%;line-height:1.15;margin:0}button,input{overflow:visible}button,select{text-transform:none}button,html [type=\"button\"],[type=\"reset\"],[type=\"submit\"]{-webkit-appearance:button}button::-moz-focus-inner,[type=\"button\"]::-moz-focus-inner,[type=\"reset\"]::-moz-focus-inner,[type=\"submit\"]::-moz-focus-inner{border-style:none;padding:0}button:-moz-focusring,[type=\"button\"]:-moz-focusring,[type=\"reset\"]:-moz-focusring,[type=\"submit\"]:-moz-focusring{outline:1px dotted ButtonText}fieldset{padding:0.35em 0.75em 0.625em}legend{box-sizing:border-box;color:inherit;display:table;max-width:100%;padding:0;white-space:normal}progress{display:inline-block;vertical-align:baseline}textarea{overflow:auto}[type=\"checkbox\"],[type=\"radio\"]{box-sizing:border-box;padding:0}[type=\"number\"]::-webkit-inner-spin-button,[type=\"number\"]::-webkit-outer-spin-button{height:auto}[type=\"search\"]{-webkit-appearance:textfield;outline-offset:-2px}[type=\"search\"]::-webkit-search-cancel-button,[type=\"search\"]::-webkit-search-decoration{-webkit-appearance:none}::-webkit-file-upload-button{-webkit-appearance:button;font:inherit}details,menu{display:block}summary{display:list-item}canvas{display:inline-block}template{display:none}[hidden]{display:none}@media (min-width: 641px){.has-animations [class*=reveal-]{opacity:0;will-change:opacity, transform}.has-animations .reveal-from-top{transform:translateY(-10px)}.has-animations .reveal-from-bottom{transform:translateY(10px)}.has-animations .reveal-from-left{transform:translateX(-10px)}.has-animations .reveal-from-right{transform:translateX(10px)}.has-animations .reveal-scale-up{transform:scale(.95)}.has-animations .reveal-scale-down{transform:scale(1.05)}.has-animations .reveal-rotate-from-left{transform:perspective(1000px) rotateY(-45deg)}.has-animations .reveal-rotate-from-right{transform:perspective(1000px) rotateY(45deg)}.has-animations.is-loaded [class*=reveal-]{transition:opacity 1s cubic-bezier(0.39, 0.575, 0.565, 1),transform 1s cubic-bezier(0.39, 0.575, 0.565, 1)}.has-animations.is-loaded [class*=reveal-].is-revealed{opacity:1;transform:translate(0)}}html{box-sizing:border-box}*,*:before,*:after{box-sizing:inherit}body{background:#16171B;-moz-osx-font-smoothing:grayscale;-webkit-font-smoothing:antialiased}hr{border:0;display:block;height:1px;background:#292B32;margin-top:24px;margin-bottom:24px}ul,ol{margin-top:0;padding-left:24px}ul:not(:last-child),ol:not(:last-child){margin-bottom:24px}ul{list-style:disc}ol{list-style:decimal}li:not(:last-child){margin-bottom:12px}li>ul,li>ol{margin-top:12px;margin-bottom:0}dl{margin-top:0;margin-bottom:24px}dt{font-weight:700}dd{margin-left:24px;margin-bottom:24px}img{border-radius:2px}img,svg,video{display:block;height:auto;max-width:100%}figure{margin:48px 0}figcaption{padding:8px 0}table{font-size:16px;line-height:24px;letter-spacing:-0.1px;border-collapse:collapse;margin-bottom:24px;width:100%}tr{border-bottom:1px solid #292B32}th{font-weight:700;text-align:left}th,td{padding:8px 16px}th:first-child,td:first-child{padding-left:0}th:last-child,td:last-child{padding-right:0}.invert-color hr{display:block;height:1px;background:#e5e9ff}.invert-color tr{border-bottom:1px solid #e5e9ff}html{font-size:20px;line-height:32px;letter-spacing:-0.1px}body{color:#959CB1;font-size:1rem}body,button,input,select,textarea{font-family:\"Heebo\", sans-serif;font-weight:400}h1,h2,h3,h4,h5,h6,.h1,.h2,.h3,.h4,.h5,.h6{font-family:\"Fira Sans\", sans-serif;font-weight:600;clear:both;color:#F9FAFF;word-wrap:break-word;overflow-wrap:break-word}h1,.h1{font-size:38px;line-height:48px}h2,.h2{font-size:32px;line-height:42px}h3,.h3{font-size:24px;line-height:34px;letter-spacing:-0.1px}h4,.h4{font-size:24px;line-height:34px;letter-spacing:-0.1px}h5,.h5{font-size:20px;line-height:32px;letter-spacing:-0.1px}h6,.h6,small,.text-sm{font-size:18px;line-height:30px;letter-spacing:-0.1px}.text-xs{font-size:16px;line-height:24px;letter-spacing:-0.1px}.text-xxs{font-size:14px;line-height:22px}figcaption{font-size:14px;line-height:22px}a:not(.button){color:inherit}a:not(.button):hover,a:not(.button):active{color:#F9FAFF;outline:0}a.button-link{color:#6A6F82}a.button-link:hover,a.button-link:active{color:#959CB1}a.func-link{color:#376DF9}a.func-link:hover,a.func-link:active{color:#6991FA}h1,.h1{margin-top:48px;margin-bottom:32px}h2,.h2{margin-top:48px;margin-bottom:32px}h3,.h3{margin-top:36px;margin-bottom:24px}h4,h5,h6,.h4,.h5,.h6{margin-top:24px;margin-bottom:24px}p{margin-top:0;margin-bottom:24px}dfn,cite,em,i{font-style:italic}blockquote{font-size:20px;line-height:32px;letter-spacing:-0.1px;margin-top:24px;margin-bottom:24px;margin-left:24px}blockquote::before{content:\"\\201C\"}blockquote::after{content:\"\\201D\"}blockquote p{display:inline}address{border-width:1px 0;border-style:solid;border-color:#292B32;padding:24px 0;margin:0 0 24px}pre,pre h1,pre h2,pre h3,pre h4,pre h5,pre h6,pre .h1,pre .h2,pre .h3,pre .h4,pre .h5,pre .h6{font-family:\"Courier 10 Pitch\", Courier, monospace}pre,code,kbd,tt,var{background:#0d0d10}pre{font-size:16px;line-height:24px;letter-spacing:-0.1px;max-width:100%;overflow:auto;padding:24px 24px;margin-top:24px;margin-bottom:24px}code,kbd,tt,var{font-family:Monaco, Consolas, \"Andale Mono\", \"DejaVu Sans Mono\", monospace;font-size:16px;line-height:24px;letter-spacing:-0.1px;padding:2px 4px}abbr,acronym{cursor:help}mark,ins{text-decoration:none}b,strong{font-weight:700}.invert-color{color:#6A6F82}.invert-color a:not(.button):hover,.invert-color a:not(.button):active{color:#1C1D22;outline:0}.invert-color a.button-link:hover,.invert-color a.button-link:active{color:#376DF9}.invert-color a.func-link:hover,.invert-color a.func-link:active{color:#6991FA}.invert-color h1,.invert-color h2,.invert-color h3,.invert-color h4,.invert-color h5,.invert-color h6,.invert-color .h1,.invert-color .h2,.invert-color .h3,.invert-color .h4,.invert-color .h5,.invert-color .h6{color:#16171B}.invert-color address{border-color:#e5e9ff}.invert-color pre,.invert-color code,.invert-color kbd,.invert-color tt,.invert-color var{background:#0d0d10}@media (max-width: 640px){.h1-mobile{font-size:38px;line-height:48px}.h2-mobile{font-size:32px;line-height:42px}.h3-mobile{font-size:24px;line-height:34px;letter-spacing:-0.1px}.h4-mobile{font-size:24px;line-height:34px;letter-spacing:-0.1px}.h5-mobile{font-size:20px;line-height:32px;letter-spacing:-0.1px}.h6-mobile{font-size:18px;line-height:30px;letter-spacing:-0.1px}}@media (min-width: 641px){h1,.h1{font-size:44px;line-height:54px}h2,.h2{font-size:38px;line-height:48px}h3,.h3{font-size:32px;line-height:42px}}.container,.container-sm,.container-xs{width:100%;margin:0 auto;padding-left:16px;padding-right:16px}@media (min-width: 481px){.container,.container-sm,.container-xs{padding-left:24px;padding-right:24px}}.container{max-width:1128px}.container-sm{max-width:944px}.container-xs{max-width:668px}[class*=container] [class*=container]{padding-left:0;padding-right:0}[class*=container] .container-sm{max-width:896px}[class*=container] .container-xs{max-width:620px}.button{display:inline-flex;font-size:14px;line-height:22px;font-weight:700;padding:12px 31px;height:48px;text-decoration:none !important;text-transform:uppercase;color:#6A6F82;background-color:#F9FAFF;border-width:1px;border-style:solid;border-color:rgba(0,0,0,0);border-radius:2px;cursor:pointer;justify-content:center;text-align:center;letter-spacing:inherit;white-space:nowrap;transition:background .15s ease}.button:active{outline:0}.button:hover{background-color:#fff}.button.is-loading{position:relative;color:transparent !important;pointer-events:none}.button.is-loading::after{content:'';display:block;position:absolute;width:22px;height:22px;margin-left:-11px;margin-top:-11px;top:50%;left:50%;border:2px solid #6A6F82;border-radius:50%;border-right-color:transparent !important;border-top-color:transparent !important;z-index:1;animation:button-loading .6s infinite linear}.button[disabled]{cursor:not-allowed;color:#16171B;background-color:#292B32 !important}.button[disabled].is-loading::after{border-color:#16171B}.button-sm{padding:6px 23px;height:36px}.button-dark{color:#F9FAFF;background-color:#292B32}.button-dark:hover{background-color:#30323a}.button-dark.is-loading::after{border-color:#F9FAFF}.button-primary{color:#F9FAFF;background-color:#376DF9}.button-primary:hover{background-color:#4678f9}.button-primary.is-loading::after{border-color:#F9FAFF}.button-secondary{color:#F9FAFF;background-color:#FF5FA0}.button-secondary:hover{background-color:#ff6ea9}.button-secondary.is-loading::after{border-color:#F9FAFF}.button-block{display:flex;width:100%}.button-group{display:flex;flex-wrap:wrap;align-items:center;margin-right:-8px;margin-left:-8px;margin-top:-8px}.button-group:last-of-type{margin-bottom:-8px}.button-group:not(:last-of-type){margin-bottom:8px}.button-group>[class*=button]{margin:8px}@media (max-width: 640px){.button-wide-mobile{width:100%;max-width:280px}}@keyframes button-loading{0%{transform:rotate(0)}100%{transform:rotate(360deg)}}fieldset{padding:0;margin:0;border:0}.form-label,.form-switch{color:#6A6F82;font-weight:500}.form-label{font-size:14px;line-height:22px}.form-input,.form-select,.form-checkbox input,.form-radio input{-moz-appearance:none;-webkit-appearance:none;background-color:#F9FAFF;border-width:1px;border-style:solid;border-color:#16171B}.form-input:hover,.form-select:hover,.form-checkbox input:hover,.form-radio input:hover{border-color:#6A6F82}.form-input:active,.form-input:focus,.form-select:active,.form-select:focus,.form-checkbox input:active,.form-checkbox input:focus,.form-radio input:active,.form-radio input:focus{outline:none;border-color:#376DF9}.form-input[disabled],.form-select[disabled],.form-checkbox input[disabled],.form-radio input[disabled]{cursor:not-allowed;background-color:#292B32;border-color:#1C1D22}.form-input.form-error,.form-select.form-error,.form-checkbox input.form-error,.form-radio input.form-error{border-color:#FF5FA0}.form-input.form-warning,.form-select.form-warning,.form-checkbox input.form-warning,.form-radio input.form-warning{border-color:#FFC55A}.form-input.form-success,.form-select.form-success,.form-checkbox input.form-success,.form-radio input.form-success{border-color:#1EC198}.form-input,.form-select{display:block;font-size:16px;line-height:24px;letter-spacing:-0.1px;padding:11px 15px;height:48px;border-radius:0;color:#16171B;box-shadow:none;max-width:100%;width:100%}.form-input::placeholder{color:#959CB1}.form-input::-ms-input-placeholder{color:#959CB1}textarea.form-input{height:auto;resize:vertical}.form-select{padding-right:46px;background-image:url(\"data:image/svg+xml;charset=US-ASCII,%3Csvg%20viewBox%3D%220%200%2016%2016%22%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%3E%3Cpath%20d%3D%22M8%2011.4L2.6%206%204%204.6l4%204%204-4L13.4%206%208%2011.4z%22%20fill%3D%22%23F9FAFF%22%20fill-rule%3D%22evenodd%22%2F%3E%3C%2Fsvg%3E\");background-position:right 15px center;background-repeat:no-repeat;background-size:16px 16px}.form-select-sm{padding-right:38px;background-position:right 11px center}.form-select-sm,.form-input-sm{padding:5px 11px;height:36px}.has-icon-left,.has-icon-right{position:relative}.has-icon-left svg,.has-icon-right svg{pointer-events:none;position:absolute;top:50%;transform:translateY(-50%)}.has-icon-left .form-input{padding-left:46px}.has-icon-left .form-input+svg{left:15px}.has-icon-left .form-input-sm{padding-left:38px}.has-icon-left .form-input-sm+svg{left:11px}.has-icon-right .form-input{padding-right:46px}.has-icon-right .form-input+svg{right:15px}.has-icon-right .form-input-sm{padding-right:38px}.has-icon-right .form-input-sm+svg{right:11px}.form-checkbox,.form-radio,.form-switch{font-size:16px;line-height:24px;letter-spacing:-0.1px;cursor:pointer}.form-checkbox,.form-radio{color:#959CB1}.form-checkbox,.form-radio{position:relative;padding-left:24px}.form-checkbox input,.form-radio input{position:absolute;left:0;top:3px;width:16px;height:16px;cursor:pointer}.form-checkbox input:checked,.form-radio input:checked{background-color:#376DF9 !important;border-color:#376DF9 !important;background-position:50%}.form-checkbox input{border-radius:2px}.form-checkbox input:checked{background-image:url(data:image/svg+xml;base64,PHN2ZyB3aWR0aD0iMTQiIGhlaWdodD0iMTQiIHhtbG5zPSJodHRwOi8vd3d3LnczLm9yZy8yMDAwL3N2ZyI+IDxwYXRoIGQ9Ik0xMS40IDVMMTAgMy42bC00IDQtMi0yTDIuNiA3IDYgMTAuNHoiIGZpbGw9IiNGRkYiIGZpbGwtcnVsZT0iZXZlbm9kZCIvPjwvc3ZnPg==)}.form-radio input{border-radius:50%}.form-radio input:checked{background-image:url(data:image/svg+xml;base64,PHN2ZyB3aWR0aD0iMTQiIGhlaWdodD0iMTQiIHhtbG5zPSJodHRwOi8vd3d3LnczLm9yZy8yMDAwL3N2ZyI+PGNpcmNsZSBmaWxsPSIjRkZGIiBjeD0iNyIgY3k9IjciIHI9IjMiIGZpbGwtcnVsZT0iZXZlbm9kZCIvPjwvc3ZnPg==)}.form-switch{display:inline-flex;align-items:center;user-select:none}.form-switch input{clip:rect(0, 0, 0, 0);height:1px;margin:-1px;overflow:hidden;position:absolute;width:1px}.form-switch .form-switch-icon{display:block;position:relative;min-width:60px;width:60px;height:32px;border-radius:16px;background:#292B32}.form-switch .form-switch-icon::before{content:'';display:block;position:absolute;top:2px;left:2px;width:28px;height:28px;border-radius:14px;background:#F9FAFF;transition:all .15s ease-out}.form-switch input:checked+.form-switch-icon{background:#376DF9}.form-switch input:checked+.form-switch-icon::before{left:30px}.form-switch>span:not(.form-switch-icon){order:-1;margin-right:12px}.form-switch>span:not(.form-switch-icon):last-child{order:initial;margin-left:12px;margin-right:0}.invert-color .form-label,.invert-color .form-switch{color:#292B32}.invert-color .form-input,.invert-color .form-select,.invert-color .form-checkbox input,.invert-color .form-radio input{border-color:#e5e9ff}.invert-color .form-input:active,.invert-color .form-input:focus,.invert-color .form-select:active,.invert-color .form-select:focus,.invert-color .form-checkbox input:active,.invert-color .form-checkbox input:focus,.invert-color .form-radio input:active,.invert-color .form-radio input:focus{border-color:#376DF9}.invert-color .form-input[disabled],.invert-color .form-select[disabled],.invert-color .form-checkbox input[disabled],.invert-color .form-radio input[disabled]{background-color:#e5e9ff}.invert-color .form-input,.invert-color .form-select{color:#292B32}.invert-color .form-select{background-image:url(\"data:image/svg+xml;charset=US-ASCII,%3Csvg%20viewBox%3D%220%200%2016%2016%22%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%3E%3Cpath%20d%3D%22M8%2011.4L2.6%206%204%204.6l4%204%204-4L13.4%206%208%2011.4z%22%20fill%3D%22%23292B32%22%20fill-rule%3D%22evenodd%22%2F%3E%3C%2Fsvg%3E\")}.invert-color .form-checkbox,.invert-color .form-radio{color:#292B32}.invert-color .form-checkbox input:checked,.invert-color .form-radio input:checked{background-color:!important;border-color:!important}.form-group{display:flex}.form-group .form-input{flex-grow:1;flex-shrink:1;margin-right:12px}.form-group .button{padding-left:24px;padding-right:24px;flex-shrink:0}.form-hint{font-size:14px;line-height:22px;margin-top:8px}@media (max-width: 640px){.form-group-desktop .form-input{margin-bottom:12px}.form-group-desktop .button{width:100%}}@media (min-width: 641px){.form-group-desktop{display:flex}.form-group-desktop .form-input{flex-grow:1;flex-shrink:1;margin-right:12px}.form-group-desktop .button{padding-left:24px;padding-right:24px;flex-shrink:0}}.header-nav-toggle{background:transparent;border:0;outline:0;padding:0;cursor:pointer}.hamburger,.hamburger-inner{display:block;pointer-events:none}.hamburger{position:relative;width:24px;height:24px}.hamburger-inner,.hamburger-inner::before,.hamburger-inner::after{width:24px;height:2px;position:absolute;background:#959CB1}.invert-color .hamburger-inner,.invert-color .hamburger-inner::before,.invert-color .hamburger-inner::after{background:#1C1D22}.hamburger-inner{top:50%;margin-top:-1px;transition-duration:0.22s;transition-timing-function:cubic-bezier(0.55, 0.055, 0.675, 0.19)}.hamburger-inner::before,.hamburger-inner::after{content:'';display:block}.hamburger-inner::before{top:-7px;transition:top 0.1s 0.25s ease-in, opacity 0.1s ease-in}.hamburger-inner::after{bottom:-7px;transition:bottom 0.1s 0.25s ease-in,transform 0.22s cubic-bezier(0.55, 0.055, 0.675, 0.19),width 0.1s 0.25s ease-in}.off-nav-is-active .hamburger-inner{transform:rotate(225deg);transition-delay:0.12s;transition-timing-function:cubic-bezier(0.215, 0.61, 0.355, 1)}.off-nav-is-active .hamburger-inner::before{top:0;opacity:0;transition:top 0.1s ease-out, opacity 0.1s 0.12s ease-out}.off-nav-is-active .hamburger-inner::after{width:24px;bottom:0;transform:rotate(-90deg);transition:bottom 0.1s ease-out,transform 0.22s 0.12s cubic-bezier(0.215, 0.61, 0.355, 1),width 0.1s ease-out}.accordion li{position:relative}.accordion li::before{content:'';position:absolute;top:0;left:0;width:100%;display:block;height:1px;background:#292B32}.accordion li:last-of-type{position:relative}.accordion li:last-of-type::after{content:'';position:absolute;bottom:0;left:0;width:100%;display:block;height:1px;background:#292B32}.invert-color .accordion li{position:relative}.invert-color .accordion li::before{content:'';position:absolute;top:0;left:0;width:100%;display:block;height:1px;background:#e5e9ff}.invert-color .accordion li:last-of-type{position:relative}.invert-color .accordion li:last-of-type::after{content:'';position:absolute;bottom:0;left:0;width:100%;display:block;height:1px;background:#e5e9ff}.accordion-header{display:flex;justify-content:space-between;align-items:center;padding-top:24px;padding-bottom:24px;cursor:pointer}.accordion-header span{width:calc(100% - (16px * 2))}.accordion-content{max-height:0;opacity:0;overflow:hidden;transition:max-height .15s ease-in-out,opacity .15s}.is-active .accordion-content{opacity:1}.accordion-content p:last-child{margin-bottom:24px}.accordion-icon{position:relative;width:16px;height:16px}.accordion-icon::before,.accordion-icon::after{content:'';position:absolute;background:#376DF9;transition:transform .25s ease-out}.accordion-icon::before{top:0;left:50%;width:2px;height:100%;margin-left:-1px}.accordion-icon::after{top:50%;left:0;width:100%;height:2px;margin-top:-1px}.is-active .accordion-icon{cursor:pointer}.is-active .accordion-icon::before{transform:rotate(90deg)}.is-active .accordion-icon::after{transform:rotate(180deg)}.modal,.modal::before{bottom:0;left:0;right:0;top:0}.modal{display:none;align-items:center;flex-direction:column;justify-content:center;overflow:hidden;position:fixed;z-index:40}.modal.modal-video .modal-inner{padding:0;max-width:1024px}.modal::before,.modal .modal-inner{display:none}.modal::before{content:'';position:absolute;background-color:rgba(22,23,27,0.88)}.modal.is-active{display:flex}.modal.is-active::before,.modal.is-active .modal-inner{display:block}.modal.is-active .modal-inner{animation:slideUpInModal .15s ease-in-out both}.modal.is-active::before{animation:slideUpInModalBg .15s ease-in-out both}.modal-inner{max-height:calc(100vh - 16px * 2);overflow:auto;position:relative;width:calc(100%  - ( 16px * 2 ));max-width:480px;margin-left:16px;margin-right:16px;background:#292B32}.modal-content{padding:48px 16px}.modal-close{background:transparent;border:0;outline:0;padding:0;cursor:pointer;position:absolute;right:24px;top:24px;width:16px;height:16px}.modal-close::before,.modal-close::after{content:'';display:block;position:absolute;top:50%;left:50%;margin-top:-1px;margin-left:-8px;width:16px;height:2px;background:#6A6F82}.modal-close::before{transform:rotate(225deg)}.modal-close::after{transform:rotate(-45deg)}.modal-close:hover::before,.modal-close:hover::after{background:#959CB1}@media (min-width: 641px){.modal-inner{margin:0 auto;max-height:calc(100vh - 48px * 2)}.modal-content{padding-top:48px;padding-bottom:48px;padding-left:32px;padding-right:32px}}@keyframes slideUpInModal{0%{opacity:0;transform:translateY(-24px)}to{opacity:1;transform:translateY(0)}}@keyframes slideUpInModalBg{0%{opacity:0}to{opacity:1}}.carousel-item{display:none}.carousel-item.is-loading:not(.is-active){display:block;position:absolute;visibility:hidden;opacity:0}.carousel-item.is-active{display:block}.carousel-bullets{display:inline-flex}.carousel-bullet{display:block;position:relative;width:20px;height:20px;padding:0;cursor:pointer;line-height:0;border:none;background:transparent}.carousel-bullet::before{content:'';position:absolute;left:6px;top:6px;background:#292B32;width:8px;height:8px;border-radius:50%;transition:background .25s ease}.carousel-bullet:focus{outline:none}.carousel-bullet.is-active::before{background:#6A6F82}.carousel-bullet:hover::before{background:#959CB1}.invert-color .carousel-bullet::before{background:#6A6F82}.invert-color .carousel-bullet.is-active::before{background:#292B32}.invert-color .carousel-bullet:hover::before{background:#376DF9}.split-wrap{margin-top:-24px}.split-wrap:last-of-type{margin-bottom:-24px}.split-wrap:not(:last-of-type){margin-bottom:24px}.split-wrap .split-item{padding-top:24px;padding-bottom:24px;display:flex;flex-direction:column}.split-wrap .split-item .split-item-image{position:relative;width:100%}.split-wrap .split-item .split-item-image img,.split-wrap .split-item .split-item-image svg,.split-wrap .split-item .split-item-image video{width:auto;height:auto;max-width:100%;overflow:visible}.split-wrap .split-item .split-item-image.split-item-image-fill img,.split-wrap .split-item .split-item-image.split-item-image-fill svg,.split-wrap .split-item .split-item-image.split-item-image-fill video{width:100%}@media (max-width: 640px){.split-wrap .split-item .split-item-content{margin-bottom:32px}.split-wrap.invert-mobile .split-item .split-item-content{order:1;margin-bottom:0 !important}.split-wrap.invert-mobile .split-item .split-item-image{margin-bottom:32px}}@media (min-width: 641px){.split-wrap{margin-top:-40px}.split-wrap:last-of-type{margin-bottom:-40px}.split-wrap:not(:last-of-type){margin-bottom:40px}.split-wrap .split-item{padding-top:40px;padding-bottom:40px;flex-direction:row;flex-wrap:nowrap;align-items:center;justify-content:flex-start}.split-wrap .split-item .split-item-content{flex-shrink:0;width:396px;margin-bottom:0;margin-right:64px}.split-wrap .split-item .split-item-image{min-width:436px}.split-wrap:not(.invert-desktop) .split-item:nth-child(even),.split-wrap.invert-desktop .split-item:nth-child(odd){justify-content:flex-end}.split-wrap:not(.invert-desktop) .split-item:nth-child(even) .split-item-content,.split-wrap.invert-desktop .split-item:nth-child(odd) .split-item-content{order:1;margin-left:64px;margin-right:0}.split-wrap:not(.invert-desktop) .split-item:nth-child(odd) .split-item-image img,.split-wrap:not(.invert-desktop) .split-item:nth-child(odd) .split-item-image svg,.split-wrap:not(.invert-desktop) .split-item:nth-child(odd) .split-item-image video,.split-wrap.invert-desktop .split-item:nth-child(even) .split-item-image img,.split-wrap.invert-desktop .split-item:nth-child(even) .split-item-image svg,.split-wrap.invert-desktop .split-item:nth-child(even) .split-item-image video{margin-left:auto}.split-wrap.align-top .split-item{align-items:flex-start}}@media (min-width: 821px){.container .split-wrap .split-item .split-item-content{width:488px}.container .split-wrap .split-item .split-item-image{min-width:528px}}.tiles-wrap{display:flex;flex-wrap:wrap;justify-content:center;margin-right:-12px;margin-left:-12px;margin-top:-12px}.tiles-wrap:last-of-type{margin-bottom:-12px}.tiles-wrap:not(:last-of-type){margin-bottom:12px}.tiles-wrap.push-left::after{content:'';flex-basis:330px;max-width:330px;box-sizing:content-box;padding-left:12px;padding-right:12px;height:0}.tiles-item{flex-basis:330px;max-width:330px;box-sizing:content-box;padding:12px}.tiles-item *{box-sizing:border-box}.tiles-item-inner{display:flex;flex-wrap:wrap;flex-direction:column;height:100%;padding:32px 24px}.site-header{position:absolute !important;top:0;width:100%;z-index:10 !important}.site-header+.site-content .section:first-of-type{padding-top:80px}.site-header .brand{margin-right:32px}.site-header-inner{display:flex;justify-content:space-between;align-items:center;height:80px}.header-nav{flex-grow:1}.header-nav .header-nav-inner{display:flex;flex-grow:1}.header-nav ul{display:flex;align-items:center;flex-grow:1;white-space:nowrap;margin-bottom:0}.header-nav ul:first-of-type{flex-wrap:wrap}.header-nav li+.header-button{margin-left:32px}.header-nav a:not(.button){display:block;text-decoration:none;font-weight:500;text-transform:uppercase;padding:0 32px}.invert-color .header-nav a:not(.button){text-decoration:none}.header-nav a.button{margin-left:32px}.header-nav-center:first-of-type{flex-grow:1;justify-content:flex-end}.header-nav-right{justify-content:flex-end}.header-nav-right+.header-nav-right{flex-grow:0}.header-nav-toggle{display:none}@media (max-width: 640px){.header-nav-toggle{display:block}.header-nav-toggle+.header-nav{flex-direction:column;position:absolute;left:0;right:0;top:100%;z-index:9999;background:#292B32;max-height:0;opacity:0;overflow:hidden;transition:max-height .25s ease-in-out, opacity .15s}.header-nav-toggle+.header-nav.is-active{opacity:1}.header-nav-toggle+.header-nav .header-nav-inner{flex-direction:column;padding:24px}.header-nav-toggle+.header-nav ul{display:block;text-align:center}.header-nav-toggle+.header-nav ul a:not(.button){display:inline-flex;padding-top:12px;padding-bottom:12px}.header-nav-toggle+.header-nav a.button{margin-left:0;margin-top:12px;margin-bottom:12px}}.is-boxed{background:#1b1c21}.is-boxed .body-wrap{max-width:1440px;margin:0 auto;box-shadow:0 20px 48px rgba(22,23,27,0.8)}.is-boxed .body-wrap::before{content:'';position:absolute;top:0;left:0;width:100%;height:100%;background:#16171B;z-index:-10}.body-wrap{position:relative;overflow:hidden;display:flex;flex-direction:column;min-height:100vh}.site-content{flex:1 0 auto}.site-footer{position:relative}.site-footer::before{content:'';position:absolute;bottom:0;left:0;width:100%;height:100%;background:#16171B;z-index:-3}.site-footer-inner{padding:48px 0}.footer-top{padding-bottom:12px}.footer-bottom{padding-top:12px}.footer-blocks{display:flex;flex-wrap:wrap;margin-right:-24px;margin-left:-24px;margin-top:-12px}.footer-blocks:last-of-type{margin-bottom:28px}.footer-blocks:not(:last-of-type){margin-bottom:12px}.footer-block{flex-grow:1;flex-basis:160px;box-sizing:content-box;padding:12px 24px}.footer-block *{box-sizing:border-box}.footer-block ul li:not(:last-child){margin-bottom:4px}.footer-block a{color:#6A6F82;text-decoration:none}.footer-block a:hover,.footer-block a:active{color:#959CB1}.invert-color .footer-block a{text-decoration:none}.footer-block-title{font-size:14px;line-height:22px;font-weight:700;color:#F9FAFF;text-transform:uppercase;margin-bottom:8px}.invert-color .footer-block-title{color:#16171B}.footer-social a,.footer-nav a{display:flex}.footer-social ul,.footer-nav ul{display:flex;flex-wrap:wrap;justify-content:center;align-items:center;white-space:nowrap;margin-bottom:0}.footer-social ul{margin-right:-16px;margin-left:-16px}.footer-social li{padding:0 8px}.footer-social a{padding:8px}.footer-social a svg{fill:#376DF9;transition:fill .15s ease}.footer-social a:hover svg{fill:#6991FA}.footer-nav{margin-right:-12px;margin-left:-12px}.footer-nav a{color:#6A6F82;text-decoration:none;padding:0 12px}.footer-nav a:hover,.footer-nav a:active{color:#959CB1}.invert-color .footer-nav a{text-decoration:none}@media (max-width: 640px){.footer-top>*:not(:last-child),.footer-bottom>*:not(:last-child){margin-bottom:24px}}@media (min-width: 641px){.site-footer-inner{padding:64px 0}.footer-top.space-between,.footer-bottom.space-between{display:flex;justify-content:space-between;align-items:center}.footer-top.invert-order-desktop>*:first-child,.footer-bottom.invert-order-desktop>*:first-child{order:1}}.section-inner{position:relative;padding-top:48px;padding-bottom:48px}.section-header{padding-bottom:48px}@media (min-width: 641px){.section-inner{padding-top:80px;padding-bottom:80px}.section-header{padding-bottom:80px}}.hero-inner>.hero-content+.hero-figure,.hero-inner>.hero-figure+.hero-content{margin-top:48px}.hero-inner>.hero-figure>a{display:inline-flex;align-items:center;vertical-align:top}@media (max-width: 640px){.hero .split-wrap .split-item .split-item-content{margin-bottom:48px}.hero .split-wrap.invert-mobile .split-item .split-item-image{margin-bottom:48px}}@media (min-width: 641px){.hero-inner>.hero-content+.hero-figure,.hero-inner>.hero-figure+.hero-content{margin-top:64px}}@media (min-width: 641px){.features-split .section-header{padding-bottom:92px}}.features-tiles .tiles-wrap{margin-right:-16px;margin-left:-16px;margin-top:-16px}.features-tiles .tiles-wrap:last-of-type{margin-bottom:-16px}.features-tiles .tiles-wrap:not(:last-of-type){margin-bottom:16px}.features-tiles .tiles-wrap.push-left::after{flex-basis:360px;max-width:360px;padding-left:16px;padding-right:16px}.features-tiles .tiles-item{flex-basis:360px;max-width:360px;padding:16px}.features-tiles .tiles-item-inner{padding-top:0;padding-bottom:0;padding-left:0;padding-right:0}@media (min-width: 641px){.features-tiles .tiles-wrap{margin-right:-32px;margin-left:-32px;margin-top:-32px}.features-tiles .tiles-wrap:last-of-type{margin-bottom:-32px}.features-tiles .tiles-wrap:not(:last-of-type){margin-bottom:32px}.features-tiles .tiles-wrap.push-left::after{padding-left:32px;padding-right:32px}.features-tiles .tiles-item{padding:32px}}.pricing .tiles-wrap.push-left::after{flex-basis:344px;max-width:344px}.pricing .tiles-item{flex-basis:344px;max-width:344px}.pricing .tiles-item-inner{padding-top:24px;padding-bottom:24px;padding-left:24px;padding-right:24px}.pricing-item-content{flex-grow:1;width:100%}ul.pricing-item-features-list li{display:flex;align-items:center;margin-bottom:12px}.pricing-switcher{margin-bottom:48px}@media (min-width: 641px){.pricing-switcher{margin-bottom:64px}}.testimonial .tiles-wrap.push-left::after{flex-basis:344px;max-width:344px}.testimonial .tiles-item{flex-basis:344px;max-width:344px}.testimonial .tiles-item-inner{padding-top:20px;padding-bottom:20px;padding-left:24px;padding-right:24px}.testimonial-item-content{flex-grow:1}.testimonial-item-source{display:inline-flex;flex-wrap:wrap;align-items:center}.team .tiles-wrap{margin-right:-16px;margin-left:-16px;margin-top:-16px}.team .tiles-wrap:last-of-type{margin-bottom:-16px}.team .tiles-wrap:not(:last-of-type){margin-bottom:16px}.team .tiles-wrap.push-left::after{flex-basis:296px;max-width:296px;padding-left:16px;padding-right:16px}.team .tiles-item{flex-basis:296px;max-width:296px;padding:16px}.team .tiles-item-inner{padding-top:0;padding-bottom:0;padding-left:0;padding-right:0}@media (min-width: 641px){.team .section-header{padding-bottom:80px}.team .tiles-wrap{margin-right:-32px;margin-left:-32px;margin-top:-32px}.team .tiles-wrap:last-of-type{margin-bottom:-32px}.team .tiles-wrap:not(:last-of-type){margin-bottom:32px}.team .tiles-wrap.push-left::after{padding-left:32px;padding-right:32px}.team .tiles-item{padding:32px}}.cta .section-inner{padding-top:48px;padding-bottom:48px}.cta-slogan{margin-bottom:40px}@media (min-width: 641px){.cta .section-inner{padding-top:64px;padding-bottom:64px}.cta-split{display:flex;justify-content:space-between;align-items:center}.cta-split .cta-slogan{margin-bottom:0;margin-right:48px}}.clients .section-inner{padding-top:26px;padding-bottom:26px}.clients-inner ul{display:flex;flex-wrap:wrap;flex-direction:column;justify-content:center;align-items:center;margin:0}.clients-inner li{padding:12px 28px}@media (min-width: 641px){.clients .clients-inner ul{flex-direction:row}}.signin .section-header{padding-bottom:32px}.signin .tiles-item-inner{padding-top:0;padding-bottom:0;padding-left:0;padding-right:0}@media (min-width: 641px){.signin .section-header{padding-bottom:48px}}.signin-footer{display:flex;flex-wrap:wrap;justify-content:space-between}[class*=illustration-]{position:relative}[class*=illustration-]::after{pointer-events:none}[class*=illustration-element-]::after{z-index:-1}[class*=illustration-section-]::after{z-index:-2}.illustration-section-01::after{content:'';position:absolute;width:100%;max-width:100%;height:612px;background-image:url(../images/illustration-section-01.svg);background-repeat:no-repeat;background-size:auto;left:50%;top:0;background-position:center top;transform:translate(-50%)}.illustration-section-02::after{content:'';position:absolute;width:100%;max-width:100%;height:612px;background-image:url(../images/illustration-section-02.svg);background-repeat:no-repeat;background-size:auto;left:50%;top:0;background-position:center top;transform:translate(-50%)}.site-footer{color:#6A6F82}.features-tiles-item-image{display:inline-flex;border-radius:50%;background:radial-gradient(circle at bottom, #376DF9 0%, #ff79af 50%, #FF8D74 100%)}.pricing .tiles-item-inner{background:#292B32}.pricing-item-header{position:relative}.pricing-item-header::after{content:'';position:absolute;bottom:0;left:0;width:100%;display:block;height:1px;background:#292B32}.pricing-item-header::after{background:rgba(106,111,130,0.32);max-width:88px}.pricing-item-price-currency{color:#959CB1}ul.pricing-item-features-list{position:relative}ul.pricing-item-features-list::after{content:'';position:absolute;bottom:0;left:0;width:100%;display:block;height:1px;background:#292B32}ul.pricing-item-features-list::after{background:rgba(106,111,130,0.32)}ul.pricing-item-features-list li{margin-bottom:0;padding:14px 0;position:relative}ul.pricing-item-features-list li::before{content:'';position:absolute;top:0;left:0;width:100%;display:block;height:1px;background:#292B32}ul.pricing-item-features-list li::before{background:rgba(106,111,130,0.32)}ul.pricing-item-features-list li::after{content:'';display:block;width:24px;height:24px;margin-right:12px;background-image:url(\"data:image/svg+xml;charset=US-ASCII,%3Csvg%20width%3D%2224%22%20height%3D%2224%22%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%3E%3Cpath%20d%3D%22M5%2011h14v2H5z%22%20fill%3D%22%236A6F82%22%20fill-rule%3D%22nonzero%22%2F%3E%3C%2Fsvg%3E\");background-repeat:no-repeat;order:-1}ul.pricing-item-features-list li.is-checked::after{background-image:url(\"data:image/svg+xml;charset=US-ASCII,%3Csvg%20width%3D%2224%22%20height%3D%2224%22%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%3E%3Cg%20fill-rule%3D%22nonzero%22%20fill%3D%22none%22%3E%3Ccircle%20fill%3D%22%231EC198%22%20cx%3D%2212%22%20cy%3D%2212%22%20r%3D%2212%22%2F%3E%3Cpath%20fill%3D%22%23292B32%22%20d%3D%22M10.5%2012.267l-2.5-1.6-1%201.066L10.5%2016%2017%209.067%2016%208z%22%2F%3E%3C%2Fg%3E%3C%2Fsvg%3E\")}.testimonial .tiles-item-inner{background:#292B32}.testimonial-item-content{position:relative}.testimonial-item-content::before{content:'';display:block;width:24px;height:18px;margin-top:12px;margin-bottom:16px;background-image:url(\"data:image/svg+xml;charset=US-ASCII,%3Csvg%20width%3D%2224%22%20height%3D%2218%22%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%3E%3Cpath%20d%3D%22M0%2013.481c0-2.34.611-4.761%201.833-7.263C3.056%203.716%204.733%201.643%206.865%200L11%202.689C9.726%204.382%208.777%206.093%208.152%207.824c-.624%201.73-.936%203.578-.936%205.545V18H0v-4.519zm13%200c0-2.34.611-4.761%201.833-7.263%201.223-2.502%202.9-4.575%205.032-6.218L24%202.689c-1.274%201.693-2.223%203.404-2.848%205.135-.624%201.73-.936%203.578-.936%205.545V18H13v-4.519z%22%20fill%3D%22%23FF5FA0%22%20fill-rule%3D%22nonzero%22%2F%3E%3C%2Fsvg%3E\");background-repeat:no-repeat}.testimonial-item-footer{font-family:\"Fira Sans\", sans-serif;font-weight:600;padding-top:20px}.testimonial-item-footer.has-top-divider::before{background:rgba(106,111,130,0.32)}.testimonial-item-link{color:#376DF9}.testimonial-item-link a{color:#376DF9;text-decoration:none}.testimonial-item-link a:hover{color:#6991FA}.cta .form-input{border-color:transparent;border-radius:2px}.cta-inner{padding-left:16px;padding-right:16px;background-color:#376DF9;background:linear-gradient(100deg, #376DF9 0, #FF5FA0 75%, #FFC55A 100%)}@media (min-width: 641px){.cta .form-input{min-width:280px}.cta-inner{padding-left:48px;padding-right:48px}}.screen-reader{position:absolute;width:1px;height:1px;padding:0;overflow:hidden;clip:rect(0, 0, 0, 0);white-space:nowrap;border:0}.list-reset{list-style:none;padding:0}.list-reset li{margin:0}.ta-l{text-align:left}.ta-c{text-align:center}.ta-r{text-align:right}.fw-400{font-weight:400}.fw-500{font-weight:500}.fw-600{font-weight:600}.fw-700{font-weight:700}.text-color-high{color:#F9FAFF}.text-color-mid{color:#959CB1}.text-color-low{color:#6A6F82}.text-color-primary{color:#376DF9}.text-color-secondary{color:#FF5FA0}.text-color-error{color:#FF5FA0}.text-color-warning{color:#FFC55A}.text-color-success{color:#1EC198}.invert-color .text-color-high{color:#16171B}.invert-color .text-color-mid{color:#1C1D22}.invert-color .text-color-low{color:#6A6F82}.tt-u{text-transform:uppercase}.image-full{width:100%}.image-larger{position:relative;left:50%;transform:translateX(-50%);width:calc(100% + 96px);max-width:100vw}.has-bg-color{position:relative;background-color:#fff;z-index:0}.has-shadow{box-shadow:0 24px 64px rgba(22,23,27,0.64)}img.has-shadow{border-radius:2px}.has-top-divider{position:relative}.has-top-divider::before{content:'';position:absolute;top:0;left:0;width:100%;display:block;height:1px;background:#292B32}.has-bottom-divider{position:relative}.has-bottom-divider::after{content:'';position:absolute;bottom:0;left:0;width:100%;display:block;height:1px;background:#292B32}.invert-color .has-top-divider{position:relative}.invert-color .has-top-divider::before{content:'';position:absolute;top:0;left:0;width:100%;display:block;height:1px;background:#e5e9ff}.invert-color .has-bottom-divider{position:relative}.invert-color .has-bottom-divider::after{content:'';position:absolute;bottom:0;left:0;width:100%;display:block;height:1px;background:#e5e9ff}.center-content{text-align:center}.center-content img,.center-content svg,.center-content video{margin-left:auto;margin-right:auto}.center-content .button-group{justify-content:center}.responsive-video{position:relative;padding-bottom:56.25%;height:0}.responsive-video.is-4-3{padding-bottom:75%}.responsive-video iframe{position:absolute;top:0;left:0;width:100%;height:100%}.m-0{margin:0}.mt-0{margin-top:0}.mr-0{margin-right:0}.mb-0{margin-bottom:0}.ml-0{margin-left:0}.m-4{margin:4px}.mt-4{margin-top:4px}.mr-4{margin-right:4px}.mb-4{margin-bottom:4px}.ml-4{margin-left:4px}.m-8{margin:8px}.mt-8{margin-top:8px}.mr-8{margin-right:8px}.mb-8{margin-bottom:8px}.ml-8{margin-left:8px}.m-12{margin:12px}.mt-12{margin-top:12px}.mr-12{margin-right:12px}.mb-12{margin-bottom:12px}.ml-12{margin-left:12px}.m-16{margin:16px}.mt-16{margin-top:16px}.mr-16{margin-right:16px}.mb-16{margin-bottom:16px}.ml-16{margin-left:16px}.m-24{margin:24px}.mt-24{margin-top:24px}.mr-24{margin-right:24px}.mb-24{margin-bottom:24px}.ml-24{margin-left:24px}.m-32{margin:32px}.mt-32{margin-top:32px}.mr-32{margin-right:32px}.mb-32{margin-bottom:32px}.ml-32{margin-left:32px}.p-0{padding:0}.pt-0{padding-top:0}.pr-0{padding-right:0}.pb-0{padding-bottom:0}.pl-0{padding-left:0}.p-4{padding:4px}.pt-4{padding-top:4px}.pr-4{padding-right:4px}.pb-4{padding-bottom:4px}.pl-4{padding-left:4px}.p-8{padding:8px}.pt-8{padding-top:8px}.pr-8{padding-right:8px}.pb-8{padding-bottom:8px}.pl-8{padding-left:8px}.p-12{padding:12px}.pt-12{padding-top:12px}.pr-12{padding-right:12px}.pb-12{padding-bottom:12px}.pl-12{padding-left:12px}.p-16{padding:16px}.pt-16{padding-top:16px}.pr-16{padding-right:16px}.pb-16{padding-bottom:16px}.pl-16{padding-left:16px}.p-24{padding:24px}.pt-24{padding-top:24px}.pr-24{padding-right:24px}.pb-24{padding-bottom:24px}.pl-24{padding-left:24px}.p-32{padding:32px}.pt-32{padding-top:32px}.pr-32{padding-right:32px}.pb-32{padding-bottom:32px}.pl-32{padding-left:32px}.spacer-4{padding-top:4px}.spacer-8{padding-top:8px}.spacer-12{padding-top:12px}.spacer-16{padding-top:16px}.spacer-24{padding-top:24px}.spacer-32{padding-top:32px}.spacer-48{padding-top:48px}.spacer-64{padding-top:64px}@media (max-width: 640px){.ta-l-mobile{text-align:left}.ta-c-mobile{text-align:center}.ta-r-mobile{text-align:right}.center-content-mobile{text-align:center}.center-content-mobile img,.center-content-mobile svg,.center-content-mobile video{margin-left:auto;margin-right:auto}.center-content-mobile .button-group{justify-content:center}.spacer-4-mobile{padding-top:4px}.spacer-8-mobile{padding-top:8px}.spacer-12-mobile{padding-top:12px}.spacer-16-mobile{padding-top:16px}.spacer-24-mobile{padding-top:24px}.spacer-32-mobile{padding-top:32px}.spacer-48-mobile{padding-top:48px}.spacer-64-mobile{padding-top:64px}}@media (min-width: 641px){.ta-l-desktop{text-align:left}.ta-c-desktop{text-align:center}.ta-r-desktop{text-align:right}.center-content-desktop{text-align:center}.center-content-desktop img,.center-content-desktop svg,.center-content-desktop video{margin-left:auto;margin-right:auto}.center-content-desktop .button-group{justify-content:center}}\n"]} */ \ No newline at end of file diff --git a/public/landing/images/clients-01.svg b/public/landing/images/clients-01.svg new file mode 100755 index 0000000..40510aa --- /dev/null +++ b/public/landing/images/clients-01.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/public/landing/images/clients-02.svg b/public/landing/images/clients-02.svg new file mode 100755 index 0000000..0fe5ebf --- /dev/null +++ b/public/landing/images/clients-02.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/public/landing/images/clients-03.svg b/public/landing/images/clients-03.svg new file mode 100755 index 0000000..b18db75 --- /dev/null +++ b/public/landing/images/clients-03.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/public/landing/images/clients-04.svg b/public/landing/images/clients-04.svg new file mode 100755 index 0000000..04c30fc --- /dev/null +++ b/public/landing/images/clients-04.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/public/landing/images/clients-05.svg b/public/landing/images/clients-05.svg new file mode 100755 index 0000000..a437997 --- /dev/null +++ b/public/landing/images/clients-05.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/public/landing/images/feature-tile-icon-01.svg b/public/landing/images/feature-tile-icon-01.svg new file mode 100755 index 0000000..a1c4e2d --- /dev/null +++ b/public/landing/images/feature-tile-icon-01.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/public/landing/images/feature-tile-icon-02.svg b/public/landing/images/feature-tile-icon-02.svg new file mode 100755 index 0000000..d06548d --- /dev/null +++ b/public/landing/images/feature-tile-icon-02.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/public/landing/images/feature-tile-icon-03.svg b/public/landing/images/feature-tile-icon-03.svg new file mode 100755 index 0000000..b5da414 --- /dev/null +++ b/public/landing/images/feature-tile-icon-03.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/public/landing/images/feature-tile-icon-04.svg b/public/landing/images/feature-tile-icon-04.svg new file mode 100755 index 0000000..13236c4 --- /dev/null +++ b/public/landing/images/feature-tile-icon-04.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/public/landing/images/feature-tile-icon-05.svg b/public/landing/images/feature-tile-icon-05.svg new file mode 100755 index 0000000..3e092f4 --- /dev/null +++ b/public/landing/images/feature-tile-icon-05.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/public/landing/images/feature-tile-icon-06.svg b/public/landing/images/feature-tile-icon-06.svg new file mode 100755 index 0000000..99d4d42 --- /dev/null +++ b/public/landing/images/feature-tile-icon-06.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/public/landing/images/features-split-image-01.svg b/public/landing/images/features-split-image-01.svg new file mode 100755 index 0000000..0c3fbb3 --- /dev/null +++ b/public/landing/images/features-split-image-01.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/public/landing/images/features-split-image-02.svg b/public/landing/images/features-split-image-02.svg new file mode 100755 index 0000000..36cdf59 --- /dev/null +++ b/public/landing/images/features-split-image-02.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/public/landing/images/illustration-section-01.svg b/public/landing/images/illustration-section-01.svg new file mode 100755 index 0000000..c38025b --- /dev/null +++ b/public/landing/images/illustration-section-01.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/public/landing/images/illustration-section-02.svg b/public/landing/images/illustration-section-02.svg new file mode 100755 index 0000000..633ed57 --- /dev/null +++ b/public/landing/images/illustration-section-02.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/public/landing/images/image-placeholder.svg b/public/landing/images/image-placeholder.svg new file mode 100755 index 0000000..16c62da --- /dev/null +++ b/public/landing/images/image-placeholder.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/public/landing/images/logo.svg b/public/landing/images/logo.svg new file mode 100755 index 0000000..777ea8e --- /dev/null +++ b/public/landing/images/logo.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/public/landing/images/team-member-01.jpg b/public/landing/images/team-member-01.jpg new file mode 100755 index 0000000..0a71e53 Binary files /dev/null and b/public/landing/images/team-member-01.jpg differ diff --git a/public/landing/images/team-member-02.jpg b/public/landing/images/team-member-02.jpg new file mode 100755 index 0000000..d332bf2 Binary files /dev/null and b/public/landing/images/team-member-02.jpg differ diff --git a/public/landing/images/team-member-03.jpg b/public/landing/images/team-member-03.jpg new file mode 100755 index 0000000..d65b207 Binary files /dev/null and b/public/landing/images/team-member-03.jpg differ diff --git a/public/landing/images/team-member-04.jpg b/public/landing/images/team-member-04.jpg new file mode 100755 index 0000000..15a1a3c Binary files /dev/null and b/public/landing/images/team-member-04.jpg differ diff --git a/public/landing/images/team-member-05.jpg b/public/landing/images/team-member-05.jpg new file mode 100755 index 0000000..43630c3 Binary files /dev/null and b/public/landing/images/team-member-05.jpg differ diff --git a/public/landing/images/team-member-06.jpg b/public/landing/images/team-member-06.jpg new file mode 100755 index 0000000..49bdb38 Binary files /dev/null and b/public/landing/images/team-member-06.jpg differ diff --git a/public/landing/images/video-placeholder.svg b/public/landing/images/video-placeholder.svg new file mode 100755 index 0000000..3ea74aa --- /dev/null +++ b/public/landing/images/video-placeholder.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/public/landing/js/accordion.js b/public/landing/js/accordion.js new file mode 100755 index 0000000..4eb978f --- /dev/null +++ b/public/landing/js/accordion.js @@ -0,0 +1,26 @@ +; (function () { + 'use strict' + const accordionEl = document.getElementsByClassName('accordion-header') + + function openAccordion (parent, panel) { + parent.classList.add('is-active') + panel.style.maxHeight = panel.scrollHeight + 'px' + } + + function closeAccordion (parent, panel) { + parent.classList.remove('is-active') + panel.style.maxHeight = null + } + + if (accordionEl.length > 0) { + for (let i = 0; i < accordionEl.length; i++) { + const el = accordionEl[i] + const parent = el.parentNode + const panel = el.nextElementSibling + parent.classList.contains('is-active') && openAccordion(parent, panel) + el.addEventListener('click', function () { + parent.classList.contains('is-active') ? closeAccordion(parent, panel) : openAccordion(parent, panel) + }) + } + } +}()) diff --git a/public/landing/js/carousel.js b/public/landing/js/carousel.js new file mode 100755 index 0000000..3a80383 --- /dev/null +++ b/public/landing/js/carousel.js @@ -0,0 +1,171 @@ +; (function () { + 'use strict' + + // Swipe detector + // https://gist.github.com/chrishaensel/e17c9f3838f246d75fe3bd19d6bb92e8#file-swipe-js + let swipe = { + touchStartX: 0, + touchEndX: 0, + minSwipePixels: 30, + detectionZone: undefined, + swipeCallback: function () { }, + + init: function (detectionZone, callback) { + swipe.swipeCallback = callback + detectionZone.addEventListener('touchstart', function (event) { + swipe.touchStartX = event.changedTouches[0].screenX + }, false) + detectionZone.addEventListener('touchend', function (event) { + swipe.touchEndX = event.changedTouches[0].screenX + swipe.handleSwipeGesture() + }, false) + }, + + handleSwipeGesture: function () { + let direction, moved + if (swipe.touchEndX <= swipe.touchStartX) { + moved = swipe.touchStartX - swipe.touchEndX + direction = 'left' + } + if (swipe.touchEndX >= swipe.touchStartX) { + moved = swipe.touchEndX - swipe.touchStartX + direction = 'right' + } + if (moved > swipe.minSwipePixels && direction !== 'undefined') { + swipe.swipe(direction, moved) + } + }, + + swipe: function (direction, movedPixels) { + let ret = {} + ret.direction = direction + ret.movedPixels = movedPixels + swipe.swipeCallback(ret) + } + } + + const carousels = document.getElementsByClassName('carousel-items') + + // Rotate the carousel forward or backward + function rotateCarousel(el, dir) { + if (dir === undefined) { + dir = 'next' + } + let currentItem = el.getElementsByClassName('carousel-item is-active')[0] + let nextItem = (dir === 'next') ? currentItem.nextElementSibling : currentItem.previousElementSibling + let index = currentItem.getAttribute('data-carousel') + let currentBullet = el.parentNode.getElementsByClassName('carousel-bullet')[index] + let nextBullet = (dir === 'next') ? currentBullet.nextElementSibling : currentBullet.previousElementSibling + currentItem.classList.remove('is-active') + currentBullet.classList.remove('is-active') + if (nextItem) { + nextItem.classList.add('is-active') + nextBullet.classList.add('is-active') + } else { + if (dir === 'next') { + el.firstElementChild.classList.add('is-active') + el.parentNode.getElementsByClassName('carousel-bullets')[0].firstElementChild.classList.add('is-active') + } else { + el.lastElementChild.classList.add('is-active') + el.parentNode.getElementsByClassName('carousel-bullets')[0].lastElementChild.classList.add('is-active') + } + } + } + + // Equal heights fix + function equalHeightCarousel(carousel, items) { + let taller = 0 + let height + for (let i = 0; i < items.length; i++) { + items[0].parentNode.style.minHeight = taller + 'px' + items[i].classList.add('is-loading') + height = items[i].offsetHeight + items[i].classList.remove('is-loading') + if (height > taller) { + taller = height + } + } + items[0].parentNode.style.minHeight = taller + 'px' + } + + // Clear autorotate + function clearAutorotate(autorotate) { + if (autorotate) { + clearInterval(autorotate) + } + } + + if (carousels.length > 0) { + for (let i = 0; i < carousels.length; i++) { + let carousel = carousels[i] + let items = carousel.getElementsByClassName('carousel-item') + let activeItem = 0 + let autorotateTiming = carousel.getAttribute('data-autorotate') + // Generate bullets container + const bulletsContainer = document.createElement('div') + bulletsContainer.className = 'carousel-bullets' + carousel.parentNode.insertBefore(bulletsContainer, carousel.nextSibling) + for (let i = 0; i < items.length; i++) { + // Add data attributes + items[i].setAttribute('data-carousel', i) + // Determine a new active item, if any + if (items[i].classList.contains('is-active')) activeItem = i + // Generate bullets + let bullet = document.createElement('button') + bullet.className = 'carousel-bullet' + bullet.setAttribute('data-bullet', i) + carousel.parentNode.getElementsByClassName('carousel-bullets')[0].appendChild(bullet) + } + // Add is-active class to first carousel item and bullet + items[activeItem].classList.add('is-active') + let bullets = carousel.parentNode.getElementsByClassName('carousel-bullet') + bullets[activeItem].classList.add('is-active') + // Equal height items + equalHeightCarousel(carousel, items) + window.addEventListener('resize', function () { + equalHeightCarousel(carousel, items) + }) + // Autorotate + let autorotate = false + if (autorotateTiming) { + autorotate = setInterval(function () { + rotateCarousel(carousel, 'next') + }, autorotateTiming) + } + // Rotate by bullet click + for (let i = 0; i < bullets.length; i++) { + let bullet = bullets[i] + bullet.addEventListener('click', function (e) { + e.preventDefault() + // Do nothing if item is active + if (bullet.classList.contains('is-active')) { + return + } + // Remove active classes + for (let i = 0; i < bullets.length; i++) { + bullets[i].classList.remove('is-active') + } + for (let i = 0; i < items.length; i++) { + items[i].classList.remove('is-active') + } + // Add active classes to corresponding items and bullets + let index = this.getAttribute('data-bullet') + items[index].classList.add('is-active') + this.classList.add('is-active') + // Clear autorotate timing + clearAutorotate(autorotate) + }) + } + // Rotate on swipe + swipe.init(carousel, function (e) { + if (e.direction === 'left') { + rotateCarousel(carousel, 'next') + } else if (e.direction === 'right') { + rotateCarousel(carousel, 'prev') + } + // Clear autorotate timing + clearAutorotate(autorotate) + }) + } + } +}()) diff --git a/public/landing/js/main.js b/public/landing/js/main.js new file mode 100755 index 0000000..cd4b054 --- /dev/null +++ b/public/landing/js/main.js @@ -0,0 +1,9 @@ +;(function () { + 'use strict' + document.documentElement.classList.remove('no-js') + document.documentElement.classList.add('js') + + window.addEventListener('load', function () { + document.body.classList.add('is-loaded') + }) +}()) diff --git a/public/landing/js/main.min.js b/public/landing/js/main.min.js new file mode 100644 index 0000000..3984dc1 --- /dev/null +++ b/public/landing/js/main.min.js @@ -0,0 +1 @@ +!function(){"use strict";const e=document.getElementsByClassName("accordion-header");function t(e,t){e.classList.add("is-active"),t.style.maxHeight=t.scrollHeight+"px"}function n(e,t){e.classList.remove("is-active"),t.style.maxHeight=null}if(e.length>0)for(let i=0;i=e.touchStartX&&(n=e.touchEndX-e.touchStartX,t="right"),n>e.minSwipePixels&&"undefined"!==t&&e.swipe(t,n)},swipe:function(t,n){let i={};i.direction=t,i.movedPixels=n,e.swipeCallback(i)}};const t=document.getElementsByClassName("carousel-items");function n(e,t){void 0===t&&(t="next");let n=e.getElementsByClassName("carousel-item is-active")[0],i="next"===t?n.nextElementSibling:n.previousElementSibling,s=n.getAttribute("data-carousel"),a=e.parentNode.getElementsByClassName("carousel-bullet")[s],l="next"===t?a.nextElementSibling:a.previousElementSibling;n.classList.remove("is-active"),a.classList.remove("is-active"),i?(i.classList.add("is-active"),l.classList.add("is-active")):"next"===t?(e.firstElementChild.classList.add("is-active"),e.parentNode.getElementsByClassName("carousel-bullets")[0].firstElementChild.classList.add("is-active")):(e.lastElementChild.classList.add("is-active"),e.parentNode.getElementsByClassName("carousel-bullets")[0].lastElementChild.classList.add("is-active"))}function i(e,t){let n,i=0;for(let e=0;ei&&(i=n);t[0].parentNode.style.minHeight=i+"px"}function s(e){e&&clearInterval(e)}if(t.length>0)for(let a=0;a0&&t.length>0)for(let e=0;edocument.querySelectorAll("[class*=reveal-].is-revealed").length)return;window.removeEventListener("load",i),window.removeEventListener("scroll",s),window.removeEventListener("resize",a)}()}function s(){n(30,i())}function a(){t=window.innerHeight,n(30,i())}e.length>0&&document.body.classList.contains("has-animations")&&(window.addEventListener("load",i),window.addEventListener("scroll",s),window.addEventListener("resize",a))}(),function(){"use strict";const e=document.getElementsByClassName("smooth-scroll"),t=(e,n,i,s,a)=>{const l=n-e;let c=l/i;const o=function(e){return e<.5?2*e*e:(4-2*e)*e-1}(c=Math.min(c,1));window.scroll(0,a+s*o),l{const l=n||(new Date).getTime();t(e,l,i,s,a)})};if(e.length>0)for(let n=0;n{const n=e||(new Date).getTime(),i=n,l=window.pageYOffset,c=s.getBoundingClientRect().top;t(i,n,a,c,l)})})}}(); \ No newline at end of file diff --git a/public/landing/js/mobile-menu.js b/public/landing/js/mobile-menu.js new file mode 100755 index 0000000..0155d4f --- /dev/null +++ b/public/landing/js/mobile-menu.js @@ -0,0 +1,28 @@ +;(function () { + 'use strict' + const navToggle = document.getElementById('header-nav-toggle') + const mainNav = document.getElementById('header-nav') + + if (navToggle) { + // Open menu + navToggle.addEventListener('click', function () { + document.body.classList.toggle('off-nav-is-active') + mainNav.classList.toggle('is-active') + if (mainNav.style.maxHeight) { + mainNav.style.maxHeight = null + } else { + mainNav.style.maxHeight = mainNav.scrollHeight + 'px' + } + this.getAttribute('aria-expanded') === 'true' ? this.setAttribute('aria-expanded', 'false') : this.setAttribute('aria-expanded', 'true') + }) + // Close menu + document.addEventListener('click', function (e) { + if (e.target !== mainNav && e.target !== navToggle && !mainNav.contains(e.target)) { + document.body.classList.remove('off-nav-is-active') + mainNav.classList.remove('is-active') + mainNav.style.maxHeight = null + navToggle.setAttribute('aria-expanded', 'false') + } + }) + } +}()) diff --git a/public/landing/js/modal.js b/public/landing/js/modal.js new file mode 100755 index 0000000..583bb80 --- /dev/null +++ b/public/landing/js/modal.js @@ -0,0 +1,56 @@ +;(function () { + 'use strict' + const modals = document.getElementsByClassName('modal') + const modalTriggers = document.getElementsByClassName('modal-trigger') + + function openModal (el) { + if (el) { + document.body.classList.add('modal-is-active') + el.classList.add('is-active') + } + } + + function closeModals () { + document.body.classList.remove('modal-is-active') + for (let i = 0; i < modals.length; i++) { + modals[i].classList.remove('is-active') + } + } + + if (modals.length > 0 && modalTriggers.length > 0) { + for (let i = 0; i < modalTriggers.length; i++) { + let modalTrigger = modalTriggers[i] + let modal = document.getElementById(modalTrigger.getAttribute('aria-controls')) + if (modal) { + // Modal video + if (modalTrigger.hasAttribute('data-video')) { + if (modal.querySelector('iframe') !== null) { + modal.querySelector('iframe').setAttribute('src', modalTrigger.getAttribute('data-video')) + } else if (modal.querySelector('video') !== null) { + modal.querySelector('video').setAttribute('src', modalTrigger.getAttribute('data-video')) + } + } + modalTrigger.addEventListener('click', function (e) { + e.preventDefault() + if (modalTrigger.hasAttribute('aria-controls')) { + openModal(modal) + } + }) + } + } + } + + document.addEventListener('click', function (e) { + if (e.target.classList.contains('modal') || e.target.classList.contains('modal-close-trigger')) { + e.preventDefault() + closeModals() + } + }) + + document.addEventListener('keydown', function (event) { + var e = event || window.event + if (e.keyCode === 27) { + closeModals() + } + }) +}()) diff --git a/public/landing/js/pricing-switcher.js b/public/landing/js/pricing-switcher.js new file mode 100755 index 0000000..7b5fa8d --- /dev/null +++ b/public/landing/js/pricing-switcher.js @@ -0,0 +1,22 @@ +;(function () { + 'use strict' + const pricingToggle = document.getElementById('pricing-toggle') + + if (pricingToggle) { + window.addEventListener('load', pricingSwitch) + pricingToggle.addEventListener('change', pricingSwitch) + } + + function pricingSwitch () { + const switchables = document.getElementsByClassName('pricing-switchable') + if (pricingToggle.checked) { + for (let i = 0; i < switchables.length; i++) { + switchables[i].innerHTML = switchables[i].getAttribute('data-pricing-yearly') + } + } else { + for (let i = 0; i < switchables.length; i++) { + switchables[i].innerHTML = switchables[i].getAttribute('data-pricing-monthly') + } + } + } +}()) diff --git a/public/landing/js/scroll-reveal.js b/public/landing/js/scroll-reveal.js new file mode 100755 index 0000000..67c43b9 --- /dev/null +++ b/public/landing/js/scroll-reveal.js @@ -0,0 +1,62 @@ +;(function () { + 'use strict' + const revealEl = document.querySelectorAll('[class*=reveal-]') + let viewportHeight = window.innerHeight + + function throttle (delay, fn) { + var lastCall = 0 + return function () { + var now = new Date().getTime() + if (now - lastCall < delay) { + return + } + lastCall = now + return fn.apply(void 0, arguments) + } + } + + function elementIsVisible (el, offset) { + return (el.getBoundingClientRect().top <= viewportHeight - offset) + } + + function revealElements () { + for (let i = 0; i < revealEl.length; i++) { + let el = revealEl[i] + let revealDelay = el.getAttribute('data-reveal-delay') + let revealOffset = (el.getAttribute('data-reveal-offset') ? el.getAttribute('data-reveal-offset') : '200') + let listenedEl = (el.getAttribute('data-reveal-container') ? el.closest(el.getAttribute('data-reveal-container')) : el) + if (elementIsVisible(listenedEl, revealOffset) && !el.classList.contains('is-revealed')) { + if (revealDelay && revealDelay !== 0) { + setTimeout(function () { + el.classList.add('is-revealed') + }, revealDelay) + } else { + el.classList.add('is-revealed') + } + } + } + revealDone() + } + + function revealScroll () { + throttle(30, revealElements()) + } + + function revealResize () { + viewportHeight = window.innerHeight + throttle(30, revealElements()) + } + + function revealDone () { + if (revealEl.length > document.querySelectorAll('[class*=reveal-].is-revealed').length) return + window.removeEventListener('load', revealElements) + window.removeEventListener('scroll', revealScroll) + window.removeEventListener('resize', revealResize) + } + + if (revealEl.length > 0 && document.body.classList.contains('has-animations')) { + window.addEventListener('load', revealElements) + window.addEventListener('scroll', revealScroll) + window.addEventListener('resize', revealResize) + } +}()) diff --git a/public/landing/js/smooth-scroll.js b/public/landing/js/smooth-scroll.js new file mode 100755 index 0000000..6d06297 --- /dev/null +++ b/public/landing/js/smooth-scroll.js @@ -0,0 +1,51 @@ +;(function () { + 'use strict' + const smoothScrollLinks = document.getElementsByClassName('smooth-scroll') + + const easeInOutQuad = function (t) { + return t < 0.5 ? 2 * t * t : -1 + (4 - 2 * t) * t + } + + const scrollToEl = (startTime, currentTime, duration, scrollEndElemTop, startScrollOffset) => { + const runtime = currentTime - startTime + let progress = runtime / duration + + progress = Math.min(progress, 1) + + const ease = easeInOutQuad(progress) + + window.scroll(0, startScrollOffset + (scrollEndElemTop * ease)) + if (runtime < duration) { + window.requestAnimationFrame((timestamp) => { + const currentTime = timestamp || new Date().getTime() + scrollToEl(startTime, currentTime, duration, scrollEndElemTop, startScrollOffset) + }) + } + } + + if (smoothScrollLinks.length > 0) { + for (let i = 0; i < smoothScrollLinks.length; i++) { + const smoothScrollLink = smoothScrollLinks[i] + + smoothScrollLink.addEventListener('click', function (e) { + e.preventDefault() + const link = e.target.closest('.smooth-scroll') + const targetId = link.href.split('#')[1] + const target = document.getElementById(targetId) + const duration = link.getAttribute('data-duration') || 1000 + + if (!target) return + + window.requestAnimationFrame((timestamp) => { + const stamp = timestamp || new Date().getTime() + const start = stamp + + const startScrollOffset = window.pageYOffset + const scrollEndElemTop = target.getBoundingClientRect().top + + scrollToEl(start, stamp, duration, scrollEndElemTop, startScrollOffset) + }) + }) + } + } +}()) diff --git a/public/landing/landing.html b/public/landing/landing.html new file mode 100755 index 0000000..f27fd5f --- /dev/null +++ b/public/landing/landing.html @@ -0,0 +1,327 @@ + + + + + + + Neon Chat + + + +
+ +
+
+
+
+
+
+

The most advanced + video chat ever created.

+

Decentralized video + calling provides real-time HD quality and latency simply + not available with traditional technology.

+ +
+ +
+
+
+
+
+ +
+ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +
+ +
+
+
+
+

Build up the whole picture

+

Duis aute irure dolor in reprehenderit in voluptate velit esse cillum dolore + eu fugiat nulla pariatur excepteur sint — occaecat cupidatat non proident, sunt in culpa + qui.

+
+
+
+
+
+
Feature tile icon 01
+
+

Generate Leads

+

Duis aute irure dolor in reprehenderit in voluptate velit + esse cillum dolore eu fugiat nulla pariatur. Excepteur sint occaecat + cupidatat.

+
+
+
+
+
+
Feature tile icon 02
+
+

Generate Leads

+

Duis aute irure dolor in reprehenderit in voluptate velit + esse cillum dolore eu fugiat nulla pariatur. Excepteur sint occaecat + cupidatat.

+
+
+
+
+
+
Feature tile icon 03
+
+

Generate Leads

+

Duis aute irure dolor in reprehenderit in voluptate velit + esse cillum dolore eu fugiat nulla pariatur. Excepteur sint occaecat + cupidatat.

+
+
+
+
+
+
Feature tile icon 04
+
+

Generate Leads

+

Duis aute irure dolor in reprehenderit in voluptate velit + esse cillum dolore eu fugiat nulla pariatur. Excepteur sint occaecat + cupidatat.

+
+
+
+
+
+
Feature tile icon 05
+
+

Generate Leads

+

Duis aute irure dolor in reprehenderit in voluptate velit + esse cillum dolore eu fugiat nulla pariatur. Excepteur sint occaecat + cupidatat.

+
+
+
+
+
+
Feature tile icon 06
+
+

Generate Leads

+

Duis aute irure dolor in reprehenderit in voluptate velit + esse cillum dolore eu fugiat nulla pariatur. Excepteur sint occaecat + cupidatat.

+
+
+ +
+
+ Try now +
+
+ +
+ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +
+ +
+
+
+ +
+
+
+ + + \ No newline at end of file diff --git a/public/landing/later/additional.html b/public/landing/later/additional.html new file mode 100755 index 0000000..a081b6e --- /dev/null +++ b/public/landing/later/additional.html @@ -0,0 +1,559 @@ + + + + + + + Neon Template + + + +
+ +
+
+
+
+
+

Engage Your Visitors with a beautiful template

+
+
+
+
+
+
+
+
+
$27/m
+
Lorem ipsum is a common text
+
+
+
What’s + included +
+
    +
  • Excepteur sint occaecat velit
  • +
  • Excepteur sint occaecat velit
  • +
  • Excepteur sint occaecat velit
  • +
  • Excepteur sint occaecat velit
  • +
  • Excepteur sint occaecat velit
  • +
+
+
+ +
+
+
+
+
+
+
$47/m
+
Lorem ipsum is a common text
+
+
+
What’s + included +
+
    +
  • Excepteur sint occaecat velit
  • +
  • Excepteur sint occaecat velit
  • +
  • Excepteur sint occaecat velit
  • +
  • Excepteur sint occaecat velit
  • +
  • Excepteur sint occaecat velit
  • +
+
+
+ +
+
+
+
+
+
+
$67/m
+
Lorem ipsum is a common text
+
+
+
What’s + included +
+
    +
  • Excepteur sint occaecat velit
  • +
  • Excepteur sint occaecat velit
  • +
  • Excepteur sint occaecat velit
  • +
  • Excepteur sint occaecat velit
  • +
  • Excepteur sint occaecat velit
  • +
+
+
+ +
+
+
+
+
+
+
+
+
+
+

Meet the team - Lorem ipsum is placeholder + text.

+

Duis aute irure dolor in reprehenderit in voluptate velit esse cillum dolore + eu fugiat nulla pariatur excepteur sint — occaecat cupidatat non proident, sunt in culpa + qui.

+
+
+
+
+
+
Team member 01
+
+
Markus Hasinika
+
Founder & + CEO +
+

Magnis dis parturient montes nascetur. Quam quisque id diam + vel quam ultricies leo integer.

+
+
+
+
+
+
Team member 02
+
+
Diana Stafford
+
Founder & + CEO +
+

Magnis dis parturient montes nascetur. Quam quisque id diam + vel quam ultricies leo integer.

+
+
+
+
+
+
Team member 03
+
+
Patricia + Collins
+
Founder & + CEO +
+

Magnis dis parturient montes nascetur. Quam quisque id diam + vel quam ultricies leo integer.

+
+
+
+
+
+
Team member 04
+
+
Anton Klenkov
+
Founder & + CEO +
+

Magnis dis parturient montes nascetur. Quam quisque id diam + vel quam ultricies leo integer.

+
+
+
+
+
+
Team member 05
+
+
Nick Kornilov
+
Founder & + CEO +
+

Magnis dis parturient montes nascetur. Quam quisque id diam + vel quam ultricies leo integer.

+
+
+
+
+
+
Team member 01
+
+
Andrea Engler
+
Founder & + CEO +
+

Magnis dis parturient montes nascetur. Quam quisque id diam + vel quam ultricies leo integer.

+
+
+
+
+
+
+
+
+
+
+

Features - Lorem ipsum is placeholder + text.

+

Duis aute irure dolor in reprehenderit in voluptate velit esse cillum dolore + eu fugiat nulla pariatur excepteur sint — occaecat cupidatat non proident, sunt in culpa + qui.

+
+
+
+

Data-driven insights

+

Lorem ipsum dolor sit amet, consectetur adipiscing elit, sed do eiusmod + tempor incididunt ut labore et dolore magna aliqua — Ut enim ad minim veniam, quis + nostrud exercitation ullamco laboris nisi ut aliquip ex ea commodo consequat.

+
+
Features split image 01
+
+
+

Data-driven insights

+

Lorem ipsum dolor sit amet, consectetur adipiscing elit, sed do eiusmod + tempor incididunt ut labore et dolore magna aliqua — Ut enim ad minim veniam, quis + nostrud exercitation ullamco laboris nisi ut aliquip ex ea commodo consequat.

+
+
Features split image 02
+
+
+

Data-driven insights

+

Lorem ipsum dolor sit amet, consectetur adipiscing elit, sed do eiusmod + tempor incididunt ut labore et dolore magna aliqua — Ut enim ad minim veniam, quis + nostrud exercitation ullamco laboris nisi ut aliquip ex ea commodo consequat.

+
+
Features split image 03
+
+
+
+
+
+
+
+
+

Lorem ipsum is placeholder text commonly used in the + graphic.

+

Lorem ipsum dolor sit amet, consectetur adipiscing elit, sed do eiusmod + tempor incididunt ut labore et dolore magna aliqua. Ut enim ad minim veniam, quis nostrud + exercitation ullamco laboris nisi ut aliquip ex ea commodo consequat.

+

Duis aute irure dolor in reprehenderit in voluptate velit esse cillum dolore eu fugiat nulla + pariatur. Excepteur sint occaecat cupidatat non proident, sunt in culpa qui officia deserunt + mollit anim id est laborum.

+
Image placeholder +
A super-nice image 😀 +
+
+

Flexibility

+

Lorem ipsum dolor sit amet, consectetur adipiscing elit, sed do eiusmod tempor incididunt ut + labore et dolore magna aliqua. Ut enim ad minim veniam, quis nostrud exercitation ullamco + laboris nisi ut aliquip ex ea commodo consequat sint occaecat cupidatat non proident, sunt + in culpa qui officia deserunt mollit anim id est laborum.

+
    +
  • Lorem ipsum dolor sit amet, consectetur.
  • +
  • Lorem ipsum dolor sit amet, consectetur.
  • +
  • Lorem ipsum dolor sit amet, consectetur.
  • +
+

Lorem ipsum dolor sit amet, consectetur adipiscing elit, sed do eiusmod tempor incididunt ut + labore et dolore magna aliqua. Ut enim ad minim veniam, quis nostrud exercitation ullamco + laboris.

+
+
+
+
+
+
+
+

Modal - Lorem ipsum is placeholder + text commonly used.

+ + +
+
+
+
+
+
+
+
+

Buttons - Lorem ipsum is placeholder text commonly + used.

+ + +
+
+
+
+
+
+
+
+

Input forms - Lorem ipsum is + placeholder text commonly used.

+
+
+
+ +
+
+
+
+ +
+
+
+
+ +
+
Something is wrong.
+
+
+
+ +
+
You’ve done it.
+
+
+
+
+
+
+
+
+
+
+

FAQ - Lorem ipsum is placeholder text + commonly used.

+
    +
  • +
    Nisi porta lorem mollis aliquam ut. +
    +
    +

    Lorem ipsum is placeholder text commonly used + in the graphic, print, and publishing industries for previewing layouts and visual + mockups.

    +
  • +
  • +
    Nisi porta lorem mollis aliquam ut. +
    +
    +

    Lorem ipsum is placeholder text commonly used + in the graphic, print, and publishing industries for previewing layouts and visual + mockups.

    +
  • +
  • +
    Nisi porta lorem mollis aliquam ut. +
    +
    +

    Lorem ipsum is placeholder text commonly used + in the graphic, print, and publishing industries for previewing layouts and visual + mockups.

    +
  • +
  • +
    Nisi porta lorem mollis aliquam ut. +
    +
    +

    Lorem ipsum is placeholder text commonly used + in the graphic, print, and publishing industries for previewing layouts and visual + mockups.

    +
  • +
  • +
    Nisi porta lorem mollis aliquam ut. +
    +
    +

    Lorem ipsum is placeholder text commonly used + in the graphic, print, and publishing industries for previewing layouts and visual + mockups.

    +
  • +
+
+
+
+
+
+
+
+

For previewing layouts and visual?

+
+
+ + + +
+
+
+
+
+
+ +
+ + + \ No newline at end of file diff --git a/public/landing/later/login.html b/public/landing/later/login.html new file mode 100755 index 0000000..d3d9347 --- /dev/null +++ b/public/landing/later/login.html @@ -0,0 +1,62 @@ + + + + + + + Neon Template + + + +
+ +
+ +
+
+ + + \ No newline at end of file diff --git a/public/landing/later/signup.html b/public/landing/later/signup.html new file mode 100755 index 0000000..a7261a3 --- /dev/null +++ b/public/landing/later/signup.html @@ -0,0 +1,62 @@ + + + + + + + Neon Template + + + +
+ +
+ +
+
+ + + \ No newline at end of file diff --git a/public/main.css b/public/main.css deleted file mode 100644 index 8e437ae..0000000 --- a/public/main.css +++ /dev/null @@ -1,12 +0,0 @@ -/*html, body {*/ -/* width: 100%;*/ -/* height: 100%;*/ -/* margin: 0;*/ -/* padding: 0;*/ -/* background-color: #DCECFE;*/ -/* background: -webkit-linear-gradient(-450deg, transparent, rgba(0, 0, 0, 0.05)) repeat-y, -webkit-linear-gradient(-450deg, transparent, rgba(0, 0, 0, 0.05)) repeat-y, -webkit-linear-gradient(-450deg, transparent, rgba(0, 0, 0, 0.05)) repeat-y, -webkit-linear-gradient(-450deg, transparent, rgba(0, 0, 0, 0.05)) repeat-y, -webkit-linear-gradient(-450deg, transparent, rgba(0, 0, 0, 0.05)) repeat-y, -webkit-linear-gradient(-390deg, #DCECFE 0%, #F5E1EE 100%) no-repeat;*/ -/* background: linear-gradient(180deg, transparent, rgba(0, 0, 0, 0.05)) repeat-y, linear-gradient(180deg, transparent, rgba(0, 0, 0, 0.05)) repeat-y, linear-gradient(180deg, transparent, rgba(0, 0, 0, 0.05)) repeat-y, linear-gradient(180deg, transparent, rgba(0, 0, 0, 0.05)) repeat-y, linear-gradient(180deg, transparent, rgba(0, 0, 0, 0.05)) repeat-y, linear-gradient(120deg, #DCECFE 0%, #F5E1EE 100%) no-repeat;*/ -/* background-position: 10%, 30%, 50%, 70%, 90%, 0;*/ -/* background-size: 2px auto, 2px auto, 2px auto, 2px auto, 2px auto, 100% auto;*/ -/* background-attachment: fixed;*/ -/*}*/ \ No newline at end of file diff --git a/index.js b/server.js similarity index 97% rename from index.js rename to server.js index 6fb032b..82aeaf3 100644 --- a/index.js +++ b/server.js @@ -15,7 +15,7 @@ app.get('/', function (req, res) { }); app.get('/landing', function (req, res) { - res.sendFile(path.join(public, 'landing.html')); + res.sendFile(path.join(public, 'landing/landing.html')); }); function log(msg, room) {