@charset "UTF-8";
@import url("https://fonts.googleapis.com/css?family=Akaya Kanadaka|Lora|Oswald|Neuton|Droid Serif");

body,div,dl,dt,dd,ul,ol,li,h1,h2,h3,h4,h5,h6,pre,
form,fieldset,input,textarea,blockquote,th,td {
    padding: 0;
    margin: 0;
}
a{
	text-decoration:none;
}
table {
    border-spacing: 0;
}
fieldset,img {
    border: 0;
}
address,caption,cite,code,dfn,em,strong,th,var {
    font-weight: normal;
    font-style: normal;
}
strong{
	font-weight: bold;
}
ol,ul {
    list-style: none;
    margin:0;
    padding:0;
}
caption,th {
    text-align: left;

}
h1,h2,h3,h4,h5,h6 {
    font-weight: normal;
    font-size: 100%;
    margin:0;
    padding:0;
    color:#444;
}
q:before,q:after {
    content:'';
}
abbr,acronym { border: 0;
}

/* Custom CSS
 * --------------------------------------- */
html, body {
 margin: 0;
 width: 100%;
 height: 100%;
 font-family: 'Lora';
 font-size: 16px;
	--anim-time: 3s;
	--anim-delay-first: 1s;
	--anim-delay-second: calc(var(--anim-delay-first) + var(--anim-time));
	--anim-time-total: calc(var(--anim-time) + var(--anim-delay-first)/3 + var(--anim-delay-second));
 scroll-snap-type: y proximity;
 overflow-x: hidden;
 -webkit-overflow-scrolling: touch;
}

/* Works on Firefox */
* {
 scrollbar-width: thin;
 scrollbar-color: #808080 #E0E0E0;
}

/* Works on Chrome, Edge, and Safari */
*::-webkit-scrollbar {
 width: 7px;
}

*::-webkit-scrollbar-track {
 background: #E0E0E0;
}

*::-webkit-scrollbar-thumb {
 background-color: #808080;
 border-radius: 20px;
 border: 3px solid #808080;
}

* {
 box-sizing: border-box;
}

.bg-day{
 width: 100%;
 height: 100%;
 background-image: url('../img/style/bg-day.jpg');
 background-position: top center;
	background-size: 100% 100%;
 background-repeat: no-repeat;
 background-attachment: fixed;
}

.bg-night{
 width: 100%;
 height: 100%;
 background-image: url('../img/style/bg-night.jpg');
 background-position: top center;
	background-size: 100% 100%;
 background-repeat: no-repeat;
 background-attachment: fixed;
}

.loading {
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background-color: #000;
  text-align: center;
  font-size: 48px;
  color:#fff;
  font-family:'Lora';
  z-index: 1600;
}

.loading > .progress { margin-top: 300px; }
.loading > .error { margin-top: 100px; }

.wrapper {
 position: absolute;
 width: 100%;
 height: 100%;
 z-index: 1;
 overflow-x-hidden;
}

.parallax-container {
 position: relative;
 background-size: cover;
 background-repeat: no-repeat;
 background-position: 50% 50%;
 width: 100%;
 z-index: 10;
}

.parallax-container-video { 
 position: relative;
 background-image: url('../img/style/bgwhite-top.png');
 background-position: top center;
	background-size: 100% 200px;
 background-repeat: no-repeat;
 height: 500px;
}
.parallax-container-inner { 
 background-image: url('../img/style/bgwhite-bottom.png');
 background-position: bottom center;
	background-size: 100% 200px;
 background-repeat: no-repeat;
 height: 500px;
 padding-bottom: 50px;
 padding-top: 50px; 
}
.parallax-container-video video{ 
 max-width: 100%;
 position: absolute;
 top:0;
 z-index: -999;
}

.roadsign {
 position: relative;
 margin-top: 200px;
 background-image: url('../img/style/roadsign.png');
 background-position: top center;
 background-repeat: no-repeat;
 width: 100%;
 height: 220px;
 z-index:15;
}

.bgimg-1 {
 background-image: url("../img/style/scripting.jpg");
 min-height: 500px;;
}

/* Screen size ----------- */
@media screen and (max-width: 1200px) {
  .bgimg-1 {
    background-attachment: scroll;
  }
}

.section {
 position: relative;
 width: 100%;
 z-index: 10;
}

.minheight {
 min-height: 100%;
}

.splash {
 position: relative;
 height: calc(70% + 250px);
 overflow-x:hidden;
 width: 100%;
}

