/******************************************************************/
* {
  margin: 0;
  padding: 0;
  outline: 0 none;
  border: 0 none;
  box-sizing: border-box;
  position: relative;
  -webkit-font-feature-settings: "liga" 0, "clig" 0;
     -moz-font-feature-settings: "liga" 0, "clig" 0;
          font-feature-settings: "liga" 0, "clig" 0;
  -webkit-font-variant-ligatures: no-common-ligatures;
     -moz-font-variant-ligatures: no-common-ligatures;
          font-variant-ligatures: no-common-ligatures; }

html {
  width: 100%;
  height: 100%; }

body {
  background: #222;
  color: #fff;
  font-size: 16px;
  line-height: 1.5;
  font-family: 'Fira Mono', monospace; }

h1 {
  font-weight: 700;
  font-size: 2rem; }

p {
  margin-top: 1.5rem;
  margin-bottom: 1.5rem; }
  p:first-child {
    margin-top: 0; }
  p:last-child {
    margin-bottom: 0; }

a {
  color: #fff;
  text-decoration: none; }
  a:hover {
    color: #1DAC4A; }
  a.is-active {
    color: #1DAC4A; }

.video {
  position: relative;
  padding-bottom: 56.25%;
  /* 16:9 */
  height: 0; }
  .video iframe {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%; }

.canvas {
  background: url(../assets/background.jpg) no-repeat fixed;
  background-size: cover;
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0; }

.canvas--is-faded {
  overflow: hidden !important; }
  .canvas--is-faded .fade {
    -webkit-transition: all 0.2s ease-in-out;
            transition: all 0.2s ease-in-out;
    background: #000;
    opacity: .5;
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    z-index: 10; }

.block {
  background: #222;
  padding: 1.5rem;
  position: absolute;
  overflow: hidden;
  z-index: 5;
  -webkit-transform: translate(0, 0);
      -ms-transform: translate(0, 0);
          transform: translate(0, 0);
  -webkit-transition: all 0.2s ease-in-out;
          transition: all 0.2s ease-in-out; }
  .block .content {
    overflow: auto;
    height: 100%; }
  .block.block--is-active {
    -webkit-transform: translate(0, 0);
        -ms-transform: translate(0, 0);
            transform: translate(0, 0);
    z-index: 20; }

.block--content {
  padding: 2rem; }
  .block--content img {
    width: 100%; }

.logo {
  width: 25rem; }
  @media screen and (max-width: 640px) {
    .logo {
      width: 100%; } }
  .logo svg {
    width: 100%; }
  .logo .st0 {
    fill: #fff; }

.logo-partners {
  margin-top: 4rem;
  display: table;
  width: 100%; }
  .logo-partners::after {
    content: '';
    clear: both;
    display: table; }

.logo-partner {
  display: table-cell;
  width: 25%;
  padding-right: 2rem;
  vertical-align: bottom; }
  .logo-partner:last-child {
    padding-right: 0; }
  .logo-partner img {
    vertical-align: middle;
    display: inline-block;
    width: 100%; }
  @media screen and (max-width: 640px) {
    .logo-partner {
      width: 50% !important;
      display: block;
      float: left;
      margin-bottom: 2rem;
      padding-right: 4rem; }
      .logo-partner:first-child, .logo-partner:nth-child(2) {
        padding-right: 2rem; }
      .logo-partner:nth-child(3), .logo-partner:nth-child(4) {
        margin-bottom: 0; } }

.logo-partner--kisd {
  width: 28%; }

.logo-partner--th {
  width: 23%; }

.logo-partner--simple {
  width: 23%; }

.logo-partner--messe {
  width: 26%; }

.media {
  visibility: hidden;
  opacity: 0;
  background: rgba(0, 0, 0, 0.5);
  padding: 2rem;
  position: fixed;
  left: 0;
  right: 0;
  top: 0;
  bottom: 0;
  z-index: 50;
  overflow: auto;
  -webkit-transition: all 0.2s ease-in-out;
          transition: all 0.2s ease-in-out; }
  .media.media--is-active {
    visibility: visible;
    opacity: 1; }
  .media .close {
    position: absolute;
    z-index: 60;
    top: 1rem;
    left: 1rem;
    font-size: 2rem;
    line-height: 1;
    text-transform: uppercase; }

.media-wrap {
  position: relative;
  padding-bottom: 56.25%;
  /* 16:9 */
  height: 0; }
  .media-wrap iframe {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%; }

.block--start {
  bottom: 15%;
  width: 35rem;
  left: 6rem; }
  @media screen and (max-height: 575px) {
    .block--start {
      bottom: auto;
      top: 5%; } }
  @media screen and (max-width: 800px) {
    .block--start {
      left: 3rem; } }
  @media screen and (max-width: 640px) {
    .block--start {
      width: 90%;
      top: auto;
      position: relative;
      left: 0;
      margin: 1rem auto 20rem; } }

.block--content {
  top: 0;
  bottom: 0;
  right: 0;
  width: 50%;
  -webkit-transform: translateX(150%);
      -ms-transform: translateX(150%);
          transform: translateX(150%);
  min-width: 40rem; }
  @media screen and (max-width: 640px) {
    .block--content {
      width: 100%;
      min-width: 0; } }

.block--contact {
  width: 30%;
  min-width: 30rem;
  -webkit-transform: translateX(130%);
      -ms-transform: translateX(130%);
          transform: translateX(130%); }
  @media screen and (max-width: 640px) {
    .block--contact {
      width: 100%;
      min-width: 0; } }
