html,
body,
div {
  font-family: "Trebuchet MS", "Lucida Grande", "Lucida Sans Unicode", "Lucida Sans", Tahoma, sans-serif;
}

::-webkit-scrollbar {
  display: none;
}


div,
img,
a,
td {
  -webkit-touch-callout: none;
  /* iOS Safari */
  -webkit-user-select: none;
  /* Safari */
  -khtml-user-select: none;
  /* Konqueror HTML */
  -moz-user-select: none;
  /* Firefox */
  -ms-user-select: none;
  /* Internet Explorer/Edge */
  user-select: none;
  /* Non-prefixed version, currently supported by Chrome and Opera */
  cursor: default;
  -webkit-overflow-scrolling: auto;

}

td {
  vertical-align: top;
}

.selectable {
  -webkit-touch-callout: text;
  /* iOS Safari */
  -webkit-user-select: text;
  /* Safari */
  -khtml-user-select: text;
  /* Konqueror HTML */
  -moz-user-select: text;
  /* Firefox */
  -ms-user-select: text;
  /* Internet Explorer/Edge */
  user-select: text;
  /* Non-prefixed version, currently supported by Chrome and Opera */
}

div,
img,
body {
  border-width: 0;
  margin: 0;
  padding: 0;
}

table {
  border-collapse: collapse;
}

span.and {
  font-family: Verdana;
}

body {
  font-size: 9pt;
  color: silver;
  background-color: #000;
  background-image: url('../images/landing_page_BG3.jpg');
  background-repeat: no-repeat;
  background-position: center 0px;
  width: 100vw;
  height: 100vh;
  -webkit-overflow-scrolling: auto;

}

a {
  text-decoration: none;
  color: #AAA;
  cursor: pointer;
}

a:hover {
  color: #EEE
}

h1,
h2,
h3 {
  font-weight: 400;
  text-transform: uppercase;
}

h2 {
  font-size: 16pt;
  line-height: 16pt
}



/*==========================================================================================
PROJECTS
==========================================================================================  */

.Posters {
  position: absolute;
  /*min-width: 80vh;*/
  max-width: 100vh;
  width: 100vw;
  left: 50%;
  transform: translateX(-50%);
  top: 45vh;
  text-align: center;
  white-space: normal;
  overflow-x: hidden;
  overflow-y: scroll;
  height: 45vh;
}

.Poster {
  cursor: pointer;
  -webkit-filter: grayscale(100%);
  /* Safari 6.0 - 9.0 */
  filter: grayscale(100%);
}

.Poster img {}

img.Poster {
  mix-blend-mode: luminosity;
}

.Tile {
  margin: 1vh;
  height: 20vh;
  width: 14vh;
}

.DoubleTile {
  margin: 1vh;
  height: 20vh;
  width: 29vh;
}


.Poster:hover {
  -webkit-filter: brightness(100%);
  /* Safari 6.0 - 9.0 */
  filter: brightness(100%);
  mix-blend-mode: normal;

}

/*==========================================================================================
SERVICES
==========================================================================================  */
div.Service {
  display: inline-block;
  cursor: pointer;
  width: 48vh;
  height: 20vh;
  margin: 10px;
  background-size: 100% 100%;
  -webkit-filter: grayscale(100%);
  /* Safari 6.0 - 9.0 */
  filter: grayscale(100%);
}



div.Service:hover {
  -webkit-filter: brightness(100%);
  /* Safari 6.0 - 9.0 */
  filter: brightness(100%);
  mix-blend-mode: normal;
}


.ServicePosters {
  position: absolute;
  max-width: 150vh;
  width: 100vw;
  left: 50%;
  transform: translateX(-50%);
  top: 15vh;
  white-space: normal;
  overflow-x: hidden;
  overflow-y: scroll;
  height: 75vh;
}

/*==========================================================================================
TEAM
==========================================================================================  */

.CoreTeam {
  text-align: center;
  white-space: normal;
}

.TeamMember {
  display: inline-block;
  background-size: 14vh 20vh;
  background-repeat: no-repeat;
  text-align: left;
  position: relative;
  padding: 0.2em;
}

.TeamMember:hover {
  //   -webkit-filter: brightness(50%); /* Safari 6.0 - 9.0 */
  //   filter: brightness(50%);
}

.TeamMember:hover .Name,
.TeamMember:hover .Function {
  opacity: 1;
}


.TeamMember .Name {
  opacity: 0;
  background-color: rgba(50, 50, 50, 0.5);
  color: white;
  text-shadow:
    -1px -1px 0 #000,
    1px -1px 0 #000,
    -1px 1px 0 #000,
    1px 1px 0 #000;
  position: absolute;
  top: 0;
  text-align: center;
  padding-top: 5vh;
  left: 0;
  width: 14vh;
  height: 15vh;

}

