/* ------- Reset Default Browser Style ------- */
html, body, div, span, object, iframe,
h1, h2, h3, h4, h5, h6, p, blockquote, pre,
a, abbr, acronym, address, code,
del, dfn, em, img, q, dl, dt, dd, ol, ul, li,
fieldset, form, label, legend,
table, caption, tbody, tfoot, thead, tr, th, td,
section, header, footer, aside, button, input{
margin: 0;
padding: 0;
border: 0;
vertical-align: baseline;
font-family: 'Quicksand', sans-serif;
font-weight: 400;
color: inherit;
}

* {
margin: 0;
padding: 0; }

/*@font-face {
    font-family: 'nexa_bold';
    src: url('fonts/Nexa_Free_Bold-webfont.eot');
    src: url('fonts/Nexa_Free_Bold-webfont.eot?#iefix') format('embedded-opentype'),
         url('fonts/Nexa_Free_Bold-webfont.woff') format('woff'),
         url('fonts/Nexa_Free_Bold-webfont.ttf') format('truetype'),
         url('fonts/Nexa_Free_Bold-webfont.svg#nexa_boldregular') format('svg');
    font-weight: normal;
    font-style: normal;

}

@font-face {
    font-family: 'nexa_light';
    src: url('fonts/Nexa_Free_Light-webfont.eot');
    src: url('fonts/Nexa_Free_Light-webfont.eot?#iefix') format('embedded-opentype'),
         url('fonts/Nexa_Free_Light-webfont.woff') format('woff'),
         url('fonts/Nexa_Free_Light-webfont.ttf') format('truetype'),
         url('fonts/Nexa_Free_Light-webfont.svg#nexa_boldregular') format('svg');
    font-weight: normal;
    font-style: normal;

}*/

.bold, b{
  font-weight: 700 !important;
}

.opacity-0{
  opacity: 0 !important;
}

.opacity-1{
  opacity: 1 !important;
}

::-webkit-scrollbar {
    width: 0px;
    background: transparent; 
}


*{
  -webkit-box-sizing: border-box !important;
  -moz-box-sizing: border-box !important;
  box-sizing: border-box !important;
  -webkit-user-select: none;  /* Chrome all / Safari all */
  -moz-user-select: none;     /* Firefox all */
  -ms-user-select: none;      /* IE 10+ */
  user-select: none;  
 /* -ms-overflow-style: none;
  overflow: -moz-scrollbars-none;
*/}

button{
  cursor: pointer;
}

*:focus {
    outline: 0;
}

/* Tables still need 'cellspacing="0"' in the markup. */
table { border-collapse: separate; border-spacing: 0; }
caption, th, td { text-align: left; font-weight: normal; }
table, td, th { vertical-align: middle; }

/* Remove possible quote marks (") from <q>, <blockquote>. */
blockquote:before, blockquote:after, q:before, q:after { content: ""; }
blockquote, q { quotes: "" ""; }

/* Remove annoying border on linked images. */
a img { border: none; }
a {
  text-decoration: none;
  color: inherit;
  vertical-align:middle;
}

body{
  position: relative;
  height: 100vh;
  width: 100%;
  background: #232323;
  color: #232323;
}

#barba-wrapper, .barba-container{
  position: relative;
  height: 100%;
  min-height: 100% !important;
  background: white !important;
}

#splash-page{
  position: fixed;
  top: 0px;
  left: 0px;
  height: 100%;
  width: 100%;
  z-index: 9999999;
  color: white;
  background: white;
  opacity: 0;
  visibility: hidden;
}

body.loading #splash-page{
  visibility: visible !important;
  opacity: 1;
}

body.loaded #splash-page{
  opacity: 0 !important;
  visibility: hidden !important;
  -webkit-transition: all 600ms cubic-bezier(0.19, 1, 0.22, 1);                  
  -moz-transition: all 600ms cubic-bezier(0.19, 1, 0.22, 1);                 
  -o-transition: all 600ms cubic-bezier(0.19, 1, 0.22, 1);   
  -ms-transition: all 600ms cubic-bezier(0.19, 1, 0.22, 1);          
  transition: all 600ms cubic-bezier(0.19, 1, 0.22, 1);
}

#enter-cont{
  height: 100%;
  width: 100%;
  position: absolute;
  top: 0px;
  left: 0px;
  z-index: 999999;
  color: #232323;
  text-align: center;
  background: white;
  opacity: 0;
  -webkit-transition: all 600ms cubic-bezier(0.19, 1, 0.22, 1);                  
  -moz-transition: all 600ms cubic-bezier(0.19, 1, 0.22, 1);                 
  -o-transition: all 600ms cubic-bezier(0.19, 1, 0.22, 1);   
  -ms-transition: all 600ms cubic-bezier(0.19, 1, 0.22, 1);          
  transition: all 600ms cubic-bezier(0.19, 1, 0.22, 1);
}

ul, li{
  list-style: none;
}

/* body:before will also work
 as will body:after */
:root:before {
  content: url(port_Images/me.jpg)
           url(port_Images/me1.png)
           url(port_Images/renders/render-7.jpg)
           url(port_Images/hig-team.jpg)
           url(port_Images/phone.png)
           url(port_Images/rower-ux3.jpg)
           url(port_Images/hampette-ux2.jpg)
           url(port_Images/flexscroll-ux.jpg)
           url(port_Images/retro-tv.png)
           url(port_Images/retro-tv-screen.png)
           url(port_Images/monitor.png)
           url(port_Images/channels/channel-0.png)
           url(port_Images/channels/channel-1.png)
           url(port_Images/mpics-app-hm.jpg)
           url(port_Images/paiet-app-hm.jpg)
           url(port_Images/dsl-ph.jpg);
  visibility: hidden;
  position: absolute;
  height: 5px;
  width: 5px;
  overflow: hidden;
  left: -999em;
}

#navigation, #navigation .swiper-wrapper{
  width: 100%;
  height: 100%;
}

#navigation{
  -webkit-mask-image: linear-gradient(to bottom, rgba(255,255,255,0) 0%, rgba(255,255,255,0) 3%, rgba(255,255,255,1) 15%, rgba(255,255,255,1) 85%, rgba(255,255,255,0) 97%, rgba(255,255,255,0) 100%);
}

#navigation .swiper-slide{
  height: 25vh;
  width: 100%;
  text-align: right;
  display: inline-block;
  vertical-align: top;
  opacity: .25;
  transition: all 1s cubic-bezier(0.19, 1, 0.22, 1);
}

#navigation .swiper-slide.swiper-slide-active{
  opacity: 1;
}

#navigation h2{
  font-size:11vh;
  position: absolute;
  right: 4vw;
  top: 4vh;
  transition: all 400ms cubic-bezier(0.19, 1, 0.22, 1);
}

.h-link{
  position: absolute;
  visibility: hidden;
  width: 100%;
  height: 100%;
  top: 0px;
  left: 0px;
  z-index: 99;
}

.swiper-slide-active .h-link{
  visibility: visible !important;
}

#navigation .swiper-slide.swiper-slide-active h2 {
  font-size: 12vh !important;
}

#img-container{
  height: 100%;
  width: 60%;
  position: absolute;
  left: 0px;
  top: 0px;
}

.h-img{
  position: absolute;
  width: 250px;
  opacity: 0;
  transform: translateY(10vh) skewY(8deg);
  transition: all 1s cubic-bezier(0.19, 1, 0.22, 1);
}

#h-phone{
  width: 250px;
}

#h-about{
  width: 30vw;
}

#h-dwell{
  width: 50vw
}

#h-dsl{
  width: 50vw;
}

#h-mobile, #g-mobile{
  width: 26vw;
}

