.tns-outer {
  padding: 0!important
}

.tns-outer [hidden] {
  display: none!important
}

.tns-outer [aria-controls], .tns-outer [data-action] {
  cursor: pointer
}

.tns-slider {
  -webkit-transition: all 0s;
  -moz-transition: all 0s;
  transition: all 0s
}

.tns-slider>.tns-item {
  -webkit-box-sizing: border-box;
  -moz-box-sizing: border-box;
  box-sizing: border-box
}

.tns-horizontal.tns-subpixel {
  white-space: nowrap
}

.tns-horizontal.tns-subpixel>.tns-item {
  display: inline-block;
  vertical-align: top;
  white-space: normal
}

.tns-horizontal.tns-no-subpixel:after {
  content: "";
  display: table;
  clear: both
}

.tns-horizontal.tns-no-subpixel>.tns-item {
  float: left
}

.tns-horizontal.tns-carousel.tns-no-subpixel>.tns-item {
  margin-right: -100%
}

.tns-gallery, .tns-no-calc {
  position: relative;
  left: 0
}

.tns-gallery {
  min-height: 1px
}

.tns-gallery>.tns-item {
  position: absolute;
  left: -100%;
  -webkit-transition: transform 0s, opacity 0s;
  -moz-transition: transform 0s, opacity 0s;
  transition: transform 0s, opacity 0s
}

.tns-gallery>.tns-slide-active {
  position: relative;
  left: auto!important
}

.tns-gallery>.tns-moving {
  -webkit-transition: all .25s;
  -moz-transition: all .25s;
  transition: all .25s
}

.tns-autowidth {
  display: inline-block
}

.tns-lazy-img {
  -webkit-transition: opacity .6s;
  -moz-transition: opacity .6s;
  transition: opacity .6s;
  opacity: .6
}

.tns-lazy-img.tns-complete {
  opacity: 1
}

.tns-ah {
  -webkit-transition: height 0s;
  -moz-transition: height 0s;
  transition: height 0s
}

.tns-ovh {
  overflow: hidden
}

.tns-visually-hidden {
  position: absolute;
  left: -10000em
}

.tns-transparent {
  opacity: 0;
  visibility: hidden
}

.tns-fadeIn {
  opacity: 1;
  filter: alpha(opacity=100);
  z-index: 0
}

.tns-fadeOut, .tns-normal {
  opacity: 0;
  filter: alpha(opacity=0);
  z-index: -1
}

.tns-vpfix {
  white-space: nowrap
}

.tns-vpfix>div, .tns-vpfix>li {
  display: inline-block
}

.tns-t-subp2 {
  margin: 0 auto;
  width: 310px;
  position: relative;
  height: 10px;
  overflow: hidden
}

.tns-t-ct {
  width: 2333.3333333%;
  width: 2333.33333%;
  position: absolute;
  right: 0
}

.tns-t-ct:after {
  content: "";
  display: table;
  clear: both
}

.tns-t-ct>div {
  width: 1.4285714%;
  width: 1.42857%;
  height: 10px;
  float: left
}

.blocker {
  position: fixed;
  top: 0;
  right: 0;
  bottom: 0;
  left: 0;
  width: 100%;
  height: 100%;
  overflow: auto;
  z-index: 1;
  padding: 20px;
  box-sizing: border-box;
  background-color: #000;
  background-color: rgba(0, 0, 0, .75);
  text-align: center
}

.blocker:before {
  content: "";
  display: inline-block;
  height: 100%;
  vertical-align: middle;
  margin-right: -.05em
}

.blocker.behind {
  background-color: transparent
}

.modal {
  display: none;
  vertical-align: middle;
  position: relative;
  z-index: 2;
  max-width: 500px;
  box-sizing: border-box;
  width: 90%;
  background: #fff;
  padding: 15px 30px;
  -webkit-border-radius: 8px;
  -moz-border-radius: 8px;
  -o-border-radius: 8px;
  -ms-border-radius: 8px;
  border-radius: 8px;
  -webkit-box-shadow: 0 0 10px #000;
  -moz-box-shadow: 0 0 10px #000;
  -o-box-shadow: 0 0 10px #000;
  -ms-box-shadow: 0 0 10px #000;
  box-shadow: 0 0 10px #000;
  text-align: left
}

.modal a.close-modal {
  position: absolute;
  top: -12.5px;
  right: -12.5px;
  display: block;
  width: 30px;
  height: 30px;
  text-indent: -9999px;
  background-size: contain;
  background-repeat: no-repeat;
  background-position: 50%;
  background-image: url("data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAADwAAAA8CAYAAAA6/NlyAAAAAXNSR0IArs4c6QAAA3hJREFUaAXlm8+K00Acx7MiCIJH/yw+gA9g25O49SL4AO3Bp1jw5NvktC+wF88qevK4BU97EmzxUBCEolK/n5gp3W6TTJPfpNPNF37MNsl85/vN/DaTmU6PknC4K+pniqeKJ3k8UnkvDxXJzzy+q/yaxxeVHxW/FNHjgRSeKt4rFoplzaAuHHDBGR2eS9G54reirsmienDCTRt7xwsp+KAoEmt9nLaGitZxrBbPFNaGfPloGw2t4JVamSt8xYW6Dg1oCYo3Yv+rCGViV160oMkcd8SYKnYV1Nb1aEOjCe6L5ZOiLfF120EjWhuBu3YIZt1NQmujnk5F4MgOpURzLfAwOBSTmzp3fpDxuI/pabxpqOoz2r2HLAb0GMbZKlNV5/Hg9XJypguryA7lPF5KMdTZQzHjqxNPhWhzIuAruOl1eNqKEx1tSh5rfbxdw7mOxCq4qS68ZTjKS1YVvilu559vWvFHhh4rZrdyZ69Vmpgdj8fJbDZLJpNJ0uv1cnr/gjrUhQMuI+ANjyuwftQ0bbL6Erp0mM/ny8Fg4M3LtdRxgMtKl3jwmIHVxYXChFy94/Rmpa/pTbNUhstKV+4Rr8lLQ9KlUvJKLyG8yvQ2s9SBy1Jb7jV5a0yapfF6apaZLjLLcWtd4sNrmJUMHyM+1xibTjH82Zh01TNlhsrOhdKTe00uAzZQmN6+KW+sDa/JD2PSVQ873m29yf+1Q9VDzfEYlHi1G5LKBBWZbtEsHbFwb1oYDwr1ZiF/2bnCSg1OBE/pfr9/bWx26UxJL3ONPISOLKUvQza0LZUxSKyjpdTGa/vDEr25rddbMM0Q3O6Lx3rqFvU+x6UrRKQY7tyrZecmD9FODy8uLizTmilwNj0kraNcAJhOp5aGVwsAGD5VmJBrWWbJSgWT9zrzWepQF47RaGSiKfeGx6Szi3gzmX/HHbihwBser4B9UJYpFBNX4R6vTn3VQnez0SymnrHQMsRYGTr1dSk34ljRqS/EMd2pLQ8YBp3a1PLfcqCpo8gtHkZFHKkTX6fs3MY0blKnth66rKCnU0VRGu37ONrQaA4eZDFtWAu2fXj9zjFkxTBOo8F7t926gTp/83Kyzzcy2kZD6xiqxTYnHLRFm3vHiRSwNSjkz3hoIzo8lCKWUlg/YtGs7tObunDAZfpDLbfEI15zsEIY3U/x/gHHc/G1zltnAgAAAABJRU5ErkJggg==")
}

.modal-spinner {
  display: none;
  position: fixed;
  top: 50%;
  left: 50%;
  transform: translateY(-50%) translateX(-50%);
  padding: 12px 16px;
  border-radius: 5px;
  background-color: #111;
  height: 20px
}

.modal-spinner>div {
  border-radius: 100px;
  background-color: #fff;
  height: 20px;
  width: 2px;
  margin: 0 1px;
  display: inline-block;
  -webkit-animation: sk-stretchdelay 1.2s ease-in-out infinite;
  animation: sk-stretchdelay 1.2s ease-in-out infinite
}

.modal-spinner .rect2 {
  -webkit-animation-delay: -1.1s;
  animation-delay: -1.1s
}

.modal-spinner .rect3 {
  -webkit-animation-delay: -1s;
  animation-delay: -1s
}

