@import url("https://fonts.googleapis.com/css?family=Source+Sans+Pro:300,300i,400,400i,700,700i|Montserrat:300,700|Vollkorn:");
@keyframes appearBG {
  0% {
    background: #fff; }
  20% {
    background: #333; }
  30% {
    background: #ff5555; }
  40% {
    background: #fff; }
  100% {
    background: #fff; } }

@keyframes upNoBG {
  0% {
    background: #fff; }
  100% {
    top: 10px;
    background: #fff; } }

@keyframes expandVanish {
  0% {
    top: 30%;
    width: 70%;
    height: 25%;
    display: block; }
  80% {
    top: 0;
    max-width: 100%;
    width: 100vw;
    height: 100vh;
    display: block; }
  100% {
    top: 0;
    max-width: 100%;
    width: 100vw;
    height: 100vh;
    display: block;
    box-sizing: border-box;
    border: 20px solid #ffe6e6;
    background: #fff;
    z-index: 0; } }

@keyframes grow {
  0% {
    width: 50px;
    height: 20px;
    transform: translateY(-200%);
    top: 0%;
    opacity: 1; }
  20% {
    width: 50px;
    height: 20px;
    transform: translateY(0);
    top: 40%;
    opacity: 1; }
  30% {
    width: 50px;
    height: 20px;
    transform: translateY(0);
    top: 40%;
    opacity: 0; }
  35% {
    width: 50px;
    height: 20px;
    transform: translateY(0);
    top: 40%;
    opacity: 1; }
  36% {
    width: 50px;
    height: 20px;
    transform: translateY(0);
    top: 40%;
    opacity: 0; }
  38% {
    width: 50px;
    height: 20px;
    transform: translateY(0);
    top: 40%;
    opacity: 1; }
  41% {
    width: 50px;
    height: 20px;
    transform: translateY(0);
    top: 40%;
    opacity: 0; }
  45% {
    width: 50px;
    height: 20px;
    transform: translateY(0);
    top: 40%;
    opacity: 1; }
  50% {
    width: 50px;
    height: 20px;
    transform: translateY(0);
    top: 40%;
    opacity: 0; }
  56% {
    width: 50px;
    height: 20px;
    transform: translateY(0);
    top: 40%;
    opacity: 1; }
  63% {
    width: 50px;
    height: 20px;
    transform: translateY(0);
    top: 40%;
    opacity: 0; }
  70% {
    width: 50px;
    height: 20px;
    transform: translateY(0);
    top: 40%;
    opacity: 1; }
  80% {
    width: 70%;
    height: 20px;
    transform: translateY(0);
    top: 40%;
    opacity: 1; }
  90% {
    width: 70%;
    height: 25%;
    transform: translateY(0);
    top: 30%;
    opacity: 1; }
  98% {
    width: 70%;
    height: 25%;
    transform: translateY(0);
    top: 30%;
    opacity: 1; }
  100% {
    width: 70%;
    height: 25%;
    transform: translateY(0);
    top: 30%;
    opacity: 1; } }

@keyframes rotateWords {
  0% {
    opacity: 1;
    animation-timing-function: ease-in;
    height: 0px; }
  8% {
    opacity: 1;
    height: 100px; }
  19% {
    opacity: 1;
    height: 100px; }
  20% {
    opacity: 0;
    height: 0px; }
  100% {
    opacity: 0; } }

@keyframes highlightSci {
  0% {
    color: #ff5555; }
  25%, 100% {
    color: #333; } }

@keyframes highlightDev {
  0% {
    color: #333; }
  25% {
    color: #ff5555; }
  50%, 100% {
    color: #333; } }

@keyframes highlightDes {
  0% {
    color: #333; }
  50% {
    color: #ff5555; }
  75%, 100% {
    color: #333; } }

@keyframes highlightWri {
  0%, 74% {
    color: #333; }
  75% {
    color: #ff5555; }
  100% {
    color: #ff5555; } }

@keyframes highlightRed {
  0%, 18% {
    color: #ff5555; }
  19%, 100% {
    color: #333; } }

/*
    Flaticon icon font: Flaticon
    Creation date: 24/07/2017 18:00
    */
@font-face {
  font-family: "Flaticon";
  src: url("./Flaticon.eot");
  src: url("./Flaticon.eot?#iefix") format("embedded-opentype"), url("./Flaticon.woff") format("woff"), url("./Flaticon.ttf") format("truetype"), url("./Flaticon.svg#Flaticon") format("svg");
  font-weight: normal;
  font-style: normal; }

@media screen and (-webkit-min-device-pixel-ratio: 0) {
  @font-face {
    font-family: "Flaticon";
    src: url("./Flaticon.svg#Flaticon") format("svg"); } }

.fi:before {
  display: inline-block;
  font-family: "Flaticon";
  font-style: normal;
  font-weight: normal;
  font-variant: normal;
  line-height: 1;
  text-decoration: inherit;
  text-rendering: optimizeLegibility;
  text-transform: none;
  -moz-osx-font-smoothing: grayscale;
  -webkit-font-smoothing: antialiased;
  font-smoothing: antialiased; }

.flaticon-coding:before {
  content: "\f100"; }

.flaticon-pen:before {
  content: "\f101"; }

.flaticon-paint-palette:before {
  content: "\f102"; }

.flaticon-microscope:before {
  content: "\f103"; }

.title {
  position: absolute;
  left: 0;
  top: 0;
  min-width: 400px;
  font-family: "Source Sans Pro";
  font-weight: 700;
  color: #333;
  -moz-transition: all 1s ease;
  -webkit-transition: all 1s ease;
  transition: all 1s ease;
  opacity: 0;
  animation: fadeIn 1s ease forwards 0.7s;
  -webkit-animation: fadeIn 1s ease forwards 0.7s; }

@keyframes fadeIn {
  to {
    opacity: 1; } }
  @media (min-width: 610px) {
    .title {
      left: 10%;
      margin-top: 3%; } }
  @media (min-height: 650px) and (min-width: 1075px) {
    .title {
      top: 5%; } }
  @media (max-width: 610px) {
    .title {
      transform: scale(0.66);
      left: -60px; } }
  @media (max-height: 650px) {
    .title {
      transform: scale(0.66);
      left: -60px;
      top: -80px; } }
  .title__hello {
    position: relative;
    left: 20px;
    top: 20px;
    line-height: 80px;
    font-size: 92px; }
  .title__myName {
    position: relative;
    float: left;
    top: 25px;
    left: 20px;
    line-height: 80px;
    margin-right: 6px;
    font-size: 92px;
    color: #ff5555; }
  .title__sub {
    position: relative;
    top: 25px;
    left: 20px;
    float: left;
    padding-right: 20px;
    line-height: 80px;
    font-size: 92px;
    font-weight: 400; }
  .title__jobs {
    position: relative;
    display: block;
    float: left;
    clear: both;
    top: 30px;
    left: 22px;
    font-size: 66px;
    font-weight: 400;
    line-height: 80px; }
  .title__rotating-words {
    position: relative;
    display: block;
    float: left;
    top: 30px;
    left: 40px; }
  .title__rotating-words span {
    position: absolute;
    display: block;
    float: left;
    color: #ff5555;
    font-size: 66px;
    font-weight: 700;
    line-height: 80px;
    opacity: 0;
    overflow: hidden;
    animation: rotateWords 16s linear infinite 0s;
    -webkit-animation: rotateWords 16s linear infinite 0s; }
  .title__rotating-words span:nth-child(2) {
    animation-delay: 4s; }
  .title__rotating-words span:nth-child(3) {
    animation-delay: 8s; }
  .title__rotating-words span:nth-child(4) {
    animation-delay: 12s; }
  .title__tagline {
    position: relative;
    display: block;
    clear: both;
    float: left;
    top: 25px;
    left: 24px;
    min-width: 501px;
    font-weight: 400;
    font-size: 42px; }
    .title__tagline--highlight {
      color: #ff5555;
      font-weight: 700; }
    .title__tagline--part-two {
      position: relative;
      display: block;
      float: left;
      top: 25px;
      left: 24px;
      font-weight: 400;
      font-size: 42px;
      margin-right: 30px; }
  .title__icon_wrapper {
    position: relative;
    top: 80px;
    clear: both; }
  .title__icon_wrapper span {
    display: block;
    float: left;
    padding-right: 20px;
    padding: 10px 25px 10px 0px;
    width: 80px;
    height: 70px;
    margin-right: 20px;
    animation: highlightRed 16s ease infinite 0s;
    -webkit-animation: highlightRed 16s ease infinite 0s; }
  .title__icon_wrapper span:nth-child(1) {
    animation-delay: 0s; }
  .title__icon_wrapper span:nth-child(2) {
    animation-delay: 4s; }
  .title__icon_wrapper span:nth-child(3) {
    animation-delay: 8s; }
  .title__icon_wrapper span:nth-child(4) {
    animation-delay: 12s; }
  @media (min-height: 650px) {
    .title__jobs, .title__rotating-words, .title__tagline {
      margin-top: 50px; }
    .title__tagline--part-two {
      margin-top: 0; } }

@media (min-height: 650px) and (min-width: 1075px) {
  .title__tagline--part-two {
    margin-top: 50px; } }

[class^="flaticon-"]:before, [class*=" flaticon-"]:before, [class^="flaticon-"]:after, [class*=" flaticon-"]:after {
  font-size: 64px;
  transition: all 0.5s ease; }

.flaticon:hover {
  border-bottom: solid 10px #ff5555;
  padding-bottom: 10px; }

body {
  margin: 0;
  box-sizing: border-box;
  color: #333;
  margin-right: 30px; }

h1 {
  font-family: "Source Sans Pro";
  color: #333;
  font-weight: 700;
  font-size: 72px; }

.container {
  position: relative;
  width: 100vw;
  height: 100vh;
  animation: appearBG 1.5s ease forwards 0s; }

.hidden {
  display: none; }

.details__anchor-scientist, .details__anchor-dev, .details__anchor-design, .details__anchor-write {
  position: absolute;
  color: #bf4040;
  font-size: 20px;
  text-transform: uppercase;
  opacity: 0;
  animation: fadeIn 0.5s ease forwards 0.5s;
  -webkit-animation: fadeIn 0.5s ease forwards 0.5s; }

@keyframes fadeIn {
  to {
    opacity: 1; } }
  .details__anchor-scientist--hidden, .details__anchor-dev--hidden, .details__anchor-design--hidden, .details__anchor-write--hidden {
    display: none; }
  .details__anchor-scientist:hover, .details__anchor-dev:hover, .details__anchor-design:hover, .details__anchor-write:hover {
    color: #ff5555;
    font-size: 24px;
    -moz-transition: 0.3s ease;
    -webkit-transition: 0.3s ease;
    transition: 0.3s ease; }

.details__anchor-scientist, .details__anchor-write {
  left: 50%;
  transform: translateX(-50%); }

.details__anchor-scientist {
  top: 0; }

.details__anchor-write {
  bottom: 0; }

.details__anchor-dev, .details__anchor-design {
  top: calc(50% - 50px);
  height: 100px; }
  .details__anchor-dev:hover, .details__anchor-design:hover {
    transform: rotate(0);
    top: calc(50% - 15px); }

.details__anchor-dev {
  left: -10px;
  transform: rotate(-90deg); }
  .details__anchor-dev:hover {
    left: 0; }

.details__anchor-design {
  right: 0;
  transform: rotate(90deg); }
  .details__anchor-design:hover {
    top: calc(50% - 15px);
    transform: rotate(0);
    right: 0; }

.details__descriptor {
  font-family: "Work Sans";
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  font-size: 18px;
  text-align: center;
  text-transform: uppercase;
  opacity: 0;
  animation: fadeIn 0.5s ease forwards 0.5s;
  -webkit-animation: fadeIn 0.5s ease forwards 0.5s; }

@keyframes fadeIn {
  to {
    opacity: 1; } }
  .details__descriptor--hidden {
    display: none; }

.developer__panel,
.scientist__panel,
.design__panel,
.write__panel {
  position: absolute;
  background: #ffd3cc;
  -moz-transition: all 0.5s ease;
  -webkit-transition: all 0.5s ease;
  transition: all 0.5s ease; }

.developer__panel {
  height: 100vh;
  width: 0; }
  .developer__panel--visible {
    width: 100vw;
    left: -20px;
    top: -20px; }

.design__panel {
  height: 100vh;
  width: 100vw;
  left: 100vw; }
  .design__panel--visible {
    left: -20px;
    top: -20px; }

.scientist__panel {
  top: 0;
  left: 0;
  height: 0;
  width: 100vw; }
  .scientist__panel--visible {
    height: 100vh; }

.write__panel {
  left: 0;
  top: 100vh;
  height: 0;
  width: 100vw; }
  .write__panel--visible {
    top: 0;
    height: 100vh; }