/*#g-mobile{
  width: 24vw;
}*/

#h-interact{
  width: 45vw;
}

#h-ui{
  width: 45vw;
}

#h-vid{
  width: 43vw;
}

#h-3d{
  width: 35vw;
}

.h-show{
  opacity: 1 !important;
  transform: translateY(0vh) skewY(0deg) !important;
}


.kinetic-block, .block{
  position: absolute;
  display: block;
  width: 70vw;
  height: 35vw;
  background: #f5f5f5;
  transition:all 1s cubic-bezier(0.19, 1, 0.22, 1);
  -webkit-perspective:2000px; 
  perspective:2000px;
}

#k1{
  top: 110vh;
    right: 5vw;
    height: 30vw;
}

#k2{
  top: 200vh;
    left: : 5vw;
}

#k3{
  top: 300vh;
    right: 5vw;
}

.first-cont{
  height: 500px;
}

.first{
  height: 100vh;
  width: 100%;
  background: #f5f5f5;
  padding: 0px 10vw !important;
}

.first .third, .first .two-third, .first .fourty, .first .sixty{
  height: 100%;
}

.first .title-container{
  background: #f5f5f5 !important;
}

.previous{
  height: 4vw;
  width: 4vw;
  background: url(port_Images/previous.svg);
  background-position: center;
  background-size: 60% auto;
  background-repeat: no-repeat;
  background-color: transparent;
  visibility: hidden;
  cursor: pointer;
  opacity: 0;
  border-radius: 4vw;
  border: 2px solid white;
  -webkit-transition: all 250ms cubic-bezier(0.19, 1, 0.22, 1);                  
  -moz-transition: all 250ms cubic-bezier(0.19, 1, 0.22, 1);                 
  -o-transition: all 250ms cubic-bezier(0.19, 1, 0.22, 1);   
  -ms-transition: all 250ms cubic-bezier(0.19, 1, 0.22, 1);          
  transition: all 250ms cubic-bezier(0.19, 1, 0.22, 1);
  /*-webkit-clip-path: polygon(0 6%, 100% 0, 91% 100%, 10% 88%);
  clip-path: polygon(0 6%, 100% 0, 91% 100%, 10% 88%);*/
 /* border-radius: 5vw;*/
}

/*#home{
  background-color: black;
  position: fixed;
  height: 50px;
  width: 50px;
  line-height: 50px;
  z-index: 99999;
  color: white;
  text-align:center;
  bottom: 10px;
  left: 10px;
  vertical-align: middle;
  cursor: pointer;
  -webkit-transition: all 250ms cubic-bezier(0.19, 1, 0.22, 1);                  
  -moz-transition: all 250ms cubic-bezier(0.19, 1, 0.22, 1);                 
  -o-transition: all 250ms cubic-bezier(0.19, 1, 0.22, 1);   
  -ms-transition: all 250ms cubic-bezier(0.19, 1, 0.22, 1);          
  transition: all 250ms cubic-bezier(0.19, 1, 0.22, 1);
  visibility: hidden;
}*/

#home{
  position: fixed;
  top: 20px;
  left: 40px;
  color: white;
  z-index: 99999;
  mix-blend-mode: difference;
  text-transform: uppercase;
  font-weight: 700;
  display: none;
  visibility: hidden;
}

#home-icon{
  vertical-align: middle;
  width: 30px;
  display: inline-block;
  line-height: 50px;
}

/*#home:active{
  left: -2px !important;
}*/

/*#ui-content #home{
  background: white !important;
  color: black !important;
}

#ui-content #home-icon{
  background: white !important;
  color: black !important;
  -webkit-filter: brightness(0);
  filter: brightness(0);
}*/

.inline-link{
  color: #ccc;
  border-bottom: 1px solid #ccc;
  pointer-events: initial !important;
  display: inline-block;
  margin-top: -4px;
}

/*#barba-wrapper{
  height: 100%;
  width: 100%;
}
*/
/*#nav-container{
  width: auto;
  height: auto;
  position: relative;
}*/

#img-block{
  width: 60%;
  height: 100%;
  float: left;
}

/*nav{
  width: 20vw;
  height: 100%;
  float: right;
  padding-left: 20px;
}

nav ul {
  list-style: none;
}

nav li {
  list-style: none;
  width: 100%;
  text-align: left;
  font-size: 24px;
  color: #232323;
  clear: both;
  line-height: 40px;
  -webkit-transition: all 600ms cubic-bezier(0.19, 1, 0.22, 1);                  
  -moz-transition: all 600ms cubic-bezier(0.19, 1, 0.22, 1);                 
  -o-transition: all 600ms cubic-bezier(0.19, 1, 0.22, 1);   
  -ms-transition: all 600ms cubic-bezier(0.19, 1, 0.22, 1);          
  transition: all 600ms cubic-bezier(0.19, 1, 0.22, 1);
}

nav a{
  width: 100%;
  height: auto;
  display: inline-block;
}

nav li:hover {
  font-size: 28px;
  font-weight: 600;
}

li span {
  position: relative;
  display: inline-block;
  padding: 0px 10px;
  cursor: pointer;
}

li span:before, li span:after {
  content: '';
  position: absolute;
  width: 0%;
  height: 2px;
  top: 50%;
  margin-top: -0.5px;
  background: #232323;
}

li span:before {
  left: -2.5px;
}
li span:after {
  right: 2.5px;
  background: #232323;
  transition: width 0.8s cubic-bezier(0.22, 0.61, 0.36, 1);
}

li span:hover:before {
  background: #232323;
  width: 100%;
  transition: width 0.5s cubic-bezier(0.22, 0.61, 0.36, 1);
}

li span:hover:after {
  background: transparent;
  width: 100%;
  transition: 0s;
}

li a:visited{
  opacity: .5 !important;
}

.visited span:before{
  width: 100%;
}*/
#layer-1, #layer-2{
  height: 100%;
  width: 100%;
  position: absolute;
  top: 0px;
  left: 0px;
   -webkit-transition: all 1.5s cubic-bezier(0.19, 1, 0.22, 1);                  
  -moz-transition: all 1.5s cubic-bezier(0.19, 1, 0.22, 1);                 
  -o-transition: all 1.5s cubic-bezier(0.19, 1, 0.22, 1);   
  -ms-transition: all 1.5s cubic-bezier(0.19, 1, 0.22, 1);          
  transition: all 1.5s cubic-bezier(0.19, 1, 0.22, 1);
}

#layer-1{
  background-image: url('port_Images/me.jpg');
  background-position: 0px -30vw;
  background-size: 100%;
  background-repeat: no-repeat;
 -webkit-clip-path: polygon(9% 23%, 89% 16%, 81% 70%, 19% 63%);
clip-path: polygon(9% 23%, 89% 16%, 81% 70%, 19% 63%);
}

#layer-2{
  background-image: url('port_Images/me1.png');
  background-position: 0px -30vw;
  -webkit-clip-path: polygon(9% 23%, 89% 16%, 100% 100%, 0 100%);
  clip-path: polygon(9% 23%, 89% 16%, 100% 100%, 0 100%);
  background-repeat: no-repeat;
  background-size: 100%;
  z-index: 99;
}

.slideIn{
  background-position: 0px 0px !important;
}


/* --------------------------------------------*/
/* ------- General :: Styling ------- */

.large-txt{
  font-size: 5vw;
}

.medium-txt{
  font-size: 2vw;
}

.small-text{
  font-size: 16px;
  font-size: 1.5vw;
}

