@charset "UTF-8";
/* COLOR VARIABLES */
/* Imports */
/*! * * * * * * * * * * * * * * * * * * * *\  
  CSShake :: Package
  v1.5.0
  CSS classes to move your DOM
  (c) 2015 @elrumordelaluz
  http://elrumordelaluz.github.io/csshake/
  Licensed under MIT
\* * * * * * * * * * * * * * * * * * * * */
.shake, .hero__shaker:hover, .shake-little, .shake-slow, .shake-hard, .shake-horizontal, .shake-vertical, .shake-rotate, .shake-opacity, .shake-crazy, .shake-chunk {
  display: inline-block;
  transform-origin: center center; }

.shake-freeze,
.shake-constant.shake-constant--hover:hover,
.shake-trigger:hover .shake-constant.shake-constant--hover {
  animation-play-state: paused; }

.shake-freeze:hover,
.shake-trigger:hover .shake-freeze, .shake:hover, .hero__shaker:hover,
.shake-trigger:hover .shake,
.shake-trigger:hover .hero__shaker:hover, .shake-little:hover,
.shake-trigger:hover .shake-little, .shake-slow:hover,
.shake-trigger:hover .shake-slow, .shake-hard:hover,
.shake-trigger:hover .shake-hard, .shake-horizontal:hover,
.shake-trigger:hover .shake-horizontal, .shake-vertical:hover,
.shake-trigger:hover .shake-vertical, .shake-rotate:hover,
.shake-trigger:hover .shake-rotate, .shake-opacity:hover,
.shake-trigger:hover .shake-opacity, .shake-crazy:hover,
.shake-trigger:hover .shake-crazy, .shake-chunk:hover,
.shake-trigger:hover .shake-chunk {
  animation-play-state: running; }

@keyframes shake {
  2% {
    transform: translate(-0.5px, -0.5px) rotate(0.5deg); }
  4% {
    transform: translate(2.5px, -1.5px) rotate(-0.5deg); }
  6% {
    transform: translate(2.5px, 0.5px) rotate(1.5deg); }
  8% {
    transform: translate(-0.5px, 2.5px) rotate(-0.5deg); }
  10% {
    transform: translate(1.5px, -0.5px) rotate(1.5deg); }
  12% {
    transform: translate(0.5px, -1.5px) rotate(-0.5deg); }
  14% {
    transform: translate(0.5px, -1.5px) rotate(0.5deg); }
  16% {
    transform: translate(-0.5px, 0.5px) rotate(0.5deg); }
  18% {
    transform: translate(-1.5px, 1.5px) rotate(0.5deg); }
  20% {
    transform: translate(-0.5px, -1.5px) rotate(-0.5deg); }
  22% {
    transform: translate(1.5px, 1.5px) rotate(0.5deg); }
  24% {
    transform: translate(-1.5px, 2.5px) rotate(1.5deg); }
  26% {
    transform: translate(-0.5px, 0.5px) rotate(0.5deg); }
  28% {
    transform: translate(-1.5px, 1.5px) rotate(-0.5deg); }
  30% {
    transform: translate(1.5px, 0.5px) rotate(0.5deg); }
  32% {
    transform: translate(1.5px, -0.5px) rotate(0.5deg); }
  34% {
    transform: translate(2.5px, 1.5px) rotate(-0.5deg); }
  36% {
    transform: translate(-1.5px, -0.5px) rotate(-0.5deg); }
  38% {
    transform: translate(1.5px, 2.5px) rotate(-0.5deg); }
  40% {
    transform: translate(-0.5px, -1.5px) rotate(0.5deg); }
  42% {
    transform: translate(0.5px, 0.5px) rotate(0.5deg); }
  44% {
    transform: translate(1.5px, 1.5px) rotate(-0.5deg); }
  46% {
    transform: translate(-1.5px, 0.5px) rotate(-0.5deg); }
  48% {
    transform: translate(1.5px, 1.5px) rotate(1.5deg); }
  50% {
    transform: translate(0.5px, -0.5px) rotate(0.5deg); }
  52% {
    transform: translate(-0.5px, 0.5px) rotate(1.5deg); }
  54% {
    transform: translate(1.5px, -1.5px) rotate(0.5deg); }
  56% {
    transform: translate(-0.5px, -1.5px) rotate(1.5deg); }
  58% {
    transform: translate(2.5px, 1.5px) rotate(0.5deg); }
  60% {
    transform: translate(-0.5px, -0.5px) rotate(1.5deg); }
  62% {
    transform: translate(1.5px, 2.5px) rotate(-0.5deg); }
  64% {
    transform: translate(-1.5px, 0.5px) rotate(-0.5deg); }
  66% {
    transform: translate(2.5px, 1.5px) rotate(-0.5deg); }
  68% {
    transform: translate(2.5px, 0.5px) rotate(1.5deg); }
  70% {
    transform: translate(-1.5px, -1.5px) rotate(0.5deg); }
  72% {
    transform: translate(-1.5px, -0.5px) rotate(-0.5deg); }
  74% {
    transform: translate(-0.5px, -1.5px) rotate(1.5deg); }
  76% {
    transform: translate(1.5px, 1.5px) rotate(0.5deg); }
  78% {
    transform: translate(1.5px, -0.5px) rotate(1.5deg); }
  80% {
    transform: translate(-0.5px, 1.5px) rotate(1.5deg); }
  82% {
    transform: translate(2.5px, 2.5px) rotate(0.5deg); }
  84% {
    transform: translate(-0.5px, 0.5px) rotate(1.5deg); }
  86% {
    transform: translate(1.5px, -0.5px) rotate(1.5deg); }
  88% {
    transform: translate(2.5px, -1.5px) rotate(0.5deg); }
  90% {
    transform: translate(0.5px, -1.5px) rotate(-0.5deg); }
  92% {
    transform: translate(-0.5px, -1.5px) rotate(1.5deg); }
  94% {
    transform: translate(2.5px, 0.5px) rotate(1.5deg); }
  96% {
    transform: translate(-0.5px, -1.5px) rotate(-0.5deg); }
  98% {
    transform: translate(-0.5px, -1.5px) rotate(0.5deg); }
  0%, 100% {
    transform: translate(0, 0) rotate(0); } }
.shake:hover, .hero__shaker:hover,
.shake-trigger:hover .shake,
.shake-trigger:hover .hero__shaker:hover, .shake.shake-freeze, .shake-freeze.hero__shaker:hover, .shake.shake-constant, .shake-constant.hero__shaker:hover {
  animation-name: shake;
  animation-duration: 100ms;
  animation-timing-function: ease-in-out;
  animation-iteration-count: infinite; }

@keyframes shake-little {
  2% {
    transform: translate(0px, 0px) rotate(0.5deg); }
  4% {
    transform: translate(1px, 1px) rotate(0.5deg); }
  6% {
    transform: translate(1px, 1px) rotate(0.5deg); }
  8% {
    transform: translate(1px, 1px) rotate(0.5deg); }
  10% {
    transform: translate(1px, 0px) rotate(0.5deg); }
  12% {
    transform: translate(0px, 1px) rotate(0.5deg); }
  14% {
    transform: translate(0px, 0px) rotate(0.5deg); }
  16% {
    transform: translate(1px, 1px) rotate(0.5deg); }
  18% {
    transform: translate(0px, 0px) rotate(0.5deg); }
  20% {
    transform: translate(1px, 0px) rotate(0.5deg); }
  22% {
    transform: translate(1px, 1px) rotate(0.5deg); }
  24% {
    transform: translate(0px, 1px) rotate(0.5deg); }
  26% {
    transform: translate(0px, 0px) rotate(0.5deg); }
  28% {
    transform: translate(0px, 0px) rotate(0.5deg); }
  30% {
    transform: translate(1px, 1px) rotate(0.5deg); }
  32% {
    transform: translate(1px, 0px) rotate(0.5deg); }
  34% {
    transform: translate(1px, 0px) rotate(0.5deg); }
  36% {
    transform: translate(0px, 0px) rotate(0.5deg); }
  38% {
    transform: translate(1px, 1px) rotate(0.5deg); }
  40% {
    transform: translate(1px, 1px) rotate(0.5deg); }
  42% {
    transform: translate(1px, 1px) rotate(0.5deg); }
  44% {
    transform: translate(1px, 0px) rotate(0.5deg); }
  46% {
    transform: translate(0px, 0px) rotate(0.5deg); }
  48% {
    transform: translate(1px, 1px) rotate(0.5deg); }
  50% {
    transform: translate(1px, 0px) rotate(0.5deg); }
  52% {
    transform: translate(0px, 0px) rotate(0.5deg); }
  54% {
    transform: translate(0px, 0px) rotate(0.5deg); }
  56% {
    transform: translate(1px, 0px) rotate(0.5deg); }
  58% {
    transform: translate(1px, 1px) rotate(0.5deg); }
  60% {
    transform: translate(1px, 1px) rotate(0.5deg); }
  62% {
    transform: translate(1px, 1px) rotate(0.5deg); }
  64% {
    transform: translate(1px, 1px) rotate(0.5deg); }
  66% {
    transform: translate(0px, 0px) rotate(0.5deg); }
  68% {
    transform: translate(1px, 1px) rotate(0.5deg); }
  70% {
    transform: translate(1px, 0px) rotate(0.5deg); }
  72% {
    transform: translate(1px, 0px) rotate(0.5deg); }
  74% {
    transform: translate(1px, 1px) rotate(0.5deg); }
  76% {
    transform: translate(0px, 1px) rotate(0.5deg); }
  78% {
    transform: translate(0px, 0px) rotate(0.5deg); }
  80% {
    transform: translate(0px, 0px) rotate(0.5deg); }
  82% {
    transform: translate(0px, 0px) rotate(0.5deg); }
  84% {
    transform: translate(0px, 0px) rotate(0.5deg); }
  86% {
    transform: translate(1px, 0px) rotate(0.5deg); }
  88% {
    transform: translate(1px, 1px) rotate(0.5deg); }
  90% {
    transform: translate(1px, 1px) rotate(0.5deg); }
  92% {
    transform: translate(1px, 0px) rotate(0.5deg); }
  94% {
    transform: translate(1px, 0px) rotate(0.5deg); }
  96% {
    transform: translate(1px, 1px) rotate(0.5deg); }
  98% {
    transform: translate(1px, 1px) rotate(0.5deg); }
  0%, 100% {
    transform: translate(0, 0) rotate(0); } }