.TeamMember .Function {
  opacity: 0;
  font-size: 0.8em;
  color: white;
  text-align: center;
  text-shadow:
    -1px -1px 0 #000,
    1px -1px 0 #000,
    -1px 1px 0 #000,
    1px 1px 0 #000;
}


@media (max-width: 960px) {
  .ServiceDescription {
    text-align: justify;
    text-align-last: left;
    max-width: 77vh;
  }

  .PopUp,
  .ServicePopUp {
    opacity: 0;

    display: none;
    position: absolute;
    text-align: center;
    left: 0;
    top: 0;
    height: 100vh;

    width: 100vw;
    padding-top: 5vh;
    overflow: hidden;
    white-space: normal;
    background-color: rgba(50, 50, 50, 0.85);
  }

  .LargePoster {
    height: 40vh;
    width: 28vh;
  }

  .Project table {
    width: 100%;
    padding: 0;
    margin: 0;
  }

  .Details {
    text-align: left;

    position: absolute;

    display: block;
    padding: 0.5em;

  }

  .Close {
    display: inline-block;
    float: right;
    clear: none;
    position: absolute;
    top: 3vh;
    right: 1vh;
    text-align: right;
    height: 0;
    overflow: visible;
  }

}

ul {
  padding-left: 20px;
}


@media (min-width: 960px) {

  .ServiceDescription {
    text-align: justify;
    text-align-last: left;
    padding: 1vh;
    margin: 0;
  }

  .ServiceDescriptionWrapper {
    width: 80vh;
    min-width: 35vw;
    margin: 0;
    padding: 0;
  }

  .ServicePopUp {
    opacity: 0;
    display: none;
    position: absolute;

    left: 50vw;
    top: 18vh;
    transform: translateX(-50%);
    min-width: 35vw;
    width: 80vh;
    padding: 1vh;

    white-space: normal;
    background-color: rgba(50, 50, 50, 0.95);
  }

  .PopUp {
    opacity: 0;
    display: none;
    position: absolute;

    left: 25vw;
    top: 23vh;
    height: 50vh;

    width: 50vw;
    padding: 2vh;
    overflow: hidden;
    white-space: normal;
    background-color: rgba(50, 50, 50, 0.95);
  }


  .LargePoster {
    height: 50vh;
    width: 35vh;
  }

  .Project table {
    width: 100%;
    padding: 0;
    margin: 0;
  }

  .Details {
    display: inline-block;
    padding: 1em;
    float: right;
    clear: none;
    top: 0;
    position: absolute;
    height: 100%;
    overflow: scroll;
  }

  .Close {
    display: inline-block;
    float: right;
    clear: none;
    position: absolute;
    top: 1vh;
    right: 1vh;
    text-align: right;
    height: 0;
    overflow: visible;
  }

}

img.close {
  cursor: pointer;
  width: 25px;
  height: 25px;
  filter: brightness(0%);
}

h1 {
  padding: 0;
  margin: 0;
  text-transform: uppercase;
}

#Main {
  display: flex;
  align-items: center;
  width: 100vw;
  height: 100vh;

  white-space: nowrap;
  overflow-y: hidden;
  overflow-x: auto;
  -webkit-overflow-scrolling: auto;
  /* scroll-snap-type: mandatory;
      scroll-snap-destination: 0% 100%;
      scroll-snap-points-x: repeat(100%);*/
}

.Page {
  padding-top: 10vh;
  scroll-snap-align: start;
  width: 100%;
  height: 100%;
  display: inline-block;
  vertical-align: top;
  font-size: initial;
}

.Inside {
  width: 100vw;
  height: 100vh;
  position: relative;
  overflow: hidden;
  overflow-x: visible;
  overflow-y: scroll;
}

table.Menu {
  position: absolute;
  top: 0;
  left: 50vw;
  transform: translateX(-50%);
  z-index: 100;
}


table.Menu td {
  font-variant: small-caps;
  cursor: pointer;
  width: 100px;
  font-size: 100%;
  text-align: center;
  color: grey;
  border-bottom-color: grey;
  border-bottom-width: 1px;
  border-bottom-style: none;
}

table.Menu td:hover {
  cursor: pointer;
  width: 100px;
  font-size: 100%;
  text-align: center;
  color: white;
  border-bottom-style: solid;
  border-bottom-color: white;
}

table.Menu td.highlight {
  border-bottom-style: solid;
  border-bottom-width: 1px;
}

table.Menu td.CallToAction,
.CallToAction {
  background-color: green;
  color: white;
}