/*.flex{
  -webkit-box-flex: 0;
  -webkit-flex: none;
  -ms-flex: none;
  flex: none;
  -webkit-box-flex: 1;
  -webkit-flex: 1;
  -ms-flex: 1;
  flex: 1
}*/

.flex{
  display: flex !important;
}

.gone{
  transform: translateX(-100%);
}

.aligner {
  display: flex !important;
  align-items: center;
  justify-content: center;
}



.swiper-button-prev, .swiper-button-next {
    background-image: url(port_Images/arrow-next2.svg);
    width: 40px;
    background-size: 15px 60px;
    -webkit-transition: all .5s ease;                  
    -moz-transition: all .5s ease;                 
    -o-transition: all .5s ease;   
    -ms-transition: all .5s ease;          
    transition: all .5s ease;
    opacity: 1;
}

.swiper-button-disabled{
  opacity: 0 !important;
}

.swiper-button-prev {
    -ms-transform: rotate(180deg);
    -webkit-transform: rotate(180deg);
    transform: rotate(180deg);
    left: 3vw;
}

.swiper-button-next {
    right: 3vw;
}

.out-of-bounds{
  overflow: visible !important;
}

.out-of-bounds .swiper-button-next {
    right: -6vw;
}

.out-of-bounds .swiper-button-prev {
    left: -58vw;
}

#project-slides, .swiper-wrapper, .swiper-slide{
  width: 100%;
  height: 100%;
}

.project-slide a{
  display: block;
  width: 100%;
  height: 100%;
  background: #232323;
}

.half{
  position: relative;
  width: 50%;
  height: 100%;
  float: left;
}

#menu-outbounds{
  width: 100%;
  height: 100%;
  background: rgba(0,0,0,0);
  position: absolute;
  top: 0px;
  left: -100%;
  -webkit-transition: left 0.25s, background 0.25s 0.25s;                  
  -moz-transition: left 0.25s, background 0.25s 0.25s;                 
  -o-transition: left 0.25s, background 0.25s 0.25s ;   
  -ms-transition: left 0.25s, background 0.25s 0.25s;          
  transition: left 0.25s, background 0.25s 0.25s;
  z-index: 99999;
}

.reveal{
  left: 0% !important;
  background: rgba(0,0,0,0.5) !important;
}

#chat-icon{
  width: 30px;
}

.menu-slide{
  width: 50% !important;
  float: right;
  position: relative;
}

.animate{
  -webkit-transition: all 0.25s ease;                  
    -moz-transition: all 0.25s ease;                 
    -o-transition: all 0.25s ease;   
    -ms-transition: all 0.25s ease;          
    transition: all 0.25s ease;
}

.animate-1s{
  -webkit-transition: all .5s ease;                  
    -moz-transition: all .5s ease;                 
    -o-transition: all .5s ease;   
    -ms-transition: all .5s ease;          
    transition: all .5s ease;
}

.animate-slow{
  -webkit-transition: all 1s ease;                  
    -moz-transition: all 1s ease;                 
    -o-transition: all 1s ease;   
    -ms-transition: all 1s ease;          
    transition: all 1s ease;
}

.container-hidden{
  width: 100%;
  height: 100%;
  position: relative;
  overflow: hidden;
}

#menu{
  position: absolute;
  top: 0px;
  left: 0px;
  width: 100%;
  padding: 20px 40px;
  z-index: 99999;
}

#name{
  position: relative;
  float: left;
  font-weight: 700;
  /*text-transform: uppercase;*/
}

#speaker{
  padding: 8px;
  width: 40px;
  float: left;
  margin-right: 10px;
  display: inline-block;
  margin-top: -2px;
  cursor: pointer;
  border: solid 1.5px rgba(0,0,0,0.15);
  background-color: rgba(0,0,0,0);
  border-radius: 40px;
}

#speaker:hover{
  background-color: rgba(0,0,0,0.05);
}

#resume, #chat{
  position: relative;
  float: right;
  font-weight: 700;
 /* text-transform: uppercase;*/
}

#chat{
  padding-right: 20px;
}

#project-slides{
  background: transparent;
  /*-webkit-mask-image: linear-gradient(to bottom, rgba(255,0,0,0) 0%, rgba(255,0,0,1) 30%);*/
}

.shadow{
  -webkit-box-shadow: 10px 10px 19px -4px rgba(0,0,0,0.18);
  -moz-box-shadow: 10px 10px 19px -4px rgba(0,0,0,0.18);
  box-shadow: 10px 10px 19px -4px rgba(0,0,0,0.18);
}

.blur{
  -webkit-filter: blur(3px);
  -moz-filter: blur(3px);
  -o-filter: blur(3px);
  -ms-filter: blur(3px);
  filter: blur(3px);
}

.drop-shadow{
  filter: drop-shadow(3px 3px 4px rgba(0,0,0,0.25));
}

.drop-shadow:active{
  filter: drop-shadow(1px 1px 2px rgba(0,0,0,0.3));
  transform: scale(.95);
}

.press:active{
  -webkit-box-shadow: 1px 1px 0px 0px rgba(0,0,0,0.3) !important;
  -moz-box-shadow: 1px 1px 0px 0px rgba(0,0,0,0.3) !important;
  box-shadow: 1px 1px 0px 0px rgba(0,0,0,0.3) !important;
  transform: scale(.95);
}

.fade-swiper .swiper-pagination-fraction{
  position: absolute;
  width: auto;
  right: -6vw;
  bottom: 2vw;
  text-align: right;
  font-weight: 700 !important;
  display: none;
}

.fade-swiper .page-pagination-fraction, .fade-swiper .swiper-pagination-fraction span{
  font-weight: 700 !important;
}

.title-container{
  text-align: left;
  width: 100%;
  display: inline-block;
  position: relative;
  -webkit-perspective: 300px;
  -moz-perspective: 300px;
  -ms-perspective: 300px;
  perspective: 300px;
  color: white;
  background: white;
  opacity: .87;
}

.title{
  position: relative;
  mix-blend-mode: difference;
  /*padding-bottom: 2vw;*/
}

.title-block{
  width: 50%;
  position: absolute;
  height: 100%;
  top: 0px;
  left: 20px;
  background: black;
  -webkit-clip-path: polygon(0 0, 100% 3%, 81% 95%, 13% 100%);
  clip-path: polygon(0 0, 100% 3%, 81% 95%, 13% 100%);
}

.blurb{
  text-align: left;
  position: relative;
  padding-top: 30px;
  padding-left: 0px;
  -webkit-perspective: 500px;
  -moz-perspective: 500px;
  -ms-perspective: 500px;
  perspective: 500px;
  /*margin-bottom: 50px;*/
}

.blurb-title{
  font-size: 3vw;
  padding-bottom: 20px;
  position: relative;
}

.blurb-block{
  background: #f5f5f5;
  width: 100%;
  height: 100%;
  position: absolute;
  top: 0px;
}

/* --------------------------------------------*/
/* ------- Animated Arrow :: Styling ------- */
.arrow-container{
  width: 80px;
  height: 65px;
  position: absolute;
  top: 0px;
  right: 0;
  left: 0;
  margin: 0 auto;
  z-index: 9999;
}

.scroll{
  width: 100%;
  height: 40px;
  position: absolute;
  top: 0px;
  right: 0px;
  text-align: center;
  color: white;
  font-size: 14px;
  background: #232323;
  -webkit-clip-path: polygon(50% 100%, 0 0, 100% 0);
  clip-path: polygon(50% 100%, 0 0, 100% 0);
}

.hide{
  top: -65px !important;
}

