@charset "UTF-8";
/*! normalize.css 2011-08-31T22:02 UTC · http://github.com/necolas/normalize.css */
/* =============================================================================
   HTML5 display definitions
   ========================================================================== */
/*
 * Corrects block display not defined in IE6/7/8/9 & FF3
 */
article,
aside,
details,
figcaption,
figure,
footer,
header,
hgroup,
nav,
section {
  display: block; }

/*
 * Corrects inline-block display not defined in IE6/7/8/9 & FF3
 */
audio,
canvas,
video {
  display: inline-block;
  *display: inline;
  *zoom: 1; }

/*
 * Prevents modern browsers from displaying 'audio' without controls
 */
audio:not([controls]) {
  display: none; }

/*
 * Addresses styling for 'hidden' attribute not present in IE7/8/9, FF3, S4
 * Known issue: no IE6 support
 */
[hidden] {
  display: none; }

/* =============================================================================
   Base
   ========================================================================== */
/*
 * 1. Corrects text resizing oddly in IE6/7 when body font-size is set using em units
 *    http://clagnut.com/blog/348/#c790
 * 2. Keeps page centred in all browsers regardless of content height
 * 3. Prevents iOS text size adjust after orientation change, without disabling user zoom
 *    www.456bereastreet.com/archive/201012/controlling_text_size_in_safari_for_ios_without_disabling_user_zoom/
 */
html {
  font-size: 100%;
  /* 1 */
  overflow-y: scroll;
  /* 2 */
  -webkit-text-size-adjust: 100%;
  /* 3 */
  -ms-text-size-adjust: 100%;
  /* 3 */ }

/*
 * Addresses margins handled incorrectly in IE6/7
 */
body {
  margin: 0; }

/*
 * Addresses font-family inconsistency between 'textarea' and other form elements.
 */
body,
button,
input,
select,
textarea {
  font-family: sans-serif; }

/* =============================================================================
   Links
   ========================================================================== */
