/* @import "main.css"; */
@import "font-awesome.min.css";
@import "fonts.css";


* {
  margin:0;
  padding:0;
}

body {
	background-color: #222;
	font-family: "Helvetica Neue", sans-serif;
	font-weight: 400;
	font-size: 18px;
	color:#ddd;
	line-height: 1.6;
}


header {
  position: fixed;
  width: 130px;
  height:100%;
  left:50%;
  top: 0;
  bottom: 0;
  margin-left: -65px;
  z-index: 22;
  -ms-user-select: none; 
 -moz-user-select: none; 
 -webkit-user-select: none; 
 user-select: none; 
}

.logo {
  margin-top:90px;
  transition: margin 0.5s ease-in-out;
  text-align: center;
}

.logo a {
  background-color: #009de0;
  color: #fff;
  font-family: "Bebas", sans-serif;
  font-weight: 400;
  font-size: 3em;
  text-align: center;
  border-radius: 50%;
  width:1.75em;
  height:1.75em;
  line-height:1.85em;
  display: inline-block;
  text-decoration: none;
}

.logo a:hover {
  background-color: #fc7800;
  color: #fff;
}

.navi {
  position: absolute;
  bottom:90px;
  margin-left: 36px;
}

.navi .hamburger,
.navi .phone {
  background-color: #fff;
  width: 40px;
  height:34px;
  cursor: pointer;
  text-align: center;
  padding: 10px 8px;
  margin-top: 10px;
  position: relative;
  color: #009de0;
  border-radius: 50%;
}

.navi.open .hamburger,
.navi .phone.open {
  background-color: #fc7800;
  color: #fff;
}

.navi .hamburger .ham {
  background-color: #009de0;
  width: 30px;
  height:5px;
  display: block;
  margin: 5px;
}

.navi.open .hamburger .ham {
  background-color: #fff;
}

.navi .phone i {
  font-size: 36px;
}
.navi .menu,
.navi .phone .tip {
  position: absolute;
  left:80px;
  bottom: 0;
  background-color: #fff;
  padding: 5px 10px;
  display: none;
  white-space: nowrap;
  text-align: left;
}

.navi .menu::before,
.navi .phone .tip::before {
  clip-path: polygon(0 50% , 100% 0, 100% 100%);
  background-color: #fff;
  content: '';
  width: 20px;
  height: 30px;
  position: absolute;
  left:-20px;
  bottom:10px;
}

.navi .phone .tip {
  padding: 5px 20px;
  height: 40px;
}

.navi.open .menu,
.navi .phone.open .tip {
  display: block;
}

.navi .menu ul {
  padding: 10px;
}

.navi .menu li {
  list-style: none;
}


.navi  a {
  display: block;
  text-decoration: none;
  color: #009de0;
  font-family: "Bebas", sans-serif;
  font-weight: 400;
  font-size: 1.4em;
}

.navi  a:hover, a.active {
  color: #fc7800;
}

.stage section {
  min-height: 100%;
  -ms-user-select: none; 
 -moz-user-select: none; 
 -webkit-user-select: none; 
 user-select: none; 
}
.stage.left {
  width: 50%;
}
.stage.right {
  top: 0;
  right: 0;
  bottom: 0;
  width: 50%;
  position: fixed;
  background-color: #dbdedd;
}

.stage.left section {
  display: table;
}

.stage.left .inner {
  padding: 100px 70px 100px 100px;
  display: table-cell;
  vertical-align: middle;
}
.stage.right .inner {
  text-align: center;
  position: absolute;
  bottom: 90px;
  width: 95%;
}

.stageslider {
  position: absolute;
  top:0px;
  left:0;
  right:0px;
  bottom:0px;
  z-index: 12;
  opacity: 0;
  transition: opacity 1s ease-in-out;
}

.stageslider > div {
  height: 100%;
}

.imgbox {
  border: 1px solid #eee;
  padding: 5px;
  width: 95%;
  text-align: center;
  max-width: 350px;
}

.imgbox img {
  width: 100%;
  height: auto;
}

a {
  color: #009de0;
}

a:hover {
  color: #fc7800;
}

.focus {
  opacity: 1;
  z-index: 22;
}

h1,h2,h3,h4,h5,h6 {
	line-height: 1.1;
	margin:0 0 0.5em 0;	
  font-family: "Bebas", sans-serif;
  font-weight: 400;
  color: #eee;
	text-rendering: optimizeLegibility !important;
	-webkit-font-smoothing: antialiased !important;
	-moz-osx-font-smoothing: grayscale !important; 
}

h1 {
  font-size: 2em;
}
h2 {
  font-size: 1.5em;
}

.bigtext {
  font-size: 1.25em;
}

p {
  margin: 1em 0;
}

.hide {
  display: none;
}

.mousescroll {
  width: 25px;
  height: auto;
  opacity: 0.75;

  animation-name: mousescroll;
  animation-duration: 3s;
  animation-iteration-count: infinite;
}

@keyframes mousescroll {
  
  0%{
    opacity: 0.5;
  }

  50% {
    opacity: 1;
  }

  100% {
    opacity: 0.5;
  }
}

footer {
  background-color: #222;
  padding: 5px 10px;
  font-size: 12px;
  position: fixed;
  bottom: 0px;
  left:65px;
  z-index: 130;
  right: 50%;
}

.mspacer {
  display: none;
}


@media only screen and (max-width: 780px) {

  .stage.left {
    width: 100%;
  }

  .stage.left .inner {
    padding: 60px 40px 40px 40px;
    display:block;
  }

  .stage.right {
    top: 0;
    left: 0;
    width: 100%;
    height: 40%;

  bottom: 90px;
  }

  .stage.right .inner {
  bottom: 40px;
  width: 100%;
  }

  header {
    width: 100%;
    height:80px;
    left:0;
    top: 40%;
    bottom: auto;
    margin-left: 0;
    z-index: 22;
    margin-top:-40px;
  }
  
  .logo {
    margin-top:-5px;
    transition: margin 0.5s ease-in-out;
    height: 100%;
    float: right;
    margin-right: 30px;
  }

  .logo img {
    height: 100%;
    width: auto;
  }

  .navi .hamburger,
  .navi .phone {
    display: inline-block;
    vertical-align: middle;
    margin-right: 10px;
  }

  .navi {
    position: relative;
    bottom: auto;
    margin-left: 30px;
    margin-top: 5px;
  }

  .navi .menu, .navi .phone .tip {
    left: 85px;
    z-index: 99;
    }

  .navi .menu {
    bottom: auto;
    top:-75px;
  }

  .navi .menu::before {
    top: 110px;
  bottom:auto;
}

  .slick-dots {
    bottom: auto;
    top: 15px;
  }

  .stage.right .text, .stage.right .subtext, .stage.right .bttn {
    top:30%;
    padding: 7px 10px 5px 10px;
  }
  
  footer {
    left:40px;
    right: 0;
    width: auto;
  }

  .stage.left section {
    display:block;
  }

  .mspacer {
    display: block;
  }


}

@media only screen and (max-width: 480px) {
  
  body {
    font-size: 16px;
  }

}