.arrow {
  padding-top: 80px;
}
.arrow span {
  position: absolute;
  top: 0;
  left: 50%;
  width: 80px;
  height: 80px;
  margin-left: -40px;
  border-left: 1px solid rgba(0,0,0,0.2);
  border-bottom: 1px solid rgba(0,0,0,0.2);
  -webkit-transform: rotate(-45deg);
  transform: rotate(-45deg);
  -webkit-animation: sdb07 2s infinite;
  animation: sdb07 2s infinite;
  opacity: 0;
  box-sizing: border-box;
}
.arrow span:nth-of-type(1) {
  top: -80%;
  -webkit-animation-delay: 0s;
  animation-delay: 0s;
}
.arrow span:nth-of-type(2) {
  top: -72%;
  -webkit-animation-delay: .15s;
  animation-delay: .15s;
}
.arrow span:nth-of-type(3) {
  top: -65%;
  -webkit-animation-delay: .3s;
  animation-delay: .3s;
}
@-webkit-keyframes sdb07 {
  0% {
    opacity: 0;
  }
  50% {
    opacity: 1;
  }
  100% {
    opacity: 0;
  }
}
@keyframes sdb07 {
  0% {
    opacity: 0;
  }
  50% {
    opacity: 1;
  }
  100% {
    opacity: 0;
  }
}

.white .scroll{
  color: #232323 !important;
  background: white;
}

.white span{
  border-left: 1px solid rgba(255,255,255,0.2) !important;
  border-bottom: 1px solid rgba(255,255,255,0.2) !important;
}

/* --------------------------------------------*/
/* ------- About Section :: Styling ------- */

#about-content{
  overflow-y: auto;
  width: 100%;
  height: 100%;
  padding: 0px 15vw;
  overflow-x: hidden;
}

.black-out{
  background: #232323 !important;
}

/*#about .content-container:after {
  content: '';
  position: absolute;
  top: 0px;
  right: 0px;
  background: #01ffff;
  -webkit-clip-path: polygon(60% 0, 100% 0%, 78% 100%, 37% 100%);
  clip-path: polygon(60% 0, 100% 0%, 78% 100%, 37% 100%);
  width: 100%;
  height: 100%;
}*/

#about-me-container{
  width: 100%;
  margin-top: 100px;
  position: relative;
  display: inline-block;
  -webkit-perspective: 1200px;
  -moz-perspective: 1200px;
  -ms-perspective: 1200px;
  perspective: 1200px;
}

#about-me-img{
  width: 50%;
  background: white;
  position: absolute;
  top: 0px;
  right: 0px;
}

#about-me-title{
  text-align: left;
  position: absolute;
  font-family: nexa_light;
  top: 0px;
  left: 0px;
  width: 60%;
}

#about-me-blurb{
  text-align: left;
  position: relative;
  margin-top: 10vw;
  float: left;
  background: #CD4AF4;
  color: white;
  padding: 3vw;
  width: 60%;
  padding-right: 10%;
  font-family: nexa_light;
  z-index: 99;
  -webkit-clip-path: polygon(0 0, 100% 0, 94% 85%, 0 100%);
  clip-path: polygon(0 0, 100% 0, 94% 85%, 0 100%);
}

.letter-box-container{
  width: 100%;
  height: 50vw;
  position: relative;
  z-index: 9999;
  -webkit-perspective: 1200px;
  -moz-perspective: 1200px;
  -ms-perspective: 1200px;
  perspective: 1200px;
}

#idesign, #icreate{
  height: 55vw !important;
}

.letter-box{
  display: inline-flex;
  flex-direction: row;
  position: relative;
  transition:all 1s cubic-bezier(0.19, 1, 0.22, 1);
}

#idesign .letter-box, #icode .letter-box, #icreate .letter-box{
  margin-top: 100px;
}

#icreate{
  margin-bottom: 100px;
}

.animate-top{
  -webkit-transition: top 0.25s linear;                  
  -moz-transition: top 0.25s linear;                 
  -o-transition: top 0.25s linear;   
  -ms-transition: top 0.25s linear;          
  transition: top 0.25s linear;
}


.letter-column{
  display: flex;
  flex-direction: column;
  z-index: 9999;
  -webkit-perspective: 200px;
  -moz-perspective: 200px;
  -ms-perspective: 200px;
  perspective: 200px;
  /*-webkit-transition: margin-top 0.25s linear;                  
  -moz-transition: margin-top 0.25s linear;                 
  -o-transition: margin-top 0.25s linear;   
  -ms-transition: margin-top 0.25s linear;          
  transition: margin-top 0.25s linear;*/
}

.letter{
  position: relative;
  font-size: 4.6vw;
  line-height: 5vw;
  vertical-align: middle;
  height: 5vw;
  width: 5vw;
  text-align: center;
  text-transform: uppercase;
  transform: translateY(0px);
 /* -webkit-transition: all 8s linear;                  
  -moz-transition: all 8s linear;                 
  -o-transition: all 8s linear;   
  -ms-transition: all 8s linear;          
  transition: all 8s linear;*/
  -webkit-transform-style: preserve-3d;
  -moz-transform-style: preserve-3d;
  -ms-transform-style: preserve-3d;
  transform-style: preserve-3d;
}
.reset{
  transition: all 5s cubic-bezier(0.19, 1, 0.22, 1) !important;
  transform: rotate(0deg) translate(0px 0px) !important;
  transform: translateY(0px) !important;
}

.highlight{
  height: 5vw;
  width: 0%;
  position: absolute;
  z-index: 999;
  top: 0px;
  left: 0px;
  background: #f9ee53;
  -webkit-clip-path: inset(30% 0 0 0);
  clip-path: inset(30% 0 0 0);
  /*transition-delay: .5s !important;*/
}

.grow{
  width: 100% !important;
}


#icode .highlight{
  top: 5vw;
}

#idesign .highlight, #icreate .highlight{
  top: 15vw;
}

.about-blurb{
  width: 40%;
  position: absolute;
  bottom: 0;
  top: -50px;
  margin:auto 0;
  height: 80px;
  text-align: left;
  /*line-height: 20px;*/
  opacity: 0;
  z-index: 99;
  -webkit-transition: all 1s ease;                  
  -moz-transition: all 1s ease;                 
  -o-transition: all 1s ease;   
  -ms-transition: all 1s ease;          
  transition: all 1s ease;
}

#icode .about-blurb, #icreate .about-blurb{
  padding-bottom: 20vw;
  left: 0px;
}

#idesign .about-blurb{
  right: 0px;
}

.fade-in-top{
  top: 0px !important;
  opacity: 1 !important;
}

#icode{
  margin-top: 10vw;
}

#icode .letter-box, #icreate .letter-box{
  float: right;
}

#idesign .about-blurb, #icreate .about-blurb{
  width: 30%;
}

/*.about-blurb:before {
    content: "\00a0\00a0\00a0\00a0\00a0\00a0\00a0\00a0\00a0\00a0\00a0\00a0\00a0\00a0\00a0\00a0";
    text-decoration: line-through;
    position: absolute;
    top: 0px;
    right: calc(100% + 10px);
}
*/
.about-bkgd-layer{
  width: 100%;
  height: 50%;
  position: absolute;
  top: 0;
  bottom: 0;
  margin:auto 0;
  background: white;
}