.shake-little:hover,
.shake-trigger:hover .shake-little, .shake-little.shake-freeze, .shake-little.shake-constant {
  animation-name: shake-little;
  animation-duration: 100ms;
  animation-timing-function: ease-in-out;
  animation-iteration-count: infinite; }

@keyframes shake-slow {
  2% {
    transform: translate(4px, 4px) rotate(1.5deg); }
  4% {
    transform: translate(-5px, 10px) rotate(-1.5deg); }
  6% {
    transform: translate(7px, 2px) rotate(0.5deg); }
  8% {
    transform: translate(5px, -7px) rotate(1.5deg); }
  10% {
    transform: translate(-2px, 10px) rotate(2.5deg); }
  12% {
    transform: translate(-1px, -9px) rotate(-1.5deg); }
  14% {
    transform: translate(-1px, 5px) rotate(2.5deg); }
  16% {
    transform: translate(3px, 1px) rotate(2.5deg); }
  18% {
    transform: translate(6px, 7px) rotate(-0.5deg); }
  20% {
    transform: translate(2px, -7px) rotate(-1.5deg); }
  22% {
    transform: translate(-8px, 9px) rotate(-1.5deg); }
  24% {
    transform: translate(8px, 3px) rotate(-0.5deg); }
  26% {
    transform: translate(6px, 0px) rotate(-1.5deg); }
  28% {
    transform: translate(-2px, -3px) rotate(1.5deg); }
  30% {
    transform: translate(-5px, -9px) rotate(-1.5deg); }
  32% {
    transform: translate(-9px, -8px) rotate(-2.5deg); }
  34% {
    transform: translate(7px, 1px) rotate(-0.5deg); }
  36% {
    transform: translate(-3px, 10px) rotate(3.5deg); }
  38% {
    transform: translate(-4px, 10px) rotate(2.5deg); }
  40% {
    transform: translate(5px, 10px) rotate(-0.5deg); }
  42% {
    transform: translate(10px, -5px) rotate(0.5deg); }
  44% {
    transform: translate(2px, 7px) rotate(-0.5deg); }
  46% {
    transform: translate(6px, -5px) rotate(3.5deg); }
  48% {
    transform: translate(3px, -1px) rotate(-2.5deg); }
  50% {
    transform: translate(0px, -1px) rotate(2.5deg); }
  52% {
    transform: translate(-7px, -7px) rotate(3.5deg); }
  54% {
    transform: translate(-3px, 10px) rotate(-2.5deg); }
  56% {
    transform: translate(1px, 5px) rotate(-0.5deg); }
  58% {
    transform: translate(1px, 0px) rotate(-0.5deg); }
  60% {
    transform: translate(-9px, -1px) rotate(-0.5deg); }
  62% {
    transform: translate(2px, -3px) rotate(0.5deg); }
  64% {
    transform: translate(-5px, 8px) rotate(-2.5deg); }
  66% {
    transform: translate(-3px, 4px) rotate(2.5deg); }
  68% {
    transform: translate(5px, 9px) rotate(-2.5deg); }
  70% {
    transform: translate(-6px, 8px) rotate(1.5deg); }
  72% {
    transform: translate(-1px, 1px) rotate(2.5deg); }
  74% {
    transform: translate(2px, 6px) rotate(3.5deg); }
  76% {
    transform: translate(-5px, -7px) rotate(-1.5deg); }
  78% {
    transform: translate(-1px, -4px) rotate(-1.5deg); }
  80% {
    transform: translate(0px, 3px) rotate(2.5deg); }
  82% {
    transform: translate(4px, 10px) rotate(-2.5deg); }
  84% {
    transform: translate(1px, 8px) rotate(2.5deg); }
  86% {
    transform: translate(-9px, 5px) rotate(3.5deg); }
  88% {
    transform: translate(3px, 9px) rotate(1.5deg); }
  90% {
    transform: translate(0px, -2px) rotate(-2.5deg); }
  92% {
    transform: translate(-5px, 5px) rotate(-0.5deg); }
  94% {
    transform: translate(-6px, 0px) rotate(-0.5deg); }
  96% {
    transform: translate(5px, -6px) rotate(3.5deg); }
  98% {
    transform: translate(5px, 4px) rotate(-0.5deg); }
  0%, 100% {
    transform: translate(0, 0) rotate(0); } }
.shake-slow:hover,
.shake-trigger:hover .shake-slow, .shake-slow.shake-freeze, .shake-slow.shake-constant {
  animation-name: shake-slow;
  animation-duration: 5s;
  animation-timing-function: ease-in-out;
  animation-iteration-count: infinite; }

@keyframes shake-hard {
  2% {
    transform: translate(-4px, 2px) rotate(-2.5deg); }
  4% {
    transform: translate(-7px, 9px) rotate(-1.5deg); }
  6% {
    transform: translate(0px, 4px) rotate(-2.5deg); }
  8% {
    transform: translate(9px, -4px) rotate(-1.5deg); }
  10% {
    transform: translate(6px, 4px) rotate(1.5deg); }
  12% {
    transform: translate(-6px, -9px) rotate(-0.5deg); }
  14% {
    transform: translate(9px, -9px) rotate(-0.5deg); }
  16% {
    transform: translate(-2px, 2px) rotate(-2.5deg); }
  18% {
    transform: translate(8px, -2px) rotate(-1.5deg); }
  20% {
    transform: translate(-2px, -8px) rotate(1.5deg); }
  22% {
    transform: translate(3px, 8px) rotate(-2.5deg); }
  24% {
    transform: translate(2px, 10px) rotate(0.5deg); }
  26% {
    transform: translate(-3px, 8px) rotate(-0.5deg); }
  28% {
    transform: translate(10px, 0px) rotate(-1.5deg); }
  30% {
    transform: translate(7px, 5px) rotate(2.5deg); }
  32% {
    transform: translate(7px, 6px) rotate(1.5deg); }
  34% {
    transform: translate(0px, 9px) rotate(0.5deg); }
  36% {
    transform: translate(10px, -8px) rotate(0.5deg); }
  38% {
    transform: translate(-1px, 9px) rotate(3.5deg); }
  40% {
    transform: translate(-6px, 2px) rotate(2.5deg); }
  42% {
    transform: translate(-1px, -8px) rotate(-1.5deg); }
  44% {
    transform: translate(-9px, 4px) rotate(1.5deg); }
  46% {
    transform: translate(-8px, -6px) rotate(1.5deg); }
  48% {
    transform: translate(-2px, 8px) rotate(-2.5deg); }
  50% {
    transform: translate(3px, 9px) rotate(-2.5deg); }
  52% {
    transform: translate(7px, -9px) rotate(3.5deg); }
  54% {
    transform: translate(-6px, 4px) rotate(-2.5deg); }
  56% {
    transform: translate(2px, -4px) rotate(-2.5deg); }
  58% {
    transform: translate(4px, -9px) rotate(2.5deg); }
  60% {
    transform: translate(-1px, 4px) rotate(-1.5deg); }
  62% {
    transform: translate(-8px, -5px) rotate(-1.5deg); }
  64% {
    transform: translate(-5px, -6px) rotate(-2.5deg); }
  66% {
    transform: translate(9px, -7px) rotate(2.5deg); }
  68% {
    transform: translate(-6px, -3px) rotate(-0.5deg); }
  70% {
    transform: translate(6px, -8px) rotate(1.5deg); }
  72% {
    transform: translate(9px, 8px) rotate(0.5deg); }
  74% {
    transform: translate(7px, 1px) rotate(2.5deg); }
  76% {
    transform: translate(-9px, -4px) rotate(1.5deg); }
  78% {
    transform: translate(-8px, 0px) rotate(-0.5deg); }
  80% {
    transform: translate(6px, -7px) rotate(1.5deg); }
  82% {
    transform: translate(8px, -2px) rotate(2.5deg); }
  84% {
    transform: translate(4px, -5px) rotate(1.5deg); }
  86% {
    transform: translate(6px, 5px) rotate(-1.5deg); }
  88% {
    transform: translate(-2px, -2px) rotate(-1.5deg); }
  90% {
    transform: translate(-3px, 4px) rotate(-0.5deg); }
  92% {
    transform: translate(-6px, -4px) rotate(-0.5deg); }
  94% {
    transform: translate(6px, -7px) rotate(2.5deg); }
  96% {
    transform: translate(-5px, -3px) rotate(3.5deg); }
  98% {
    transform: translate(5px, 9px) rotate(-2.5deg); }
  0%, 100% {
    transform: translate(0, 0) rotate(0); } }