.modal-spinner .rect4 {
  -webkit-animation-delay: -.9s;
  animation-delay: -.9s
}

@-webkit-keyframes sk-stretchdelay {
  0%, 40%, to {
    -webkit-transform: scaleY(.5)
  }
  20% {
    -webkit-transform: scaleY(1)
  }
}

@keyframes sk-stretchdelay {
  0%, 40%, to {
    transform: scaleY(.5);
    -webkit-transform: scaleY(.5)
  }
  20% {
    transform: scaleY(1);
    -webkit-transform: scaleY(1)
  }
}

html {
  line-height: 1.15;
  -webkit-text-size-adjust: 100%
}

body {
  margin: 0
}

main {
  display: block
}

h1 {
  font-size: 2em;
  margin: .67em 0
}

hr {
  box-sizing: content-box;
  height: 0;
  overflow: visible
}

pre {
  font-family: monospace, monospace;
  font-size: 1em
}

a {
  background-color: transparent
}

abbr[title] {
  border-bottom: none;
  text-decoration: underline;
  -webkit-text-decoration: underline dotted;
  text-decoration: underline dotted
}

b, strong {
  font-weight: bolder
}

code, kbd, samp {
  font-family: monospace, monospace;
  font-size: 1em
}

small {
  font-size: 80%
}

sub, sup {
  font-size: 75%;
  line-height: 0;
  position: relative;
  vertical-align: baseline
}

sub {
  bottom: -.25em
}

sup {
  top: -.5em
}

img {
  border-style: none
}

button, input, optgroup, select, textarea {
  font-family: inherit;
  font-size: 100%;
  line-height: 1.15;
  margin: 0
}

button, input {
  overflow: visible
}

button, select {
  text-transform: none
}

[type=button], [type=reset], [type=submit], button {
  -webkit-appearance: button
}

[type=button]::-moz-focus-inner, [type=reset]::-moz-focus-inner, [type=submit]::-moz-focus-inner, button::-moz-focus-inner {
  border-style: none;
  padding: 0
}

[type=button]:-moz-focusring, [type=reset]:-moz-focusring, [type=submit]:-moz-focusring, button:-moz-focusring {
  outline: 1px dotted ButtonText
}

fieldset {
  padding: .35em .75em .625em
}

legend {
  box-sizing: border-box;
  color: inherit;
  display: table;
  max-width: 100%;
  padding: 0;
  white-space: normal
}