.space-drift-right {
    -webkit-animation-name: drfit;
    -webkit-animation-timing-function: ease-in-out;
    -webkit-animation-iteration-count: infinite;
    -webkit-animation-duration: 5s;

    animation-name: drfit;
    animation-timing-function: ease-in-out;
    animation-iteration-count: infinite;
    animation-duration: 5s;

    -webkit-transform-style: preserve-3d;
    -moz-transform-style: preserve-3d;
    -ms-transform-style: preserve-3d;
    transform-style: preserve-3d;
  }

  .space-drift-left {
    -webkit-animation-name: drfitB;
    -webkit-animation-timing-function: ease-in-out;
    -webkit-animation-iteration-count: infinite;
    -webkit-animation-duration: 5s;

    animation-name: drfitB;
    animation-timing-function: ease-in-out;
    animation-iteration-count: infinite;
    animation-duration: 5s;

    -webkit-transform-style: preserve-3d;
    -moz-transform-style: preserve-3d;
    -ms-transform-style: preserve-3d;
    transform-style: preserve-3d;
  }

 /* WebKit and Opera browsers */
  @-webkit-keyframes drfit {
    0% { -webkit-transform: rotateY(0deg) rotateX(0deg) rotateZ(0deg);    }
    50%   { -webkit-transform: rotateY(-10deg) rotateX(-10deg) rotateZ(-4deg); }
    100% { -webkit-transform: rotateY(0deg) rotateX(0deg) rotateZ(0deg);    }
  }

  /* all other browsers */
  @keyframes drfit {
    0% {
      -moz-transform: rotateY(0deg) rotateX(0deg) rotateZ(0deg);
      -ms-transform: rotateY(0deg) rotateX(0deg) rotateZ(0deg);
      transform: rotateY(0deg) rotateX(0deg) rotateZ(0deg);
    }
    50% {
      -moz-transform: rotateY(-10deg) rotateX(-10deg) rotateZ(-4deg);
      -ms-transform: rotateY(-10deg) rotateX(-10deg) rotateZ(-4deg);
      transform: rotateY(-10deg) rotateX(-10deg) rotateZ(-4deg);
    }
    100% {
      -moz-transform: rotateY(0deg) rotateX(0deg) rotateZ(0deg);
      -ms-transform: rotateY(0deg) rotateX(0deg) rotateZ(0deg);
      transform: rotateY(0deg) rotateX(0deg) rotateZ(0deg);
    }
  }

/* WebKit and Opera browsers */
  @-webkit-keyframes drfitB {
    0% { -webkit-transform: rotateY(0deg) rotateX(0deg) rotateZ(0deg);    }
    50%   { -webkit-transform: rotateY(12deg) rotateX(6deg) rotateZ(2deg); }
    100% { -webkit-transform: rotateY(0deg) rotateX(0deg) rotateZ(0deg);    }
  }

  /* all other browsers */
  @keyframes drfitB {
    0% {
      -moz-transform: rotateY(0deg) rotateX(0deg) rotateZ(0deg);
      -ms-transform: rotateY(0deg) rotateX(0deg) rotateZ(0deg);
      transform: rotateY(0deg) rotateX(0deg) rotateZ(0deg);
    }
    50% {
      -moz-transform: rotateY(12deg) rotateX(6deg) rotateZ(2deg);
      -ms-transform: rotateY(12deg) rotateX(6deg) rotateZ(2deg);
      transform: rotateY(12deg) rotateX(6deg) rotateZ(2deg);
    }
    100% {
      -moz-transform: rotateY(0deg) rotateX(0deg) rotateZ(0deg);
      -ms-transform: rotateY(0deg) rotateX(0deg) rotateZ(0deg);
      transform: rotateY(0deg) rotateX(0deg) rotateZ(0deg);
    }
  }


/* --------------------------------------------*/
/* ------- Animations Section :: Styling ------- */

#animations-content{
  width: 100%;
  height: 100%;
  position: relative;
  z-index: 99;
  background-color: #232323;
  background-image: url('port_Images/grid-tile.svg');
  background-size: 50px 50px; 
  padding: 0px 15vw;
  overflow-y: auto !important;
  color: white !important;
}

#animations-blurb{
  width: 80%;
}

#animations-header{
  height: 80vh;
  margin-bottom: 50px;
}

#screen{
  width: 100%;
  height: 100%;
  cursor: pointer;
  position: absolute;
  top: 0px;
  right: 0px;
}

.year{
  color: black;
  padding-top: 30px;
  float: right;
  text-align: right;
  color: #ccc;
  padding-right: 10px;
}

.video-container{
  width: 100%;
  position: relative;
  margin-bottom: 10vh;
  display: inline-block;
}

#video-modal{
  width: 100%;
  height: 100%;
  z-index: 9999999999;
  position: absolute;
  top: 0px;
  left: 0px;
  background-color: rgba(0,0,0,0);
  pointer-events: none;
}

.modal-visible{
  background-color: rgba(0,0,0,0.75) !important;
  pointer-events: inherit !important;
}

#video-cont{
  width: 70vw;
  height: 39.3vw;
  background-color: black;
  position: relative;
  margin-top: 25vh;
  -webkit-transition: all 400ms cubic-bezier(0.19, 1, 0.22, 1);                  
  -moz-transition: all 400ms cubic-bezier(0.19, 1, 0.22, 1);                 
  -o-transition: all 400ms cubic-bezier(0.19, 1, 0.22, 1);   
  -ms-transition: all 400ms cubic-bezier(0.19, 1, 0.22, 1);          
  transition: all 400ms cubic-bezier(0.19, 1, 0.22, 1);
  visibility: hidden;
  opacity: 0;
  transition-delay: .15s !important;
}

#slide-show{
  width: 80vw;
  height: 47.7vw;
  position: relative;
  margin-top: 25vh;
  -webkit-transition: all 400ms cubic-bezier(0.19, 1, 0.22, 1);                  
  -moz-transition: all 400ms cubic-bezier(0.19, 1, 0.22, 1);                 
  -o-transition: all 400ms cubic-bezier(0.19, 1, 0.22, 1);   
  -ms-transition: all 400ms cubic-bezier(0.19, 1, 0.22, 1);          
  transition: all 400ms cubic-bezier(0.19, 1, 0.22, 1);
  visibility: hidden;
  opacity: 0;
  transition-delay: .15s !important;
}

#video-modal.modal-visible #video-cont, #video-modal.modal-visible #slide-show{
  margin-top: 0vh !important;
  visibility: visible !important;
  opacity: 1 !important;
}

#video-back{
  position: absolute;
  right: 3vw;
  bottom: 3vw;
}

#video-modal.modal-visible #video-back{
  opacity: 1 !important;
  visibility: visible !important;
}

.video{
  width: 50vw;
  height: 28.125vw;
  background: black;
  position: relative;
  opacity: .75;
}

.video-cover{
  width: 50vw;
  height: 28.125vw;
  background: url(port_Images/tv-bars.png);
  background-size: cover;
  background-position: center;
  position: relative; 
  z-index: 99;
  position: absolute;
  top: 0px;
  right: 0px;
  display: none;
}

.visible-true{
  display: block !important;
}

.video-right{
  float: right;
}

.video-left{
 float: left;
}

.video-blurb-container{
  position: absolute;
  width: 35%;
  top: 0;
  bottom: 0;
  margin:auto 0;
  padding-top: 20px;
  height: 130px;
  -webkit-perspective: 200px;
  -moz-perspective: 200px;
  -ms-perspective: 200px;
  perspective: 200px;
  z-index: 99;
}

.video-blurb-right{
  right: 0px;
  padding-left: 80px;
}

.video-blurb-left{
  left: 0px;
  padding-right: 80px;
}

.video-blurb{
  mix-blend-mode: difference;
}

.blurb-block-left, .blurb-block-right{
  position: absolute;
  top: 0px;
  left: 0px;
  height: 100%;
  width: 70%;
  background-color: white;
  -webkit-clip-path: polygon(0 0, 100% 2%, 94% 80%, 22% 100%);
  clip-path: polygon(0 0, 100% 2%, 94% 80%, 22% 100%);
}