.shake-hard:hover,
.shake-trigger:hover .shake-hard, .shake-hard.shake-freeze, .shake-hard.shake-constant {
  animation-name: shake-hard;
  animation-duration: 100ms;
  animation-timing-function: ease-in-out;
  animation-iteration-count: infinite; }

@keyframes shake-horizontal {
  2% {
    transform: translate(0px, 0) rotate(0); }
  4% {
    transform: translate(4px, 0) rotate(0); }
  6% {
    transform: translate(-5px, 0) rotate(0); }
  8% {
    transform: translate(8px, 0) rotate(0); }
  10% {
    transform: translate(3px, 0) rotate(0); }
  12% {
    transform: translate(4px, 0) rotate(0); }
  14% {
    transform: translate(-6px, 0) rotate(0); }
  16% {
    transform: translate(9px, 0) rotate(0); }
  18% {
    transform: translate(-6px, 0) rotate(0); }
  20% {
    transform: translate(6px, 0) rotate(0); }
  22% {
    transform: translate(9px, 0) rotate(0); }
  24% {
    transform: translate(-1px, 0) rotate(0); }
  26% {
    transform: translate(-2px, 0) rotate(0); }
  28% {
    transform: translate(3px, 0) rotate(0); }
  30% {
    transform: translate(10px, 0) rotate(0); }
  32% {
    transform: translate(3px, 0) rotate(0); }
  34% {
    transform: translate(-9px, 0) rotate(0); }
  36% {
    transform: translate(8px, 0) rotate(0); }
  38% {
    transform: translate(-2px, 0) rotate(0); }
  40% {
    transform: translate(1px, 0) rotate(0); }
  42% {
    transform: translate(-5px, 0) rotate(0); }
  44% {
    transform: translate(-4px, 0) rotate(0); }
  46% {
    transform: translate(0px, 0) rotate(0); }
  48% {
    transform: translate(3px, 0) rotate(0); }
  50% {
    transform: translate(10px, 0) rotate(0); }
  52% {
    transform: translate(7px, 0) rotate(0); }
  54% {
    transform: translate(-8px, 0) rotate(0); }
  56% {
    transform: translate(-5px, 0) rotate(0); }
  58% {
    transform: translate(-4px, 0) rotate(0); }
  60% {
    transform: translate(7px, 0) rotate(0); }
  62% {
    transform: translate(-1px, 0) rotate(0); }
  64% {
    transform: translate(9px, 0) rotate(0); }
  66% {
    transform: translate(7px, 0) rotate(0); }
  68% {
    transform: translate(4px, 0) rotate(0); }
  70% {
    transform: translate(9px, 0) rotate(0); }
  72% {
    transform: translate(1px, 0) rotate(0); }
  74% {
    transform: translate(2px, 0) rotate(0); }
  76% {
    transform: translate(-9px, 0) rotate(0); }
  78% {
    transform: translate(0px, 0) rotate(0); }
  80% {
    transform: translate(0px, 0) rotate(0); }
  82% {
    transform: translate(6px, 0) rotate(0); }
  84% {
    transform: translate(-4px, 0) rotate(0); }
  86% {
    transform: translate(10px, 0) rotate(0); }
  88% {
    transform: translate(-5px, 0) rotate(0); }
  90% {
    transform: translate(-8px, 0) rotate(0); }
  92% {
    transform: translate(0px, 0) rotate(0); }
  94% {
    transform: translate(-5px, 0) rotate(0); }
  96% {
    transform: translate(-2px, 0) rotate(0); }
  98% {
    transform: translate(8px, 0) rotate(0); }
  0%, 100% {
    transform: translate(0, 0) rotate(0); } }
.shake-horizontal:hover,
.shake-trigger:hover .shake-horizontal, .shake-horizontal.shake-freeze, .shake-horizontal.shake-constant {
  animation-name: shake-horizontal;
  animation-duration: 100ms;
  animation-timing-function: ease-in-out;
  animation-iteration-count: infinite; }

@keyframes shake-vertical {
  2% {
    transform: translate(0, -5px) rotate(0); }
  4% {
    transform: translate(0, 3px) rotate(0); }
  6% {
    transform: translate(0, 0px) rotate(0); }
  8% {
    transform: translate(0, 3px) rotate(0); }
  10% {
    transform: translate(0, -1px) rotate(0); }
  12% {
    transform: translate(0, -4px) rotate(0); }
  14% {
    transform: translate(0, -3px) rotate(0); }
  16% {
    transform: translate(0, 0px) rotate(0); }
  18% {
    transform: translate(0, 5px) rotate(0); }
  20% {
    transform: translate(0, 9px) rotate(0); }
  22% {
    transform: translate(0, 7px) rotate(0); }
  24% {
    transform: translate(0, -3px) rotate(0); }
  26% {
    transform: translate(0, 10px) rotate(0); }
  28% {
    transform: translate(0, 1px) rotate(0); }
  30% {
    transform: translate(0, 8px) rotate(0); }
  32% {
    transform: translate(0, -7px) rotate(0); }
  34% {
    transform: translate(0, 5px) rotate(0); }
  36% {
    transform: translate(0, 2px) rotate(0); }
  38% {
    transform: translate(0, -7px) rotate(0); }
  40% {
    transform: translate(0, -2px) rotate(0); }
  42% {
    transform: translate(0, 10px) rotate(0); }
  44% {
    transform: translate(0, 2px) rotate(0); }
  46% {
    transform: translate(0, 0px) rotate(0); }
  48% {
    transform: translate(0, -5px) rotate(0); }
  50% {
    transform: translate(0, 10px) rotate(0); }
  52% {
    transform: translate(0, 1px) rotate(0); }
  54% {
    transform: translate(0, -7px) rotate(0); }
  56% {
    transform: translate(0, -7px) rotate(0); }
  58% {
    transform: translate(0, -9px) rotate(0); }
  60% {
    transform: translate(0, 6px) rotate(0); }
  62% {
    transform: translate(0, 5px) rotate(0); }
  64% {
    transform: translate(0, -9px) rotate(0); }
  66% {
    transform: translate(0, 3px) rotate(0); }
  68% {
    transform: translate(0, 3px) rotate(0); }
  70% {
    transform: translate(0, -5px) rotate(0); }
  72% {
    transform: translate(0, 9px) rotate(0); }
  74% {
    transform: translate(0, 8px) rotate(0); }
  76% {
    transform: translate(0, 1px) rotate(0); }
  78% {
    transform: translate(0, 8px) rotate(0); }
  80% {
    transform: translate(0, -1px) rotate(0); }
  82% {
    transform: translate(0, -6px) rotate(0); }
  84% {
    transform: translate(0, -4px) rotate(0); }
  86% {
    transform: translate(0, 2px) rotate(0); }
  88% {
    transform: translate(0, -5px) rotate(0); }
  90% {
    transform: translate(0, 10px) rotate(0); }
  92% {
    transform: translate(0, -4px) rotate(0); }
  94% {
    transform: translate(0, -1px) rotate(0); }
  96% {
    transform: translate(0, 2px) rotate(0); }
  98% {
    transform: translate(0, 2px) rotate(0); }
  0%, 100% {
    transform: translate(0, 0) rotate(0); } }
.shake-vertical:hover,
.shake-trigger:hover .shake-vertical, .shake-vertical.shake-freeze, .shake-vertical.shake-constant {
  animation-name: shake-vertical;
  animation-duration: 100ms;
  animation-timing-function: ease-in-out;
  animation-iteration-count: infinite; }