a {
  color: #00e; }

a:visited {
  color: #551a8b; }

/*
 * Addresses outline displayed oddly in Chrome
 */
a:focus {
  outline: thin dotted; }

/*
 * Improves readability when focused and also mouse hovered in all browsers
 * people.opera.com/patrickl/experiments/keyboard/test
 */
a:hover,
a:active {
  outline: 0; }

/* =============================================================================
   Typography
   ========================================================================== */
/*
 * Addresses styling not present in IE7/8/9, S5, Chrome
 */
abbr[title] {
  border-bottom: 1px dotted; }

/*
 * Addresses style set to 'bolder' in FF3/4, S4/5, Chrome
*/
b,
strong {
  font-weight: bold; }

blockquote {
  margin: 1em 40px; }

/*
 * Addresses styling not present in S5, Chrome
 */
dfn {
  font-style: italic; }

/*
 * Addresses styling not present in IE6/7/8/9
 */
mark {
  background: #ff0;
  color: #000; }

/*
 * Corrects font family set oddly in IE6, S4/5, Chrome
 * en.wikipedia.org/wiki/User:Davidgothberg/Test59
 */
pre,
code,
kbd,
samp {
  font-family: monospace, serif;
  _font-family: 'courier new', monospace;
  font-size: 1em; }

/*
 * Improves readability of pre-formatted text in all browsers
 */
pre {
  white-space: pre;
  white-space: pre-wrap;
  word-wrap: break-word; }

/*
 * 1. Addresses CSS quotes not supported in IE6/7
 * 2. Addresses quote property not supported in S4
 */
/* 1 */
q {
  quotes: none; }

/* 2 */
q:before,
q:after {
  content: '';
  content: none; }

small {
  font-size: 75%; }

/*
 * Prevents sub and sup affecting line-height in all browsers
 * gist.github.com/413930
 */
sub,
sup {
  font-size: 75%;
  line-height: 0;
  position: relative;
  vertical-align: baseline; }

sup {
  top: -0.5em; }

sub {
  bottom: -0.25em; }

/* =============================================================================
   Lists
   ========================================================================== */
ul,
ol {
  margin: 1em 0;
  padding: 0 0 0 40px; }

dd {
  margin: 0 0 0 40px; }

nav ul,
nav ol {
  list-style: none;
  list-style-image: none; }

/* =============================================================================
   Embedded content
   ========================================================================== */
/*
 * 1. Removes border when inside 'a' element in IE6/7/8/9, F3
 * 2. Improves image quality when scaled in IE7
 *    code.flickr.com/blog/2008/11/12/on-ui-quality-the-little-things-client-side-image-resizing/
 */
img {
  border: 0;
  /* 1 */
  -ms-interpolation-mode: bicubic;
  /* 2 */ }

/*
 * Corrects overflow displayed oddly in IE9
 */
svg:not(:root) {
  overflow: hidden; }

/* =============================================================================
   Figures
   ========================================================================== */
/*
 * Addresses margin not present in IE6/7/8/9, S5, O11
 */
figure {
  margin: 0; }

/* =============================================================================
   Forms
   ========================================================================== */
/*
 * Corrects margin displayed oddly in IE6/7
 */
form {
  margin: 0; }

/*
 * Define consistent margin and padding
 */
fieldset {
  margin: 0 2px;
  padding: 0.35em 0.625em 0.75em; }

/*
 * 1. Corrects color not being inherited in IE6/7/8/9
 * 2. Corrects alignment displayed oddly in IE6/7
 */
legend {
  border: 0;
  /* 1 */
  *margin-left: -7px;
  /* 2 */ }

/*
 * 1. Corrects font size not being inherited in all browsers
 * 2. Addresses margins set differently in IE6/7, F3/4, S5, Chrome
 * 3. Improves appearance and consistency in all browsers
 */
button,
input,
select,
textarea {
  font-size: 100%;
  /* 1 */
  margin: 0;
  /* 2 */
  vertical-align: baseline;
  /* 3 */
  *vertical-align: middle;
  /* 3 */ }

/*
 * 1. Addresses FF3/4 setting line-height using !important in the UA stylesheet
 * 2. Corrects inner spacing displayed oddly in IE6/7
 */
button,
input {
  line-height: normal;
  /* 1 */
  *overflow: visible;
  /* 2 */ }

/*
 * Corrects overlap and whitespace issue for buttons and inputs in IE6/7
 * Known issue: reintroduces inner spacing
 */
table button,
table input {
  *overflow: auto; }

/*
 * 1. Improves usability and consistency of cursor style between image-type 'input' and others
 * 2. Corrects inability to style clickable 'input' types in iOS
 */
button,
html input[type="button"],
input[type="reset"],
input[type="submit"] {
  cursor: pointer;
  /* 1 */
  -webkit-appearance: button;
  /* 2 */ }

/*
 * 1. Addresses box sizing set to content-box in IE8/9
 * 2. Addresses excess padding in IE8/9
 */
input[type="checkbox"],
input[type="radio"] {
  box-sizing: border-box;
  /* 1 */
  padding: 0;
  /* 2 */ }

/*
 * 1. Addresses appearance set to searchfield in S5, Chrome
 * 2. Addresses box sizing set to border-box in S5, Chrome (include -moz to future-proof)
 */
input[type="search"] {
  -webkit-appearance: textfield;
  /* 1 */
  -moz-box-sizing: content-box;
  -webkit-box-sizing: content-box;
  /* 2 */
  box-sizing: content-box; }

/*
 * Corrects inner padding displayed oddly in S5, Chrome on OSX
 */
input[type="search"]::-webkit-search-decoration {
  -webkit-appearance: none; }

/*
 * Corrects inner padding and border displayed oddly in FF3/4
 * www.sitepen.com/blog/2008/05/14/the-devils-in-the-details-fixing-dojos-toolbar-buttons/
 */
button::-moz-focus-inner,
input::-moz-focus-inner {
  border: 0;
  padding: 0; }

/*
 * 1. Removes default vertical scrollbar in IE6/7/8/9
 * 2. Improves readability and alignment in all browsers
 */
textarea {
  overflow: auto;
  /* 1 */
  vertical-align: top;
  /* 2 */ }

/* =============================================================================
   Tables
   ========================================================================== */
/*
 * Remove most spacing between table cells
 */
table {
  border-collapse: collapse;
  border-spacing: 0; }

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

h1, h2, h3, h4, h5, h6 {
  margin: 0;
  font-weight: normal; }

ul,
ol {
  margin: 0;
  padding: 0;
  list-style: none; }

a:active, a:focus {
  outline: none; }

button {
  padding: 0;
  border: 0;
  background: none; }
  button:focus {
    outline: none; }

input,
textarea {
  padding: 0;
  border: 0;
  border-radius: 0;
  -webkit-border-radius: 0;
  -webkit-appearance: none; }
  input:focus,
  textarea:focus {
    outline: none; }
  input::-ms-clear,
  textarea::-ms-clear {
    display: none; }
  input::-ms-reveal,
  textarea::-ms-reveal {
    display: none; }

textarea {
  resize: vertical; }

::-moz-selection {
  background: #b3d4fc;
  text-shadow: none; }

::selection {
  background: #b3d4fc;
  text-shadow: none; }

img,
iframe {
  vertical-align: middle; }

* {
  -webkit-tap-highlight-color: transparent;
  -webkit-tap-highlight-color: transparent; }

@inport "vars";
@font-face {
  font-family: 'Poppins';
  src: url("/media/fonts/Poppins-Bold.eot");
  /* IE9 Compat Modes */
  src: url("/media/fonts/Poppins-Bold.eot?#iefix") format("embedded-opentype"), url("/media/fonts/Poppins-Bold.woff") format("woff"), url("/media/fonts/Poppins-Bold.ttf") format("truetype"), url("/media/fonts/Poppins-Bold.svg#b4703b063877c2078f24c3169a826873") format("svg");
  /* Legacy iOS */
  font-style: normal;
  font-weight: 700; }

@font-face {
  font-family: 'Poppins Light';
  src: url("/media/fonts/Poppins-Light.eot");
  /* IE9 Compat Modes */
  src: url("/media/fonts/Poppins-Light.eot?#iefix") format("embedded-opentype"), url("/media/fonts/Poppins-Light.woff") format("woff"), url("/media/fonts/Poppins-Light.ttf") format("truetype"), url("/media/fonts/Poppins-Light.svg#2162ff326e5a0867cd9f3e3f06a50c83") format("svg");
  /* Legacy iOS */
  font-style: normal;
  font-weight: 200; }

@font-face {
  font-family: 'Poppins Medium';
  src: url("/media/fonts/Poppins-Medium.eot");
  /* IE9 Compat Modes */
  src: url("/media/fonts/Poppins-Medium.eot?#iefix") format("embedded-opentype"), url("/media/fonts/Poppins-Medium.woff") format("woff"), url("/media/fonts/Poppins-Medium.ttf") format("truetype"), url("/media/fonts/Poppins-Medium.svg#5e1fb5531a1ff02eee3647f2c2aa5053") format("svg");
  /* Legacy iOS */
  font-style: normal;
  font-weight: 400; }

@font-face {
  font-family: 'Poppins';
  src: url("/media/fonts/Poppins-Regular.eot");
  /* IE9 Compat Modes */
  src: url("/media/fonts/Poppins-Regular.eot?#iefix") format("embedded-opentype"), url("/media/fonts/Poppins-Regular.woff") format("woff"), url("/media/fonts/Poppins-Regular.ttf") format("truetype"), url("/media/fonts/Poppins-Regular.svg#2466034d15617d3db897f621d4352752") format("svg");
  /* Legacy iOS */
  font-style: normal;
  font-weight: 400; }

@font-face {
  font-family: 'Poppins SemiBold';
  src: url("/media/fonts/Poppins-SemiBold.eot");
  /* IE9 Compat Modes */
  src: url("/media/fonts/Poppins-SemiBold.eot?#iefix") format("embedded-opentype"), url("/media/fonts/Poppins-SemiBold.woff") format("woff"), url("/media/fonts/Poppins-SemiBold.ttf") format("truetype"), url("/media/fonts/Poppins-SemiBold.svg#a3c63071076ae65a265993c984b3ccf1") format("svg");
  /* Legacy iOS */
  font-style: normal;
  font-weight: 700; }

@keyframes scroll-arrow {
  0% {
    transform: translateY(-30px); }
  20% {
    transform: translateY(0); }
  80% {
    transform: translateY(0); }
  100% {
    transform: translateY(50px); } }

html {
  font-size: 10px; }

html,
body {
  height: 100%; }

body {
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale; }

a {
  text-decoration: none; }

.title .scroll-arrow {
  position: absolute;
  bottom: -50px;
  left: 5px;
  height: 35px;
  width: 13px;
  overflow: hidden; }
  .title .scroll-arrow svg {
    transform: translateY(-30px);
    animation-name: scroll-arrow;
    animation-duration: 5s;
    animation-timing-function: cubic-bezier(0.785, 0.04, 0.165, 0.995);
    animation-delay: 0;
    animation-iteration-count: infinite;
    animation-direction: normal;
    animation-fill-mode: forwards; }

header {
  position: fixed;
  z-index: 12;
  top: 0;
  width: 100%; }
  header .logo {
    position: absolute;
    left: 40px;
    top: 20px;
    cursor: pointer;
    transition: opacity 0.5s;
    opacity: 1; }
    @media (max-width: 768px) {
      header .logo {
        left: 15px; } }
  header .menu-btn {
    position: absolute;
    right: 40px;
    top: 25px;
    cursor: pointer;
    color: #011e28;
    transition: color 1s 0.5s; }
    @media (max-width: 768px) {
      header .menu-btn {
        right: 15px; } }
    header .menu-btn span {
      position: relative;
      display: inline-block;
      padding-right: 23px;
      font-family: 'Poppins';
      font-size: 14px;
      line-height: 25px;
      letter-spacing: 0px;
      font-weight: 400; }
    header .menu-btn svg {
      position: absolute;
      right: 0;
      top: 50%;
      transform: translateY(-50%); }
  header svg {
    transition: transform 0.5s;
    transform-origin: 50%  50%; }
    header svg .stroke, header svg .fill {
      transition: fill 1s 0.5s, stroke 1s 0.5s; }
    header svg .stroke {
      stroke: #011E28; }
    header svg .fill {
      fill: #011E28; }
  header.light .menu-btn {
    color: #f0f0f0; }
  header.light svg .stroke {
    stroke: #f0f0f0; }
  header.light svg .fill {
    fill: #f0f0f0; }

.menu-open header .logo {
  opacity: 0; }

.menu-open header .menu-btn {
  color: #f0f0f0;
  transition: color 1s; }
  .menu-open header .menu-btn svg {
    transform: translateY(-50%) rotate(-135deg); }

.menu-open header svg .stroke, .menu-open header svg .fill {
  transition: fill 1s, stroke 1s; }

.menu-open header svg .stroke {
  stroke: #f0f0f0; }

.menu-open header svg .fill {
  fill: #f0f0f0; }

menu {
  width: 100%;
  height: 100%;
  position: fixed;
  top: 0;
  left: 0;
  z-index: 10;
  background: #011E28;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: opacity 0.4s, visibility 0.5s 0s;
  visibility: hidden;
  opacity: 0;
  margin: 0;
  padding: 0; }
  menu .inner {
    width: 100%;
    max-width: 400px;
    color: white;
    text-align: center; }
    menu .inner h1 {
      position: relative;
      padding-bottom: 10px;
      margin-bottom: 40px;
      cursor: pointer;
      transform: translateY(-10px);
      opacity: 0;
      font-size: 36px; }
      menu .inner h1 a, menu .inner h1 a:visited, menu .inner h1 a:hover, menu .inner h1 a:active {
        color: white; }
      menu .inner h1 .underline {
        display: block;
        width: 166px;
        bottom: 0;
        height: 2px;
        position: absolute;
        left: 50%;
        margin-left: -83px;
        transform: scaleX(0.8) translateY(20px);
        opacity: 0; }
        menu .inner h1 .underline span {
          display: block;
          width: 100%;
          height: 100%;
          background: white;
          transition: transform 0.2s; }
      menu .inner h1:hover .underline span {
        transform: scaleX(1.2); }
      menu .inner h1:nth-child(1) {
        transition: opacity 2s 0.4s cubic-bezier(0.245, 0.615, 0.085, 1.075), transform 2s 0.4s cubic-bezier(0.245, 0.615, 0.085, 1.075); }
        menu .inner h1:nth-child(1) .underline {
          transition: opacity 2s 0.4s cubic-bezier(0.245, 0.615, 0.085, 1.075), transform 2s 0.4s cubic-bezier(0.245, 0.615, 0.085, 1.075); }
      menu .inner h1:nth-child(2) {
        transition: opacity 2s 0.6s cubic-bezier(0.245, 0.615, 0.085, 1.075), transform 2s 0.6s cubic-bezier(0.245, 0.615, 0.085, 1.075); }
        menu .inner h1:nth-child(2) .underline {
          transition: opacity 2s 0.6s cubic-bezier(0.245, 0.615, 0.085, 1.075), transform 2s 0.6s cubic-bezier(0.245, 0.615, 0.085, 1.075); }
      menu .inner h1:nth-child(3) {
        transition: opacity 2s 0.8s cubic-bezier(0.245, 0.615, 0.085, 1.075), transform 2s 0.8s cubic-bezier(0.245, 0.615, 0.085, 1.075); }
        menu .inner h1:nth-child(3) .underline {
          transition: opacity 2s 0.8s cubic-bezier(0.245, 0.615, 0.085, 1.075), transform 2s 0.8s cubic-bezier(0.245, 0.615, 0.085, 1.075); }

.menu-open menu {
  visibility: visible;
  opacity: 1; }
  .menu-open menu h1 {
    transform: translateY(0);
    opacity: 1; }
    .menu-open menu h1 .underline {
      opacity: 1;
      transform: scaleX(1) translateY(0); }

body, html {
  height: 100%;
  width: 100%;
  background: #f6f6f6;
  background: white;
  color: #011E28; }

.cover {
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 100vh;
  z-index: 0;
  background-size: cover;
  transform: translate3d(0, 0, 0) scale(1.2);
  background-position: center center;
  overflow: hidden; }
  .cover.show {
    visibility: visibile; }
  .cover img {
    position: absolute;
    left: 50%;
    top: 50%;
    transform: translate(-50%, -50%); }

.injection {
  position: relative;
  z-index: 1;
  width: 100%;
  height: 100%;
  transition: opacity 0.5s;
  opacity: 1; }
  .injection.fade {
    opacity: 0; }

h1 {
  font-family: 'Poppins';
  font-size: 48px;
  line-height: 56px;
  letter-spacing: -1px;
  font-weight: 700;
  max-width: 100%; }
  @media (max-width: 768px) {
    h1 {
      font-size: 30px;
      line-height: 40px; } }
  @media (min-width: 1440px) {
    h1 {
      font-size: 60px;
      line-height: 70px; } }

h2 {
  font-family: 'Poppins';
  font-size: 36px;
  line-height: 90px;
  letter-spacing: -1px;
  font-weight: 700;
  max-width: 100%; }

h3 {
  font-family: 'Poppins';
  font-size: 14px;
  line-height: 56px;
  letter-spacing: 5px;
  font-weight: 400;
  text-transform: uppercase;
  max-width: 100%; }
  @media (max-width: 768px) {
    h3 {
      font-size: 12px; } }
  @media (min-width: 1440px) {
    h3 {
      font-size: 18px;
      letter-spacing: 6.4px; } }

p {
  font-family: 'Poppins';
  font-size: 12px;
  line-height: 25px;
  letter-spacing: 0px;
  font-weight: 400; }
  @media (min-width: 1200px) {
    p {
      font-size: 14px; } }

.frame > div {
  z-index: 2;
  position: fixed;
  background: white;
  transition: transform 2s cubic-bezier(0.785, 0.04, 0.165, 0.995); }

.frame .left {
  height: 100%;
  width: 40px;
  left: 0;
  top: 0;
  transform: translate3d(0, 0, 0); }

.frame .right {
  height: 100%;
  width: 40px;
  right: 0;
  top: 0;
  transform: translate3d(0, 0, 0); }

.frame .top {
  height: 70px;
  width: 100%;
  top: 0;
  left: 0;
  transform: translate3d(0, 0, 0); }

.frame .bottom {
  bottom: 0;
  left: 0;
  height: 40px;
  width: 100%;
  transform: translate3d(0, 0, 0); }

.frame.hide .left {
  transform: translate3d(-45px, 0, 0); }

.frame.hide .right {
  transform: translate3d(45px, 0, 0); }

.frame.hide .top {
  transform: translate3d(0, -75px, 0); }

.frame.hide .bottom {
  transform: translate3d(0, 45px, 0); }

@media (max-width: 768px) {
  .frame .bottom {
    height: 15px; }
  .frame .left, .frame .right {
    width: 15px; }
  .frame.hide .left {
    transform: translate3d(-18px, 0, 0); }
  .frame.hide .right {
    transform: translate3d(18px, 0, 0); }
  .frame.hide .bottom {
    transform: translate3d(0, 18px, 0); } }

.projects {
  width: 100%;
  height: 100%;
  position: absolute;
  overflow: hidden; }
  .projects .dots {
    position: absolute;
    position: absolute;
    left: 90px;
    top: 50%;
    transform: translate3d(0, -50%, 0);
    transition: opacity 1s;
    height: 350px;
    flex-direction: column;
    display: flex;
    justify-content: space-between; }
    @media (max-width: 768px) {
      .projects .dots {
        display: none; } }
    .projects .dots .dot {
      width: 1px;
      height: 1px;
      width: 30px;
      height: 30px;
      position: relative;
      cursor: pointer; }
      .projects .dots .dot::after {
        position: absolute;
        top: 50%;
        left: 50%;
        width: 7px;
        height: 7px;
        content: '';
        background-color: #bebebe;
        border: 1px solid #bebebe;
        border-radius: 3px;
        transform: translate(-50%, -50%) scale(0.6);
        transition: border-color 0.5s, background-color 0.5s, transform 0.5s; }
      .projects .dots .dot:hover::after {
        transform: translate(-50%, -50%) scale(1.2);
        transition: border-color 0.1s, background-color 0.1s, transform 0.1s; }
      .projects .dots .dot.active::after {
        background-color: rgba(255, 255, 255, 0);
        border: 1px solid #bebebe;
        transform: translate(-50%, -50%) scale(1);
        transition: border-color 0.5s, background-color 0.5s, transform 0.5s; }
    .projects .dots.hide {
      opacity: 0; }
  .projects .project, .projects .intro {
    width: 100%;
    height: 100vh;
    position: absolute;
    overflow: hidden;
    top: 0;
    left: 0;
    visibility: hidden;
    cursor: pointer; }
    .projects .project .project-inner, .projects .intro .project-inner {
      width: 100%;
      height: 100%;
      overflow: hidden; }
      .projects .project .project-inner .title-outer, .projects .intro .project-inner .title-outer {
        position: relative;
        width: 100%;
        height: 100%; }
      .projects .project .project-inner .title, .projects .intro .project-inner .title {
        position: absolute;
        top: 50%;
        transform: translate3d(0, -50%, 0);
        color: white;
        left: 160px;
        transition: transform 2s cubic-bezier(0.785, 0.04, 0.165, 0.995); }
        @media (max-width: 768px) {
          .projects .project .project-inner .title, .projects .intro .project-inner .title {
            left: 40px;
            padding-right: 40px;
            box-sizing: border-box; } }
        .projects .project .project-inner .title .inner-title, .projects .intro .project-inner .title .inner-title {
          transition: transform 1.2s cubic-bezier(0.785, 0.04, 0.165, 0.995);
          backface-visibility: hidden;
          transform-style: preserve-3d;
          position: relative;
          z-index: 1;
          visibility: visible; }
          @media (max-width: 1024px) {
            .projects .project .project-inner .title .inner-title, .projects .intro .project-inner .title .inner-title {
              transition: transform 0.8s cubic-bezier(0.42, 0.725, 0.1, 0.99); } }
          .projects .project .project-inner .title .inner-title::after, .projects .intro .project-inner .title .inner-title::after {
            display: block;
            position: absolute;
            content: '';
            width: 1px;
            height: 200vh;
            top: 50%;
            transform: translateY(-50%);
            left: 50%; }
        .projects .project .project-inner .title .arrow-color, .projects .intro .project-inner .title .arrow-color {
          stroke: #011E28; }
        .projects .project .project-inner .title .scroll-arrow, .projects .intro .project-inner .title .scroll-arrow {
          display: none; }
          @media (max-width: 768px) {
            .projects .project .project-inner .title .scroll-arrow, .projects .intro .project-inner .title .scroll-arrow {
              display: block; } }
    .projects .project.top, .projects .intro.top {
      transform: translate(0, -100%); }
      .projects .project.top .project-inner, .projects .intro.top .project-inner {
        transform: translate(0, 90%); }
        .projects .project.top .project-inner .title .inner-title, .projects .intro.top .project-inner .title .inner-title {
          transform: translate(0, -20px); }
    .projects .project.bottom, .projects .intro.bottom {
      transform: translate(0, 100%); }
      .projects .project.bottom .project-inner, .projects .intro.bottom .project-inner {
        transform: translate(0, -90%); }
        .projects .project.bottom .project-inner .title .inner-title, .projects .intro.bottom .project-inner .title .inner-title {
          transform: translate(0, 20px); }
    .projects .project.current, .projects .intro.current {
      visibility: visible;
      transform: translate(0, 0);
      transition: transform 1.2s cubic-bezier(0.785, 0.04, 0.165, 0.995); }
      @media (max-width: 1024px) {
        .projects .project.current, .projects .intro.current {
          transition: transform 1s cubic-bezier(0.42, 0.725, 0.1, 0.99); } }
      .projects .project.current .project-inner, .projects .intro.current .project-inner {
        transform: translate(0, 0);
        transition: transform 1.2s cubic-bezier(0.785, 0.04, 0.165, 0.995); }
        @media (max-width: 1024px) {
          .projects .project.current .project-inner, .projects .intro.current .project-inner {
            transition: transform 1s cubic-bezier(0.42, 0.725, 0.1, 0.99); } }
        .projects .project.current .project-inner .title .inner-title, .projects .intro.current .project-inner .title .inner-title {
          transform: translate(0, 0);
          opacity: 1; }
    .projects .project.prev, .projects .intro.prev {
      visibility: visible;
      transform: translate(0, -100%);
      transition: transform 1.2s cubic-bezier(0.785, 0.04, 0.165, 0.995); }
      @media (max-width: 1024px) {
        .projects .project.prev, .projects .intro.prev {
          transition: transform 1s cubic-bezier(0.42, 0.725, 0.1, 0.99); } }
      .projects .project.prev .project-inner, .projects .intro.prev .project-inner {
        transform: translate(0, 90%);
        transition: transform 1.2s cubic-bezier(0.785, 0.04, 0.165, 0.995); }
        @media (max-width: 1024px) {
          .projects .project.prev .project-inner, .projects .intro.prev .project-inner {
            transition: transform 1s cubic-bezier(0.42, 0.725, 0.1, 0.99); } }
        .projects .project.prev .project-inner .title .inner-title, .projects .intro.prev .project-inner .title .inner-title {
          transform: translate(0, -20px); }
    .projects .project.next, .projects .intro.next {
      visibility: visible;
      transform: translate(0, 100%);
      transition: transform 1.2s cubic-bezier(0.785, 0.04, 0.165, 0.995); }
      @media (max-width: 1024px) {
        .projects .project.next, .projects .intro.next {
          transition: transform 1s cubic-bezier(0.42, 0.725, 0.1, 0.99); } }
      .projects .project.next .project-inner, .projects .intro.next .project-inner {
        transform: translate(0, -90%);
        transition: transform 1.2s cubic-bezier(0.785, 0.04, 0.165, 0.995); }
        @media (max-width: 1024px) {
          .projects .project.next .project-inner, .projects .intro.next .project-inner {
            transition: transform 1s cubic-bezier(0.42, 0.725, 0.1, 0.99); } }
        .projects .project.next .project-inner .title .inner-title, .projects .intro.next .project-inner .title .inner-title {
          transform: translate(0, 20px); }
    .projects .project .outer, .projects .project .inner, .projects .project .image, .projects .intro .outer, .projects .intro .inner, .projects .intro .image {
      width: 100%;
      height: 100vh;
      position: absolute;
      overflow: hidden;
      transition: transform 2s cubic-bezier(0.785, 0.04, 0.165, 0.995); }
      .projects .project .outer img, .projects .project .inner img, .projects .project .image img, .projects .intro .outer img, .projects .intro .inner img, .projects .intro .image img {
        position: absolute;
        left: 50%;
        top: 50%;
        transform: translate(-50%, -50%); }
    .projects .project .outer .inner .image, .projects .intro .outer .inner .image {
      background-size: cover;
      background-position: center center; }
    .projects .project.anim .title, .projects .intro.anim .title {
      transform: translate3d(-110px, -50%, 0); }
      @media (max-width: 768px) {
        .projects .project.anim .title, .projects .intro.anim .title {
          transform: translate3d(0, -50%, 0); } }
    .projects .project.anim .outer, .projects .intro.anim .outer {
      transform: translate3d(0, 0, 0); }
      .projects .project.anim .outer .inner, .projects .intro.anim .outer .inner {
        transform: translate3d(0, 0, 0); }
        .projects .project.anim .outer .inner .image, .projects .intro.anim .outer .inner .image {
          transform: translate3d(0, 0, 0) scale(1); }
  .projects.no-anim .project {
    transition: none; }
    .projects.no-anim .project .project-inner {
      transition: none; }
      .projects.no-anim .project .project-inner .title .inner-title {
        transition: none; }
  .projects .intro {
    cursor: initial; }
    .projects .intro .project-inner {
      width: 100%;
      height: 100%;
      overflow: hidden;
      background-color: white; }
      .projects .intro .project-inner .title {
        max-width: 1000px;
        color: #011e28;
        padding-right: 50px; }
        @media (min-width: 1660px) {
          .projects .intro .project-inner .title {
            width: 70%;
            max-width: 1600px; } }

.project-page .section.head {
  width: 100%;
  height: 100vh;
  overflow: hidden;
  position: relative; }
  .project-page .section.head .bg {
    width: 100%;
    height: 100vh;
    transform: translate3d(0, 0, 0) scale(1.2);
    background-size: cover;
    background-position: center center;
    position: absolute;
    overflow: hidden; }
    .project-page .section.head .bg img {
      position: absolute;
      left: 50%;
      top: 50%;
      transform: translate(-50%, -50%); }
  .project-page .section.head .title-outer {
    position: relative;
    width: 100%;
    height: 100%; }
  .project-page .section.head .title {
    position: absolute;
    top: 50%;
    transform: translateY(-50%);
    color: white;
    left: 50px; }
    @media (max-width: 768px) {
      .project-page .section.head .title {
        left: 40px;
        padding-right: 40px;
        box-sizing: border-box; } }

.project-page .section.main-content {
  background: white;
  padding: 100px 0 0;
  box-sizing: border-box; }
  .project-page .section.main-content p {
    max-width: 700px;
    margin: 0 auto 20px;
    padding: 0 40px; }
    @media (min-width: 1200px) {
      .project-page .section.main-content p {
        max-width: 820px; } }
  .project-page .section.main-content .img-wrap {
    width: 100%; }
  .project-page .section.main-content img {
    width: 100%;
    max-width: 1600px;
    transition: transform 1s, opacity 1s;
    transform: translateY(20px);
    opacity: 0;
    margin: 0 auto;
    display: block; }
    .project-page .section.main-content img.loaded.active {
      transform: translateY(0);
      opacity: 1; }
  .project-page .section.main-content .video-outer {
    position: relative;
    width: 100%;
    max-width: 1600px;
    margin: 100px auto 0; }
    .project-page .section.main-content .video-outer .video-inner {
      width: 100%;
      padding-bottom: 56.25%; }
    .project-page .section.main-content .video-outer iframe {
      position: absolute;
      left: 0;
      top: 0;
      width: 100%;
      height: 100%; }
  .project-page .section.main-content blockquote {
    width: 100%;
    max-width: 420px;
    text-align: center;
    margin: 10% auto; }
    .project-page .section.main-content blockquote p {
      font-size: 14px; }
    .project-page .section.main-content blockquote .title {
      text-transform: uppercase;
      position: relative;
      font-size: 12px; }
      .project-page .section.main-content blockquote .title::before {
        content: '\201C';
        font-size: 110px;
        position: absolute;
        top: 5px;
        left: 50%;
        font-family: 'Poppins';
        transform: translateX(-50%); }
    @media (min-width: 1440px) {
      .project-page .section.main-content blockquote {
        max-width: 520px; }
        .project-page .section.main-content blockquote p {
          font-size: 18px; }
        .project-page .section.main-content blockquote .title {
          font-size: 14px; } }

.project-page .footer {
  background: #011E28;
  display: flex;
  align-items: center;
  height: 400px; }
  .project-page .footer a, .project-page .footer a:visited, .project-page .footer a:active, .project-page .footer a:hover {
    color: white;
    display: inline-block; }
  .project-page .footer .inner {
    padding-left: 100px; }
    .project-page .footer .inner span {
      display: inline-flex;
      flex-basis: auto; }
  .project-page .footer .small {
    display: none; }
  @media (max-width: 768px) {
    .project-page .footer {
      height: 230px; }
      .project-page .footer .inner {
        padding-left: 40px; }
        .project-page .footer .inner h1 {
          display: none; }
        .project-page .footer .inner .small {
          display: inline-block; } }
  .project-page .footer h1 {
    padding-bottom: 5px;
    position: relative;
    margin-bottom: 20px;
    width: auto;
    display: inline-block; }
  .project-page .footer h3 {
    line-height: 18px; }
  .project-page .footer a:hover h1, .project-page .footer a:hover h3 {
    color: #007493; }

.about {
  background: white;
  height: 100%;
  display: flex;
  align-items: center;
  padding-top: 100px;
  padding-bottom: 50px; }
  .about .content {
    width: 80%;
    padding-left: 10%;
    max-height: 80%; }
    .about .content .heading {
      padding-bottom: 100px; }
      .about .content .heading a, .about .content .heading a:visited, .about .content .heading a:active {
        color: #1AA2C7; }
      .about .content .heading a:hover {
        color: #007493; }
      .about .content .heading span {
        white-space: nowrap; }
    .about .content h3 {
      line-height: 1em;
      padding-bottom: 30px; }
    .about .content .recognition-outer {
      display: flex;
      align-items: flex-start;
      flex-wrap: wrap; }
      .about .content .recognition-outer .recognition {
        display: flex;
        align-items: flex-start;
        flex-wrap: wrap;
        max-width: 800px; }
        .about .content .recognition-outer .recognition .item {
          width: 300px;
          padding: 0 0 10px; }
          .about .content .recognition-outer .recognition .item .title {
            font-family: 'Poppins';
            font-weight: 700;
            font-size: 12px; }
          .about .content .recognition-outer .recognition .item .copy {
            font-family: 'Poppins';
            font-weight: 400;
            font-size: 12px; }
    .about .content .social {
      padding-top: 40px;
      padding-bottom: 50px; }
      .about .content .social a, .about .content .social a:visited, .about .content .social a:active {
        color: #1AA2C7;
        font-size: 14px;
        padding: 0 10px 0 0;
        display: inline-block; }
      .about .content .social a:hover {
        color: #011E28; }

.default-link, .default-link:visited {
  color: #1AA2C7;
  font-size: 14px;
}

.default-link:hover {
  color: #011E28;
}

.contact {
  background: white;
  height: 100%;
  display: flex;
  align-items: center;
  padding-top: 100px;
  padding-bottom: 50px; }
  .contact .content {
    width: 80%;
    padding-left: 10%;
    max-height: 80%; }
    .contact .content h1 {
      padding-bottom: 20px; }
      .contact .content h1 span {
        display: inline-flex;
        flex-basis: auto; }
      .contact .content h1 a, .contact .content h1 a:visited, .contact .content h1 a:active {
        color: #1AA2C7; }
      .contact .content h1 a:hover {
        color: #007493; }
      @media (max-width: 768px) {
        .contact .content h1 a {
          font-size: 20px; } }