.blurb-block-right{
 -webkit-clip-path: polygon(0 0, 100% 3%, 81% 95%, 13% 100%);
clip-path: polygon(0 0, 100% 3%, 81% 95%, 13% 100%);
}

.video-title-left{
    transform: rotate(-90deg);
    position: absolute;
    transform-origin: top right;
    top: 0px;
    margin-bottom: 20px;
    white-space: nowrap;
    right: calc(100% + 30px);
}

.video-title-left{
  transform: rotate(-90deg);
  position: absolute;
  transform-origin: top right;
  top: 0px;
  white-space: nowrap;
  right: calc(100% + 30px);
}

.video-title-right{
  transform: rotate(90deg);
  position: absolute;
  transform-origin: top left;
  top: 0px;
  width: 28.125vw;
  white-space: nowrap;
  right: calc(-28.125vw - 30px);
}

.video-title-left:after {
    content: "\00a0\00a0\00a0\00a0\00a0\00a0\00a0\00a0\00a0\00a0\00a0\00a0\00a0\00a0\00a0\00a0";
    text-decoration: line-through;
}

.video-title-right:before {
    content: "\00a0\00a0\00a0\00a0\00a0\00a0\00a0\00a0\00a0\00a0\00a0\00a0\00a0\00a0\00a0\00a0";
    text-decoration: line-through;
}

/* --------------------------------------------*/
/* ------- Mobile Section :: Styling ------- */

#mobile-content, #challenge{
  position: relative;
  width: 100vw;
  height: 100vh;
  text-align: center;
  overflow:hidden;
  z-index: 9999;
  background: white;
}

.mobile-container{
  display: inline-block;
  height: 100vh;
  position: relative;
}

.app-wireframe{
  position: absolute;
  top: 9.4vh;
  left: 27vh;
  width: 30.7vh;
  z-index: -2;
}


.app-layer{
  width: 100%;
  position: absolute;
  top: 0px;
  left: 0px;
}

#app-content, #app-layers{
  position: relative;
  height: 100%;
  float: left;
  width: 45%;
  text-align: left;
}

#app-content{
  width: 45%;
  padding-right: 20vw;
}

#app-content .swiper-button-next{
  right: 4vw !important;
}

#app-content .swiper-button-prev{
  left: -51vw !important;
}

#app-layers{
  width: 55%;
  padding-left: 25vw;
}

.fixed-container{
  position: fixed;
  height: 100%;
  width: 100%;
  top: 0px;
  left: 0px;
  /*z-index: -1;*/
}

.phone{
  height: 90vh;
  position: relative;
  z-index: 9;
}

.phone-content{
  width: auto;
  height: 100vh;
  float: left;
  position: relative;
}

.phone-container{
  display: inline-block;
  position: relative;
  margin-top: 3.5vh;
}

.phone-screen{
  height: 64.6vh;
  width: 36.8vh;
  left: 5.5vh;
  position: absolute;
  top: 11.3vh;
  overflow-y: hidden;
  opacity: 1;
  background:#232323;
}

.app-walk .swiper-wrapper, .app-walk{
  width: 30vw;
  height: 100%;
  float: left;
}

.blurb-slide{
  width: 30vw !important;
  float: left !important;
  height: 100%;
}

.mobile-video{
  width: 100%;
  position: absolute;
  top: 0px;
  left: 0px;
}

.progress-bar{
  height: 2px;
  opacity: .5;
  background: #eee;
  width: 0%;
  position: absolute;
  top: 0px;
  left: 0px;
  z-index: 99;
}

#mobile-next, #mobile-prev{
  position: absolute;
  color: #232323;
  top: 40px;
  right: 40px;
  font-weight: 700;
  text-transform: uppercase;
  cursor: pointer;
}
/* --------------------------------------------*/
/* ------- Video Section :: Styling ------- */

#video-content, #ui-content, #interact-content{
  width: 100%;
  height: 100%;
  background: white;
  position: relative;
}

#video-container, #interact-container{
  width: 100%;
  height: 100%;
  position: relative;
  padding-left: 5vw;
 padding-right: 10vw
}

#tv{
  width: 100%;
  position: relative;
  z-index: 99;
}

#tv-glass{
  width: 100%;
  position: absolute;
  z-index: 999;
  top: 0px;
  right: 0px;
}

#tv-container{
  width: 60%;
}

#tv-blurb{
  width: 40%;
  z-index: 999;
}

#tv-blurb .blurb{
  padding-right: 30px;
}

.fade-swiper .swiper-wrapper, .fade-swiper .swiper-slide{
  width: 100%;
  height: 100%;
  background: white;
}

#tv-blurb .swiper-button-prev{
  left: -52vw !important;
}

/*#tv-blurb .swiper-pagination, #app-content .swiper-pagination{
  left: 0px !important;
}*/

#ui-content .swiper-pagination{
  right: 3vw !important;
}

#tv-screen{
  width: 22.25vw;
  height: 18vw;
  position: absolute;
  left: 9.6vw;
  top: 14vw;
}

.tv-channels{
  position: relative;
}

.btn{
  margin-top: 20px;
  background: transparent;
  border: 2px solid #232323;
  padding: 6px 15px;
  text-align: center;
  border-radius: 50px;
  font-weight: 700 !important;
}

a.btn{
  display: inline-block;
}

/* --------------------------------------------*/
/* ------- Scrolling Pages :: Styling ------- */

.container{
  width: 100%;
  height: 100%;
  position: relative;
  overflow-y: auto;
}

#dwell-canvas{
  overflow-y: auto;
  width: 100%;
  height: 100%;
}

.two-third{
  position: relative;
  width: 67%;
  float: left;
}

.third{
  position: relative;
  width: 33%;
  float: left;
}

.sixty{
  position: relative;
  width: 60%;
  float: left;
}

.fourty{
  position: relative;
  width: 40%;
  float: left;
}

.hero-img{
  width: 100%;
  padding-right:5vw;
  z-index: 9; 
}

.section-container{
  width: 100%;
  display: inline-block;
  background:white;
}

.section{
  width: 100%;
  position: relative;
  display: inline-block;
  padding: 10vw;
  /*background: white;*/
}

.sub-section{
  margin-bottom: 10vw;
  display: inline-block;
  display: flex;
}

.section h2, .app-blurb h2, #dsl-container h2{
  font-size: 3vw;
  margin-bottom: 20px;
}

.you-img{
  width: 25vw;
  position: absolute;
}

.you-img-1{
  bottom: 0;
  left: 14vw;
  z-index: 9;
  transform: rotateY(180deg);
}

.you-img-2{
  top: 10vw;
  left: 5vw;
}

.you-img-3{
  top: 0px;
  right: 5vw;
}

.you-img-4{
  right: 0px;
  z-index: 9;
  top: 0;
  bottom: 0;
  margin: auto;
}

#you-img-container{
  height: 40vw;
}

#components{
  padding: 5vw 0px !important;
}

#components .blurb, #conclusion .blurb{
  padding: 0px !important;
}

#components .blurb{
  opacity: 0;
  top:-50px;
}

#components .swiper-slide{
  background: white;
  padding: 0px 10vw;
}

#components, #conclusion{
  display: flex;
}

#conclusion{
  color: white !important;
  background: #232323;
  margin-top: 10px;
}

.blurb-full{
  width: 100%;
  padding-right: 50%;
}

#dwell-video{
 /* margin-top: 5vw;*/
  width: 100%;
  height: 27.4vw;
  float: right;
}

.section .swiper-container{
  width: 100%;
}

/*Swiper hack for auto width*/
.gallery .swiper-wrapper{
  width: 20000px;
}