.main {
 width: 100%;
 height: calc(100% - 250px);
}

.bgwave-top {
 width: 100%;
 height: 158px;
 background-image: url('../img/style/bgwave-top.png');
 background-position: bottom center;
	background-size: cover;
 background-repeat: no-repeat;
 overflow: hidden;
}

.bgwave-bottom {
 width: 100%;
 height: 200px;
 background-image: url('../img/style/bgwave-bottom.png');
 background-position: top center;
	background-size: cover;
 background-repeat: no-repeat;
 overflow: hidden;
}

.cl_bg {
 width: 100%;
 height: 250px;
 background-image: url('../img/style/clouds-bg.png');
 background-position: top center;
	background-size: cover;
 background-repeat: no-repeat;
 overflow: hidden;
}

.section .container {
 left: 0; 
 right: 0; 
 margin-left: auto; 
 margin-right: auto; 
 width: 100%;

 -webkit-touch-callout: none; /* iOS Safari */
   -webkit-user-select: none; /* Safari */
    -khtml-user-select: none; /* Konqueror HTML */
      -moz-user-select: none; /* Old versions of Firefox */
       -ms-user-select: none; /* Internet Explorer/Edge */
           user-select: none; /* Non-prefixed version, currently
                                 supported by Chrome, Edge, Opera and Firefox */
}

