/*
 Copyright (c) 2016 Wayne Parrott
*/

/* TODO: clean up code */
body {
    background-color: black;  
    margin: 0px;
}

.container {
  background-color: black;
  width: 100%;
  height: 500px;
}

.scene {    
  background-image: linear-gradient(to bottom, rgb(32,36,58), rgb(20,24,26));
  width: 100%;
  -webkit-perspective: 500px;
  -moz-perspective: 500px;
          perspective: 500px;
  -webkit-perspective-origin: 50% 50%;
  -moz-perspective-origin: 50% 50%;
          perspective-origin: 50% 50%;
  -webkit-transform: translateY(50%);
  -moz-transform: translateY(50%);
          transform: translateY(50%);
            
}

.lightandbeam {
  position: relative;
  margin: 100px auto;
  width: 100%;
  height: 200px;
  -webkit-transform-style: preserve-3d;
  -moz-transform-style: preserve-3d;
          transform-style: preserve-3d;
}
    
.lighthouse {
    position: absolute;
    left: 50%;
    top: 50%;
    margin: -15px 0 0 -10px;
    z-index: 100;
}

.lightBase {
  display: block;
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 200px;    
}

.beam {
  height: 2px;
  top: 105px;  
  background-image: linear-gradient(to right, 
     rgba(200,250,250,0.5) 5%,  
     rgba(150,150,150,0.05) 20%,
     rgba(50,50,50,0.0) 50%, 
     rgba(30,30,30,0.0) 60%, 
     rgba(0,0,0,0));
  -webkit-transform: translate3d(50%,-15px,0px);
  -moz-transform: translate3d(50%,-15px,0px);
          transform: translate3d(50%,-15px,0px);
}

.light { 
  top: -9px;
  background-image: radial-gradient(circle 15px at 50% 50%, 
    rgb(200,200,200), rgba(50,75,75,0.2), rgba(0,0,0,0));
  -webkit-transform: translateX(0px) rotateY(-90deg);
  -moz-transform: translateX(0px) rotateY(-90deg);
          transform: translateX(0px) rotateY(-90deg);
}

.rotate {
  -webkit-animation: spinY 5s infinite linear;
  -moz-animation: spinY 5s infinite linear;
          animation: spinY 5s infinite linear;
}

@-webkit-keyframes spinY {
  from {
    -webkit-transform: rotateY(0);
            transform: rotateY(0);
  }
  to {
    -webkit-transform: rotateY(360deg);
    transform: rotateY(360deg);
  }
}

@-moz-keyframes spinY {
  from {
    -moz-transform: rotateY(0);
     transform: rotateY(0);
  }
  to {
    -moz-transform: rotateY(360deg);
     transform: rotateY(360deg);
  }
}


@keyframes spinY {
  from {
    transform: rotateY(0);
    transform: rotateY(0);
  }
  to {
    transform: rotateY(360deg);
    transform: rotateY(360deg);
  }
}