.gallery .swiper-slide{
  width: auto;
  height: 20vw;
}

.gallery-img{
  height: 100%;
  max-width: 30vw;
  float: left;
  cursor: pointer;
}

.section-img{
  width: 100%;
  float: left;
  padding-left: 5vw;
}

.swiper-section h2{
  margin-left: 10vw;
  font-size: 3vw;
  margin-bottom: 20px;
  margin-top: 5vw;
}

#connected{
  background: #f5f5f5;
  margin-top: 10px;
  padding-bottom: 0px !important;
}

#home-iq{
  width: 60vw;
  margin-right: -10vw;
  float: right;
}


/* --------------------------------------------*/
/* ------- UX/UI Page :: Styling ------- */

#ui-back{
  position: fixed;
  bottom: 10px;
  right: 10px;
  opacity: 0;
  z-index: 9999;
}

.ui-scroll #ui-back{
  opacity: 1 !important;
  visibility: visible !important;
}

#ui-info{
  padding: 0px 10vw;
  position: absolute;
  top: 0px;
  right: 0%;
  -webkit-box-shadow: -7px 0px 25px -4px rgba(0,0,0,0.28);
-moz-box-shadow: -7px 0px 25px -4px rgba(0,0,0,0.28);
box-shadow: -7px 0px 25px -4px rgba(0,0,0,0.28);
}

#ui-info .swiper-slide{
  background: white;
}

#ui-explore{
  background: #232323;
  position: relative;
  overflow: hidden;
  margin-right: 0%;
}

.ux-img-cont{
  position: absolute;
  width: calc(100vw - 17px);
  overflow-x: hidden;
  transform-origin: 0% 50%;
  transform: rotate(-45deg);
}

.rotate{
  transform: rotate(0deg)!important;
}

.ux-img{
  top: 0px;
  width: 100%;
  float: left;
  position: relative;
  z-index: 99;
}

.ux-img-bg{
  position: absolute;
  width: 100%;
  top: 0vw;
  left: 0vw;
  z-index: 9;
  -webkit-clip-path: inset(100% 0 0 0);
  clip-path: inset(100% 0 0 0);
  -webkit-transition: all .75s ease;                  
    -moz-transition: all .75s ease;                 
    -o-transition: all .75s ease;   
    -ms-transition: all .75s ease;          
    transition: all .75s ease;
}

.ui-scroll{
  overflow: auto !important;
  width: 100vw !important;
}

.hide-info{
  right: -100% !important; 
}

#ux-scroll{
  top:-65px;
  opacity: 0;
}

/* --------------------------------------------*/
/* ------- Interact Page :: Styling ------- */


#interact-container .third, #interact-container .two-third{
  height: 100% !important;
}

#interact-container .swiper-slide{
  background: white;
}

/*#interact-info .swiper-pagination{
  left: 0px !important;
}*/

.clip-mask{
  -webkit-clip-path: inset(100% 0 0 0);
  clip-path: inset(100% 0 0 0);
}



.goto-top{
  -webkit-clip-path: inset(0% 0 0 0) !important;
  clip-path: inset(0% 0 0 0) !important;
  display: block;
}

.vid-container{
  position: absolute;
  background: #232323;
  top: 0;
  bottom: 7.55vw;
  margin: auto;
  height: 23.8vw;
  width: 41.5vw;
  left: 7.7vw;
  z-index: 9;
  overflow: hidden;
}

.interact-video{
  position: absolute;
  top: 0px;
  left: 0px;
  height: 100%;
}

#monitor{
  padding: 0px !important;
  pointer-events: none !important;
}

#path-container{
  position: relative;
  width: 30vw;
  left: 50%;
  margin-left: -12vw;
  z-index: 3;
}

.step-box{
  background: white;
  padding: 3vw;
  width: 35vw;
  color: white;
  z-index: 9;
  visibility: hidden;
  -webkit-box-shadow: 0px 0px 0px 0px rgba(0,0,0,0);
  -moz-box-shadow: 0px 0px 19px 0px rgba(0,0,0,0);
  box-shadow: 0px 0px 0px 0px rgba(0,0,0,0);
  -webkit-transform: scale(0.98);
  -ms-transform: scale(0.98);
  transform: scale(0.98);
  z-index: 8;
  opacity: 0;
}

.step-box-2{
  background: #f5f5f5;
  padding: 3vw;
  width: 60vw;
  padding-left: 30vw;
  color: #232323;
  z-index: 1;
  opacity: 0;
  -webkit-clip-path: inset(0 100% 0 0);
  clip-path: inset(0 100% 0 0);
}

#ux-process{
  position: relative;
}

#ux-pattern-def{
  padding: 3vw;
  width: 40vw;
  color: white;
  z-index: 9;
  margin-top: 10vw;
  position: relative;
  margin-right: 10vw;
  margin-left: auto;
  background: #232323;
}

#step-1{
  position: absolute;
  top: 32vw;
  left: 15vw;
  text-align: right;
}

#step-2{
  position: absolute;
  top: 40vw;
  right: 10vw;
  text-align: left;
}

#step-3{
  position: absolute;
  top: 75vw;
  left: 20vw;
  text-align: center;
}

#step-4{
  position: absolute;
  text-align: right;
  top:119vw;
  left: 10vw;
}

#step-5{
  position: absolute;
  top: 127vw;
  left: 23vw;
  text-align: left;
}

#dsl-layers{
  position: absolute;
  top: -12vw;
  left: 0px;
  width: 55vw;
  z-index: 9;
}

#dsl-monitor{
  position: absolute;
  bottom: 43vw;
  right: 0px;
  width: 45vw;
}

.step-box-visible{
  opacity: 1;
  background: #232323;
  visibility: visible;
  -webkit-box-shadow: 10px 10px 19px -4px rgba(0,0,0,0.25);
  -moz-box-shadow: 10px 10px 19px -4px rgba(0,0,0,0.25);
  box-shadow: 10px 10px 19px -4px rgba(0,0,0,0.25);
  -webkit-transform: scale(1);
  -ms-transform: scale(1);
  transform: scale(1);
  z-index: 99;
}

.step-box-2-visible{
  opacity: 1;
  -webkit-clip-path: inset(0 0% 0 0);
  clip-path: inset(0 0% 0 0);
}

#hig{
  color: white !important;
  background: #232323;
}

#dsl-container .blurb, #role .blurb{
  padding-right:30px; 
}

#hig .blurb{
  padding: 0px !important;
  padding-left: 5vw !important;
}

#hig .half{
  height: auto !important;
}

.frame{
  border:5px solid #f5f5f5;
}

#ebay-intro{
  width: 100%;
}

.bullets{
  position: absolute;
  z-index: 99999;
  right: -17.5vw !important;
}

.swiper-pagination-bullet {
    width: 15px;
    height: 15px;
    display: inline-block;
    border-radius: 100%;
    border: solid 2px black;
    background: transparent;
}

.pagination-bullet-active {
    background: black;
}

#mobile-content .swiper-button-next, #mobile-content .swiper-button-prev{
  top: 3vw;
}

#mobile-content .swiper-container{
  overflow: visible !important;
}

#g3-h1{
  padding: 0px 10vw;
}

#g3-h2{
  position: relative;
  height: 100%;
  padding: 8vw 0px;
  padding-right: 10vw;
  overflow-y: auto;
  /*-webkit-mask-image: linear-gradient(to bottom, rgba(255,255,255,0) 0%, rgba(255,255,255,0) 3%, rgba(255,255,255,1) 15%, rgba(255,255,255,1) 85%, rgba(255,255,255,0) 97%, rgba(255,255,255,0) 100%);*/
}