.bg-white{background: #FFFFFF;}
.bg-black{background: #000000;}
.bg-green{background: #335969;}
.bg-gray{background: #5D5D5D;}
.bg-red{background: #B00000;}

.stop-scrolling { 
 overflow: hidden; 
} 

h1{font-size:36px; font-weight: 800;}h2{font-size:30px}h3{font-size:24px}h4{font-size:20px}h5{font-size:18px}h6{font-size:16px}
.ef-wide{letter-spacing:4px}
.ef-justify{text-align:justify!important}
.ef-opacity,.ef-hover-opacity:hover{opacity:0.60}
.ef-font{font-family: 'Lora'; font-size: 20px;}
.ef-font-small{font-family: 'Lora'; font-size: 16px;}
.ef-upper{text-transform: uppercase;}
.ef-bold{font-weight: bold;}
.ef-content{margin-left:auto;margin-right:auto}.ef-content{max-width:980px}
.ef-content-popup{margin-left:auto;margin-right:auto}.ef-content-popup{max-width:750px}
.ef-grid{margin-left:auto;margin-right:auto}.ef-grid{max-width:980px}
.ef-slogan{margin-left:auto;margin-right:auto}.ef-slogan{max-width:740px}
.ef-center{text-align:center!important}
.ef-padding-32{padding-top:32px!important;padding-bottom:32px!important}
.ef-padding-64{padding-top:64px!important;padding-bottom:64px!important}
.ef-live{font-family: 'Averia Serif Libre'; font-weight: 800; font-size: 20px;}
.ef-black{color:#000;}
.ef-white{color:#fff;}
.ef-red{color:#B00000;}

/* Screen size ----------- */
@media screen and (min-width: 768px) and (max-width: 1024px) {
.ef-content{margin-left:auto;margin-right:auto}.ef-content{max-width:680px}
}

.content {
 position: absolute;
 top: 50%;
 left: 50%;
 transform: translate(-50%, -50%);
	cursor: default;
	text-transform: uppercase;
	pointer-events: auto;
 z-index:10;

  -webkit-touch-callout: none; /* iOS Safari */
    -webkit-user-select: none; /* Safari */
     -khtml-user-select: none; /* Konqueror HTML */
       -moz-user-select: none; /* Old versions of Firefox */
        -ms-user-select: none; /* Internet Explorer/Edge */
            user-select: none; /* Non-prefixed version, currently
                                  supported by Chrome, Edge, Opera and Firefox */
}

.content__subtitle {
	font-family: -apple-system, BlinkMacSystemFont, Segoe UI, Helvetica, Arial, sans-serif;
	font-size: 1.65rem;
	font-weight: inherit;
 font-style: normal;
	color: #000;
	-webkit-text-stroke: 1px #fff;
	text-stroke: 1px #fff;
 text-align:center;
 font-weight: 800;
}

.content__title {
 position: relative;
	font-family: -apple-system, BlinkMacSystemFont, Segoe UI, Helvetica, Arial, sans-serif;
	font-size: 3rem;
	font-weight: inherit;
	color: #fff;
	-webkit-text-stroke: 2px #fff;
	text-stroke: 2px #fff;
 background: url("../img/style/forrest.jpg") repeat;
 background-position: 40% 50%;
 -webkit-background-clip: text;
	-webkit-text-fill-color: transparent;
	text-fill-color: transparent;
	color: transparent;
 font-size: 8vw;
 font-weight: 800;
}

.content__title span {
 cursor:pointer;
}

.center-outer {
 display: table;
 width: 100%;
 height: 100%;
}
.center-inner {
 display: table-cell;
 vertical-align: middle;
 text-align: center;
}

.bubbles {
 display: inline-block;
 font-family: arial;
 position: relative;
}

.individual-bubble {
 position: absolute;
 border-radius: 100%;
 bottom: 10px;
 background-color: #fff;
 z-index: 1;
}

.cl-1 {
 position: absolute;
 top: 10px;
 left: 20px;
 background-image: url('../img/style/cloud1.png');
 background-position: top center;
	background-size: 100% 100%;
 background-repeat: no-repeat;
 width:500px;
 height:250px;
 z-index:1;
 cursor:pointer;
}

.cl-2 {
 position: absolute;
 top: 100px;
 left: 500px;
 background-image: url('../img/style/cloud2.png');
 background-position: top center;
	background-size: 100% 100%;
 background-repeat: no-repeat;
 width:600px;
 height:278px;
 z-index:2;
 cursor:pointer;
}

.cl-3 {
 position: absolute;
 top: 280px;
 left: 100px;
 background-image: url('../img/style/cloud3.png');
 background-position: top center;
	background-size: 100% 100%;
 background-repeat: no-repeat;
 width:800px;
 height:450px;
 z-index:3;
 cursor:pointer;
}

.quotation{
  font-size: 20px;
  quotes: "\201C""\201D""\2018""\2019";
  padding: 10px 20px;
  line-height: 1.4;
}
.quotation:before {
  content: open-quote;
  display: inline;
  height: 0;
  line-height: 0;
  left: -10px;
  position: relative;
  top: 30px;
  font-size: 3em;
}
.quotation::after {
  content: close-quote;
  display: inline;
  height: 0;
  line-height: 0;
  left: 10px;
  position: relative;
  top: 35px;
  font-size: 3em;
}
.quotation-footer{
  margin:0;
  padding-bottom:10px;
  text-align: right;
  font-style: italic;
}

a {font-family: 'Averia Serif Libre', Arial, sans-serif; font-weight: 500; font-size: 20px; color: #335969; text-decoration: none;}
a:link {font-family: 'Averia Serif Libre', Arial, sans-serif; font-weight: 500; font-size: 20px; color: #335969; text-decoration: none;}
a:visited {font-family: 'Averia Serif Libre', Arial, sans-serif; font-weight: 500; font-size: 20px; color: #335969; text-decoration: none;}
a:hover {font-family: 'Averia Serif Libre', Arial, sans-serif; font-weight: 500; font-size: 20px; color: #335969; text-decoration: underline;}
a:active {font-family: 'Averia Serif Libre', Arial, sans-serif; font-weight: 500; font-size: 20px; color: #335969; text-decoration: underline;}

.visible{
 display:block;
}

.nav-menu {
 position: absolute;
 top: 0;
 background: rgba(255, 255, 255, 0);
 width: 100%;
 height: 50px;
 text-align: center;
 z-index: 1500;
  -webkit-touch-callout: none; /* iOS Safari */
    -webkit-user-select: none; /* Safari */
     -khtml-user-select: none; /* Konqueror HTML */
       -moz-user-select: none; /* Old versions of Firefox */
        -ms-user-select: none; /* Internet Explorer/Edge */
            user-select: none; /* Non-prefixed version, currently
                                  supported by Chrome, Edge, Opera and Firefox */

 -webkit-transition: all 0.3s ease-in-out;
    -moz-transition: all 0.3s ease-in-out;
      -o-transition: all 0.3s ease-in-out;
         transition: all 0.3s ease-in-out;
}

.nav-menu-fixed {
 position: fixed;
 top: 0;
 background: #335969;
 width: 100%;
 height: 50px;
 text-align: center;
 visibility: hidden;
 opacity: 0;
 z-index: 1500;
  -webkit-touch-callout: none; /* iOS Safari */
    -webkit-user-select: none; /* Safari */
     -khtml-user-select: none; /* Konqueror HTML */
       -moz-user-select: none; /* Old versions of Firefox */
        -ms-user-select: none; /* Internet Explorer/Edge */
            user-select: none; /* Non-prefixed version, currently
                                  supported by Chrome, Edge, Opera and Firefox */

 -webkit-transition: all 0.3s ease-in-out;
    -moz-transition: all 0.3s ease-in-out;
      -o-transition: all 0.3s ease-in-out;
         transition: all 0.3s ease-in-out;
}

.fadeIn {
 visibility: visible;
 opacity: 1;
 -webkit-transition: all 0.3s ease-in-out;
    -moz-transition: all 0.3s ease-in-out;
      -o-transition: all 0.3s ease-in-out;
         transition: all 0.3s ease-in-out;
}

.fadeOut {
 visibility: hidden;
 opacity: 0;
 -webkit-transition: all 0.3s ease-in-out;
    -moz-transition: all 0.3s ease-in-out;
      -o-transition: all 0.3s ease-in-out;
         transition: all 0.3s ease-in-out;
}

.nav-items {
 display: inline-block;
 *display: inline; /* For IE7 */
	margin: 2px auto;
 width: 750px;
	font-family: -apple-system, BlinkMacSystemFont, Segoe UI, Helvetica, Arial, sans-serif;
	font-size: 1.4rem;
 text-align: center;
}
.nav-items .nav-item {
 display: inline-block;
	list-style: none;
	margin: 0 10px;
 padding: 0.3em 0;
	position: relative;
}
.nav-items .nav-item a {
	display: block;
	font-family: -apple-system, BlinkMacSystemFont, Segoe UI, Helvetica, Arial, sans-serif;
	font-size: 1.2rem;
	font-weight: 500;
	height: 28px;
	overflow: hidden;
	position: relative;
	text-decoration: none;
	text-transform: uppercase;
}
.nav-items .nav-item a span {
	color: #ffffff;
	display: block;
	transition: transform 0.5s ease;
	width: 100%;
}
.nav-items .nav-item a span:nth-child(1) {
	color: #ffffff;
}
.nav-items .nav-item:hover a span:nth-child(1) {
	transform: translateY(-100%);
}
.nav-items .nav-item a span:nth-child(2) {
	color: #ffffff;
}
.nav-items .nav-item:hover a span:nth-child(2) {
	transform: translateY(-100%);
}
.nav-items a:before,
.nav-items a:after {
  position: absolute;
  -webkit-transition: all 0.35s ease;
  transition: all 0.35s ease;
}
.nav-items a:before {
  bottom: 0;
  display: block;
  height: 3px;
  width: 0%;
  content: "";
  background-color: #fff;
}
.nav-items a:after {
  left: 0;
  top: 0;
  padding: 0.5em 0;
  position: absolute;
  content: attr(data-hover);
  color: #ffffff;
  white-space: nowrap;
  max-width: 0%;
  overflow: hidden;
}
.nav-items .nav-item:hover a:before,
.nav-items .nav-item .current:before {
  opacity: 1;
  width: 100%;
}
.nav-items .nav-item:hover a:after,
.nav-items .nav-item .current:after {
  max-width: 100%;
}

.nav-mobile {
 position: absolute;
 left: 50px;
}

.nav-logo {
 position: absolute;
 top: 8px;
 left: 30px;
	font-family: -apple-system, BlinkMacSystemFont, Segoe UI, Helvetica, Arial, sans-serif;
	font-size: 1.2rem;
	font-weight: inherit;
	color: #fff;
	-webkit-text-stroke: 1px #fff;
	text-stroke: 1px #fff;
 font-weight: 400;
 cursor: pointer;
 transform: scale(1);
 -webkit-transition: all 0.3s ease-in-out;
    -moz-transition: all 0.3s ease-in-out;
      -o-transition: all 0.3s ease-in-out;
         transition: all 0.3s ease-in-out;

}

.nav-logo:hover {
 transform: scale(1.3);
 -webkit-transition: all 0.3s ease-in-out;
    -moz-transition: all 0.3s ease-in-out;
      -o-transition: all 0.3s ease-in-out;
         transition: all 0.3s ease-in-out;
}

.bg-warning {
  background: #090d00;
}
.bg-warning-text {
  font: 400 1em/1.5 "Neuton";
  color: rgba(255, 255, 255, 0.25);
}
.warning {
  text-transform: uppercase;
  letter-spacing: 0.5em;
  display: inline-block;
  position: relative;
  top: 18%;
  width: 40em;
}
.warning span {
  font: 700 4em "Oswald", sans-serif;
  letter-spacing: 0;
  padding: 0.25em 0 0.325em;
  display: block;
  margin: 0 auto;
  text-shadow: 0 0 80px rgba(255, 255, 255, 0.5);

  /* Clip Background Image */
  background: url("../img/style/animated-text-fill.png") repeat-y;
  -webkit-background-clip: text;
  background-clip: text;

  /* Animate Background Image */
  -webkit-text-fill-color: transparent;
  -webkit-animation: aitf 80s linear infinite;

  /* Activate hardware acceleration for smoother animations */
  -webkit-transform: translate3d(0, 0, 0);
  -webkit-backface-visibility: hidden;
}
/* Animate Background Image */
@-webkit-keyframes aitf {
  0% {
    background-position: 0% 50%;
  }
  100% {
    background-position: 100% 50%;
  }
}

/* -------------------------------- 
   Grid items
-------------------------------- */

.items {
 margin-left: auto;
 margin-right: auto;
 display: grid;
 grid-gap: 20px;
 grid-template-columns: repeat(3, 1fr);
}
.item {
 display: grid;
 grid-gap: 2px;
	grid-template-columns: 80px;
}
.item_icon {
 grid-column: 1;
 grid-row: 1 / 2;
 color: #335969;
 user-select: none;
}
.item_title {
 grid-column: 2;
 grid-row: 1;
	font-family: -apple-system, BlinkMacSystemFont, Segoe UI, Helvetica, Arial, sans-serif;
	font-size: 20px;
 color: #335969;
	font-weight: bold;
 text-align:left;
}
.item_experience {
 margin-top:-8px;
 grid-column: 2;
 grid-row: 2;
	font-family: -apple-system, BlinkMacSystemFont, Segoe UI, Helvetica, Arial, sans-serif;
	font-size: 18px;
 color: #B2B2B2;
	font-weight: normal;
 text-align:left;
}

/* -------------------------------- 
   Form
-------------------------------- */
.form-style {
 max-width: 750px;
 padding: 0;
 margin: 0 auto;
}
.form-style ul {
 padding:0;
 margin:0;
 list-style:none;
}
.form-style ul li {
 display: block;
 margin-bottom: 10px;
 min-height: 35px;
}
.form-style-thankyou {
 margin: 0 auto;
 background: #fff;
 background-image: url('../img/style/thankyou.jpg');
 background-position: center center;
 background-size: contain;
 background-repeat: no-repeat;
 width: 750px;
 height: 438px;
}
.form-style ul li .field-style {
 background: #fff;
 background-image: url('../img/style/blank.gif');
 background-position-x: right 5px;
 background-position-y: top 4px;
 background-size: 24px 24px;
 background-repeat: no-repeat;
 padding: 8px;
 text-decoration: none;
 font-family: Verdana, Arial;
 font-size: 10pt;
 border: 1px solid #E0E0E0;

 -webkit-transition: all 0.30s ease-in-out;
    -moz-transition: all 0.30s ease-in-out;
     -ms-transition: all 0.30s ease-in-out;
      -o-transition: all 0.30s ease-in-out;
}
.form-style ul li .text-style {
 background: #fff;
 padding: 8px;
 text-decoration: none;
 font-family: Verdana, Arial;
 font-size: 10pt;
}
.form-style ul li .error {
 background: #fff;
 background-image: url('../img/icons/error.png');
 background-position-x: right 5px;
 background-position-y: top 4px;
 background-size: 24px 24px;
 background-repeat: no-repeat;
 padding: 8px;
 text-decoration: none;
 font-family: Verdana, Arial;
 font-size: 10pt;
 border: 1px solid #ff0000;

 -webkit-transition: all 0.30s ease-in-out;
    -moz-transition: all 0.30s ease-in-out;
     -ms-transition: all 0.30s ease-in-out;
      -o-transition: all 0.30s ease-in-out;
}
.form-style ul li .picture {
 background-image: url('../img/style/stamp.png');
 background-position: center center;
 background-size: contain;
 background-repeat: no-repeat;
 height:120px;

 -webkit-transition: all 0.30s ease-in-out;
    -moz-transition: all 0.30s ease-in-out;
     -ms-transition: all 0.30s ease-in-out;
      -o-transition: all 0.30s ease-in-out;
}
.form-style ul li .reload {
 background-image: url('../img/icons/reload.png');
 background-position: center center;
 background-size: contain;
 background-repeat: no-repeat;
 height:17px;

 -webkit-transition: all 0.30s ease-in-out;
    -moz-transition: all 0.30s ease-in-out;
     -ms-transition: all 0.30s ease-in-out;
      -o-transition: all 0.30s ease-in-out;
}
.form-style ul li .field-style:focus, .form-style ul li .field-style:hover {
 border: 1px solid #808080;
 cursor: pointer;

 -webkit-transition: all 0.30s ease-in-out;
    -moz-transition: all 0.30s ease-in-out;
     -ms-transition: all 0.30s ease-in-out;
      -o-transition: all 0.30s ease-in-out;
}
.form-style ul li .field-split{
    width: 49%;
}
.form-style ul li .field-split82 {
    width: 87%;
}
.form-style ul li .field-split12 {
    width: 12%;
}
.form-style ul li .field-split90 {
    width: 95%;
}
.form-style ul li .field-split4 {
    width: 4%;
}
.form-style ul li .field-full {
    width: 100%;
}
.form-style ul li textarea{
 outline: none;
 width: 100%;
 height: 120px;
}
.form-style ul li input, .form-style ul li select{
 outline: none;
}
.form-style ul li input:focus,
.form-style ul li select:focus{
   
 border: 1px solid #ccc;
 cursor: pointer;

 -webkit-transition: all 0.30s ease-in-out;
    -moz-transition: all 0.30s ease-in-out;
     -ms-transition: all 0.30s ease-in-out;
      -o-transition: all 0.30s ease-in-out;
}
.form-style ul li input.align-left,
.form-style ul li select.align-left,
.form-style ul li div.align-left{
 float:left;
}
.form-style ul li input.align-right,
.form-style ul li select.align-right,
.form-style ul li div.align-right{
 float:right;
}
.form-style ul li .button_big {
    background-color: #000;
    padding: 8px;
    color: #fff;
    text-decoration: none;
    font-family: Verdana, Arial;
    font-size: 12pt;
    font-weight: bold;
    text-align: center;
    text-transform:uppercase;
    opacity:1;

 -webkit-transition: all 0.30s ease-in-out;
    -moz-transition: all 0.30s ease-in-out;
     -ms-transition: all 0.30s ease-in-out;
      -o-transition: all 0.30s ease-in-out;
}
.form-style ul li .button_big:hover {
    opacity:0.70;
    cursor: pointer;

 -webkit-transition: all 0.30s ease-in-out;
    -moz-transition: all 0.30s ease-in-out;
     -ms-transition: all 0.30s ease-in-out;
      -o-transition: all 0.30s ease-in-out;
}

.button_green {
 background-color: #335969;
 padding: 8px;
 width:180px;
 color: #fff;
 text-decoration: none;
 font-family: Verdana, Arial;
 font-size: 12pt;
 font-weight: bold;
 text-align: center;
 text-transform:uppercase;
 opacity:1;

 -webkit-transition: all 0.30s ease-in-out;
    -moz-transition: all 0.30s ease-in-out;
     -ms-transition: all 0.30s ease-in-out;
      -o-transition: all 0.30s ease-in-out;
}
.button_green:hover {
 opacity:0.70;
 cursor: pointer;

 -webkit-transition: all 0.30s ease-in-out;
    -moz-transition: all 0.30s ease-in-out;
     -ms-transition: all 0.30s ease-in-out;
      -o-transition: all 0.30s ease-in-out;
}

/* -------------------------------- 
Fullscreen Menu
-------------------------------- */
.flex-center {
  display: flex;
  align-items: center;
  justify-content: center;
}
.hamburger-menu * {
  box-sizing: border-box;
  font-family: "Open Sans", sans-serif;
  font-weight: 400;
}
.hamburger-menu {
  position: fixed;
  top: -5px;
  left: 10px;
  z-index: 10000;
}
.hamburger-menu .checkbox-toggle {
  position: absolute;
  top: 0;
  left: 0;
  z-index: 20000;
  cursor: pointer;
  width: 60px;
  height: 60px;
  opacity: 0;
}
.hamburger-menu .checkbox-toggle:checked + .hamburger > div {
  transform: rotate(135deg);
}
.hamburger-menu .checkbox-toggle:checked + .hamburger > div:before,
.hamburger-menu .checkbox-toggle:checked + .hamburger > div:after {
  top: 0;
  transform: rotate(90deg);
}
.hamburger-menu .checkbox-toggle:checked + .hamburger > div:after {
  opacity: 0;
}
.hamburger-menu .checkbox-toggle:checked ~ .menu {
  pointer-events: auto;
  visibility: visible;
}
.hamburger-menu .checkbox-toggle:checked ~ .menu > div {
  transform: scale(1);
  transition-duration: 1s;
}
.hamburger-menu .checkbox-toggle:checked ~ .menu > div > div {
  opacity: 1;
  transition: opacity 0.4s ease 0.3s;
}
.hamburger-menu .checkbox-toggle:hover + .hamburger {
  box-shadow: inset 0 0 10px rgba(0, 0, 0, 0.1);
}
.hamburger-menu .checkbox-toggle:checked:hover + .hamburger > div {
  transform: rotate(225deg);
}
.hamburger-menu .hamburger {
  position: absolute;
  top: 0;
  left: 0;
  z-index: 1;
  width: 60px;
  height: 60px;
  padding: 0.5em 1em;
  background: rgba(33, 150, 243, 0);
  border-radius: 0 0.12em 0.12em 0;
  cursor: pointer;
  transition: box-shadow 0.4s ease;
  -webkit-backface-visibility: hidden;
          backface-visibility: hidden;
  display: flex;
  align-items: center;
  justify-content: center;
}
.hamburger-menu .hamburger > div {
  position: relative;
  flex: none;
  width: 100%;
  height: 2px;
  background: #fff;
  transition: all 0.4s ease;
  display: flex;
  align-items: center;
  justify-content: center;
}
.hamburger-menu .hamburger > div:before,
.hamburger-menu .hamburger > div:after {
  content: "";
  position: absolute;
  z-index: 1;
  top: -10px;
  left: 0;
  width: 100%;
  height: 2px;
  background: inherit;
  transition: all 0.4s ease;
}
.hamburger-menu .hamburger > div:after {
  top: 10px;
}
.hamburger-menu .menu {
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  pointer-events: none;
  visibility: hidden;
  overflow: hidden;
  -webkit-backface-visibility: hidden;
          backface-visibility: hidden;
  outline: 1px solid transparent;
  display: flex;
  align-items: center;
  justify-content: center;
}
.hamburger-menu .menu > div {
  width: 200vw;
  height: 200vw;
  color: #fefefe;
  background: #0eabd0;
  border-radius: 50%;
  transition: all 0.4s ease;
  flex: none;
  transform: scale(0);
  -webkit-backface-visibility: hidden;
          backface-visibility: hidden;
  overflow: hidden;
  display: flex;
  align-items: center;
  justify-content: center;
}
.hamburger-menu .menu > div > div {
  text-align: center;
  max-width: 90vw;
  max-height: 100vh;
  width: 160px;
  font-size: 20px;
  opacity: 0;
  transition: opacity 0.4s ease;
  overflow-y: auto;
  flex: none;
  display: flex;
  align-items: center;
  justify-content: center;
}
.hamburger-menu .menu > div > div > ul {
  list-style: none;
  margin: 0;
  display: block;
  max-height: 100vh;
}
.hamburger-menu .menu > div > div > ul > li {
  padding: 0;
  margin: 1em;
  display: block;
}
.hamburger-menu .menu > div > div > ul > li > a > span {
	display: block;
	font-weight: 400;
	height: 28px;
	overflow: hidden;
	position: relative;
	text-decoration: none;
	text-transform: uppercase;
}

/* -------------------------------- 
   Introscreen
-------------------------------- */

.hidden {
	position: absolute;
	overflow: hidden;
	width: 0;
	height: 0;
	pointer-events: none;
}

.screen {
	position: fixed;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	background: #000;
	z-index: 1500;
}
.screen--grid {
	display: grid;
	grid-template-columns: 100%;
	grid-template-rows: 100%;
	justify-items: center;
	align-items: center;
}
.screen--flex {
	display: flex;
	flex-direction: column;
	align-items: center;
	justify-content: center;
}
.start-anim .intro {
	animation: fadeOut 1s var(--anim-time-total) linear forwards;
}
@keyframes fadeOut {
	to {
		opacity: 0;
  visibility:hidden;
	}
}
.intro__content {
	font-family: -apple-system, BlinkMacSystemFont, Segoe UI, Helvetica, Arial, sans-serif;
	font-size: 4vw;
 color: #fff;
	grid-area: 1 / 1 / 2 / 2;
	text-align: center;
	pointer-events: none;
	margin: 0;
	opacity: 0;
}
.intro__content-line {
	display: block;
	margin: 1rem 0;
}
.intro__content-line--small {
	font-size: 1.5rem;
}
.no-js .intro {
	display: none;
}
.start-anim .intro__content {
	animation: fadeInOut var(--anim-time) var(--anim-delay-first) linear forwards;
}
.start-anim .intro__content:nth-child(2) {
	animation-delay: var(--anim-delay-second);
}

@keyframes fadeInOut {
	0% {
		opacity: 0;
	}
	50% {
		opacity: 1;
	}
	100% {
		opacity: 0;
		pointer-events: none;
	}
}
.action__line {
	margin: 1rem 0;
	cursor: default;
}

.social {
 margin: 0 auto;
 width: 160px;
 height: 30px;
}

.social > .icon{
 float: left;
 margin-right: 10px;
 background-position: top center;
 background-repeat: no-repeat;
 background-size: contain;
 height: 30px;
 width: 30px;
 opacity: 0.60;

 -webkit-transition: all 0.30s ease-in-out;
    -moz-transition: all 0.30s ease-in-out;
     -ms-transition: all 0.30s ease-in-out;
      -o-transition: all 0.30s ease-in-out;
}

.social > .icon:hover{
 opacity: 1;
 cursor: pointer;

 -webkit-transition: all 0.30s ease-in-out;
    -moz-transition: all 0.30s ease-in-out;
     -ms-transition: all 0.30s ease-in-out;
      -o-transition: all 0.30s ease-in-out;
}

.social > .fb{
 background-image: url('../img/icons/fb.png');
}

.social > .tw{
 background-image: url('../img/icons/tw.png');
}

.social > .in{
 background-image: url('../img/icons/in.png');
}

.social > .mail{
 background-image: url('../img/icons/mail.png');
}

.photo {
 position: relative;
 float:left;
 margin-top:25px;
 margin-right:10px;
 width: 240px;
 height: 360px;
 border: 1px solid #E0E0E0;
 cursor: pointer;
 overflow:hidden;
}

.photo > div{
 position: absolute; 
 left:0;
 width: 100%;
 height: 100%;
 opacity: 0;
 background-position: top center;
	background-size: contain;
 background-repeat: no-repeat;

 -webkit-transition: all 0.60s ease-in-out;
    -moz-transition: all 0.60s ease-in-out;
     -ms-transition: all 0.60s ease-in-out;
      -o-transition: all 0.60s ease-in-out;
}

.photo-me{
 background-image: url('../img/photos/me.jpg');
}

.photo-you{
 background-image: url('../img/photos/you.jpg');
}

.photo-us{
 background-image: url('../img/photos/us.jpg');
}

.photo > div.show, .photo > div.startup {
 opacity: 1;

 -webkit-transition: all 0.60s ease-in-out;
    -moz-transition: all 0.60s ease-in-out;
     -ms-transition: all 0.60s ease-in-out;
      -o-transition: all 0.60s ease-in-out;
}

.photo > div.gone {
 opacity: 0;

 -webkit-transition: all 0.60s ease-in-out;
    -moz-transition: all 0.60s ease-in-out;
     -ms-transition: all 0.60s ease-in-out;
      -o-transition: all 0.60s ease-in-out;
}

/* -------------------------------- 
   Grid gallery
-------------------------------- */
.gallery{
	display: grid;
 grid-gap: 2px;
	grid-template-columns: 200px 200px 200px 200px 200px;
 place-items: center;
 place-self: center;
}
.gallery__item{
 width: 100%;
 height: 150px;
 border: 2px solid #fff;
 overflow: hidden;
}
.gallery__item--1{
	grid-column: 1 / span 2;
}
.gallery__item--9{
 height: 300px;
	grid-column: 5;
	grid-row: 2 / span 2;
}
.gallery__item--16{
	grid-column: 3 / span 2;
}
.gallery .gallery__item img{
 height: 100%;
 width: 100%;
 object-position: top center;
 object-fit: cover;
 text-indent: -140px;
 opacity:1;

 -webkit-transition: all 0.60s ease-in-out;
    -moz-transition: all 0.60s ease-in-out;
     -ms-transition: all 0.60s ease-in-out;
      -o-transition: all 0.60s ease-in-out;
}
.gallery .gallery__item img:hover{
 opacity:0.65;
  -webkit-transform: scale(1.1);
          transform: scale(1.1);

 -webkit-transition: all 0.60s ease-in-out;
    -moz-transition: all 0.60s ease-in-out;
     -ms-transition: all 0.60s ease-in-out;
      -o-transition: all 0.60s ease-in-out;
}