@keyframes shake-rotate {
  2% {
    transform: translate(0, 0) rotate(3.5deg); }
  4% {
    transform: translate(0, 0) rotate(-1.5deg); }
  6% {
    transform: translate(0, 0) rotate(-5.5deg); }
  8% {
    transform: translate(0, 0) rotate(0.5deg); }
  10% {
    transform: translate(0, 0) rotate(4.5deg); }
  12% {
    transform: translate(0, 0) rotate(-3.5deg); }
  14% {
    transform: translate(0, 0) rotate(5.5deg); }
  16% {
    transform: translate(0, 0) rotate(5.5deg); }
  18% {
    transform: translate(0, 0) rotate(0.5deg); }
  20% {
    transform: translate(0, 0) rotate(7.5deg); }
  22% {
    transform: translate(0, 0) rotate(-4.5deg); }
  24% {
    transform: translate(0, 0) rotate(-0.5deg); }
  26% {
    transform: translate(0, 0) rotate(4.5deg); }
  28% {
    transform: translate(0, 0) rotate(2.5deg); }
  30% {
    transform: translate(0, 0) rotate(-4.5deg); }
  32% {
    transform: translate(0, 0) rotate(4.5deg); }
  34% {
    transform: translate(0, 0) rotate(3.5deg); }
  36% {
    transform: translate(0, 0) rotate(-6.5deg); }
  38% {
    transform: translate(0, 0) rotate(5.5deg); }
  40% {
    transform: translate(0, 0) rotate(-4.5deg); }
  42% {
    transform: translate(0, 0) rotate(1.5deg); }
  44% {
    transform: translate(0, 0) rotate(1.5deg); }
  46% {
    transform: translate(0, 0) rotate(-4.5deg); }
  48% {
    transform: translate(0, 0) rotate(-1.5deg); }
  50% {
    transform: translate(0, 0) rotate(-4.5deg); }
  52% {
    transform: translate(0, 0) rotate(-3.5deg); }
  54% {
    transform: translate(0, 0) rotate(-6.5deg); }
  56% {
    transform: translate(0, 0) rotate(-3.5deg); }
  58% {
    transform: translate(0, 0) rotate(2.5deg); }
  60% {
    transform: translate(0, 0) rotate(3.5deg); }
  62% {
    transform: translate(0, 0) rotate(-0.5deg); }
  64% {
    transform: translate(0, 0) rotate(2.5deg); }
  66% {
    transform: translate(0, 0) rotate(0.5deg); }
  68% {
    transform: translate(0, 0) rotate(4.5deg); }
  70% {
    transform: translate(0, 0) rotate(-6.5deg); }
  72% {
    transform: translate(0, 0) rotate(-4.5deg); }
  74% {
    transform: translate(0, 0) rotate(4.5deg); }
  76% {
    transform: translate(0, 0) rotate(7.5deg); }
  78% {
    transform: translate(0, 0) rotate(-5.5deg); }
  80% {
    transform: translate(0, 0) rotate(1.5deg); }
  82% {
    transform: translate(0, 0) rotate(-5.5deg); }
  84% {
    transform: translate(0, 0) rotate(-1.5deg); }
  86% {
    transform: translate(0, 0) rotate(0.5deg); }
  88% {
    transform: translate(0, 0) rotate(-6.5deg); }
  90% {
    transform: translate(0, 0) rotate(4.5deg); }
  92% {
    transform: translate(0, 0) rotate(-4.5deg); }
  94% {
    transform: translate(0, 0) rotate(4.5deg); }
  96% {
    transform: translate(0, 0) rotate(-1.5deg); }
  98% {
    transform: translate(0, 0) rotate(7.5deg); }
  0%, 100% {
    transform: translate(0, 0) rotate(0); } }
.shake-rotate:hover,
.shake-trigger:hover .shake-rotate, .shake-rotate.shake-freeze, .shake-rotate.shake-constant {
  animation-name: shake-rotate;
  animation-duration: 100ms;
  animation-timing-function: ease-in-out;
  animation-iteration-count: infinite; }

@keyframes shake-opacity {
  10% {
    transform: translate(-4px, 2px) rotate(-0.5deg);
    opacity: 0.87; }
  20% {
    transform: translate(-1px, -3px) rotate(0.5deg);
    opacity: 0.01; }
  30% {
    transform: translate(-4px, -2px) rotate(1.5deg);
    opacity: 0.76; }
  40% {
    transform: translate(-1px, 1px) rotate(0.5deg);
    opacity: 0.4; }
  50% {
    transform: translate(-1px, -1px) rotate(2.5deg);
    opacity: 0.1; }
  60% {
    transform: translate(-1px, -1px) rotate(-1.5deg);
    opacity: 0.09; }
  70% {
    transform: translate(-2px, -1px) rotate(-1.5deg);
    opacity: 0.3; }
  80% {
    transform: translate(-1px, -3px) rotate(-0.5deg);
    opacity: 0.91; }
  90% {
    transform: translate(2px, 5px) rotate(-0.5deg);
    opacity: 0.76; }
  0%, 100% {
    transform: translate(0, 0) rotate(0); } }
.shake-opacity:hover,
.shake-trigger:hover .shake-opacity, .shake-opacity.shake-freeze, .shake-opacity.shake-constant {
  animation-name: shake-opacity;
  animation-duration: 0.5s;
  animation-timing-function: ease-in-out;
  animation-iteration-count: infinite; }

@keyframes shake-crazy {
  10% {
    transform: translate(16px, 11px) rotate(5deg);
    opacity: 0.14; }
  20% {
    transform: translate(17px, -8px) rotate(8deg);
    opacity: 0.46; }
  30% {
    transform: translate(9px, 8px) rotate(5deg);
    opacity: 0.22; }
  40% {
    transform: translate(16px, 14px) rotate(1deg);
    opacity: 0.92; }
  50% {
    transform: translate(1px, 11px) rotate(4deg);
    opacity: 0.2; }
  60% {
    transform: translate(13px, -10px) rotate(-4deg);
    opacity: 0.72; }
  70% {
    transform: translate(6px, -10px) rotate(-3deg);
    opacity: 0.2; }
  80% {
    transform: translate(11px, -18px) rotate(8deg);
    opacity: 0.7; }
  90% {
    transform: translate(-10px, -18px) rotate(9deg);
    opacity: 0.34; }
  0%, 100% {
    transform: translate(0, 0) rotate(0); } }
.shake-crazy:hover,
.shake-trigger:hover .shake-crazy, .shake-crazy.shake-freeze, .shake-crazy.shake-constant {
  animation-name: shake-crazy;
  animation-duration: 100ms;
  animation-timing-function: ease-in-out;
  animation-iteration-count: infinite; }

@keyframes shake-chunk {
  2% {
    transform: translate(-10px, -2px) rotate(8deg); }
  4% {
    transform: translate(5px, 12px) rotate(10deg); }
  6% {
    transform: translate(6px, 6px) rotate(0deg); }
  8% {
    transform: translate(-13px, -12px) rotate(-6deg); }
  10% {
    transform: translate(15px, 11px) rotate(15deg); }
  12% {
    transform: translate(-4px, -8px) rotate(2deg); }
  14% {
    transform: translate(0px, -11px) rotate(2deg); }
  16% {
    transform: translate(10px, 8px) rotate(9deg); }
  18% {
    transform: translate(3px, 12px) rotate(15deg); }
  20% {
    transform: translate(7px, 1px) rotate(10deg); }
  22% {
    transform: translate(10px, 15px) rotate(-13deg); }
  24% {
    transform: translate(3px, 5px) rotate(12deg); }
  26% {
    transform: translate(-5px, -11px) rotate(-11deg); }
  28% {
    transform: translate(11px, 11px) rotate(3deg); }
  30% {
    transform: translate(-3px, -1px) rotate(-6deg); }
  32% {
    transform: translate(11px, 5px) rotate(14deg); }
  34% {
    transform: translate(-11px, -7px) rotate(-2deg); }
  36% {
    transform: translate(3px, 6px) rotate(-14deg); }
  38% {
    transform: translate(10px, 11px) rotate(-5deg); }
  0%, 40%, 100% {
    transform: translate(0, 0) rotate(0); } }
.shake-chunk:hover,
.shake-trigger:hover .shake-chunk, .shake-chunk.shake-freeze, .shake-chunk.shake-constant {
  animation-name: shake-chunk;
  animation-duration: 4s;
  animation-timing-function: ease-in-out;
  animation-iteration-count: infinite; }

*,
*::before,
*::after {
  margin: 0;
  padding: 0;
  box-sizing: inherit; }