progress {
  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-decoration {
  -webkit-appearance: none
}

::-webkit-file-upload-button {
  -webkit-appearance: button;
  font: inherit
}

details {
  display: block
}

summary {
  display: list-item
}

[hidden], template {
  display: none
}

@font-face {
  font-family: neue;
  src: url(fonts/NeueHaasDisplay-Roman.e29878ea94d5e30a85f3d6ceed80cc21.woff) format("woff");
  font-weight: 500;
  font-style: normal
}

@font-face {
  font-family: neue;
  src: url(fonts/NeueHaasDisplay-Mediu.7b718b2da47fc7054456ccda45f87653.woff) format("woff");
  font-weight: 700;
  font-style: normal
}

@font-face {
  font-family: neue;
  src: url(fonts/NeueHaasDisplay-Thin_1.6969f0f395fe15fac1e92a33325fb0f4.woff) format("woff");
  font-weight: 300;
  font-style: normal
}

body, html {
  height: 100%;
  color: #1e1f21;
  font-family: neue, sans-serif;
  font-weight: 500
}

* {
  box-sizing: border-box
}

a {
  color: #1e1f21;
  text-decoration: none
}

button:focus {
  outline: none
}

.main {
  min-height: 100%;
  overflow: hidden
}

.main__container {
  padding-top: 100px
}

@media (min-width:1025px) {
  .main__container {
    padding-top: 0
  }
}

.wtt {
  display: none
}

@media (min-width:1025px) {
  .wtt {
    display: block
  }
}

body {
  background-color: #e7f1f2;
  transition: background-color 1s cubic-bezier(.4, 0, 0, 1);
  cursor: url(images/cursor.e3a0a808d0dd1627f27894989020261c.svg) 5 5, auto
}

body[data-page=about] {
  background-color: #f6f0e9
}

a, button {
  cursor: url(images/cursor.e3a0a808d0dd1627f27894989020261c.svg) 5 5, auto
}

.modal {
  width: 100%;
  height: 100%;
  border-radius: 0;
  padding: 0;
  max-width: none;
  transform-origin: 50% 0;
  transform: scaleY(0);
  transition: transform .45s cubic-bezier(.4, 0, 0, 1);
  box-shadow: none
}

.modal--about {
  max-width: 80%;
  height: auto;
  margin-top: 10px;
  padding-bottom: 20px;
  overflow: hidden
}

@media (min-width:1025px) {
  .modal--about {
    margin-top: 0;
    height: 100%;
    overflow: visible
  }
}

@media (min-width:1025px) {
  .modal {
    width: 602px
  }
}

.modal__inner {
  opacity: 1;
  height: 100%;
  position: relative;
  z-index: 2;
  background-color: #fff
}

.modal__container {
  max-height: 100%;
  overflow: auto;
  opacity: .01;
  height: 100%;
  transform: translateY(200px);
  transition: transform .45s cubic-bezier(.4, 0, 0, 1) .1s, opacity .45s cubic-bezier(.4, 0, 0, 1) .1s;
  padding: 30px 20px
}

.modal--about .modal__container {
  padding-top: 0;
  padding-bottom: 0
}

@media (min-width:1025px) {
  .modal--about .modal__container {
    padding-top: 10px
  }
}

.modal.open {
  transform: scaleY(1)
}

.modal.open .modal__container {
  opacity: 1;
  transform: none
}

.modal__close.round-outline-btn {
  position: absolute;
  right: 20px;
  top: 18px;
  z-index: 3
}

@media (min-width:1025px) {
  .modal__close.round-outline-btn {
    top: 20px;
    left: -80px;
    right: auto;
    transform: translateX(100px);
    transition: transform .2s cubic-bezier(.4, 0, 0, 1);
    z-index: 1
  }
  .modal__close.round-outline-btn:hover {
    transform: translateX(100px) scale(1.2)
  }
  .open .modal__close.round-outline-btn {
    transform: translateX(0);
    transition: transform .2s cubic-bezier(.4, 0, 0, 1) .35s
  }
}

.blocker {
  background-color: rgba(0, 0, 0, .4);
  padding: 0;
  z-index: 30
}

@media (min-width:1025px) {
  .blocker {
    text-align: right
  }
}

.blocker:before {
  display: none
}

.hover-reveal {
  position: absolute;
  z-index: -1;
  width: 200px;
  height: 200px;
  top: 0;
  right: 66px;
  pointer-events: none;
  opacity: 0;
  will-change: transform
}

@media (max-width:1024px) {
  .hover-reveal {
    transition: opacity .45s cubic-bezier(.4, 0, 0, 1);
    z-index: 1;
    width: 160px;
    height: 160px;
    top: -40px;
    left: auto;
    right: 0
  }
}

.hover-reveal.show-on-mobile {
  opacity: 1
}

.hover-reveal__inner {
  overflow: hidden
}

.hover-reveal__img, .hover-reveal__inner {
  width: 100%;
  height: 100%;
  position: relative
}

.hover-reveal__img {
  background-size: cover;
  background-position: 50% 50%
}

.cursor-drag {
  display: none;
  width: 80px;
  height: 80px
}

.cursor-drag__inner {
  transform-origin: 50% 50%;
  width: 100%;
  height: 100%;
  margin-left: -40px;
  margin-top: -40px
}

.cursor-drag svg {
  position: relative;
  z-index: 2
}

@media (any-pointer:fine) and (min-width:1025px) {
  .cursor-drag {
    position: fixed;
    top: 0;
    left: 0;
    display: block;
    pointer-events: none;
    z-index: 40
  }
}

.cursor-drag circle {
  fill: none;
  stroke: #1e1f21;
  stroke-width: 1px
}

.cursor-drag__circle-copy, .cursor-drag circle {
  transform: scale(.6);
  transform-origin: 50% 50%;
  transition: all .8s cubic-bezier(.4, 0, 0, 1)
}

.cursor-drag__circle-copy {
  position: absolute;
  z-index: 1;
  background-color: rgba(103, 144, 150, .1);
  -webkit-animation: bg-animation 20s ease infinite;
  animation: bg-animation 20s ease infinite;
  background-size: 700% 700%;
  width: 80px;
  height: 80px;
  top: 0;
  left: 0;
  margin-top: -40px;
  margin-left: -40px;
  opacity: 0;
  border-radius: 50%
}

.cursor-drag ellipse {
  opacity: 0;
  transition: all .8s cubic-bezier(.4, 0, 0, 1)
}

.cursor-drag.hover-carousel circle {
  transform: scale(1);
  fill: #1e1f21
}

.cursor-drag.hover-carousel ellipse {
  opacity: 1
}

.cursor-drag.hover-link circle {
  transform: scale(1);
  fill: rgba(218, 233, 235, 0);
  stroke: rgba(30, 31, 33, 0)
}

.cursor-drag.hover-link .cursor-drag__circle-copy {
  transform: scale(1);
  opacity: 1
}

@-webkit-keyframes bg-animation {
  0% {
    background-position: 0 50%
  }
  50% {
    background-position: 100% 50%
  }
  to {
    background-position: 0 50%
  }
}

@keyframes bg-animation {
  0% {
    background-position: 0 50%
  }
  50% {
    background-position: 100% 50%
  }
  to {
    background-position: 0 50%
  }
}

.pulsating-circle {
  position: absolute;
  left: 0;
  top: 0;
  transform: translateX(-50%) translateY(-50%);
  width: 30px;
  height: 30px;
  opacity: 0;
  transition: opacity 1s cubic-bezier(.4, 0, 0, 1)
}

.pulsating .pulsating-circle {
  opacity: 1
}

.pulsating-circle:before {
  content: "";
  position: relative;
  display: block;
  width: 300%;
  height: 300%;
  box-sizing: border-box;
  margin-left: -100%;
  margin-top: -100%;
  border-radius: 45px;
  background-color: rgba(30, 31, 33, .66);
  -webkit-animation: pulse-ring 1.25s cubic-bezier(.215, .61, .355, 1) infinite;
  animation: pulse-ring 1.25s cubic-bezier(.215, .61, .355, 1) infinite
}

.pulsating-circle:after {
  content: "";
  position: absolute;
  left: 0;
  top: 0;
  display: block;
  width: 100%;
  height: 100%;
  background-color: #1e1f21;
  border-radius: 15px;
  box-shadow: 0 0 8px rgba(0, 0, 0, .3);
  -webkit-animation: pulse-dot 1.25s cubic-bezier(.455, .03, .515, .955) -.4s infinite;
  animation: pulse-dot 1.25s cubic-bezier(.455, .03, .515, .955) -.4s infinite
}

@-webkit-keyframes pulse-ring {
  0% {
    transform: scale(.63)
  }
  80%, to {
    opacity: 0
  }
}

@keyframes pulse-ring {
  0% {
    transform: scale(.63)
  }
  80%, to {
    opacity: 0
  }
}

@-webkit-keyframes pulse-dot {
  0% {
    transform: scale(.8)
  }
  50% {
    transform: scale(1)
  }
  to {
    transform: scale(.8)
  }
}

@keyframes pulse-dot {
  0% {
    transform: scale(.8)
  }
  50% {
    transform: scale(1)
  }
  to {
    transform: scale(.8)
  }
}

.flip-container, .flip-container img {
  width: 100%
}

.flip-wrapper {
  font-size: 170px;
  color: #fff;
  position: absolute;
  font-weight: 700;
  transform: translate(-50%, -50%);
  top: 50%;
  left: 50%
}

@media (min-width:1025px) {
  .flip-wrapper {
    font-size: 280px
  }
}

.flip-template {
  color: #fff;
  opacity: 0
}

.flip-slice {
  color: #fff;
  position: absolute;
  top: 0;
  left: 0;
  height: 100%;
  -webkit-animation: scale 4s infinite;
  animation: scale 4s infinite;
  transition: all .1s;
  transform-origin: bottom right
}

.flip-slice.opposite {
  right: 0;
  left: auto;
  -webkit-animation: scale-opposite 4s infinite;
  animation: scale-opposite 4s infinite;
  transition: all .1s
}

.flip-slice.opposite .flip-mask {
  right: 0;
  left: auto
}

.flip-mask {
  position: absolute;
  overflow: hidden
}

@-webkit-keyframes scale {
  0% {
    transform: scaleX(1)
  }
  25% {
    transform: scaleX(0)
  }
  50% {
    transform: scaleX(1)
  }
}

@keyframes scale {
  0% {
    transform: scaleX(1)
  }
  25% {
    transform: scaleX(0)
  }
  50% {
    transform: scaleX(1)
  }
}

@-webkit-keyframes scale-opposite {
  0% {
    transform: scaleX(0)
  }
  25% {
    transform: scaleZ(0)
  }
  50% {
    transform: scaleX(0)
  }
  to {
    transform: scaleX(0)
  }
}

@keyframes scale-opposite {
  0% {
    transform: scaleX(0)
  }
  25% {
    transform: scaleZ(0)
  }
  50% {
    transform: scaleX(0)
  }
  to {
    transform: scaleX(0)
  }
}

.split-line {
  overflow: hidden;
  display: inline-block;
  position: relative
}

@media (max-width:768px) {
  .split-line--skip-mobile {
    display: inline
  }
}

.split-line__hidden-text {
  transform: translateY(100%);
  -webkit-user-select: none;
  -moz-user-select: none;
  -ms-user-select: none;
  user-select: none;
  position: absolute;
  top: 0;
  left: 0
}

.split-line__transparent-text {
  color: transparent
}

.animate-showing {
  transform: translateY(60px);
  opacity: 0;
  transition: opacity .4s cubic-bezier(.4, 0, 0, 1) .3s, transform .4s cubic-bezier(.4, 0, 0, 1) .3s
}

@media (max-width:768px) {
  .animate-showing {
    transition-delay: .1s, .1s
  }
}

.animate-showing--showed {
  opacity: 1;
  transform: none
}

@media (max-width:1024px) {
  .animate-showing-mobile {
    transition: opacity .4s cubic-bezier(.4, 0, 0, 1), transform .4s cubic-bezier(.4, 0, 0, 1);
    opacity: 0;
    transform: translateY(60px)
  }
}

.animate-showing-mobile.animate-showing--showed {
  opacity: 1;
  transform: none
}

@media (min-width:1025px) {
  .delay-0 {
    transition-delay: 0s, 0s
  }
}

@media (min-width:1025px) {
  .delay-5 {
    transition-delay: .5s, .5s
  }
}

@media (min-width:1025px) {
  .delay-7 {
    transition-delay: .7s, .7s
  }
}

@media (min-width:1025px) {
  .delay-9 {
    transition-delay: .9s, .9s
  }
}

.curtain {
  position: fixed;
  width: 100%;
  height: 100%;
  background-color: #dae9eb;
  transform: translateY(100%);
  opacity: .3;
  transition: transform .45s cubic-bezier(.4, 0, 0, 1), opacity .45s cubic-bezier(.4, 0, 0, 1)
}

.curtain.show {
  transform: translateY(0);
  opacity: 1
}

.curtain-closed {
  transition: transform .45s cubic-bezier(.4, 0, 0, 1), opacity .45s cubic-bezier(.4, 0, 0, 1);
  transform: scale(.9);
  opacity: .3
}

.btn {
  color: #fff;
  background-color: #1e1f21;
  height: 65px;
  display: inline-flex;
  align-items: center;
  padding-left: 32px;
  padding-right: 32px;
  font-size: 14px;
  letter-spacing: -.02em;
  border: none;
  cursor: pointer
}

.btn__arrow {
  margin-left: 12px
}

.btn__text {
  overflow: hidden;
  display: inline-block;
  position: relative
}

.btn__text span {
  color: transparent
}

.btn__text:after, .btn__text:before {
  content: attr(data-text);
  position: absolute;
  left: 0;
  top: 0;
  transition: transform .35s cubic-bezier(.4, 0, 0, 1)
}

.btn__text:after {
  transform: translateY(100%)
}

@media (min-width:1366px) {
  .btn:hover:not(:disabled) .btn__text:before {
    transform: translateY(-100%)
  }
  .btn:hover:not(:disabled) .btn__text:after {
    transform: none
  }
}

.btn:focus {
  outline: none
}

.round-btn {
  width: 35px;
  height: 35px;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  background-color: #fff;
  border: none;
  transition: transform .35s cubic-bezier(.4, 0, 0, 1), opacity .35s cubic-bezier(.4, 0, 0, 1)
}

.round-btn:after {
  content: "";
  position: absolute;
  z-index: 1;
  width: 100%;
  height: 100%;
  left: 0;
  top: 0;
  transform: scale(0);
  transform-origin: 50% 50%;
  background-color: #1e1f21;
  border-radius: 50%
}

.round-btn:after, .round-btn svg {
  transition: transform .35s cubic-bezier(.4, 0, 0, 1)
}

.round-btn svg {
  position: relative;
  z-index: 2
}

.round-btn svg path {
  transition: transform .35s cubic-bezier(.4, 0, 0, 1)
}

@media (min-width:1366px) {
  .round-btn:hover {
    transform: scale(1.2)
  }
  .round-btn:hover:after {
    transform: scale(1)
  }
  .round-btn:hover svg path {
    fill: #fff
  }
}

.round-outline-btn {
  width: 44px;
  height: 44px;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  border: 1px solid rgba(30, 31, 33, .2);
  background: transparent;
  overflow: hidden;
  position: relative;
  transition: transform .35s cubic-bezier(.4, 0, 0, 1);
  padding: 0
}

@media (min-width:1025px) {
  .round-outline-btn {
    width: 60px;
    height: 60px
  }
}

.round-outline-btn svg {
  position: relative;
  z-index: 2
}

.round-outline-btn:after, .round-outline-btn svg, .round-outline-btn svg path {
  transition: transform .35s cubic-bezier(.4, 0, 0, 1)
}

.round-outline-btn:after {
  content: "";
  position: absolute;
  z-index: 1;
  width: 100%;
  height: 100%;
  left: 0;
  top: 0;
  transform: scale(0);
  transform-origin: 50% 50%;
  background-color: #1e1f21;
  border-radius: 50%
}

@media (min-width:1366px) {
  .round-outline-btn:hover {
    transform: scale(1.2)
  }
  .round-outline-btn:hover:after {
    transform: scale(1)
  }
  .round-outline-btn:hover svg path {
    fill: #fff
  }
}

.round-outline-btn--solid {
  background-color: #fff
}

.round-outline-btn--no-outline-on-hover:hover {
  overflow: visible;
  border-color: transparent
}

@media (min-width:1366px) {
  .round-outline-btn--no-outline-on-hover:hover {
    transform: scale(1.2)
  }
  .round-outline-btn--no-outline-on-hover:hover:after {
    transform: scale(1.1)
  }
}

@media (min-width:1366px) {
  .round-outline-btn--no-hover:hover:after {
    transform: scale(0)
  }
  .round-outline-btn--no-hover:hover svg path {
    fill: #1e1f21
  }
}

.round-outline-btn--no-outline {
  border-color: transparent
}

.list {
  position: relative;
  transition: background-color 1s cubic-bezier(.4, 0, 0, 1)
}

.list__rotate-image-holder {
  -webkit-animation: tilt 10s linear infinite alternate;
  animation: tilt 10s linear infinite alternate;
  height: 100%;
  display: flex;
  align-items: center;
  justify-content: center
}

.list__rotate-image-holder img {
  max-height: 100%;
  display: block
}

@media (min-width:1025px) {
  .list__row {
    display: flex;
    margin-left: -10px;
    margin-right: -10px
  }
}

@media (min-width:1025px) {
  .list__col {
    flex-grow: 1;
    margin-left: 5px;
    margin-right: 5px
  }
}

@-webkit-keyframes tilt {
  0% {
    transform: perspective(1000px) rotateX(25deg) rotateY(25deg) scaleX(1)
  }
  to {
    transform: perspective(1000px) rotateX(-25deg) rotateY(-25deg) scaleX(1)
  }
}

@keyframes tilt {
  0% {
    transform: perspective(1000px) rotateX(25deg) rotateY(25deg) scaleX(1)
  }
  to {
    transform: perspective(1000px) rotateX(-25deg) rotateY(-25deg) scaleX(1)
  }
}

.point {
  width: 68px;
  height: 68px;
  background-color: #000;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  opacity: 0;
  transition: opacity .35s cubic-bezier(.4, 0, 0, 1)
}

.ready .point {
  opacity: 1
}

.point svg {
  transition: transform .35s cubic-bezier(.4, 0, 0, 1)
}

.point--up svg {
  transform: scaleY(-1)
}

.lp {
  display: none
}

@media (min-width:1025px) {
  .lp {
    display: flex;
    position: fixed;
    z-index: 20;
    padding: 26px 50px;
    height: 100vh;
    flex-direction: column;
    align-items: center;
    justify-content: space-between
  }
}

@media (min-width:1025px) {
  .lp__logo {
    display: block;
    z-index: 10;
    left: 50px;
    top: 26px
  }
}

.lp__logo-img {
  width: 65px;
  height: 65px
}

.lp__scroll-block {
  display: flex;
  align-items: center;
  transform-origin: 50% 50%;
  transform: rotate(-90deg);
  position: absolute;
  opacity: 0;
  transition: opacity .45s cubic-bezier(.4, 0, 0, 1)
}

.ready .lp__scroll-block {
  opacity: 1
}

.lp__scroll {
  height: 1px;
  width: 162px;
  position: relative
}

.lp__scroll-rail {
  position: absolute;
  width: 100%;
  height: 100%;
  background-color: rgba(30, 31, 33, .2);
  top: 0;
  left: 0
}

.lp__scroll-trigger {
  position: absolute;
  width: 24px;
  height: 100%;
  top: 0;
  right: 0;
  background-color: #1e1f21
}

.lp__title {
  font-size: 14px;
  display: inline-block;
  white-space: nowrap;
  margin-left: 14px;
  margin-right: 14px;
  transition: transform .35s cubic-bezier(.4, 0, 0, 1)
}

.lp__title--section {
  text-align: left;
  width: 80px;
  min-width: 80px;
  max-width: 80px;
  height: 16px;
  overflow: hidden
}

.lp__title--arrow {
  height: 14px;
  overflow: hidden;
  width: 18px
}

.lp__sections-list {
  display: flex;
  justify-content: flex-start;
  flex-direction: column;
  transition: transform .35s cubic-bezier(.4, 0, 0, 1)
}

.lp__sections-list--arrow {
  align-items: flex-end
}

.lp__scroll-wrap {
  position: relative;
  transform: translateX(-156px)
}

.lp__arrow {
  transform: rotate(90deg);
  position: relative
}

.lp__arrow--flip {
  right: 2px;
  top: -2px;
  transform: rotate(-90deg)
}

.top-section {
  height: calc(100vh - 100px);
  position: relative;
  display: flex;
  flex-direction: column;
  justify-content: center;
  padding-bottom: 153px
}

@media (min-width:1025px) {
  .top-section {
    display: block;
    padding-bottom: 0;
    height: auto
  }
}

.header {
  position: fixed;
  width: 100%;
  top: 0;
  left: 0;
  padding-top: 0;
  z-index: 10;
  transition: transform 1s cubic-bezier(.4, 0, 0, 1), background-color 1s cubic-bezier(.4, 0, 0, 1)
}

@media (min-width:1025px) {
  .header {
    padding-top: 23px
  }
}

.header--hide {
  transform: translateY(-100%)
}

.header__logo {
  margin-left: -7px
}

.header__logo img {
  width: 54px;
}

@media (min-width:1025px) {
  .header__logo {
    display: none
  }
}

.header__container {
  padding: 20px;
  display: flex;
  align-items: center
}

@media (min-width:1025px) {
  .header__container {
    max-width: 1440px;
    margin-left: auto;
    margin-right: auto;
    padding-left: 262px;
    padding-right: 57px
  }
}

.header__links {
  margin-left: auto;
  line-height: 130%;
  display: flex;
  align-items: center
}

@media (min-width:1025px) {
  .header__links {
    margin-right: auto;
    flex-grow: 1;
    margin-left: 0;
    align-items: baseline
  }
}

.header__link {
  margin-right: 16px;
  font-size: 12px
}

@media (min-width:1025px) {
  .header__link {
    font-size: 14px;
    display: inline-block;
    position: relative
  }
  .header__link:after, .header__link:before {
    position: absolute;
    content: "";
    height: 1px;
    width: 100%;
    background-color: #1e1f21;
    bottom: 0;
    left: 0;
    transform: scaleX(0);
    transform-origin: 100% 50%;
    transition: transform .35s cubic-bezier(.4, 0, 0, 1)
  }
  .header__link:after {
    display: none
  }
  .header__link:hover:before {
    transform-origin: 0 50%;
    transform: scaleX(1)
  }
}

.header__link--email {
  display: none
}

@media (min-width:1025px) {
  .header__link--email {
    display: inline-block;
    margin-left: auto;
    margin-right: 0
  }
  .header__link--email:before {
    transform: scaleX(1);
    transition: none
  }
  .header__link--email:after {
    display: inline-block;
    transition: none
  }
  .header__link--email:hover:before {
    transform-origin: 100% 50%;
    transform: scaleX(0);
    transition: transform .35s cubic-bezier(.4, 0, 0, 1)
  }
  .header__link--email:hover:after {
    transform-origin: 0 50%;
    transform: scaleX(1);
    transition: transform .35s cubic-bezier(.4, 0, 0, 1);
    transition-delay: .35s
  }
}

@media screen and (min-width:1441px) {
  .header__link--email {
    display: none
  }
}

.header__link--email-xl {
  display: none
}

@media screen and (min-width:1441px) {
  .header__link--email-xl {
    display: inline-block;
    top: 46px;
    right: 85px;
    position: absolute
  }
}

.header__btn {
  margin-left: 4px
}

@media (min-width:1025px) {
  .header__btn {
    display: none
  }
}

@media (min-width:1025px) {
  .introduction {
    overflow: hidden
  }
}

.introduction__container {
  position: relative;
  padding: 20px
}

@media (min-width:1025px) {
  .introduction__container {
    max-width: 1440px;
    margin-left: auto;
    margin-right: auto;
    padding: 0 57px 0 262px
  }
}

.introduction__chart {
  position: absolute;
  z-index: 1;
  width: 122px;
  height: 122px;
  top: 0;
  right: 17px;
  border-radius: 50%;
  overflow: hidden;
  background: url(images/main-chart.12b4d4202fa261b52a9e100c2fbd6aff.svg) no-repeat #dae9eb 50%;
  background-size: cover
}

@media (min-width:1025px) {
  .introduction__chart {
    background: none;
    background-color: #dae9eb;
    width: 364px;
    height: 364px;
    top: 0;
    right: 210px;
    opacity: 0
  }
}

.introduction__chart svg {
  display: none
}

@media (min-width:1025px) {
  .introduction__chart svg {
    display: block;
    margin-left: -710px;
    margin-top: 16px
  }
}

@media (min-width:1025px) {
  .curtain-fired .introduction__chart {
    opacity: 1
  }
}

.introduction__title {
  font-size: 38px;
  letter-spacing: -.01em;
  line-height: 1
}

@media (min-width:1025px) {
  .introduction__title {
    font-size: 65px;
    line-height: 1
  }
  .introduction__title .split-line {
    margin-bottom: -.15em
  }
}

.introduction__front-layer {
  position: relative;
  z-index: 2;
  padding-top: 64px
}

@media (min-width:1025px) {
  .introduction__front-layer {
    padding-top: 0;
    margin-top: 208px
  }
}

.introduction__description {
  padding-top: 17px;
  font-size: 14px;
  line-height: 140%;
  padding-bottom: 24px;
  max-width: 200px
}

@media (min-width:1025px) {
  .introduction__description {
    font-size: 20px;
    max-width: 376px;
    padding-bottom: 42px;
    padding-top: 31px
  }
}

.introduction__point {
  display: flex;
  position: absolute;
  bottom: 20px;
  left: 20px
}

@media (min-width:1025px) {
  .introduction__point {
    display: none
  }
}

@media screen and (max-width:414px) {
  .introduction__point {
    bottom: -78px
  }
}

.introduction__link-to-about {
  display: inline-block;
  margin-top: 22px;
  position: relative
}

.introduction__link-to-about:after, .introduction__link-to-about:before {
  position: absolute;
  content: "";
  height: 1px;
  width: 100%;
  background-color: #1e1f21;
  bottom: 0;
  left: 0;
  transform: scaleX(0);
  transform-origin: 100% 50%;
  transition: transform .35s cubic-bezier(.4, 0, 0, 1)
}

.introduction__link-to-about:before {
  transform: scaleX(1);
  transition: none
}

.introduction__link-to-about:after {
  display: inline-block;
  transition: none
}

.introduction__link-to-about:hover:before {
  transform-origin: 100% 50%;
  transform: scaleX(0);
  transition: transform .35s cubic-bezier(.4, 0, 0, 1)
}

.introduction__link-to-about:hover:after {
  transform-origin: 0 50%;
  transform: scaleX(1);
  transition: transform .35s cubic-bezier(.4, 0, 0, 1);
  transition-delay: .35s
}

.cursor {
  display: none
}

.item {
  padding-top: 27px;
  padding-bottom: 8px;
  border-bottom: 1px solid #1e1f21;
  font-size: 26px;
  line-height: 90%;
  letter-spacing: -.01em;
  display: flex;
  align-items: center;
  position: relative;
  transition: border-bottom-color .35s cubic-bezier(.4, 0, 0, 1)
}

@media (min-width:1025px) {
  .item {
    padding-bottom: 23px;
    padding-top: 34px
  }
}

@media (min-width:1025px) {
  .item, .item--sm {
    letter-spacing: normal;
    line-height: 1
  }
  .item--sm {
    padding-top: 40px;
    padding-bottom: 17px
  }
}

@media (min-width:1025px) {
  .item:hover {
    border-bottom-color: rgba(30, 31, 33, .4)
  }
}

@media (max-width:1024px) {
  .item .active-on-mobile {
    border-bottom-color: rgba(30, 31, 33, .4)
  }
}

.item__title {
  margin-right: auto;
  transition: opacity .35s cubic-bezier(.4, 0, 0, 1)
}

@media (min-width:1025px) {
  .item__title {
    font-size: 50px;
    line-height: 85%;
    letter-spacing: -.02em
  }
}

@media (min-width:1025px) {
  .item__title--sm {
    font-size: 30px;
    line-height: 110%
  }
}

@media (min-width:1025px) {
  .item:hover .item__title {
    opacity: .4
  }
}

@media (max-width:1024px) {
  .active-on-mobile .item__title {
    opacity: .4
  }
}

.item__number {
  flex-basis: 45px;
  flex-shrink: 0
}

@media (min-width:1025px) {
  .item__number {
    font-size: 30px;
    line-height: 90%;
    letter-spacing: -.02em
  }
}

@media (min-width:1025px) {
  .item:hover .item__number {
    opacity: .4
  }
}

@media (max-width:1024px) {
  .active-on-mobile .item__number {
    opacity: .4
  }
}

.item__hidden-img {
  display: none
}

.services {
  padding-top: 130px
}

@media (min-width:1025px) {
  .services {
    padding-top: 295px
  }
}

.services__container {
  padding-left: 20px;
  padding-right: 20px
}

@media (min-width:1025px) {
  .services__container {
    max-width: 1440px;
    margin-left: auto;
    margin-right: auto;
    padding-left: 262px;
    padding-right: 57px
  }
}

.services__title {
  padding-top: 49px;
  font-size: 22px;
  line-height: 90%;
  letter-spacing: -.01em
}

@media (min-width:1025px) {
  .services__title {
    font-size: 30px;
    line-height: 110%
  }
}

.services__list {
  padding-top: 22px
}

@media (min-width:1025px) {
  .services__list {
    padding-top: 50px;
    display: flex;
    align-items: center
  }
}

.services-introduction {
  border-bottom: 2px solid #1e1f21;
  padding-bottom: 18px
}

@media (min-width:1025px) {
  .services-introduction {
    display: flex;
    align-items: flex-start;
    padding-bottom: 45px
  }
}

.services-introduction__title {
  font-size: 26px;
  line-height: 90%;
  letter-spacing: -.01em;
  padding-bottom: 13px
}

@media (min-width:1025px) {
  .services-introduction__title {
    font-size: 50px;
    line-height: 85%;
    letter-spacing: -.02em;
    flex-basis: 340px;
    margin-right: 43px;
    flex-grow: 1;
    min-width: 340px
  }
}

.services-introduction__description {
  font-size: 14px;
  line-height: 140%
}

@media (min-width:1025px) {
  .services-introduction__description {
    font-size: 20px;
    line-height: 130%;
    padding-right: 100px
  }
}

.service {
  border-bottom: 1px solid rgba(30, 31, 33, .2);
  padding-bottom: 31px
}

@media (max-width:768px) {
  .service:not(:last-child) {
    margin-bottom: 26px
  }
}

@media (max-width:1024px) {
  .service:not(:last-child) {
    margin-bottom: 26px
  }
}

@media (min-width:1025px) {
  .service {
    margin-bottom: 0;
    padding-bottom: 0;
    padding-right: 80px;
    border-bottom: 0
  }
}

.service__number {
  font-size: 14px;
  line-height: 140%
}

@media (min-width:1025px) {
  .service__number {
    font-size: 16px;
    line-height: 150%;
    transition: transform .35s cubic-bezier(.4, 0, 0, 1);
    transition-delay: .1s
  }
  .service:hover .service__number {
    transform: translateX(10px);
    transition-delay: 0s
  }
}

.service__title {
  padding-top: 17px;
  font-size: 22px;
  line-height: 90%;
  letter-spacing: -.01em
}

@media (min-width:1025px) {
  .service__title {
    padding-top: 28px;
    font-size: 30px;
    line-height: 110%;
    transition: transform .35s cubic-bezier(.4, 0, 0, 1);
    transition-delay: .05s
  }
  .service:hover .service__title {
    transform: translateX(10px);
    transition-delay: .05s
  }
}

.service__description {
  padding-top: 12px;
  font-size: 14px;
  line-height: 140%;
  padding-bottom: 14px
}

@media (min-width:1025px) {
  .service__description {
    padding-top: 13px;
    font-size: 16px;
    line-height: 150%;
    padding-bottom: 35px;
    transition: transform .35s cubic-bezier(.4, 0, 0, 1);
    transition-delay: 0s
  }
  .service:hover .service__description {
    transform: translateX(10px);
    transition-delay: .1s
  }
}

.work {
  padding-top: 100px
}

@media (min-width:1025px) {
  .work {
    padding-top: 295px
  }
}

.work__container {
  padding-left: 20px;
  padding-right: 20px
}

@media (min-width:1025px) {
  .work__container {
    max-width: 1440px;
    margin-left: auto;
    margin-right: auto;
    padding-left: 262px;
    padding-right: 57px
  }
}

.work__title {
  font-size: 22px;
  line-height: 90%;
  letter-spacing: -.01em;
  padding-bottom: 29px;
  border-bottom: 2px solid #1e1f21
}

@media (min-width:1025px) {
  .work__title {
    font-size: 50px;
    line-height: 85%;
    letter-spacing: -.02em;
    padding-bottom: 41px
  }
}

.work__partners {
  padding-top: 46px;
  padding-bottom: 50px
}

@media (min-width:1025px) {
  .work__partners {
    padding-top: 58px
  }
}

.projects-section {
  padding-top: 100px
}

@media (min-width:1025px) {
  .projects-section {
    padding-top: 295px
  }
}

.projects-section__container {
  padding-right: 20px;
  padding-left: 20px
}

@media (min-width:1025px) {
  .projects-section__container {
    max-width: 1440px;
    margin-left: auto;
    margin-right: auto;
    padding-left: 262px;
    padding-right: 57px
  }
}

.projects-section__title {
  font-size: 26px;
  line-height: 90%;
  letter-spacing: -.01em
}

@media (min-width:1025px) {
  .projects-section__title {
    font-size: 50px;
    line-height: 85%;
    letter-spacing: -.02em;
    max-width: 464px
  }
}

.projects-section__carousel {
  padding-top: 27px;
  margin-left: -47.5%;
  margin-right: -42%
}

@media (min-width:1025px) {
  .projects-section__carousel {
    padding-top: 48px;
    margin-left: -33.5%;
    margin-right: 0
  }
}

.projects-section__footer {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding-top: 50px
}

.projects-section__btn {
  flex-shrink: 0
}

.projects-section__carousel-nav {
  display: flex;
  align-items: center;
  justify-content: space-between
}

.projects-section__carousel-nav-item {
  margin-right: 7.5px;
  margin-left: 7.5px;
  opacity: .4
}

.projects-section__carousel-nav-item.active {
  opacity: 1
}

@media (min-width:1025px) {
  .projects-section__carousel-nav-item {
    cursor: pointer
  }
}

.project-thumb__container {
  padding: 30px;
  background-color: #fff
}

@media (min-width:1025px) {
  .project-thumb__container {
    padding: 20px;
    display: flex;
    height: 100%
  }
}

@media (min-width:1025px) {
  .projects-page__list .project-thumb__container {
    padding: 30px
  }
}

@media (min-width:1025px) {
  .project-thumb__info {
    flex-grow: 1;
    margin-right: 20px;
    padding-top: 16px;
    padding-left: 23px;
    display: flex;
    flex-direction: column
  }
}

@media (min-width:1025px) {
  .projects-page__list .project-thumb__info {
    padding-left: 10px;
    padding-top: 5px
  }
}

.project-thumb__number {
  font-size: 14px;
  line-height: 140%
}

@media (min-width:1025px) {
  .project-thumb__number {
    font-size: 16px;
    line-height: 150%
  }
}

.project-thumb__title {
  font-size: 22px;
  line-height: 90%;
  letter-spacing: -.01em;
  padding-top: 17px
}

@media (min-width:1025px) {
  .project-thumb__title {
    font-size: 30px;
    line-height: 110%;
    padding-top: 28px
  }
}

.project-thumb__description {
  font-size: 14px;
  line-height: 140%;
  padding-top: 12px
}

@media (min-width:1025px) {
  .project-thumb__description {
    margin-bottom: 35px;
    font-size: 16px;
    line-height: 150%
  }
}

.project-thumb__btn {
  margin-top: 19px;
  margin-bottom: 30px
}

@media (min-width:1025px) {
  .project-thumb__btn {
    margin-top: auto;
    margin-bottom: 37px
  }
}

.project-thumb__image {
  height: 190px;
  background-size: cover;
  background-repeat: no-repeat;
  background-position: 50% 50%
}

@media (min-width:768px) and (max-width:1024px) {
  .project-thumb__image {
    height: 250px
  }
}

@media (min-width:1025px) {
  .project-thumb__image {
    flex-basis: 319px;
    flex-shrink: 0;
    height: auto;
    flex-grow: 0
  }
}

.project-thumb:first-child .project-thumb__image {
  background-image: url(images/1.f14655a558ffe78dd813e6d2ce7d2620.gif)
}

.project-thumb:nth-child(2) .project-thumb__image {
  background-image: url(images/4.08c6e6e37c9f44d54705339df25868a2.gif)
}

.projects-page__list .project-thumb {
  margin-bottom: 20px
}

@media (min-width:1025px) {
  .projects-page__list .project-thumb {
    margin-bottom: 30px;
    margin-left: 15px;
    margin-right: 15px;
    flex-grow: 1;
    flex-basis: calc(50% - 30px);
    flex-shrink: 0
  }
}

.projects-page__list .project-thumb .project-thumb__container {
  flex-direction: column
}

.footer {
  padding-top: 130px
}

@media (min-width:1340px) {
  .footer {
    height: 100vh;
    padding-top: 0
  }
}

.footer__container {
  padding-left: 20px;
  padding-right: 20px
}

@media (min-width:1340px) {
  .footer__container {
    max-width: 1440px;
    margin-left: auto;
    margin-right: auto;
    padding-left: 262px;
    padding-right: 57px;
    display: flex;
    flex-direction: column;
    height: 100%;
    justify-content: center;
    align-items: flex-start
  }
}

.footer__text {
  font-size: 18px;
  line-height: 90%;
  letter-spacing: -.01em;
  padding-bottom: 26px
}

@media (min-width:1025px) {
  .footer__text {
    font-size: 30px;
    line-height: 100%;
    padding-bottom: 39px;
    margin-top: auto;
    padding-top: 170px
  }
}

.footer__mail {
  font-size: 24px;
  line-height: 85%;
  letter-spacing: -.02em;
  position: relative;
  display: inline-block
}

.footer__mail:after, .footer__mail:before {
  position: absolute;
  content: "";
  height: 1px;
  width: 100%;
  background-color: #1e1f21;
  bottom: 0;
  left: 0;
  transform: scaleX(0);
  transform-origin: 100% 50%;
  transition: transform .35s cubic-bezier(.4, 0, 0, 1)
}

@media (min-width:1025px) {
  .footer__mail:after, .footer__mail:before {
    height: 3px;
    bottom: -2px
  }
}

.footer__mail:before {
  transform: scaleX(1);
  transition: none
}

.footer__mail:after {
  display: inline-block;
  transition: none
}

@media (min-width:1025px) {
  .footer__mail:hover:before {
    transform-origin: 100% 50%;
    transform: scaleX(0);
    transition: transform .35s cubic-bezier(.4, 0, 0, 1)
  }
  .footer__mail:hover:after {
    transform-origin: 0 50%;
    transform: scaleX(1);
    transition: transform .35s cubic-bezier(.4, 0, 0, 1);
    transition-delay: .35s
  }
}

@media (min-width:1350px) {
  .footer__mail {
    font-size: 80px;
    line-height: 85%;
    letter-spacing: -.02em;
    margin-bottom: auto
  }
}
@media (max-width:1349px) {
  .footer__mail {
    font-size: 60px;
    line-height: 85%;
    letter-spacing: -.02em;
    margin-bottom: auto
  }
}
@media (max-width:1060px) {
  .footer__mail {
    font-size: 40px;
    line-height: 85%;
    letter-spacing: -.02em;
    margin-bottom: auto
  }
}
@media (max-width:600px) {
  .footer__mail {
    font-size: 24px;
    line-height: 85%;
    letter-spacing: -.02em;
    position: relative;
    display: inline-block
  }
}


.footer__footer {
  padding-top: 76px;
  font-size: 14px;
  padding-bottom: 30px
}

@media (min-width:1025px) {
  .footer__footer {
    display: flex;
    justify-content: space-between;
    width: 100%;
    padding-top: 170px
  }
}

.footer__copyright {
  line-height: 120%
}

.footer__designers {
  padding-top: 23px;
  line-height: 130%
}

@media (min-width:1025px) {
  .footer__designers {
    padding-top: 0
  }
}

.footer__designers a {
  position: relative;
  display: inline-block
}

.footer__designers a:after, .footer__designers a:before {
  position: absolute;
  content: "";
  height: 1px;
  width: 100%;
  background-color: #1e1f21;
  bottom: 0;
  left: 0;
  transform: scaleX(0);
  transform-origin: 100% 50%;
  transition: transform .35s cubic-bezier(.4, 0, 0, 1)
}

.footer__designers a:before {
  transform: scaleX(1);
  transition: none
}

.footer__designers a:after {
  display: inline-block;
  transition: none
}

@media (min-width:1025px) {
  .footer__designers a:hover:before {
    transform-origin: 100% 50%;
    transform: scaleX(0);
    transition: transform .35s cubic-bezier(.4, 0, 0, 1)
  }
  .footer__designers a:hover:after {
    transform-origin: 0 50%;
    transform: scaleX(1);
    transition: transform .35s cubic-bezier(.4, 0, 0, 1);
    transition-delay: .35s
  }
}

.to-top-faw {
  position: fixed;
  bottom: 20px;
  right: 20px;
  width: 41px;
  height: 41px;
  background-color: #edeff1;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  transform: translateY(100px);
  transition: transform .45s cubic-bezier(.4, 0, 0, 1)
}

@media (min-width:1025px) {
  .to-top-faw {
    width: 60px;
    height: 60px;
    display: none
  }
}

.to-top-faw.visible {
  transform: none
}

@media (min-width:1025px) {
  .to-top-faw svg {
    width: 10px;
    height: 14px
  }
}

.eye {
  --pupil-x: 0;
  --pupil-y: 0;
  --color-whites: var(--fg, #fff);
  --color-lid: var(--bg, #fff);
  --color-pupil: var(--bg, #000);
  --color-glint: var(--fg, #fff);
  --scale: 0.75;
  max-width: 100%;
  max-height: 100vh;
  fill: none;
  transform: scale(var(--scale))
}

.lids {
  stroke: var(--color-lid);
  stroke-width: 5%
}

.whites {
  fill: var(--color-whites)
}

.pupil {
  fill: var(--color-pupil);
  cx: 500px;
  cy: 500px
}

.glint {
  fill: var(--color-glint)
}

.pupil-group {
  transform: translate(calc(var(--pupil-x)*1px), calc(var(--pupil-y)*1px))
}

#base-eye {
  display: none
}

#grid {
  display: block;
  width: 68px;
  height: 68px;
  border-radius: 50%;
  background-color: #000
}

.projects-carousel {
  cursor: -webkit-grab;
  cursor: grab
}

.projects-carousel.dragging {
  cursor: -webkit-grabbing;
  cursor: grabbing
}

@media (min-width:1025px) {
  .tns-ovh {
    overflow: visible
  }
}

.tns-carousel {
  display: flex
}

.project-modal__number {
  font-size: 14px;
  line-height: 140%;
  padding-bottom: 22px
}

@media (min-width:1025px) {
  .project-modal__number {
    font-size: 16px;
    line-height: 150%;
    padding-bottom: 18px
  }
}

.project-modal__number--member {
  padding-top: 20px
}

@media (min-width:1025px) {
  .project-modal__number--member {
    padding-top: 0
  }
}

.project-modal__title {
  font-size: 26px;
  line-height: 90%;
  letter-spacing: -.01em;
  padding-bottom: 10px
}

@media (min-width:1025px) {
  .project-modal__title {
    font-size: 50px;
    line-height: 100%;
    letter-spacing: -.02em;
    padding-bottom: 13px
  }
}

@media (min-width:1025px) {
  .project-modal__title--service {
    padding-bottom: 35px
  }
}

.project-modal__description {
  font-size: 14px;
  line-height: 140%;
  padding-bottom: 19px
}

@media (min-width:1025px) {
  .project-modal__description {
    font-size: 16px;
    line-height: 150%;
    padding-bottom: 33px
  }
}

.project-modal__image-wrapper {
  padding-bottom: 32px
}

@media (min-width:1025px) {
  .project-modal__image-wrapper {
    padding-bottom: 53px
  }
}

.project-modal__image {
  width: 100%;
  vertical-align: middle
}

.project-modal__row {
  border-top: 2px solid #1e1f21;
  padding-bottom: 36px;
  padding-top: 11px
}

@media (min-width:1025px) {
  .project-modal__row {
    display: flex;
    padding-bottom: 65px;
    padding-top: 14px
  }
}

.project-modal__col {
  font-size: 16px;
  line-height: 140%
}

.project-modal__col--title {
  padding-bottom: 15px
}

@media (min-width:1025px) {
  .project-modal__col--title {
    flex-basis: 154px;
    flex-shrink: 0
  }
}

@media (min-width:1025px) {
  .project-modal__col--description {
    flex-grow: 1
  }
}

.project-modal__col--description p {
  font-size: 16px;
  line-height: 150%;
  margin-top: 0;
  margin-bottom: 1em
}

.project-modal__col--description p:last-child {
  margin-bottom: 0
}

.project-modal__col--description ul {
  margin-top: 0;
  padding-left: 1em
}

.project-modal__col--description li {
  margin-bottom: 5px;
  line-height: 150%
}

.project-modal__subtitle {
  font-size: 18px;
  padding-top: 10px;
  padding-bottom: 10px
}

@media (min-width:1025px) {
  .project-modal__subtitle {
    font-size: 22px;
    padding-top: 25px;
    padding-bottom: 25px;
    line-height: 1.1
  }
}

.projects-page {
  padding-top: 30px
}

@media (min-width:1025px) {
  .projects-page {
    padding-top: 206px
  }
}

.projects-page__container {
  padding-left: 20px;
  padding-right: 20px
}

@media (min-width:1025px) {
  .projects-page__container {
    max-width: 1440px;
    margin-left: auto;
    margin-right: auto;
    padding-left: 262px;
    padding-right: 57px
  }
}

.projects-page__title {
  font-size: 26px;
  line-height: 90%;
  letter-spacing: -.01em
}

@media (min-width:1025px) {
  .projects-page__title {
    font-size: 50px;
    line-height: 85%;
    letter-spacing: -.02em
  }
}

.projects-page__list {
  padding-top: 27px
}

@media (min-width:1025px) {
  .projects-page__list {
    padding-top: 65px;
    margin: -15px;
    display: flex;
    align-items: stretch;
    flex-wrap: wrap
  }
}

.about {
  padding-top: 30px
}

@media (min-width:1025px) {
  .about {
    padding-top: 230px
  }
}

.about__container {
  padding-left: 20px;
  padding-right: 20px
}

@media (min-width:1025px) {
  .about__container {
    max-width: 1440px;
    margin-left: auto;
    margin-right: auto;
    padding-left: 262px;
    padding-right: 57px
  }
}

@media (min-width:1025px) {
  .about__row {
    display: flex
  }
}

@media (min-width:1025px) {
  .about__col--title {
    flex-basis: 340px;
    margin-right: 40px;
    flex-shrink: 0
  }
}

@media (min-width:1025px) {
  .about__col--description {
    flex-grow: 1
  }
}

.about__title {
  font-size: 26px;
  line-height: 90%;
  letter-spacing: -.01em;
  padding-bottom: 27px
}

@media (min-width:1025px) {
  .about__title {
    font-size: 50px;
    line-height: 85%;
    letter-spacing: -.02em
  }
}

.about__subtitle {
  font-size: 22px;
  line-height: 90%;
  letter-spacing: -.01em;
  padding-bottom: 13px
}

@media (min-width:1025px) {
  .about__subtitle {
    font-size: 30px;
    line-height: 110%
  }
}

.about__description {
  font-size: 14px;
  line-height: 140%
}

@media (min-width:1025px) {
  .about__description {
    font-size: 20px;
    line-height: 110%
  }
}

.about__description p {
  padding-bottom: .3em
}

.about__important {
  display: none;
  font-size: 35px;
  line-height: 100%;
  letter-spacing: -.02em;
  padding-top: 46px
}

@media (min-width:1025px) {
  .about__important {
    display: block;
    font-size: 80px;
    line-height: 100%;
    letter-spacing: -.02em;
    padding-top: 0;
    margin-top: -50px;
    position: relative;
    z-index: 2
  }
}

.about__important--mobile {
  display: block
}

@media (min-width:1025px) {
  .about__important--mobile {
    display: none
  }
}

@media (min-width:1025px) {
  .about__important .split-line {
    margin-bottom: -10px
  }
}

.about__btn {
  margin-top: 21px
}

.about br {
  display: none
}

@media (min-width:1025px) {
  .about br {
    display: inline
  }
}

.team {
  padding-top: 100px
}

@media (min-width:1025px) {
  .team {
    padding-top: 195px
  }
}

.team__container {
  padding-left: 20px;
  padding-right: 20px
}

@media (min-width:1340px) {
  .team__container {
    max-width: 1440px;
    margin-left: auto;
    margin-right: auto;
    padding-left: 262px;
    padding-right: 57px
  }
}

.team-intro {
  border-bottom: 2px solid #1e1f21;
  padding-bottom: 18px
}

@media (min-width:1025px) {
  .team-intro {
    display: flex;
    align-items: flex-start;
    padding-bottom: 45px
  }
}

.team-intro__title {
  font-size: 26px;
  line-height: 90%;
  letter-spacing: -.01em;
  padding-bottom: 13px
}

@media (min-width:1025px) {
  .team-intro__title {
    font-size: 50px;
    line-height: 85%;
    letter-spacing: -.02em;
    flex-basis: 340px;
    margin-right: 43px;
    flex-grow: 1;
    min-width: 340px
  }
}

.team-intro__description {
  font-size: 14px;
  line-height: 140%
}

@media (min-width:1025px) {
  .team-intro__description {
    font-size: 20px;
    line-height: 130%;
    padding-right: 100px
  }
}

.members {
  padding-top: 43px
}

@media (min-width:1025px) {
  .members {
    padding-top: 58px
  }
}

.members__title {
  font-size: 22px;
  line-height: 90%;
  letter-spacing: -.01em
}

@media (min-width:1025px) {
  .members__title {
    font-size: 30px;
    line-height: 110%
  }
}

.members__list {
  padding-top: 15px
}

@media (min-width:769px) {
  .members__list {
    display: flex;
    margin-left: -15px;
    margin-right: -15px;
    padding-top: 43px
  }
}

.member {
  padding-top: 12px;
  padding-bottom: 13px
}

@media (min-width:769px) {
  .member {
    margin-left: 15px;
    margin-right: 15px;
    padding-bottom: 0;
    padding-top: 0
  }
}

.member__avatar-holder {
  position: relative;
  overflow: hidden
}

.member__avatar {
  width: 100%;
  vertical-align: middle;
  -o-object-fit: cover;
  object-fit: cover
}

@media (min-width:1340px) {
    .member__avatar {
        height: 350px
    }
}

.member__btn {
  right: -2px;
  position: absolute;
  top: 0;
  z-index: 2
}

.member__name {
  font-size: 22px;
  line-height: 90%;
  padding-top: 28px;
  letter-spacing: -.01em
}

@media (min-width:1025px) {
  .member__name {
    font-size: 30px;
    line-height: 110%;
    padding-top: 25px
  }
}

.member__position {
  padding-top: 8px;
  font-size: 14px;
  line-height: 130%;
  opacity: .5
}

.member__info {
  display: none
}

@media (min-width:1025px) {
  .member__info {
    display: block;
    position: absolute;
    width: 380px;
    right: 20px;
    bottom: 20px;
    z-index: 1;
    transform: translateY(calc(100% - 60px));
    transition: transform .45s cubic-bezier(.4, 0, 0, 1)
  }
}

.member__info.open {
  transform: translateY(0)
}

@media (min-width:1025px) {
  .member__info.open .member__btn {
    top: 0
  }
  .member__info.open .member__btn svg {
    transform: rotate(45deg)
  }
}

.member__info--visible {
  display: block
}

.member__description {
  font-size: 14px;
  line-height: 140%;
  padding-top: 20px
}

@media (min-width:1025px) {
  .member__description {
    font-size: 16px;
    line-height: 150%;
    padding-top: 26px
  }
}

.member__info-inner {
  opacity: 0;
  background-color: #fff;
  padding: 20px 0 0
}

@media (min-width:1025px) {
  .member__info-inner {
    padding: 30px 60px 52px;
    transition: opacity .45s cubic-bezier(.4, 0, 0, 1)
  }
}

.open .member__info-inner {
  opacity: 1
}

.member__mobile-btn {
  display: flex;
  right: 30px;
  bottom: 30px;
  position: absolute
}

@media (min-width:1025px) {
  .member__mobile-btn {
    display: none
  }
}

.abc-board {
  padding-top: 70px
}

@media (min-width:1025px) {
  .abc-board {
    padding-top: 140px
  }
}

.abc-board__container {
  padding-left: 20px;
  padding-right: 20px
}

@media (min-width:1025px) {
  .abc-board__container {
    max-width: 1440px;
    margin-left: auto;
    margin-right: auto;
    padding-left: 262px;
    padding-right: 57px
  }
}

.abc-board__title {
  font-size: 22px;
  line-height: 90%;
  letter-spacing: -.01em
}

@media (min-width:1025px) {
  .abc-board__title {
    font-size: 30px;
    line-height: 110%
  }
}

.abc-board__members {
  padding-top: 17px
}

.abc-board__member-btn {
  position: absolute;
  right: 58px;
  bottom: 4px;
  z-index: 2;
  padding: 0
}

@media (min-width:1025px) {
  .abc-board__member-btn {
    width: 80px;
    height: 80px;
    right: 0;
    bottom: 9px;
    opacity: 0;
    margin-right: 0
  }
}

.abc-board__member:hover .abc-board__member-btn {
  opacity: 1
}