#g3-cont{
  height: auto;
  position: relative;
  width: 100%;
  float: left;
}

.g3-img{
  width: 100%;
  position: relative;
  float: left;
  margin-bottom: 10px;
  -webkit-transition: all 600ms cubic-bezier(0.19, 1, 0.22, 1);                  
  -moz-transition: all 600ms cubic-bezier(0.19, 1, 0.22, 1);                 
  -o-transition: all 600ms cubic-bezier(0.19, 1, 0.22, 1);   
  -ms-transition: all 600ms cubic-bezier(0.19, 1, 0.22, 1);          
  transition: all 600ms cubic-bezier(0.19, 1, 0.22, 1);
  -webkit-perspective:2000px; 
  perspective:2000px;
}

#loader{
  height: 80px;
  width: 80px;
  position: relative;
  right: -40px;
  top: -40px;
  animation: cool 2s infinite;
}

#shadow{
  width: 80px;
  margin-left: 40px;
  height: 7px;
  border-radius: 100%;
  background-color: black;
  position: absolute;
  margin-top: 50px;
 -webkit-animation: shadow 2s infinite; 
  animation: shadow 2s infinite;
  -webkit-filter: blur(5px);
  -moz-filter: blur(5px);
  -o-filter: blur(5px);
  -ms-filter: blur(5px);
  filter: blur(5px);
  transform-origin: bottom right;
  opacity: .2;
  overflow: visible;
}

/*@keyframes cool {
  0%   { transform:skew(0, 0); transform-origin: bottom left;}
  20%   { transform:skew(26.565deg, 0); transform-origin: bottom left;}
  40% { transform: skew(0, -26.565deg); transform-origin: top right;}
  60% {transform: skew(26.565deg, 0); transform-origin: top left;}
  80% { transform: skew(0, -26.565deg); transform-origin: bottom left;}
  100% { transform:skew(0, 0); transform-origin: bottom left;}
}*/

@keyframes cool {
  0%   { transform:skew(0, 0px); transform-origin: center;}
  12.5%   { transform:skew(26.565deg, 0); transform-origin: bottom left;}
  25%   { transform:translate(-40px, 0) skew(0, 0); transform-origin: center;}
  37.5% { transform: translate(-40px, 40px) skew(0, -26.565deg); transform-origin: bottom left;}
  50%   { transform:translate(-40px, 40px) skew(0, 0); transform-origin: center;}
  62.5% {transform: translate(0px, 40px) skew(26.565deg, 0); transform-origin: bottom left;}
  75%   { transform:translate(0px, 40px) skew(0, 0); transform-origin: bottom left;}
  87.5%   { transform:translate(0px, 40px) skew(0, -26.565deg); transform-origin: bottom left;}
  100%   { transform:translate(0px, 0px) skew(0, 0); transform-origin: bottom left;}
}

@keyframes shadow {
  0%   { transform:scale(1) translate(0px, 0px);}
  12.5%  { transform:scale(1.5, 1) translate(0px, 0px);}
  25%   { transform:translate(-40px, 0) scale(1);}
  37.5% { transform: translate(-40px, 0px) scale(1, .7);}
  50%   { transform:translate(-40px, 0px) scale(1, .7);}
  62.5% {transform: translate(0px, 0px) scale(1.5, .7);}
  75%   { transform:translate(0px, 0px) scale(1, .7);}
  87.5%   { transform:translate(0px, 0px) scale(1, .7);}
  100%   { transform:scale(1) translate(0px, 0px);}
}

.scroll-txt{
  position: absolute;
  top: 15px;
  right: 45px;
  font-size: 14px;
  color: #232323;
  font-weight: 700;
  z-index: 9999999;
  padding: 5px;
}

.w{
  color: white !important;
}

.scroll-down{
  position: absolute;
  top: 10px;
  right: 10px;
  width: 25px;
  height: 40px;
  border: 2px solid #232323;
  border-radius: 50px;
  box-sizing: border-box;
  z-index: 99999;
}
.scroll-down::before {
  position: absolute;
  top: 5px;
  left: 50%;
  content: '';
  width: 4px;
  height: 6px;
  margin-left: -2px;
  background-color: #232323;
  border-radius: 4px;
  -webkit-animation: sdb10 2s infinite;
  animation: sdb10 2s infinite;
  box-sizing: border-box;
}

.ui-scroll .scroll-down, .ui-scroll .scroll-txt{
  opacity: 1 !important;
}

.scroll-down.w{
  border: 2px solid white !important;
}
.scroll-txt.w{
  color: white !important;
}

.scroll-down.a{
  background: white;
}
.scroll-txt.a{
  background: white;
}

.w::before{
   background-color: white !important;
}

/*--------------------------Google Seated Styling-----------------------------------*/

#challenge{
  position: relative;
  width: 100vw;
  height: 100vh;
  text-align: center;
  z-index: 9999;
  background: white;
}

#mock-slider{
  height: 100vh;
  width: 100%;
}

.swiper-slide{
  height: 100%;
  width: 100%;
}

.layout-cont{
  height: 100%;
  width: 100%;
  overflow-x: scroll;
  overflow-y: hidden;
}

.layout-img{
  height: 100%;
  width: auto;
  position: relative;
  padding-right: 45vw;
}

.layout-blurb{
  position: absolute;
  top: 0px;
  height: 100%;
  width: 60%;
  background: white;
  color: black;
  right: 0px;
  z-index: 9999999;
  pointer-events: none;
  padding-left: 20vw;
  padding-right: 5vw;
  -webkit-mask-image: linear-gradient(to right, rgba(255,0,0,0) 0%, rgba(255,0,0,1) 40%);
}

.layout-blurb h1{
  font-size: 5vw;
}

.layout-blurb p{
  margin-top: 1.5vw;
  font-size: 1.7vw;
}

#logo{
  position: absolute;
  width: 7vw;
  top: 25vh;
  right: 13vw;
  text-align: center;
}

.spinner {
  width: 5vw;
  height: 5vw;
  background-color: #232323;

  margin: 100px auto;
  -webkit-animation: sk-rotateplane 1.2s infinite ease-in-out;
  animation: sk-rotateplane 1.2s infinite ease-in-out;
}

@-webkit-keyframes sk-rotateplane {
  0% { -webkit-transform: perspective(120px) }
  50% { -webkit-transform: perspective(120px) rotateY(180deg) }
  100% { -webkit-transform: perspective(120px) rotateY(180deg)  rotateX(180deg) }
}

@keyframes sk-rotateplane {
  0% { 
    transform: perspective(120px) rotateX(0deg) rotateY(0deg);
    -webkit-transform: perspective(120px) rotateX(0deg) rotateY(0deg) 
  } 50% { 
    transform: perspective(120px) rotateX(-180.1deg) rotateY(0deg);
    -webkit-transform: perspective(120px) rotateX(-180.1deg) rotateY(0deg) 
  } 100% { 
    transform: perspective(120px) rotateX(-180deg) rotateY(-179.9deg);
    -webkit-transform: perspective(120px) rotateX(-180deg) rotateY(-179.9deg);
  }
}

@-webkit-keyframes sdb10 {
  0% {
    -webkit-transform: translate(0, 0);
    opacity: 0;
  }
  40% {
    opacity: 1;
  }
  80% {
    -webkit-transform: translate(0, 10px);
    opacity: 0;
  }
  100% {
    opacity: 0;
  }
}
@keyframes sdb10 {
  0% {
    transform: translate(0, 0);
    opacity: 0;
  }
  40% {
    opacity: 1;
  }
  80% {
    transform: translate(0, 10px);
    opacity: 0;
  }
  100% {
    opacity: 0;
  }
}