html {
  box-sizing: border-box;
  font-size: 62.5%;
  background-color: #ecf0f1; }
  @media only screen and (max-width: 50em) {
    html {
      font-size: 50%; } }

body {
  margin-top: auto;
  max-height: 100vh;
  font-family: "Open Sans", sans-serif;
  color: #1F324B;
  font-weight: 300;
  line-height: 1.6; }

.btn {
  outline: none; }
  .btn, .btn:link, .btn:visited {
    text-transform: uppercase;
    text-decoration: none;
    padding: 1.5rem 4rem;
    display: inline-block;
    border: none;
    border-radius: 0;
    cursor: pointer;
    transition: all 0.1s;
    border-bottom: solid 2px #95a5a6;
    box-shadow: 0 0.5rem 1rem rgba(0, 0, 0, 0.2); }
    .btn:hover, .btn:link:hover, .btn:visited:hover {
      transform: translateY(-2px) scaleX(1.05) scaleY(1.05);
      box-shadow: 0 1rem 2rem rgba(0, 0, 0, 0.2); }
    .btn:active, .btn:focus, .btn:link:active, .btn:link:focus, .btn:visited:active, .btn:visited:focus {
      outline: none;
      transform: translateY(0px);
      box-shadow: 0 0.5rem 1rem rgba(0, 0, 0, 0.2); }

.mouse-scroller {
  padding: 4em 0;
  grid-column: 1 / 2;
  grid-row: mouse-start / mouse-end;
  justify-self: end;
  align-self: center; }
  @media screen and (max-width: 50em) {
    .mouse-scroller {
      justify-self: center; } }

.mousey {
  width: 0.3em;
  padding: 1em 1.5em;
  height: 35px;
  border: 2px solid #fff;
  border-radius: 25px;
  opacity: 0.75;
  box-sizing: content-box; }

.scroller {
  width: 3px;
  height: 10px;
  border-radius: 25%;
  background-color: #fff;
  animation-name: scroll;
  animation-duration: 2.2s;
  animation-timing-function: cubic-bezier(0.15, 0.41, 0.69, 0.94);
  animation-iteration-count: infinite; }

@keyframes scroll {
  0% {
    opacity: 0; }
  10% {
    transform: translateY(0);
    opacity: 1; }
  100% {
    transform: translateY(15px);
    opacity: 0; } }
.balboalab {
  text-transform: uppercase;
  letter-spacing: -1px;
  font-size: 115%;
  font-family: "Roboto", "sans-serif";
  font-weight: 300; }
  .balboalab::after, .balboalab::before {
    content: "\f0c3";
    font-family: FontAwesome;
    padding: 0 0.1em; }

.heading-1 {
  font-size: 4em; }

.heading-2 {
  font-size: 2.8em; }

.heading-3 {
  font-size: 2.0em; }

.heading-4 {
  font-size: 1.41em; }

.heading__container {
  padding: 1.5em 0 0.5em 0;
  display: flex;
  justify-content: center;
  font-size: 4em;
  font-family: "Roboto", sans-serif;
  font-weight: 300;
  text-transform: uppercase;
  text-align: center; }
  @media screen and (max-width: 50em) {
    .heading__container {
      font-size: 3em; } }
.heading__title--dark {
  color: #1F324B; }
  @media screen and (max-width: 50em) {
    .heading__title--dark {
      border-bottom: 1px solid #1F324B; } }
  .heading__title--dark::before, .heading__title--dark::after {
    content: "";
    height: 1px;
    width: 4em;
    background-color: #1F324B;
    display: inline-block;
    margin: 0.2em; }
    @media screen and (max-width: 50em) {
      .heading__title--dark::before, .heading__title--dark::after {
        width: 0;
        height: 0; } }
.heading__title--light {
  color: #ecf0f1; }
  @media screen and (max-width: 50em) {
    .heading__title--light {
      border-bottom: 1px solid #ecf0f1; } }
  .heading__title--light::before, .heading__title--light::after {
    content: "";
    height: 1px;
    width: 4em;
    background-color: #ecf0f1;
    display: inline-block;
    margin: 0.2em; }
    @media screen and (max-width: 50em) {
      .heading__title--light::before, .heading__title--light::after {
        width: 0; } }

/* =============================================
 *
 *   FIXED RESPONSIVE NAV
 *
 *   (c) 2014 @adtileHQ
 *   http://www.adtile.me
 *   http://twitter.com/adtilehq
 *
 *   Free to use under the MIT License.
 *
 * ============================================= */
header {
  border-bottom: 1px solid #ecf0f1;
  box-shadow: 0 1rem 1rem rgba(0, 0, 0, 0.25);
  z-index: 100; }

a:active,
a:hover {
  outline: 0; }

@-webkit-viewport {
  width: device-width; }
@-moz-viewport {
  width: device-width; }
@-ms-viewport {
  width: device-width; }
@-o-viewport {
  width: device-width; }
@viewport {
  width: device-width; }
/* ------------------------------------------
  RESPONSIVE NAV STYLES
--------------------------------------------- */
.nav-collapse ul {
  margin: 0;
  padding: 0;
  width: 100%;
  display: block;
  list-style: none;
  font-size: 1.6em; }

.nav-collapse li {
  width: 100%;
  display: block; }

.js .nav-collapse {
  clip: rect(0 0 0 0);
  max-height: 0;
  position: absolute;
  display: block;
  overflow: hidden;
  zoom: 1; }

.nav-collapse.opened {
  max-height: 9999px; }

.disable-pointer-events {
  pointer-events: none !important; }

.nav-toggle {
  -webkit-tap-highlight-color: rgba(0, 0, 0, 0);
  -webkit-touch-callout: none;
  -webkit-user-select: none;
  -moz-user-select: none;
  -ms-user-select: none;
  -o-user-select: none;
  user-select: none; }

@media screen and (min-width: 50em) {
  .js .nav-collapse {
    position: relative; }

  .js .nav-collapse.closed {
    max-height: none; }

  .nav-toggle {
    display: none; } }
/* ------------------------------------------
  DEMO STYLES
--------------------------------------------- */
p {
  width: 90%;
  margin: 0 auto; }

/* ------------------------------------------
  FIXED HEADER
--------------------------------------------- */
header {
  background: #1F324B;
  position: fixed;
  z-index: 3;
  width: 100%;
  left: 0;
  top: 0; }

.logo {
  -webkit-tap-highlight-color: rgba(0, 0, 0, 0);
  text-decoration: none;
  padding: 10px 20px;
  color: #fff;
  float: left;
  font-family: "Roboto", "sans-serif";
  font-size: 2em;
  font-weight: 300;
  letter-spacing: -1px;
  text-transform: uppercase; }

/* ------------------------------------------
  MASK
--------------------------------------------- */
.mask {
  -webkit-transition: opacity 300ms;
  -moz-transition: opacity 300ms;
  transition: opacity 300ms;
  background: rgba(0, 0, 0, 0.5);
  visibility: hidden;
  position: fixed;
  opacity: 0;
  z-index: 2;
  bottom: 0;
  right: 0;
  left: 0;
  top: 0; }

.android .mask {
  -webkit-transition: none;
  transition: none; }

.js-nav-active .mask {
  visibility: visible;
  opacity: 1; }

@media screen and (min-width: 37.5em) {
  .mask {
    display: none !important;
    opacity: 0 !important; } }
/* ------------------------------------------
  NAVIGATION STYLES
--------------------------------------------- */
.fixed {
  position: fixed;
  width: 100%;
  left: 0;
  top: 0; }

.nav-collapse,
.nav-collapse * {
  -webkit-box-sizing: border-box;
  -moz-box-sizing: border-box;
  box-sizing: border-box; }

.nav-collapse,
.nav-collapse ul {
  list-style: none;
  width: 100%;
  float: left; }

@media screen and (min-width: 37.5em) {
  .nav-collapse {
    float: right;
    width: auto; } }
.nav-collapse li {
  float: left;
  width: 100%; }

@media screen and (min-width: 37.5em) {
  .nav-collapse li {
    width: auto; } }
.nav-collapse a {
  -webkit-tap-highlight-color: rgba(0, 0, 0, 0);
  border-top: 1px solid white;
  text-decoration: none;
  background: #1F324B;
  padding: 0.7em 1em;
  color: #fff;
  width: 100%;
  float: left; }

.nav-collapse a:active,
.nav-collapse .active a {
  background: #ecf0f1;
  color: #7f8c8d; }

.nav-collapse a:hover {
  background: #ecf0f1;
  color: #7f8c8d; }

@media screen and (min-width: 37.5em) {
  .nav-collapse a {
    border-left: 1px solid white;
    padding: 1.02em 2em;
    text-align: center;
    border-top: 0;
    float: left;
    margin: 0; } }
.nav-collapse ul ul a {
  background: #ecf0f1;
  color: #7f8c8d;
  padding-left: 2em; }

@media screen and (min-width: 37.5em) {
  .nav-collapse ul ul a {
    display: none; } }
/* ------------------------------------------
  NAV TOGGLE STYLES
--------------------------------------------- */
@font-face {
  font-family: "responsivenav";
  src: url("../icons/responsivenav.eot");
  src: url("../icons/responsivenav.eot?#iefix") format("embedded-opentype"), url("../icons/responsivenav.ttf") format("truetype"), url("../icons/responsivenav.woff") format("woff"), url("../icons/responsivenav.svg#responsivenav") format("svg");
  font-weight: normal;
  font-style: normal; }
.nav-toggle {
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  text-decoration: none;
  text-indent: -300px;
  position: relative;
  overflow: hidden;
  width: 60px;
  height: 55px;
  float: right; }

.nav-toggle:before {
  color: #fff;
  /* Edit this to change the icon color */
  font: normal 28px/55px "responsivenav";
  /* Edit font-size (28px) to change the icon size */
  text-transform: none;
  text-align: center;
  position: absolute;
  content: "\2261";
  /* Hamburger icon */
  text-indent: 0;
  speak: none;
  width: 100%;
  left: 0;
  top: 0; }

.nav-toggle.active:before {
  font-size: 24px;
  content: "\78";
  /* Close icon */ }

.hero {
  background-color: #1F324B;
  color: white;
  height: minmax(600px 90vh);
  font-family: "Roboto";
  margin-top: 5em; }
  .hero__grid {
    display: grid;
    grid-template-rows: [full-start] 1fr [flask-start] 1fr [flask-end present-start] max-content [present-end lab-start] 4fr [lab-end date-start] 3fr [date-end with-start] min-content [with-end flw-start] min-content [flw-end and-start] min-content [and-end ld-start] max-content [ld-end location-start] 4fr [location-end mouse-start] 3fr [mouse-end];
    grid-template-columns: minmax(min-content, 1.5fr) minmax(min-content, 2fr);
    padding: 0 3vw 0 3vw;
    align-items: stretch; }
    .hero__grid > * {
      padding: 0 0; }
    @media screen and (max-width: 50em) {
      .hero__grid {
        margin-top: 5em;
        grid-template-columns: 1fr; } }
  .hero__presentation {
    grid-row: present-start / present-end;
    justify-self: start;
    font-size: 2em;
    font-weight: 100;
    text-transform: uppercase; }
  .hero__logo {
    grid-row: lab-start / lab-end; }
  .hero__logo--text {
    font-family: "Roboto", "sans-serif";
    font-size: 6em;
    font-weight: 300;
    letter-spacing: -2px;
    line-height: 1;
    text-transform: uppercase; }
  .hero__shaker {
    grid-row: flask-start / flask-end;
    padding: 0 0 0 3em;
    font-size: 20px;
    justify-self: startr;
    align-self: end;
    transition: color 3s; }
    .hero__shaker:hover {
      color: red; }
  .hero__teachers {
    font-size: 3em; }
    .hero__teachers--1 {
      grid-row: flw-start / flw-end;
      justify-self: end;
      padding: 0 3vw 0 0; }
    .hero__teachers--with {
      grid-row: with-start / with-end;
      justify-self: end;
      align-self: end;
      padding-right: 5em; }
    .hero__teachers--and {
      grid-row: and-start / and-end;
      justify-self: start;
      align-self: end;
      padding-left: 5em; }
    .hero__teachers--2 {
      grid-row: ld-start / ld-end;
      justify-self: start; }
  .hero__date {
    grid-row: date-start / date-end;
    font-size: 4em;
    justify-self: start;
    font-weight: 100; }
  .hero__location {
    grid-column: 1 / 2;
    grid-row: location-start / location-end;
    font-size: 1.6em;
    justify-self: end;
    align-self: end;
    text-align: right;
    padding: 0 3vw 0 0; }
  .hero__img {
    grid-column: 2 / 3;
    grid-row: full-start / mouse-start;
    background-blend-mode: screen;
    filter: grayscale(0.2);
    background-image: linear-gradient(#1F324B, #1F324B), url(../img/Sanna_Adam_playful_lg.jpg);
    width: 100%;
    background-size: cover;
    background-position: center; }

.concept {
  background-color: white; }
  .concept__grid {
    padding: 5em;
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(375px, 1fr));
    grid-template-rows: min-content;
    grid-gap: 2em; }
  .concept__card {
    padding: 3em;
    border: solid 1px #ecf0f1;
    border-radius: 3px;
    box-shadow: 0 1rem 2rem rgba(0, 0, 0, 0.25);
    margin-bottom: 1em; }
  .concept__icon {
    display: flex;
    align-items: center;
    justify-content: center;
    background-color: #1F324B;
    color: #8CA69E;
    width: 2.0em;
    height: 2.0em;
    text-align: center;
    margin: 0 auto 15px auto;
    border-radius: 50%;
    font-size: 5rem;
    box-shadow: 0 1rem 3rem rgba(0, 0, 0, 0.25); }
  .concept__text {
    font-size: 1.8em; }

.price {
  background-color: white; }
  .price__grid {
    padding: 2em 10vw 4em 10vw;
    display: grid;
    grid-row-gap: 2em;
    grid-template-columns: repeat(auto-fit, minmax(250px, 1fr));
    grid-template-rows: autofit;
    grid-column-gap: 4em; }
  .price__pass {
    padding: 0 0 3em 0;
    font-size: 1.6em;
    grid-column: 1 / -1;
    grid-row: 1 / 2; }
  .price__pass-content {
    justify-self: center;
    padding: 2em 2em; }
    .price__pass-content a, .price__pass-content:active, .price__pass-content:visited {
      text-decoration: none;
      border-bottom: 5px solid white;
      color: white; }
      .price__pass-content a:hover, .price__pass-content:active:hover, .price__pass-content:visited:hover {
        background-color: white;
        color: #1F324B; }
  .price__passlist {
    list-style: none; }
  .price__passitem:before {
    font-family: FontAwesome;
    content: "\f046";
    margin-right: 5px; }
  .price__card {
    width: 100%;
    border: solid 1px #ecf0f1;
    border-radius: 3px;
    box-shadow: 0 1rem 2rem rgba(0, 0, 0, 0.25);
    display: grid;
    grid-template-columns: 1fr;
    grid-template-rows: max-content; }
    .price__card--dark {
      background-color: #1F324B;
      color: white; }
    .price__card-title {
      font-size: 3em;
      font-family: "Roboto", "sans-serif";
      font-weight: 100;
      line-height: 1.5;
      justify-self: center;
      align-self: center;
      background-color: #1F324B;
      padding: 0.5em 1em;
      color: white;
      width: 100%;
      text-align: center; }
    .price__card-price {
      font-size: 6em;
      font-family: "Roboto", "sans-serif";
      font-weight: 100;
      font-weight: 100;
      justify-self: center; }
      .price__card-price::before {
        color: #bdc3c7;
        font-size: 50%;
        content: "CHF "; }
    .price__card-list {
      font-size: 1.4em;
      padding: 0 1em 0 4em; }
    .price__card-btn {
      background-color: #1F324B;
      color: white;
      justify-self: center;
      margin: 1.5em 0 2.5em 0; }
      .price__card-btn:hover {
        background-color: #8E98A5; }
      .price__card-btn a {
        color: white;
        text-decoration: none; }

.parties {
  background-color: #ecf0f1; }
  .parties__grid {
    padding: 2em 4em 4em 4em;
    display: grid;
    grid-row-gap: 2em;
    grid-template-columns: minmax(350px, 1fr);
    grid-template-rows: autofit;
    grid-column-gap: 4em; }
  .parties__card {
    width: 100%;
    border: solid 1px #ecf0f1;
    border-radius: 3px;
    box-shadow: 0 1rem 2rem rgba(0, 0, 0, 0.25);
    display: grid;
    padding: 2em 4em 4em 4em;
    grid-template-columns: auto-fit, minmax(400px, 1fr) auto-fit, minmax(400px, 1fr);
    grid-template-rows: auto;
    grid-template-rows: max-content;
    grid-gap: 2em;
    justify-content: center; }
    .parties__card--dark {
      background-color: #1F324B;
      color: white; }
    .parties__card--date {
      font-size: 3em;
      font-family: "Roboto", "sans-serif";
      font-weight: 100;
      line-height: 1.5;
      justify-self: center;
      align-self: center;
      background-color: #ecf0f1;
      padding: 0.5em 1em;
      color: #95a5a6;
      width: 100%;
      text-align: center; }
    .parties__card--title {
      font-size: 3em;
      font-family: "Roboto", "sans-serif";
      font-weight: 100;
      background-color: #1F324B;
      padding: 0.5em 1em;
      color: white;
      text-align: center; }
    .parties__card--price {
      font-size: 4em;
      font-family: "Roboto", "sans-serif";
      font-weight: 100;
      font-weight: 100;
      text-align: center; }
      .parties__card--price::before {
        color: #bdc3c7;
        font-size: 50%;
        content: "CHF "; }
    .parties__card--list {
      text-align: center;
      font-size: 2em;
      margin: 2em auto;
      list-style: none;
      align-self: start; }
    .parties__card--img {
      margin: 0 auto;
      width: 100%; }
    .parties__card--dj-images   {
      display: grid;
      grid-template-columns: auto-fit, minmax(400px, 1fr) minmax(400px, 1fr);
      grid-gap: 2em; }
    .parties__card--dj-img {
      height: 100%; }
    .parties__card--paragraph {
      font-size: 1.8em; }
    .parties__card--btn {
      background-color: #1F324B;
      color: white;
      justify-self: center;
      margin: 1.5em 0 2.5em 0; }

.locations {
  background-color: white; }
  .locations__grid {
    padding: 2em 4em 4em 4em;
    display: grid;
    grid-gap: 2em;
    grid-template-columns: repeat(auto-fit, minmax(530px, 1fr));
    justify-content: center; }
  .locations__card {
    padding: 2em;
    box-shadow: 0 1rem 2rem rgba(0, 0, 0, 0.25);
    border: solid 1px #ecf0f1;
    border-radius: 3px;
    text-align: center; }
  .locations__name {
    font-size: 2em;
    text-transform: uppercase; }
  .locations__address {
    font-size: 1.6em; }
  .locations__usage--list {
    padding-left: 12vw;
    margin-bottom: 1em;
    font-size: 1.6em;
    text-align: left; }
  .locations__link {
    padding-bottom: 2em; }
    .locations__link a {
      font-family: "Open Sans", sans-serif;
      text-decoration: none;
      border-bottom: 5px solid #1F324B;
      color: #1F324B; }
      .locations__link a:hover {
        background-color: #1F324B;
        color: white; }
  .locations__map {
    height: 0;
    overflow: hidden;
    padding-bottom: 56%;
    position: relative; }
    .locations__map iframe {
      height: 100%;
      left: 0;
      position: absolute;
      top: 0;
      width: 100%; }

.teachers {
  background-color: #ecf0f1;
  padding: 0 5em 3em 5em;
  width: 100%; }
  .teachers__grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(250px, 1fr));
    grid-column-gap: 7em;
    grid-row-gap: 5em;
    padding: 5vw;
    justify-content: center;
    overflow: hidden; }
  .teachers__name {
    position: relative;
    width: auto;
    margin: -3em 0 5em 7em;
    padding: 0.75em 1.3em;
    color: white;
    font-size: 3em;
    text-align: center;
    background-color: #1F324B;
    box-shadow: 0 1rem 3rem rgba(0, 0, 0, 0.25);
    z-index: 1;
    transform: rotate(-22.5deg); }
    @media screen and (max-width: 62.5em) {
      .teachers__name {
        font-size: 2em;
        left: 2em;
        top: -2.5em;
        margin: 0 0 0 0;
        padding: 1.2em 0.2em; } }
    @media screen and (max-width: 50em) {
      .teachers__name {
        font-size: 3em;
        left: 2em;
        top: -3.5em;
        margin: 0 0 0 0;
        padding: 1.3em 0.2em; } }
  .teachers__img img {
    width: 100%;
    border-radius: 50%;
    border: 10px solid #1F324B;
    box-shadow: 0 0.5rem 1rem rgba(0, 0, 0, 0.25);
    -webkit-filter: grayscale(1);
    filter: grayscale(1);
    transition: all 0.5s; }
    .teachers__img img:hover {
      -webkit-filter: none;
      background-blend-mode: screen;
      filter: grayscale(0.2); }

.levels {
  background-color: #ecf0f1;
  margin-bottom: 5em;
  padding: 0 5vw; }
  .levels__cards {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(400px, 1fr));
    grid-gap: 2em; }
  .levels__card {
    margin-bottom: 2.5em; }
  .levels__info, .levels__name {
    text-transform: uppercase;
    width: 100%;
    padding: 0.5em 1em;
    color: white;
    font-size: 3em;
    grid-row: 1 / 2;
    margin-bottom: 1em;
    box-shadow: 0 1rem 3rem rgba(0, 0, 0, 0.25); }
  .levels__info {
    background-color: #8E98A5; }
  .levels__name {
    background-color: #1F324B; }
  .levels__description {
    padding: 0 2em;
    font-size: 1.8em; }
    .levels__description p {
      margin-left: -1em; }
  .levels__listitem {
    margin-bottom: 0.5em;
    line-height: 1.4; }
  .levels__sublist {
    padding: 0 0 0 2em; }
  .levels__sounds {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(250px, 1fr));
    grid-column-gap: 1rem;
    grid-row: 3 / 4; }

.sounds__card {
  justify-self: center;
  padding: 0 3em; }
.sounds__description {
  font-size: 1.2em;
  width: 85%;
  padding: 0 0 0 2em; }
.sounds__tempo {
  font-size: 2.5em;
  margin: 0 auto;
  text-align: center; }
.sounds__video {
  align-self: end;
  justify-self: center;
  box-shadow: 0 1rem 3rem rgba(0, 0, 0, 0.25); }

.locations {
  background-color: white; }
  .locations__grid {
    padding: 2em 4em 4em 4em;
    display: grid;
    grid-gap: 2em;
    grid-template-columns: repeat(auto-fit, minmax(530px, 1fr));
    justify-content: center; }
  .locations__card {
    padding: 2em;
    box-shadow: 0 1rem 2rem rgba(0, 0, 0, 0.25);
    border: solid 1px #ecf0f1;
    border-radius: 3px;
    text-align: center; }
  .locations__name {
    font-size: 2em;
    text-transform: uppercase; }
  .locations__address {
    font-size: 1.6em; }
  .locations__usage--list {
    padding-left: 12vw;
    margin-bottom: 1em;
    font-size: 1.6em;
    text-align: left; }
  .locations__link {
    padding-bottom: 2em; }
    .locations__link a {
      font-family: "Open Sans", sans-serif;
      text-decoration: none;
      border-bottom: 5px solid #1F324B;
      color: #1F324B; }
      .locations__link a:hover {
        background-color: #1F324B;
        color: white; }
  .locations__map {
    height: 0;
    overflow: hidden;
    padding-bottom: 56%;
    position: relative; }
    .locations__map iframe {
      height: 100%;
      left: 0;
      position: absolute;
      top: 0;
      width: 100%; }

.schedule {
  background-color: #8E98A5; }
  .schedule__grid {
    padding: 5em;
    display: grid;
    grid-template-columns: repeat(2, minmax(2em, 1fr));
    grid-template-rows: min-content min-content;
    grid-gap: 2em;
    align-items: center;
    justify-items: start; }
  .schedule__text p {
    font-size: 2em; }
  .schedule__icon {
    grid-column: 1 / 2;
    display: flex;
    align-items: center;
    justify-content: center;
    background-color: #1F324B;
    color: #8CA69E;
    width: 2.0em;
    height: 2.0em;
    text-align: center;
    margin: 0 auto 15px auto;
    border-radius: 15%;
    font-size: 7rem;
    box-shadow: 0 1rem 3rem rgba(0, 0, 0, 0.25); }

td.day {
  background: grey;
  border-radius: 0px;
  color: #DADADA;
  font-size: 40px;
  font-style: bold;
  padding: 10px; }

td.level {
  background: grey;
  border-radius: 0px;
  color: #DADADA;
  font-size: 20px;
  padding: 5px; }

table, td, th {
  border: 0px solid #595959;
  border-collapse: collapse;
  text-align: center;
  border-radius: 5px;
  color: #595959;
  font-family: Arial, Verdana; }

td.reg {
  background: #374A58;
  color: #DADADA; }

td.teachers {
  background: #193441;
  color: #DADADA; }

td.training {
  background: #D0DABC; }

td.training-free {
  background: #DADADA; }

td.break {
  background: #8FA89B; }

td, th {
  padding: 3px;
  width: 30px;
  height: 25px; }

th {
  background: #f0e6cc; }

.even {
  background: #fbf8f0; }

.odd {
  background: #fefcf9; }

/* DivTable.com */
.divTable {
  display: table;
  width: 100%; }

.divTableRow {
  display: table-row; }

.divTableHeading {
  background-color: #EEE;
  display: table-header-group; }

.divTableCell, .divTableHead {
  border: 1px solid #999999;
  display: table-cell;
  padding: 3px 10px; }

.divTableHeading {
  background-color: #EEE;
  display: table-header-group;
  font-weight: bold; }

.divTableFoot {
  background-color: #EEE;
  display: table-footer-group;
  font-weight: bold; }

.divTableBody {
  display: table-row-group; }

:root {
  --registration-color: #95a5a6;
  --level-color: #FBE8D4;
  --break-color: #D0B598;
  --lunch-color: #4A5B72;
  --practice-mand-color: #64897E;
  --practice-fac-color: #8CA69E;
  --blank-color: transparent;
  --schedule-item-height: 25px; }

* {
  box-sizing: border-box; }

.full-schedule {
  display: grid;
  grid-template-columns: repeat(2, minmax(250px, 1fr));
  grid-gap: 25px;
  padding: 25px; }

.level-schedule {
  display: grid;
  grid-gap: 10px;
  font-size: 1.6em;
  grid-template-columns: [time] 100px [level] 1fr;
  grid-template-rows: [title] 1fr [line-1050] var(--schedule-item-height) [line-1075] var(--schedule-item-height) [line-1100] var(--schedule-item-height) [line-1125] var(--schedule-item-height) [line-1150] var(--schedule-item-height) [line-1175] var(--schedule-item-height) [line-1200] var(--schedule-item-height) [line-1225] var(--schedule-item-height) [line-1250] var(--schedule-item-height) [line-1275] var(--schedule-item-height) [line-1300] var(--schedule-item-height) [line-1325] var(--schedule-item-height) [line-1350] var(--schedule-item-height) [line-1375] var(--schedule-item-height) [line-1400] var(--schedule-item-height) [line-1425] var(--schedule-item-height) [line-1450] var(--schedule-item-height) [line-1475] var(--schedule-item-height) [line-1500] var(--schedule-item-height) [line-1525] var(--schedule-item-height) [line-1550] var(--schedule-item-height) [line-1575] var(--schedule-item-height) [line-1600] var(--schedule-item-height) [line-1625] var(--schedule-item-height) [line-1650] var(--schedule-item-height) [line-1675] var(--schedule-item-height) [line-1700] var(--schedule-item-height) [line-1725] var(--schedule-item-height) [line-1750] var(--schedule-item-height) [line-1775] var(--schedule-item-height) [line-1800] var(--schedule-item-height); }

.time {
  grid-column-start: time;
  padding-top: 10px;
  text-align: right; }

.level {
  grid-column-start: level;
  border-radius: 3px;
  padding: 10px;
  display: flex;
  align-items: center;
  justify-content: center;
  flex-direction: column; }

.schedule__registration {
  background-color: var(--registration-color); }

.class {
  background: var(--level-color); }

.break {
  background: var(--break-color); }

.lunch {
  background: var(--lunch-color); }

.practice-mandatory {
  background: var(--practice-mand-color); }

.practice-facultative {
  background: var(--practice-fac-color); }

.blank {
  background: var(--blank-color); }

.title {
  grid-column-start: level;
  grid-row-start: title;
  text-transform: uppercase;
  text-align: center; }
  .title__level {
    font-size: 2em; }
  .title__day {
    font-size: 1.6em; }

.start-1050 {
  grid-row-start: line-1050; }

.start-1075 {
  grid-row-start: line-1075; }

.start-1100 {
  grid-row-start: line-1100; }

.start-1125 {
  grid-row-start: line-1125; }

.start-1150 {
  grid-row-start: line-1150; }

.start-1175 {
  grid-row-start: line-1175; }

.start-1200 {
  grid-row-start: line-1200; }

.start-1225 {
  grid-row-start: line-1225; }

.start-1250 {
  grid-row-start: line-1250; }

.start-1275 {
  grid-row-start: line-1275; }

.start-1300 {
  grid-row-start: line-1300; }

.start-1325 {
  grid-row-start: line-1325; }

.start-1350 {
  grid-row-start: line-1350; }

.start-1375 {
  grid-row-start: line-1375; }

.start-1400 {
  grid-row-start: line-1400; }

.start-1425 {
  grid-row-start: line-1425; }

.start-1450 {
  grid-row-start: line-1450; }

.start-1475 {
  grid-row-start: line-1475; }

.start-1500 {
  grid-row-start: line-1500; }

.start-1525 {
  grid-row-start: line-1525; }

.start-1550 {
  grid-row-start: line-1550; }

.start-1575 {
  grid-row-start: line-1575; }

.start-1600 {
  grid-row-start: line-1600; }

.start-1625 {
  grid-row-start: line-1625; }

.start-1650 {
  grid-row-start: line-1650; }

.start-1675 {
  grid-row-start: line-1675; }

.start-1700 {
  grid-row-start: line-1700; }

.start-1725 {
  grid-row-start: line-1725; }

.start-1750 {
  grid-row-start: line-1750; }

.start-1775 {
  grid-row-start: line-1775; }

.start-1800 {
  grid-row-start: line-1800; }

.min15 {
  grid-row: span 1; }

.min30 {
  grid-row: span 2; }

.min45 {
  grid-row: span 3; }

.min60 {
  grid-row: span 4; }

.min75 {
  grid-row: span 5; }

.registration {
  background-color: #1F324B;
  color: white; }
  .registration__grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(500px, 1fr));
    grid-row-gap: 1em;
    font-size: 1.6em;
    justify-items: center; }
  .registration__intro {
    line-height: 1.2;
    justify-self: center; }
    .registration__intro a, .registration__intro:active, .registration__intro:visited {
      text-decoration: none;
      border-bottom: 5px solid white;
      color: white; }
      .registration__intro a:hover, .registration__intro:active:hover, .registration__intro:visited:hover {
        background-color: white;
        color: #1F324B; }
  .registration__list {
    list-style: none;
    line-height: 1.5; }
  .registration__list-item:before {
    font-family: FontAwesome;
    content: "\f05a";
    margin-right: 5px; }
  .registration__btn {
    margin-top: 2em;
    grid-column: 1 / -1;
    padding: 1.5rem 6rem;
    background-color: #ecf0f1;
    justify-self: center; }
    .registration__btn:hover {
      background-color: #bdc3c7; }
    .registration__btn--link {
      text-decoration: none;
      color: #1F324B;
      border-bottom: none; }
    .registration__btn--description {
      text-align: center;
      grid-column: 1 / -1;
      padding: 1.5rem 3rem; }

.audition {
  background-blend-mode: screen;
  background-image: linear-gradient(#1F324B, #1F324B), url(../img/Sanna_Adam_LightExMachina.jpg);
  max-width: 100%;
  height: 37vw;
  width: 100%;
  background-size: cover;
  background-position: center; }
  .audition__photo--credits {
    font-size: 1.2em;
    padding: 0.5em 2em;
    color: white;
    text-align: right;
    width: 100%;
    background-color: #1F324B; }
    .audition__photo--credits a, .audition__photo--credits:active, .audition__photo--credits:visited {
      text-decoration: none;
      color: white; }
      .audition__photo--credits a:hover, .audition__photo--credits:active:hover, .audition__photo--credits:visited:hover {
        background-color: white;
        color: #1F324B; }

.about {
  background-color: #8E98A5; }
  .about__grid {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    grid-template-rows: min-content;
    grid-gap: 2em; }

.agbs__list {
  grid-template-columns: minmax(150px, 1fr);
  display: grid;
  margin: 0 1em;
  font-size: 1.2em;
  padding: 0 10vw 2em 10vw;
  align-self: start; }
  .agbs__list--listitem {
    font-size: 1.2em; }
.agbs__sublist {
  font-size: 1.0em;
  margin-left: 1em; }
  .agbs__sublist--listitem {
    font-size: 1.2em; }
.agbs__status {
  font-style: italic; }

.contact {
  background-color: #1F324B; }
  .contact__grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(375px, 1fr));
    grid-template-rows: min-content;
    grid-gap: 2em;
    justify-items: space-between;
    padding: 5em 5vw 5em 5vw; }
  .contact__text-container {
    grid-column: 1 / 2;
    align-self: center;
    padding: 0 2em; }
  .contact__text {
    color: white;
    font-size: 3em;
    line-height: 1.1;
    font-weight: 100; }
    .contact__text p {
      margin-bottom: 0.7em; }
  .contact #contactform {
    font-family: "Open Sans", "sans-serif";
    justify-self: start;
    overflow: hidden; }
  .contact input[type="text"],
  .contact input[type="email"],
  .contact textarea {
    background-color: #fff;
    color: #000;
    width: 85%;
    border: none;
    padding: 1em;
    margin-bottom: 1em; }
  .contact #btn-submit {
    border: none;
    pading: 0.5em;
    outline: none; }
    .contact #btn-submit, .contact #btn-submit:link, .contact #btn-submit:visited {
      text-transform: uppercase;
      text-decoration: none;
      padding: 1rem 2rem;
      display: inline-block;
      border: none;
      border-radius: 0;
      cursor: pointer;
      transition: all 0.1s;
      border-bottom: solid 2px #95a5a6;
      box-shadow: 0 0.5rem 1rem rgba(0, 0, 0, 0.2); }
      .contact #btn-submit:hover, .contact #btn-submit:link:hover, .contact #btn-submit:visited:hover {
        transform: translateY(-2px) scaleX(1.05) scaleY(1.05);
        box-shadow: 0 1rem 2rem rgba(0, 0, 0, 0.2); }
      .contact #btn-submit:active, .contact #btn-submit:focus, .contact #btn-submit:link:active, .contact #btn-submit:link:focus, .contact #btn-submit:visited:active, .contact #btn-submit:visited:focus {
        outline: none;
        transform: translateY(0px);
        box-shadow: 0 0.5rem 1rem rgba(0, 0, 0, 0.2); }

.footer {
  background-color: #1F324B; }
  .footer__container {
    display: grid;
    grid-template-columns: repeat(8, 1fr);
    grid-auto-rows: auto;
    grid-gap: 1em;
    align-items: center;
    text-align: center;
    padding: 20px; }
  .footer__link {
    text-decoration: none;
    color: #8E98A5;
    text-transform: uppercase; }
    .footer__link:hover {
      color: white; }