div.Logo {
  text-align: center;
  height: 28vh;
  width: 100vw;
  background-position: center center;
  background-size: 42vh 28vh;
  background-image: url('../images/vg/VG_beeldmerk_600_404.png');
  background-repeat: no-repeat;
  margin: 0;
}

div.KeyWords {
  cursor: pointer;
  text-align: center;
  height: 7vh;
  width: 100vw;
  background-position: center -20px;
  background-size: 42vh 7vh;
  background-image: url('../images/vg/VG_keywords_600_100.png');
  background-repeat: no-repeat;
  margin: 0;
}

div.KeyWords:hover {
  filter: brightness(150%);
}

div.SmallLogo {
  text-align: center;
  height: 11.5vh;
  width: 100vw;
  background-position: center center;
  background-size: 17.5vh 11.5vh;
  background-image: url('../images/vg/VG_beeldmerk_600.png');
  background-repeat: no-repeat;
}

#ContactPage {
  position: absolute;
  text-align: center;
  top: 50vh;
  left: 50vw;
  transform: translateX(-50%) translateY(-50%);
}

.FadeIn {
  -webkit-animation: fadein 0.5s;
  /* Safari, Chrome and Opera > 12.1 */
  -moz-animation: fadein 0.5s;
  /* Firefox < 16 */
  -ms-animation: fadein 0.5s;
  /* Internet Explorer */
  -o-animation: fadein 0.5s;
  /* Opera < 12.1 */
  animation: fadein 0.5s;
  animation-fill-mode: forwards;
}

.FadeOut {
  pointer-events: none;
  -webkit-animation: fadeout 0.5s;
  /* Safari, Chrome and Opera > 12.1 */
  -moz-animation: fadeout 0.5s;
  /* Firefox < 16 */
  -ms-animation: fadeout 0.5s;
  /* Internet Explorer */
  -o-animation: fadeout 0.5s;
  /* Opera < 12.1 */
  animation: fadeout 0.5s;
  animation-fill-mode: forwards;
}

@keyframes fadein {
  from {
    opacity: 0;
  }

  to {
    opacity: 1;
  }
}

/* Firefox < 16 */
@-moz-keyframes fadein {
  from {
    opacity: 0;
  }

  to {
    opacity: 1;
  }
}

/* Safari, Chrome and Opera > 12.1 */
@-webkit-keyframes fadein {
  from {
    opacity: 0;
  }

  to {
    opacity: 1;
  }
}

/* Internet Explorer */
@-ms-keyframes fadein {
  from {
    opacity: 0;
  }

  to {
    opacity: 1;
  }
}

/* Opera < 12.1 */
@-o-keyframes fadein {
  from {
    opacity: 0;
  }

  to {
    opacity: 1;
  }
}

@keyframes fadeout {
  from {
    opacity: 1;
  }

  to {
    opacity: 0;
  }
}

/* Firefox < 16 */
@-moz-keyframes fadeout {
  from {
    opacity: 1;
  }

  to {
    opacity: 0;
  }
}

/* Safari, Chrome and Opera > 12.1 */
@-webkit-keyframes fadeout {
  from {
    opacity: 1;
  }

  to {
    opacity: 0;
  }
}

/* Internet Explorer */
@-ms-keyframes fadeout {
  from {
    opacity: 1;
  }

  to {
    opacity: 0;
  }
}

/* Opera < 12.1 */
@-o-keyframes fadeout {
  from {
    opacity: 1;
  }

  to {
    opacity: 0;
  }
}

#theater {
  z-index: -100;
  background-color: black;
  opacity: 0;
  top: 0;
  left: 0;
  width: 100vw;
  height: 100vh;
  position: fixed;
}

#video-placeholder {
  visibility: visible;
  width: 80vw;
  height: 45vw;
  transform: translateX(-50%) translateY(-50%);
  position: absolute;
  left: 50vw;
  top: 45vh;
}


div.scrollArrow:hover {
  opacity: 0.4;
}

div.scrollArrow {
  cursor: pointer;
  position: absolute;
  top: 35vh;
  width: 3vh;
  height: 30vh;
  background-image: url('../images/scrollArrow.png');
  background-size: 100% 100%;
  opacity: 0.2;
}

#scrollArrowLeft {
  display: none;
  left: 5px;
  -moz-transform: scaleX(-1);
  -o-transform: scaleX(-1);
  -webkit-transform: scaleX(-1);
  transform: scaleX(-1);
  filter: FlipH;
  left 5px;
  -ms-filter: "FlipH";
  background-size: 100% 100%;
}

#scrollArrowRight {
  right: 5px;
}