@font-face {
  font-family: "neontubes";
  src: url("../fonts/neontubes-webfont.ttf"); }
@font-face {
  font-family: "Seido Bold";
  src: url("../fonts/BwSeidoRound-Bold.otf"); }
@font-face {
  font-family: "Seido Regular";
  src: url("../fonts/BwSeidoRound-Regular.otf"); }
* {
  font-family: "Seido Regular"; }

body, html {
  margin: 0;
  overflow: hidden; }

* {
  box-sizing: border-box;
  scrollbar-width: auto; }

a {
  text-decoration: none;
  color: inherit; }

@keyframes blink {
  40% {
    opacity: 1; }
  42% {
    opacity: 0.8; }
  43% {
    opacity: 1; }
  45% {
    opacity: 0.2; }
  46% {
    opacity: 1; } }
@keyframes buzz {
  70% {
    opacity: 0.80; } }
/* LAYOUT */
#about-page #member-screen {
  margin-top: 200px;
  display: grid;
  grid-template-rows: repeat(3, 75vh);
  grid-gap: 40vh 0;
  padding: 0 300px; }
  #about-page #member-screen .member {
    display: grid;
    grid-template-columns: 3fr 2fr 4fr;
    grid-template-rows: 1fr auto 1fr;
    grid-template-areas: "img . .   " "img . info" "img . .   "; }
    #about-page #member-screen .member .picture {
      grid-area: img;
      position: relative;
      overflow: hidden; }
      #about-page #member-screen .member .picture img {
        position: absolute;
        top: 0;
        left: 0;
        min-width: 100%;
        min-height: 100%;
        transform: scale(1);
        transition: transform 0.25s ease; }
        #about-page #member-screen .member .picture img:hover {
          transform: scale(1.1); }
    #about-page #member-screen .member .info {
      grid-area: info; }
      #about-page #member-screen .member .info div:nth-child(1) {
        width: 100px;
        height: 4px; }
      #about-page #member-screen .member .info div:nth-child(2) {
        margin: 30px 0; }

/* STYLES */
#about-page #member-screen .member .info {
  color: white;
  font-family: "Seido Bold"; }
  #about-page #member-screen .member .info div:nth-child(1) {
    background-color: #bf00f8; }
  #about-page #member-screen .member .info div:nth-child(2) {
    font-size: 32px; }
  #about-page #member-screen .member .info div:nth-child(3) {
    font-size: 18px; }

/* LAYOUT */
#about-page #quality-screen {
  padding: 200px 175px; }
  #about-page #quality-screen #seals {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    grid-gap: 10vw;
    padding: 100px 10vw; }
    #about-page #quality-screen #seals img {
      justify-self: stretch;
      align-self: stretch; }

/* STYLE */
#about-page #quality-screen {
  text-align: center; }

/* LAYOUT */
#about-page #team-screen {
  display: grid;
  grid-template-rows: repeat(2, auto) 1fr;
  grid-template-areas: "headline" "subline" "image";
  grid-gap: 20px;
  height: calc(100vh - 100px);
  justify-items: center; }
  #about-page #team-screen .section-headline {
    grid-area: headline; }
  #about-page #team-screen .section-subline {
    grid-area: subline;
    margin-bottom: 50px; }
  #about-page #team-screen img {
    grid-area: image;
    height: 100%; }
  #about-page #team-screen #gradient {
    grid-area: image; }
  #about-page #team-screen img, #about-page #team-screen #gradient {
    position: relative; }
  #about-page #team-screen img {
    z-index: 1; }
  #about-page #team-screen #gradient {
    z-index: 2;
    width: 50vw; }

/* STYLES */
#about-page #team-screen {
  text-align: center; }
  #about-page #team-screen .section-headline {
    font-family: "neontubes";
    will-change: opacity;
    color: #ece3ff;
    text-shadow: 0 0 0 transparent, 0 0 10px #9f72ff, 0 0 20px rgba(159, 114, 255, 0.5), 0 0 40px #9f72ff, 0 0 100px #9f72ff, 0 0 200px #9f72ff, 0 0 300px #9f72ff, 0 0 500px #9f72ff;
    animation: buzz 0.01s infinite alternate; }
  #about-page #team-screen #gradient, #about-page #team-screen img {
    border-radius: 50px; }
  #about-page #team-screen #gradient {
    background: radial-gradient(rgba(0, 0, 0, 0) 0%, rgba(0, 0, 0, 0.5) 65%, #000 100%); }

/* LAYOUT */
#about-page #we-screen {
  display: grid;
  grid-template-columns: 1fr auto 1fr;
  grid-template-rows: 2fr auto 3fr;
  height: calc(100vh - 70px); }
  #about-page #we-screen div {
    grid-area: 2/2 / 3/3; }

/* STYLES */
#about-page #we-screen {
  font-family: "Seido Bold";
  color: white;
  font-size: 4vw;
  text-align: center; }
  #about-page #we-screen .red {
    font-family: "neontubes";
    will-change: opacity;
    color: #ffd9e2;
    text-shadow: 0 0 0 transparent, 0 0 10px #ff003c, 0 0 20px rgba(255, 0, 60, 0.5), 0 0 40px #ff003c, 0 0 100px #ff003c, 0 0 200px #ff003c, 0 0 300px #ff003c, 0 0 500px #ff003c, 0 0 1000px #ff003c;
    animation: blink 4s infinite alternate; }
  #about-page #we-screen .blue {
    font-family: "neontubes";
    will-change: opacity;
    color: #ece3ff;
    text-shadow: 0 0 0 transparent, 0 0 10px #9f72ff, 0 0 20px rgba(159, 114, 255, 0.5), 0 0 40px #9f72ff, 0 0 100px #9f72ff, 0 0 200px #9f72ff, 0 0 300px #9f72ff, 0 0 500px #9f72ff;
    animation: buzz 0.01s infinite alternate; }

#configurator #controls {
  border-radius: 5px;
  background-color: black;
  overflow-y: scroll; }
  #configurator #controls h1 {
    color: white;
    font-size: 16px; }
  #configurator #controls select {
    background-color: transparent;
    border: 1px solid #9f72ff;
    font-size: 14px;
    color: #9f72ff;
    display: block;
    padding-left: 10px;
    background-image: url("../configurator/arrow_down.svg");
    background-repeat: no-repeat, repeat;
    background-position: right 10px top 50%, 0 0;
    background-size: 20px auto, 100%;
    -moz-appearance: none;
    -webkit-appearance: none;
    appearance: none; }
  #configurator #controls .button {
    cursor: pointer;
    background-color: transparent;
    border: 1px solid #9f72ff;
    font-size: 14px;
    color: #9f72ff;
    padding: 9px 12px;
    text-align: center;
    border-radius: 3px; }
    #configurator #controls .button:hover {
      filter: drop-shadow(0px 3px 3px rgba(0, 0, 0, 0.25)); }
      #configurator #controls .button:hover * {
        filter: drop-shadow(0px 3px 3px rgba(0, 0, 0, 0.25)); }
    #configurator #controls .button.selected {
      background-color: #9f72ff; }
      #configurator #controls .button.selected, #configurator #controls .button.selected div {
        color: white; }
  #configurator #controls #price {
    text-align: center;
    align-self: end;
    color: #9f72ff;
    font-size: 35px; }
  #configurator #controls #buy-now {
    width: 120px; }

/* LAYOUT */
#custom-header {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  grid-template-rows: 50px;
  grid-template-areas: "leave open";
  grid-gap: 0 20px;
  position: fixed;
  top: 10px;
  left: 20px;
  z-index: 3;
  width: calc(100vw - 40px); }
  @media (min-width: 801px) {
    #custom-header {
      display: none; } }
  #custom-header #leave-config, #custom-header #open-config {
    position: relative; }
    #custom-header #leave-config > div, #custom-header #open-config > div {
      position: absolute; }
    #custom-header #leave-config > div:first-of-type, #custom-header #open-config > div:first-of-type {
      top: 2px;
      height: 46px;
      width: 46px;
      display: grid;
      grid-template-columns: 1fr 2fr 1fr;
      grid-template-rows: 1fr 2fr 1fr;
      grid-template-areas: ". . ." ". img ." ". . ."; }
      #custom-header #leave-config > div:first-of-type img, #custom-header #open-config > div:first-of-type img {
        grid-area: img;
        height: 100%;
        position: relative;
        right: 4px;
        justify-self: center; }
    #custom-header #leave-config > div:last-of-type, #custom-header #open-config > div:last-of-type {
      line-height: 50px; }
  #custom-header #leave-config {
    display: block;
    grid-area: leave; }
    #custom-header #leave-config div:first-of-type {
      left: 2px; }
    #custom-header #leave-config div:last-of-type {
      right: 4vw; }
  #custom-header #open-config {
    grid-area: open; }
    #custom-header #open-config > div:first-of-type {
      right: 2px; }
    #custom-header #open-config > div:last-of-type {
      left: 4vw; }
    #custom-header #open-config .bar {
      position: absolute;
      left: 11px;
      width: 25px;
      height: 3px;
      transition: transform 0.25s linear, opacity 0.12s linear, top 0.25s linear; }
      #custom-header #open-config .bar:nth-child(1) {
        top: 13px; }
      #custom-header #open-config .bar:nth-child(2) {
        top: 21.5px; }
      #custom-header #open-config .bar:nth-child(3) {
        top: 31px; }

/* STYLE */
#custom-header {
  background-color: black; }
  #custom-header #leave-config, #custom-header #open-config {
    border-radius: 25px;
    cursor: pointer; }
    #custom-header #leave-config > div:first-of-type, #custom-header #open-config > div:first-of-type {
      border-radius: 50%; }
    #custom-header #leave-config > div:last-of-type, #custom-header #open-config > div:last-of-type {
      color: white;
      font-size: 5vw; }
  #custom-header #leave-config {
    background-color: #2C3743; }
    #custom-header #leave-config > div:first-of-type {
      background-color: #26313A; }
  #custom-header #open-config {
    background-color: #9F72FF69; }
    #custom-header #open-config > div:first-of-type {
      background-color: #9F72FF; }
    #custom-header #open-config .bar {
      background-color: white; }

#configurator-page #configurator #controls input {
  height: 30px;
  border: 1px solid white;
  color: white;
  background-color: transparent;
  padding-left: 10px;
  border-right-width: 0;
  border-top-right-radius: 0;
  border-bottom-right-radius: 0;
  border-top-left-radius: 3px;
  border-bottom-left-radius: 3px;
  font-size: 16px;
  caret-color: white; }
#configurator-page #configurator #controls label {
  height: 30px;
  border: 1px solid white;
  color: white;
  display: block;
  padding-top: 5px;
  border-top-right-radius: 3px;
  border-bottom-right-radius: 3px;
  border-top-left-radius: 0;
  border-bottom-left-radius: 0;
  text-align: center;
  font-size: 12px; }

/* LAYOUT */
#configurator-page #render #escape {
  display: none;
  height: 26px;
  padding: 5px 0;
  border: 1px solid black;
  border-radius: 6px;
  box-shadow: 0 1px 0 black;
  background-color: grey;
  text-align: center;
  font-size: 12px;
  color: white;
  padding-left: 10px;
  padding-right: 10px;
  position: absolute;
  top: 30px;
  right: 30px; }
  #configurator-page #render #escape.space {
    padding-left: 20px;
    padding-right: 20px; }
  #configurator-page #render #escape svg {
    height: 10px;
    width: 10px; }

/* STYLES */
/* LAYOUT */
#configurator-page #render #help {
  position: absolute;
  top: 15px;
  right: 15px;
  display: grid;
  grid-auto-flow: row;
  grid-gap: 5px;
  padding: 30px; }
  #configurator-page #render #help .key-and-text {
    display: grid;
    grid-template-columns: repeat(2, auto);
    grid-gap: 15px;
    align-items: center; }
    #configurator-page #render #help .key-and-text .key {
      height: 26px;
      padding: 5px 0;
      border: 1px solid black;
      border-radius: 6px;
      box-shadow: 0 1px 0 black;
      background-color: grey;
      text-align: center;
      font-size: 12px;
      color: white; }
      #configurator-page #render #help .key-and-text .key.space {
        padding-left: 20px;
        padding-right: 20px; }
      #configurator-page #render #help .key-and-text .key svg {
        height: 10px;
        width: 10px; }
    #configurator-page #render #help .key-and-text .keys {
      display: grid;
      grid-template-columns: repeat(3, 25px);
      grid-template-rows: repeat(2, auto);
      grid-template-areas: ". w ." "a s d";
      grid-gap: 4px; }
      #configurator-page #render #help .key-and-text .keys .key:nth-child(1) {
        grid-area: w; }
      #configurator-page #render #help .key-and-text .keys .key:nth-child(2) {
        grid-area: a; }
      #configurator-page #render #help .key-and-text .keys .key:nth-child(3) {
        grid-area: s; }
      #configurator-page #render #help .key-and-text .keys .key:nth-child(4) {
        grid-area: d; }

/* STYLES */
#configurator-page #render #help {
  border-radius: 35px;
  background-color: rgba(255, 255, 255, 0.2);
  color: white;
  text-align: left; }
  #configurator-page #render #help div:nth-child(1) {
    font-size: 24px; }
  #configurator-page #render #help .key-and-text > div {
    vertical-align: middle; }
  #configurator-page #render #help .key-and-text .keys {
    font-size: 12px; }
  #configurator-page #render #help .key-and-text .desc {
    font-size: 18px; }

#configurator {
  display: grid;
  grid-gap: 50px 0; }
  @media (min-width: 1101px) {
    #configurator {
      grid-template-columns: 20px 250px 50px 1fr 50px 1fr 20px;
      grid-template-rows: 0 calc(100vh - 170px) 0;
      grid-template-areas: ". .        . .      .      .      ." ". controls . render render render ." ". .        . .      .      .      ."; } }
  @media (min-width: 801px) and (max-width: 1100px) {
    #configurator {
      grid-template-columns: 20px 250px 50px 1fr 20px;
      grid-template-rows: 0 calc(100vh - 200px) 0;
      grid-template-areas: ". .        . .      ." ". controls . render ." ". .        . .      ."; } }
  @media (max-width: 800px) {
    #configurator {
      grid-template-columns: 1fr;
      grid-template-rows: calc(100vh - 100px) 0;
      grid-template-areas: "render" "."; } }
  #configurator #controls {
    display: grid;
    grid-gap: 10px;
    grid-area: controls;
    grid-template-columns: 20px 1fr 1fr 20px;
    grid-template-rows: repeat(11, 40px) auto 40px 10px;
    grid-template-areas: ". size size ." ". height height ." ". width width ." ". glas glas ." ". material material ." ". color color ." ". lighting lighting ." ". front back ." ". inside outside ." ". mirroring mirroring ." ". off on ." ". price price ." ". buy buy ." ". . . ."; }
    #configurator #controls h1:nth-of-type(1) {
      grid-area: size; }
    #configurator #controls .grid-height {
      grid-area: height; }
    #configurator #controls .grid-width {
      grid-area: width; }
    #configurator #controls h1:nth-of-type(2) {
      grid-area: glas; }
    #configurator #controls #glass {
      grid-area: material; }
    #configurator #controls #color {
      grid-area: color; }
    #configurator #controls h1:nth-of-type(3) {
      grid-area: lighting; }
    #configurator #controls #front {
      grid-area: front; }
    #configurator #controls #back {
      grid-area: back; }
    #configurator #controls #inside {
      grid-area: inside; }
    #configurator #controls #outside {
      grid-area: outside; }
    #configurator #controls h1:nth-of-type(4) {
      grid-area: mirroring; }
    #configurator #controls #non-reflecting {
      grid-area: off; }
    #configurator #controls #reflecting {
      grid-area: on; }
    #configurator #controls #price {
      grid-area: price; }
    #configurator #controls #buy-now, #configurator #controls #mail {
      grid-area: buy;
      justify-self: center; }
    #configurator #controls .grid-width, #configurator #controls .grid-height {
      display: grid;
      grid-template-columns: 1fr 30px;
      grid-template-rows: 1fr; }
      #configurator #controls .grid-width input, #configurator #controls .grid-width label, #configurator #controls .grid-height input, #configurator #controls .grid-height label {
        display: block;
        align-self: center;
        width: 100%; }
      #configurator #controls .grid-width input, #configurator #controls .grid-height input {
        grid-area: 1/1 / 2/2; }
      #configurator #controls .grid-width label, #configurator #controls .grid-height label {
        grid-area: 1/2 / 2/3; }
    @media (max-width: 800px) {
      #configurator #controls {
        position: fixed;
        top: 70px;
        right: 0;
        z-index: 3;
        height: calc(100vh - 70px);
        max-width: 0;
        transition: max-width 0.25s ease; }
        #configurator #controls.expanded {
          max-width: 250px; } }
  #configurator.dragging-file #drop-here {
    display: block; }
  #configurator #drop-here {
    display: none;
    position: fixed;
    top: 0;
    left: 0;
    z-index: 2;
    width: 100vw;
    height: 100vh;
    padding: 3vw;
    background-color: rgba(0, 0, 0, 0.9); }
    #configurator #drop-here div {
      display: grid;
      grid-template-columns: 1fr 14fr 2fr 14fr 1fr;
      grid-template-rows: 1fr 14fr 2fr 14fr 1fr;
      grid-template-areas: "lefttop    . .      . righttop   " ".          . .      . .          " ".          . middle . .          " ".          . .      . .          " "leftbottom . .      . rightbottom";
      width: 100%;
      height: 100%; }
      #configurator #drop-here div img {
        align-self: stretch;
        justify-self: stretch; }
        #configurator #drop-here div img:nth-child(1) {
          grid-area: lefttop; }
        #configurator #drop-here div img:nth-child(2) {
          grid-area: leftbottom; }
        #configurator #drop-here div img:nth-child(3) {
          grid-area: righttop; }
        #configurator #drop-here div img:nth-child(4) {
          grid-area: rightbottom; }
        #configurator #drop-here div img:nth-child(5) {
          grid-area: middle; }
  #configurator #render {
    grid-area: render; }
    #configurator #render #three {
      width: 100%;
      height: 100%;
      position: relative; }
    #configurator #render #lights {
      position: absolute;
      left: 20px;
      bottom: 20px;
      display: grid;
      grid-template-columns: repeat(2, auto);
      grid-gap: 10px;
      align-items: center;
      padding-left: 13px; }
      #configurator #render #lights svg {
        width: 20px;
        height: 20px; }

#configurator-page #configurator #render {
  border-radius: 5px;
  position: relative;
  overflow: hidden;
  text-align: center; }
  #configurator-page #configurator #render.focused {
    border: 2px solid #9f72ff; }
    #configurator-page #configurator #render.focused #help {
      display: none; }
    #configurator-page #configurator #render.focused #escape {
      display: block; }
    #configurator-page #configurator #render.focused canvas {
      cursor: none; }
  #configurator-page #configurator #render > svg {
    position: absolute;
    top: 5%;
    left: 20%;
    z-index: 1;
    max-height: 70%;
    max-width: 70%;
    overflow: visible;
    cursor: pointer; }
    #configurator-page #configurator #render > svg #cloud-back, #configurator-page #configurator #render > svg #cloud-main, #configurator-page #configurator #render > svg #cloud-outline {
      transform-origin: center; }
    #configurator-page #configurator #render > svg #lock-inner, #configurator-page #configurator #render > svg #lock-outline {
      transform-origin: 33% 0%; }
    #configurator-page #configurator #render > svg #cloud-small-right,
    #configurator-page #configurator #render > svg #cloud-small-left,
    #configurator-page #configurator #render > svg #cloud-small-leftest,
    #configurator-page #configurator #render > svg #cloud-big-right,
    #configurator-page #configurator #render > svg #cloud-big-left,
    #configurator-page #configurator #render > svg #cloud-back,
    #configurator-page #configurator #render > svg #cloud-main,
    #configurator-page #configurator #render > svg #cloud-outline,
    #configurator-page #configurator #render > svg #upload-arrow-1,
    #configurator-page #configurator #render > svg #upload-arrow-2,
    #configurator-page #configurator #render > svg #download-arrow-1,
    #configurator-page #configurator #render > svg #download-arrow-2,
    #configurator-page #configurator #render > svg #lock-inner,
    #configurator-page #configurator #render > svg #lock-outline {
      transition: transform 0.25s ease; }
  #configurator-page #configurator #render:hover > svg #cloud-small-right {
    transform: translateX(-0.5%); }
  #configurator-page #configurator #render:hover > svg #cloud-small-left {
    transform: translateX(1%); }
  #configurator-page #configurator #render:hover > svg #cloud-small-leftest {
    transform: translateX(2.5%); }
  #configurator-page #configurator #render:hover > svg #cloud-big-right {
    transform: translateX(1.5%); }
  #configurator-page #configurator #render:hover > svg #cloud-big-left {
    transform: translateX(-2%); }
  #configurator-page #configurator #render:hover > svg #cloud-main {
    transform: scale(0.97); }
  #configurator-page #configurator #render:hover > svg #cloud-back, #configurator-page #configurator #render:hover > svg #cloud-outline {
    transform: scale(1.03); }
  #configurator-page #configurator #render:hover > svg #upload-arrow-1, #configurator-page #configurator #render:hover > svg #upload-arrow-2 {
    transform: translateY(1%); }
  #configurator-page #configurator #render:hover > svg #download-arrow-1, #configurator-page #configurator #render:hover > svg #download-arrow-2 {
    transform: translateY(-1%); }
  #configurator-page #configurator #render:hover > svg #lock-inner, #configurator-page #configurator #render:hover > svg #lock-outline {
    transform: rotate3d(-1, -2, 0, 65deg); }
  #configurator-page #configurator #render.busy canvas {
    visibility: hidden; }
  #configurator-page #configurator #render.busy > svg #upload-arrow-1, #configurator-page #configurator #render.busy > svg #upload-arrow-2 {
    transform-origin: 45% 0%;
    animation: pirouette 2s infinite; }
@keyframes pirouette {
  0% {
    transform: rotate3d(0, 1, 0, 0deg); }
  50% {
    transform: rotate3d(0, 1, 0, 360deg); }
  100% {
    transform: rotate3d(0, 1, 0, 0deg); } }
  #configurator-page #configurator #render.busy > svg #upload-cloud {
    animation: blink 2.5s infinite; }
@keyframes blink {
  0% {
    fill: #43425d; }
  50% {
    fill: #00c2df; }
  100% {
    fill: #43425d; } }
  #configurator-page #configurator #render.busy > svg #lock-inner, #configurator-page #configurator #render.busy > svg #lock-outline {
    animation: open-close 3s infinite; }
@keyframes open-close {
  0% {
    transform: rotate3d(-1, -2, 0, 0deg); }
  50% {
    transform: rotate3d(-1, -2, 0, 65deg); }
  100% {
    transform: rotate3d(-1, -2, 0, 0deg); } }
/* LAYOUT */
#landing-page #cta-screen {
  display: grid;
  margin-bottom: 100px;
  /* STYLE */
  text-align: center; }
  @media (min-width: 1201px) {
    #landing-page #cta-screen {
      grid-template-areas: ". headline headline headline headline ." ". subline  subline  subline  subline  ." ". .        .        .        .        ." ". tile1    tile2    tile3    tile4    ." ". .        .        .        .        ." ". .        cta      cta      .        .";
      grid-template-columns: 175px 1fr 1fr 1fr 1fr 175px;
      grid-template-rows: auto auto 0 minmax(min-content, calc(calc(100vw - 350px - 150px) / 4)) auto;
      grid-gap: 25px 50px; } }
  @media (min-width: 701px) and (max-width: 1200px) {
    #landing-page #cta-screen {
      grid-template-areas: ". headline ." ". subline  ." ". tile1    ." ". tile2    ." ". tile3    ." ". tile4    ." ". cta      .";
      grid-template-columns: 1fr 2fr 1fr;
      grid-template-rows: auto auto repeat(4, minmax(min-content, calc(50vw - 100px))) auto;
      grid-gap: 50px; } }
  @media (max-width: 700px) {
    #landing-page #cta-screen {
      grid-template-areas: ". headline ." ". subline  ." ". tile1    ." ". tile2    ." ". tile3    ." ". tile4    ." ". cta      .";
      grid-template-columns: 5vw 1fr 5vw;
      grid-template-rows: auto auto repeat(4, 90vw) auto;
      grid-gap: 50px 0; } }
  #landing-page #cta-screen .section-headline {
    grid-area: headline; }
  #landing-page #cta-screen .section-subline {
    grid-area: subline; }
  #landing-page #cta-screen .tile {
    position: relative;
    transition: top 2s ease, opacity 1s ease;
    display: grid;
    padding: 30px 15px 30px;
    grid-template-columns: 1fr;
    grid-template-areas: "title" "icon" "step"; }
    @media (max-width: 700px) {
      #landing-page #cta-screen .tile {
        margin: 0 10vw; } }
    @media (max-width: 800px) {
      #landing-page #cta-screen .tile {
        grid-template-rows: 80px 1fr 25px;
        grid-gap: 10vw; } }
    @media (min-width: 801px) and (max-width: 1200px) {
      #landing-page #cta-screen .tile {
        grid-template-rows: 80px 1fr 25px;
        grid-gap: 10vw; } }
    @media (min-width: 1201px) {
      #landing-page #cta-screen .tile {
        grid-template-rows: 80px 1fr 25px;
        grid-gap: 6.5vw; } }
    #landing-page #cta-screen .tile .title {
      grid-area: title; }
    #landing-page #cta-screen .tile svg {
      width: 50%;
      grid-area: icon;
      align-self: center;
      justify-self: center; }
    #landing-page #cta-screen .tile .step {
      grid-area: step; }
  #landing-page #cta-screen .control-button {
    grid-area: cta;
    justify-self: center; }
  #landing-page #cta-screen .tile {
    background: linear-gradient(rgba(255, 255, 255, 0), #26313a);
    border-radius: 40px; }
    #landing-page #cta-screen .tile .title, #landing-page #cta-screen .tile .step {
      color: white; }
    #landing-page #cta-screen .tile .title {
      font-size: 32px; }
    #landing-page #cta-screen .tile .step {
      font-size: 18px; }
  #landing-page #cta-screen #step1 {
    grid-area: tile1; }
  #landing-page #cta-screen #step2 {
    grid-area: tile2; }
  #landing-page #cta-screen #step3 {
    grid-area: tile3; }
  #landing-page #cta-screen #step4 {
    grid-area: tile4; }

/* STYLE */
/* LAYOUT */
#landing-page #delivery-screen {
  display: grid;
  margin-bottom: 100px;
  /* STYLE */
  text-align: center; }
  @media (min-width: 1201px) {
    #landing-page #delivery-screen {
      grid-template-areas: ". headline headline headline headline ." ". subline  subline  subline  subline  ." ". .        .        .        .        ." ". tile1    tile2    tile3    tile4    ." ". .        .        .        .        ." ". .        cta      cta      .        .";
      grid-template-columns: 175px 1fr 1fr 1fr 1fr 175px;
      grid-template-rows: auto auto 0 minmax(min-content, calc(calc(100vw - 350px - 150px) / 4)) auto;
      grid-gap: 25px 50px; } }
  @media (min-width: 701px) and (max-width: 1200px) {
    #landing-page #delivery-screen {
      grid-template-areas: ". headline ." ". subline  ." ". tile1    ." ". tile2    ." ". tile3    ." ". tile4    ." ". cta      .";
      grid-template-columns: 1fr 2fr 1fr;
      grid-template-rows: auto auto repeat(4, minmax(min-content, calc(50vw - 100px))) auto;
      grid-gap: 50px; } }
  @media (max-width: 700px) {
    #landing-page #delivery-screen {
      grid-template-areas: ". headline ." ". subline  ." ". tile1    ." ". tile2    ." ". tile3    ." ". tile4    ." ". cta      .";
      grid-template-columns: 5vw 1fr 5vw;
      grid-template-rows: auto auto repeat(4, 90vw) auto;
      grid-gap: 50px 0; } }
  #landing-page #delivery-screen .section-headline {
    grid-area: headline; }
  #landing-page #delivery-screen .section-subline {
    grid-area: subline; }
  #landing-page #delivery-screen .tile {
    position: relative;
    transition: top 2s ease, opacity 1s ease;
    display: grid;
    padding: 30px 15px 30px;
    grid-template-columns: 1fr;
    grid-template-areas: "title" "icon" "step"; }
    @media (max-width: 700px) {
      #landing-page #delivery-screen .tile {
        margin: 0 10vw; } }
    @media (max-width: 800px) {
      #landing-page #delivery-screen .tile {
        grid-template-rows: 80px 1fr 25px;
        grid-gap: 10vw; } }
    @media (min-width: 801px) and (max-width: 1200px) {
      #landing-page #delivery-screen .tile {
        grid-template-rows: 80px 1fr 25px;
        grid-gap: 10vw; } }
    @media (min-width: 1201px) {
      #landing-page #delivery-screen .tile {
        grid-template-rows: 80px 1fr 25px;
        grid-gap: 6.5vw; } }
    #landing-page #delivery-screen .tile .title {
      grid-area: title; }
    #landing-page #delivery-screen .tile svg {
      width: 50%;
      grid-area: icon;
      align-self: center;
      justify-self: center; }
    #landing-page #delivery-screen .tile .step {
      grid-area: step; }
  #landing-page #delivery-screen .control-button {
    grid-area: cta;
    justify-self: center; }
  #landing-page #delivery-screen .tile {
    background: linear-gradient(rgba(255, 255, 255, 0), #26313a);
    border-radius: 40px; }
    #landing-page #delivery-screen .tile .title, #landing-page #delivery-screen .tile .step {
      color: white; }
    #landing-page #delivery-screen .tile .title {
      font-size: 32px; }
    #landing-page #delivery-screen .tile .step {
      font-size: 18px; }
  #landing-page #delivery-screen #step5 {
    grid-area: tile1; }
  #landing-page #delivery-screen #step6 {
    grid-area: tile2; }
  #landing-page #delivery-screen #step7 {
    grid-area: tile3; }
  #landing-page #delivery-screen #step8 {
    grid-area: tile4; }

/* STYLE */
/* LAYOUT */
#landing-page #main-screen {
  display: grid;
  min-height: calc(100vh - 70px); }
  @media (min-width: 1501px) and (min-height: 801px) {
    #landing-page #main-screen {
      grid-template-columns: 1fr 530px 1fr 720px 1fr;
      grid-template-rows: 1fr 360px 180px 180px 1fr;
      grid-template-areas: ". .       . mask mask" ". neon    . mask mask" ". .       . mask mask" ". slogans . mask mask" ". .       . mask mask"; } }
  @media (min-width: 1381px) and (max-width: 1500px) and (min-height: 801px) {
    #landing-page #main-screen {
      grid-template-columns: 1fr 530px 1fr;
      grid-template-rows: 1fr 360px 180px 180px 1fr;
      grid-template-areas: ". .       ." ". neon    ." ". .       ." ". slogans ." ". .       ."; }
      #landing-page #main-screen #mask {
        display: none; }
      #landing-page #main-screen #slogans {
        text-align: center; } }
  @media (min-width: 701px) and (max-width: 1500px) and (min-height: 801px) {
    #landing-page #main-screen {
      grid-template-columns: 1fr 530px 1fr;
      grid-template-rows: 1fr 360px 180px 180px 1fr;
      grid-template-areas: ". .       ." ". neon    ." ". .       ." ". slogans ." ". .       ."; }
      #landing-page #main-screen #mask {
        display: none; }
      #landing-page #main-screen #slogans {
        text-align: center; } }
  @media (min-width: 1501px) and (max-height: 800px) {
    #landing-page #main-screen {
      grid-template-columns: 1fr 530px 1fr 600px 1fr;
      grid-template-rows: 1fr 300px 150px 150px 1fr;
      grid-template-areas: ". .       . mask mask" ". neon    . mask mask" ". .       . mask mask" ". slogans . mask mask" ". .       . mask mask"; } }
  @media (min-width: 701px) and (max-width: 1500px) and (max-height: 800px) {
    #landing-page #main-screen {
      grid-template-columns: 1fr 530px 1fr;
      grid-template-rows: 1fr 360px 180px 180px 1fr;
      grid-template-areas: ". .       ." ". neon    ." ". .       ." ". slogans ." ". .       ."; }
      #landing-page #main-screen #mask {
        display: none; }
      #landing-page #main-screen #slogans {
        text-align: center; } }
  @media (max-width: 700px) {
    #landing-page #main-screen {
      grid-template-columns: 1fr min-content 1fr;
      grid-template-rows: 1fr auto 1fr auto 1fr;
      grid-template-areas: ". .       ." ". neon    ." ". .       ." ". slogans ." ". .       ."; }
      #landing-page #main-screen #mask {
        display: none; }
      #landing-page #main-screen #slogans {
        text-align: center; } }
  #landing-page #main-screen #neon {
    grid-area: neon;
    white-space: nowrap;
    padding-top: 175px; }
  #landing-page #main-screen #slogans {
    grid-area: slogans; }
    #landing-page #main-screen #slogans .control-button {
      margin-top: 5%; }
  #landing-page #main-screen #mask {
    width: 100% !important;
    height: 100% !important;
    grid-area: mask; }

/* STYLE */
#landing-page #main-screen #neon {
  color: white;
  font-size: 70px;
  cursor: default;
  pointer-events: none; }
  #landing-page #main-screen #neon span {
    font-size: 70px;
    color: white; }
  #landing-page #main-screen #neon #pink {
    font-family: "neontubes";
    will-change: opacity;
    color: #ffd9e2;
    text-shadow: 0 0 0 transparent, 0 0 10px #ff003c, 0 0 20px rgba(255, 0, 60, 0.5), 0 0 40px #ff003c, 0 0 100px #ff003c, 0 0 200px #ff003c, 0 0 300px #ff003c, 0 0 500px #ff003c, 0 0 1000px #ff003c;
    animation: blink 4s infinite alternate; }
  #landing-page #main-screen #neon #blue {
    font-family: "neontubes";
    will-change: opacity;
    color: #ece3ff;
    text-shadow: 0 0 0 transparent, 0 0 10px #9f72ff, 0 0 20px rgba(159, 114, 255, 0.5), 0 0 40px #9f72ff, 0 0 100px #9f72ff, 0 0 200px #9f72ff, 0 0 300px #9f72ff, 0 0 500px #9f72ff;
    animation: buzz 0.01s infinite alternate; }
    #landing-page #main-screen #neon #blue span {
      font-family: inherit; }
#landing-page #main-screen #slogans #sub-slogan {
  font-size: 18px;
  color: white; }

/* LAYOUT */
#landing-page #quote-screen {
  display: grid; }
  @media (max-width: 1100px) {
    #landing-page #quote-screen {
      display: block;
      width: 100vw; } }
  @media (min-width: 1101px) {
    #landing-page #quote-screen {
      height: 980px;
      grid-template-columns: 1fr auto 1fr;
      grid-template-rows: 150px 1fr 150px; } }
  #landing-page #quote-screen #subgrid {
    grid-area: 2/2 / 3/3;
    display: grid;
    position: relative; }
    #landing-page #quote-screen #subgrid .jumper {
      position: absolute;
      width: 60px;
      height: 60px;
      background-color: #26313A;
      border-radius: 50%;
      cursor: pointer;
      transition: background-color 0.25s ease;
      top: calc(50% - 30px); }
      #landing-page #quote-screen #subgrid .jumper svg {
        position: absolute;
        top: 30%;
        left: 30%;
        width: 40%;
        height: 40%; }
      #landing-page #quote-screen #subgrid .jumper:hover svg path {
        stroke: #9f72ff; }
      #landing-page #quote-screen #subgrid .jumper svg path {
        stroke: white;
        transition: fill 0.25s ease; }
      #landing-page #quote-screen #subgrid .jumper#backward {
        left: -200px; }
      #landing-page #quote-screen #subgrid .jumper#forward {
        right: -200px; }
    @media (max-width: 650px) {
      #landing-page #quote-screen #subgrid {
        grid-template-columns: 10vw 1fr 10vw;
        grid-template-rows: 0 repeat(3, auto) 0;
        grid-template-areas: ". .    ." ". big  ." ". long ." ". img  ." ". .    .";
        grid-gap: 50px 0;
        text-align: center; }
        #landing-page #quote-screen #subgrid #bigquote {
          grid-area: big; }
        #landing-page #quote-screen #subgrid #longquote {
          padding: 0 25%; }
        #landing-page #quote-screen #subgrid #quoted {
          bottom: 5vw;
          right: 5vw; }
        #landing-page #quote-screen #subgrid #img {
          height: 80vw; } }
    @media (min-width: 651px) and (max-width: 1100px) {
      #landing-page #quote-screen #subgrid {
        grid-template-columns: 0 0 1fr 0 0;
        grid-template-rows: 0 auto auto auto 0;
        grid-template-areas: ". . .    . ." ". . big  . ." ". . long . ." ". . img  . ." ". . .    . .";
        grid-gap: 75px;
        text-align: center; }
        #landing-page #quote-screen #subgrid #bigquote {
          grid-area: big; }
        #landing-page #quote-screen #subgrid #longquote {
          padding: 0 25%; }
        #landing-page #quote-screen #subgrid #quoted {
          bottom: 100px;
          right: 100px; }
        #landing-page #quote-screen #subgrid #img {
          height: calc(100vw - 300px); } }
    @media (min-width: 1101px) {
      #landing-page #quote-screen #subgrid {
        grid-template-columns: 250px 680px;
        grid-template-rows: 15% auto 50px auto 1fr;
        grid-template-areas: ".    img" "big  img" ".    img" "long img" ".    img"; }
        #landing-page #quote-screen #subgrid #bigquote {
          grid-area: big-start/big-start / big-end/img-end; }
        #landing-page #quote-screen #subgrid #longquote {
          padding-right: 25px; }
        #landing-page #quote-screen #subgrid #quoted {
          bottom: 25px;
          right: 25px; } }
    #landing-page #quote-screen #subgrid #bigquote {
      z-index: 1; }
    #landing-page #quote-screen #subgrid #longquote {
      grid-area: long; }
    #landing-page #quote-screen #subgrid #img {
      grid-area: img;
      position: relative; }
    #landing-page #quote-screen #subgrid #quoted {
      position: absolute;
      z-index: 1;
      width: 150px;
      height: 150px; }

/* STYLING */
#landing-page #quote-screen #bigquote {
  font-size: 60px;
  color: #9f72ff; }
#landing-page #quote-screen #longquote {
  font-size: 14px;
  color: white; }
#landing-page #quote-screen #img {
  border-radius: 50%;
  overflow: hidden; }
  #landing-page #quote-screen #img img {
    position: absolute;
    top: 0;
    left: 0;
    min-width: 100%;
    min-height: 100%;
    transform: scale(1);
    transition: transform 0.25s ease; }
    #landing-page #quote-screen #img img:hover {
      transform: scale(1.1); }
#landing-page #quote-screen #quoted {
  background-color: #9f72ff;
  border-radius: 50%;
  color: white;
  text-align: center;
  line-height: 150px; }

/* LAYOUT */
#landing-page #reference-screen {
  display: grid; }
  @media (min-width: 1401px) and (min-height: 701px) {
    #landing-page #reference-screen {
      grid-template-columns: 1fr 3fr 1fr;
      grid-template-rows: 100px calc(100vh - 270px) 100px; } }
  @media (min-width: 801px) and (max-width: 1400px) and (min-height: 701px) {
    #landing-page #reference-screen {
      grid-template-columns: 1fr 5fr 1fr;
      grid-template-rows: 100px calc(100vh - 270px) 100px; } }
  @media (max-width: 800px) {
    #landing-page #reference-screen {
      grid-template-columns: 1fr min-content 1fr;
      grid-template-rows: auto; } }
  #landing-page #reference-screen .subgrid {
    display: grid; }
    @media (min-width: 801px) {
      #landing-page #reference-screen .subgrid {
        grid-area: 2/2 / 3/3;
        grid-template-columns: repeat(5, 1fr);
        grid-template-rows: repeat(3, 1fr); }
        #landing-page #reference-screen .subgrid #reference {
          grid-area: 1/2 / 4/6; }
        #landing-page #reference-screen .subgrid #reference-info {
          grid-area: 2/1 / 3/3; } }
    @media (max-width: 800px) {
      #landing-page #reference-screen .subgrid {
        grid-area: 1/2 / 2/2;
        grid-template-columns: 90vw;
        grid-template-rows: 5vw 90vw auto 150px;
        grid-template-areas: "." "ref" "info" "more"; }
        #landing-page #reference-screen .subgrid #reference {
          grid-area: ref; }
        #landing-page #reference-screen .subgrid #reference-info {
          grid-area: info;
          text-align: center; }
        #landing-page #reference-screen .subgrid #backward {
          left: -2.5vw !important; }
        #landing-page #reference-screen .subgrid #forward {
          right: -2.5vw !important; } }
    #landing-page #reference-screen .subgrid #reference {
      position: relative; }
      #landing-page #reference-screen .subgrid #reference div:first-of-type {
        position: absolute;
        top: 0;
        left: 0;
        width: 100%;
        height: 100%; }
      #landing-page #reference-screen .subgrid #reference #backward {
        top: 10%;
        left: -30px; }
      #landing-page #reference-screen .subgrid #reference #forward {
        right: -30px;
        bottom: 10%; }
    #landing-page #reference-screen .subgrid #reference-info {
      z-index: 1; }
  #landing-page #reference-screen .subgrid #reference div:first-of-type {
    overflow: hidden; }
    #landing-page #reference-screen .subgrid #reference div:first-of-type img {
      position: absolute;
      top: 0;
      left: 0;
      min-width: 100%;
      min-height: 100%;
      transform: scale(1);
      transition: transform 0.25s ease; }
      #landing-page #reference-screen .subgrid #reference div:first-of-type img:hover {
        transform: scale(1.1); }
  #landing-page #reference-screen .subgrid #reference .jumper {
    position: absolute;
    width: 60px;
    height: 60px;
    background-color: #26313A;
    border-radius: 50%;
    cursor: pointer;
    transition: background-color 0.25s ease; }
    #landing-page #reference-screen .subgrid #reference .jumper svg {
      position: absolute;
      top: 30%;
      left: 30%;
      width: 40%;
      height: 40%; }
    #landing-page #reference-screen .subgrid #reference .jumper:hover svg path {
      stroke: #9f72ff; }
    #landing-page #reference-screen .subgrid #reference .jumper svg path {
      stroke: white;
      transition: fill 0.25s ease; }
  #landing-page #reference-screen .subgrid #reference-info #reference-text, #landing-page #reference-screen .subgrid #reference-info #reference-company {
    font-size: 58px;
    color: #9f72ff; }
  #landing-page #reference-screen .subgrid #reference-info #reference-company {
    font-family: "Seido Bold"; }
  #landing-page #reference-screen #reference-button {
    margin-top: 30px; }

/* STYLE */
/* LAYOUT */
#reference-page #quote-screen {
  display: grid; }
  @media (max-width: 1100px) {
    #reference-page #quote-screen {
      display: block;
      width: 100vw; } }
  @media (min-width: 1101px) {
    #reference-page #quote-screen {
      height: 980px;
      grid-template-columns: 1fr auto 1fr;
      grid-template-rows: 150px 1fr 150px; } }
  #reference-page #quote-screen #subgrid {
    grid-area: 2/2 / 3/3;
    display: grid;
    position: relative; }
    #reference-page #quote-screen #subgrid .jumper {
      position: absolute;
      width: 60px;
      height: 60px;
      background-color: #26313A;
      border-radius: 50%;
      cursor: pointer;
      transition: background-color 0.25s ease;
      top: calc(50% - 30px); }
      #reference-page #quote-screen #subgrid .jumper svg {
        position: absolute;
        top: 30%;
        left: 30%;
        width: 40%;
        height: 40%; }
      #reference-page #quote-screen #subgrid .jumper:hover svg path {
        stroke: #9f72ff; }
      #reference-page #quote-screen #subgrid .jumper svg path {
        stroke: white;
        transition: fill 0.25s ease; }
      #reference-page #quote-screen #subgrid .jumper#backward {
        left: -200px; }
      #reference-page #quote-screen #subgrid .jumper#forward {
        right: -200px; }
    @media (max-width: 650px) {
      #reference-page #quote-screen #subgrid {
        grid-template-columns: 10vw 1fr 10vw;
        grid-template-rows: 0 repeat(3, auto) 0;
        grid-template-areas: ". .    ." ". big  ." ". long ." ". img  ." ". .    .";
        grid-gap: 50px 0;
        text-align: center; }
        #reference-page #quote-screen #subgrid #bigquote {
          grid-area: big; }
        #reference-page #quote-screen #subgrid #longquote {
          padding: 0 25%; }
        #reference-page #quote-screen #subgrid #quoted {
          bottom: 5vw;
          right: 5vw; }
        #reference-page #quote-screen #subgrid #img {
          height: 80vw; } }
    @media (min-width: 651px) and (max-width: 1100px) {
      #reference-page #quote-screen #subgrid {
        grid-template-columns: 0 0 1fr 0 0;
        grid-template-rows: 0 auto auto auto 0;
        grid-template-areas: ". . .    . ." ". . big  . ." ". . long . ." ". . img  . ." ". . .    . .";
        grid-gap: 75px;
        text-align: center; }
        #reference-page #quote-screen #subgrid #bigquote {
          grid-area: big; }
        #reference-page #quote-screen #subgrid #longquote {
          padding: 0 25%; }
        #reference-page #quote-screen #subgrid #quoted {
          bottom: 100px;
          right: 100px; }
        #reference-page #quote-screen #subgrid #img {
          height: calc(100vw - 300px); } }
    @media (min-width: 1101px) {
      #reference-page #quote-screen #subgrid {
        grid-template-columns: 250px 680px;
        grid-template-rows: 15% auto 50px auto 1fr;
        grid-template-areas: ".    img" "big  img" ".    img" "long img" ".    img"; }
        #reference-page #quote-screen #subgrid #bigquote {
          grid-area: big-start/big-start / big-end/img-end; }
        #reference-page #quote-screen #subgrid #longquote {
          padding-right: 25px; }
        #reference-page #quote-screen #subgrid #quoted {
          bottom: 25px;
          right: 25px; } }
    #reference-page #quote-screen #subgrid #bigquote {
      z-index: 1; }
    #reference-page #quote-screen #subgrid #longquote {
      grid-area: long; }
    #reference-page #quote-screen #subgrid #img {
      grid-area: img;
      position: relative; }
    #reference-page #quote-screen #subgrid #quoted {
      position: absolute;
      z-index: 1;
      width: 150px;
      height: 150px; }

/* STYLING */
#reference-page #quote-screen #bigquote {
  font-size: 60px;
  color: #9f72ff; }
#reference-page #quote-screen #longquote {
  font-size: 14px;
  color: white; }
#reference-page #quote-screen #img {
  border-radius: 50%;
  overflow: hidden; }
  #reference-page #quote-screen #img img {
    position: absolute;
    top: 0;
    left: 0;
    min-width: 100%;
    min-height: 100%;
    transform: scale(1);
    transition: transform 0.25s ease; }
    #reference-page #quote-screen #img img:hover {
      transform: scale(1.1); }
#reference-page #quote-screen #quoted {
  background-color: #9f72ff;
  border-radius: 50%;
  color: white;
  text-align: center;
  line-height: 150px; }

#reference-page #reference-screen {
  display: grid; }
  @media (min-width: 1401px) and (min-height: 701px) {
    #reference-page #reference-screen {
      grid-template-columns: 1fr 3fr 1fr;
      grid-template-rows: 100px calc(100vh - 270px) 100px; } }
  @media (min-width: 801px) and (max-width: 1400px) and (min-height: 701px) {
    #reference-page #reference-screen {
      grid-template-columns: 1fr 5fr 1fr;
      grid-template-rows: 100px calc(100vh - 270px) 100px; } }
  @media (max-width: 800px) {
    #reference-page #reference-screen {
      grid-template-columns: 1fr min-content 1fr;
      grid-template-rows: auto; } }
  #reference-page #reference-screen .subgrid {
    display: grid; }
    @media (min-width: 801px) {
      #reference-page #reference-screen .subgrid {
        grid-area: 2/2 / 3/3;
        grid-template-columns: repeat(5, 1fr);
        grid-template-rows: repeat(3, 1fr); }
        #reference-page #reference-screen .subgrid #reference {
          grid-area: 1/2 / 4/6; }
        #reference-page #reference-screen .subgrid #reference-info {
          grid-area: 2/1 / 3/3; } }
    @media (max-width: 800px) {
      #reference-page #reference-screen .subgrid {
        grid-area: 1/2 / 2/2;
        grid-template-columns: 90vw;
        grid-template-rows: 5vw 90vw auto 150px;
        grid-template-areas: "." "ref" "info" "more"; }
        #reference-page #reference-screen .subgrid #reference {
          grid-area: ref; }
        #reference-page #reference-screen .subgrid #reference-info {
          grid-area: info;
          text-align: center; }
        #reference-page #reference-screen .subgrid #backward {
          left: -2.5vw !important; }
        #reference-page #reference-screen .subgrid #forward {
          right: -2.5vw !important; } }
    #reference-page #reference-screen .subgrid #reference {
      position: relative; }
      #reference-page #reference-screen .subgrid #reference div:first-of-type {
        position: absolute;
        top: 0;
        left: 0;
        width: 100%;
        height: 100%; }
      #reference-page #reference-screen .subgrid #reference #backward {
        top: 10%;
        left: -30px; }
      #reference-page #reference-screen .subgrid #reference #forward {
        right: -30px;
        bottom: 10%; }
    #reference-page #reference-screen .subgrid #reference-info {
      z-index: 1; }
  #reference-page #reference-screen .subgrid #reference div:first-of-type {
    overflow: hidden; }
    #reference-page #reference-screen .subgrid #reference div:first-of-type img {
      position: absolute;
      top: 0;
      left: 0;
      min-width: 100%;
      min-height: 100%;
      transform: scale(1);
      transition: transform 0.25s ease; }
      #reference-page #reference-screen .subgrid #reference div:first-of-type img:hover {
        transform: scale(1.1); }
  #reference-page #reference-screen .subgrid #reference .jumper {
    position: absolute;
    width: 60px;
    height: 60px;
    background-color: #26313A;
    border-radius: 50%;
    cursor: pointer;
    transition: background-color 0.25s ease; }
    #reference-page #reference-screen .subgrid #reference .jumper svg {
      position: absolute;
      top: 30%;
      left: 30%;
      width: 40%;
      height: 40%; }
    #reference-page #reference-screen .subgrid #reference .jumper:hover svg path {
      stroke: #9f72ff; }
    #reference-page #reference-screen .subgrid #reference .jumper svg path {
      stroke: white;
      transition: fill 0.25s ease; }
  #reference-page #reference-screen .subgrid #reference-info #reference-text, #reference-page #reference-screen .subgrid #reference-info #reference-company {
    font-size: 58px;
    color: #9f72ff; }
  #reference-page #reference-screen .subgrid #reference-info #reference-company {
    font-family: "Seido Bold"; }
  #reference-page #reference-screen #more {
    position: relative;
    cursor: pointer; }
    @media (min-width: 801px) {
      #reference-page #reference-screen #more {
        grid-area: 3/1 / 4/2; }
        #reference-page #reference-screen #more svg {
          left: 0; }
        #reference-page #reference-screen #more div {
          left: 65px; } }
    @media (max-width: 800px) {
      #reference-page #reference-screen #more {
        grid-area: more; }
        #reference-page #reference-screen #more svg {
          left: calc(45vw - 50px); }
        #reference-page #reference-screen #more div {
          left: 45vw; } }
    #reference-page #reference-screen #more svg, #reference-page #reference-screen #more div {
      position: absolute;
      bottom: 60px; }
    #reference-page #reference-screen #more svg {
      width: 40px;
      height: 40px;
      transition: bottom 0.25s ease; }
    #reference-page #reference-screen #more div {
      color: white; }
    #reference-page #reference-screen #more:hover svg {
      bottom: 50px; }

/* LAYOUT */
@media (max-width: 800px), (max-height: 700px) {
  #reference-page #split-screens {
    margin-top: 100px; } }
#reference-page #split-screens .split-screen {
  display: grid;
  position: relative; }
  @media (min-width: 751px) {
    #reference-page #split-screens .split-screen {
      grid-template-columns: repeat(2, 1fr);
      grid-template-rows: 100%;
      grid-template-areas: "info image";
      height: 80vh;
      padding: 10vh 0; }
      #reference-page #split-screens .split-screen .info {
        grid-area: info;
        grid-template-columns: repeat(3, 1fr);
        grid-template-rows: repeat(3, 1fr); }
      #reference-page #split-screens .split-screen .image {
        grid-area: image; } }
  @media (min-width: 501px) and (max-width: 750px) {
    #reference-page #split-screens .split-screen {
      grid-template-columns: 1fr;
      grid-template-rows: minmax(min-content, 50vw) 1fr;
      grid-template-areas: "info" "image";
      height: calc(100vh - 70px); }
      #reference-page #split-screens .split-screen .info {
        grid-template-columns: 1fr 2fr 1fr;
        grid-template-rows: 1fr auto 1fr; } }
  @media (max-width: 500px) {
    #reference-page #split-screens .split-screen {
      grid-template-columns: 1fr;
      grid-template-rows: auto 1fr;
      grid-template-areas: "info" "image";
      height: calc(100vh - 70px); }
      #reference-page #split-screens .split-screen .info {
        grid-template-columns: 5vw 1fr 5vw;
        grid-template-rows: 35px auto 35px; } }
  #reference-page #split-screens .split-screen .info {
    grid-area: info;
    display: grid; }
    #reference-page #split-screens .split-screen .info .content {
      grid-area: 2/2 / 3/3; }
      #reference-page #split-screens .split-screen .info .content .bar {
        margin-bottom: 30px;
        width: 100px;
        height: 4px; }
      #reference-page #split-screens .split-screen .info .content .headline {
        margin-bottom: 30px; }
  #reference-page #split-screens .split-screen .image {
    grid-area: image;
    position: relative;
    display: grid;
    padding: 0 0 0 30px;
    grid-template-columns: 1fr 4fr 1fr 1fr;
    grid-template-rows: 60px 1fr 90px; }
    #reference-page #split-screens .split-screen .image .image-anchor {
      grid-area: 2/1 / 3/3;
      position: relative;
      z-index: 2; }
      #reference-page #split-screens .split-screen .image .image-anchor div {
        position: relative;
        overflow: hidden;
        width: 100%;
        height: 100%; }
        #reference-page #split-screens .split-screen .image .image-anchor div img {
          position: absolute;
          top: 0;
          left: 0;
          min-width: 100%;
          min-height: 100%;
          transform: scale(1);
          transition: transform 0.25s ease; }
          #reference-page #split-screens .split-screen .image .image-anchor div img:hover {
            transform: scale(1.1); }
      #reference-page #split-screens .split-screen .image .image-anchor svg {
        position: absolute;
        width: 75px;
        height: 75px; }
        #reference-page #split-screens .split-screen .image .image-anchor svg:first-of-type {
          top: -30px;
          left: -30px; }
        #reference-page #split-screens .split-screen .image .image-anchor svg:last-of-type {
          bottom: -30px;
          right: -30px; }
    #reference-page #split-screens .split-screen .image .tile {
      grid-area: 1/2 / 4/5;
      z-index: 1; }

/* STYLING */
#reference-page #split-screens .split-screen .content .bar {
  background-color: #bf00f8; }
#reference-page #split-screens .split-screen .content .headline {
  font-size: 36px;
  color: white; }
#reference-page #split-screens .split-screen .content .description {
  font-size: 14px;
  color: white; }
#reference-page #split-screens .split-screen .image {
  overflow: hidden; }
  #reference-page #split-screens .split-screen .image .tile {
    border-radius: 85px;
    background-image: linear-gradient(228deg, #bf00f8 0%, #26313a 100%); }

/* LAYOUT */
#footer {
  display: grid; }
  @media (max-width: 800px) {
    #footer {
      grid-template-areas: ". info      ." ". links     ." ". copyright ." ". .         .";
      grid-template-columns: 5vw 1fr 5vw;
      grid-template-rows: repeat(3, auto) 0;
      grid-gap: 20px 0; }
      #footer #posts, #footer .headline {
        display: none !important; }
      #footer #links {
        grid-template-columns: repeat(3, minmax(min-content, 1fr)) 0;
        grid-template-rows: repeat(2, auto);
        grid-gap: 20px 20px; } }
  @media (min-width: 801px) {
    #footer {
      grid-template-areas: ". information instagram   ." ". info        insta-posts ." ". copyright   links       ." ". .           .           .";
      grid-template-rows: 50px auto 100px 20px; } }
  @media (min-width: 801px) and (max-width: 1200px) {
    #footer {
      grid-template-columns: minmax(1fr, 175px) 2fr 4fr minmax(1fr, 175px); } }
  @media (min-width: 801px) and (min-width: 1201px) {
    #footer {
      grid-template-columns: 175px 2fr 4fr 175px; } }
  @media (min-width: 801px) {
      #footer #posts {
        grid-gap: 0 45px; } }
    @media (min-width: 801px) and (max-width: 1100px) {
      #footer #posts {
        grid-template-columns: repeat(2, 1fr); }
        #footer #posts a:nth-child(n + 3) {
          display: none; } }
    @media (min-width: 801px) and (min-width: 1101px) and (max-width: 1450px) {
      #footer #posts {
        grid-template-columns: repeat(3, 1fr); }
        #footer #posts a:nth-child(n + 4) {
          display: none; } }
    @media (min-width: 801px) and (min-width: 1451px) {
      #footer #posts {
        grid-template-columns: repeat(4, 1fr); }
        #footer #posts a:nth-child(n + 5) {
          display: none; } }
  @media (min-width: 801px) {
      #footer #links {
        grid-template-columns: repeat(3, min-content) 1fr repeat(3, min-content);
        grid-template-rows: auto;
        grid-gap: 0 20px; } }
  #footer #information {
    grid-area: information; }
  #footer #instagram {
    grid-area: instagram; }
  #footer #info {
    display: grid;
    grid-area: info;
    grid-template-columns: 100px 1fr;
    grid-template-rows: 100px 20px 20px 20px;
    grid-gap: 10px; }
    #footer #info img {
      justify-self: end;
      height: 100%; }
      #footer #info img:first-of-type {
        justify-self: stretch;
        position: relative;
        top: -35px; }
  #footer #posts {
    grid-area: insta-posts;
    display: grid; }
    #footer #posts a {
      display: block;
      position: relative;
      height: 100%; }
  #footer .footline {
    align-self: end; }
  #footer #copyright {
    grid-area: copyright;
    height: 30px; }
  #footer #links {
    grid-area: links;
    display: grid; }
    #footer #links .wrap {
      position: relative;
      height: 30px;
      width: 30px; }
      #footer #links .wrap img {
        width: 100%;
        height: 100%; }

/* STYLE */
#footer {
  color: white;
  font-size: 14px; }
  #footer .headline, #footer .footline {
    font-family: "Seido Bold"; }
  #footer #posts a {
    overflow: hidden;
    border-radius: 5px; }
    #footer #posts a img {
      position: absolute;
      top: 0;
      left: 0;
      min-width: 100%;
      min-height: 100%;
      transform: scale(1);
      transition: transform 0.25s ease; }
      #footer #posts a img:hover {
        transform: scale(1.1); }
  #footer #links .wrap {
    overflow: hidden;
    border-radius: 50%; }

#page {
  background-color: black;
  width: 100vw;
  height: 100vh;
  overflow: hidden; }
  #page > div {
    margin-top: 70px;
    height: calc(100% - 70px);
    overflow-x: hidden;
    overflow-y: scroll; }

.control-button {
  display: inline-block;
  position: relative;
  background-color: transparent;
  height: 50px;
  padding: 10px 25px;
  overflow: hidden;
  font-size: 16px;
  color: #9f72ff;
  border-width: 3px;
  border-color: #9f72ff;
  border-style: solid;
  border-radius: 3px;
  transition: background-color 0.25s ease, color 0.25s ease;
  cursor: pointer;
  filter: drop-shadow(0px 10px 5px rgba(0, 0, 0, 0.25)); }
  .control-button.round {
    border-radius: 25px; }
  .control-button:hover {
    color: white; }
    .control-button:hover::before {
      transform: translate3d(-50%, -50%, 0) scale(1);
      opacity: 1; }
  .control-button::before {
    content: "";
    display: block;
    position: absolute;
    top: 50%;
    left: 50%;
    z-index: -1;
    opacity: 0;
    background-color: #9f72ff;
    width: 150%;
    height: 300%;
    border-radius: 50%;
    transform-origin: center;
    transform: translate3d(-50%, -50%, 0) scale(0);
    transition: all 0.4s ease; }

.screen {
  position: relative;
  width: 100vw; }

.section .section-headline, .section .section-subline {
  color: white; }
.section .section-headline {
  font-size: 58px; }
.section .section-subline {
  font-size: 20px; }

/* LAYOUT */
#header {
  position: fixed;
  top: 0;
  left: 0;
  z-index: 2;
  width: 100%;
  display: grid;
  transition: grid-template-rows 0.25s ease;
  grid-template-rows: 0 10px 50px 10px;
  height: 70px; }
  #header.funnel-active {
    grid-template-rows: 50px 10px 50px 10px;
    height: 120px; }
  #header.cookies-active #cookie-banner {
    height: 50px; }
  #header #cookie-banner {
    position: fixed;
    bottom: 0;
    left: 0;
    height: 0;
    width: 100vw;
    padding: 0 175px;
    transition: height 0.25s ease;
    display: grid;
    grid-template-columns: auto 1fr repeat(2, auto);
    grid-template-areas: "notice . agree disagree"; }
    #header #cookie-banner div {
      position: relative;
      align-self: center;
      top: 3px; }
    #header #cookie-banner div:first-child {
      grid-area: notice; }
    #header #cookie-banner #cookie-agree {
      grid-area: agree; }
    #header #cookie-banner #cookie-disagree {
      padding: 0 15px;
      grid-area: disagree; }
  #header #funnel {
    overflow: hidden;
    grid-area: f;
    display: grid;
    grid-template-columns: 30px 2fr 200px 1fr 200px 1fr 200px 2fr 30px;
    grid-template-areas: ". . telephone . delivery . expert-advice . close";
    align-items: center; }
    #header #funnel div {
      vertical-align: middle; }
      #header #funnel div svg, #header #funnel div span {
        display: inline-block;
        vertical-align: middle; }
      #header #funnel div svg {
        height: 18px;
        width: 18px; }
    #header #funnel #funnel-telephone {
      grid-area: telephone; }
    #header #funnel #funnel-delivery {
      grid-area: delivery; }
    #header #funnel #funnel-expert-advice {
      grid-area: expert-advice; }
    #header #funnel #funnel-close {
      grid-area: close; }
  @media (min-width: 801px) {
    #header {
      grid-template-columns: 175px 110px 1fr auto 1fr 110px 175px;
      grid-template-areas: "f f    f f   f f            f" ". .    . .   . .            ." ". logo . nav . social-media ." ". .    . .   . .            ."; }
      #header #funnel {
        padding: 0 175px; }
      #header #navigation {
        grid-area: nav;
        display: grid;
        grid-template-columns: repeat(3, auto);
        grid-template-rows: auto;
        grid-gap: 20px;
        height: 100%; }
        #header #navigation a {
          display: block;
          justify-self: center;
          align-self: center; }
      #header #social-media {
        grid-area: social-media;
        display: grid;
        grid-template-columns: repeat(3, 30px);
        grid-template-rows: auto;
        grid-gap: 10px;
        align-self: center; }
        #header #social-media .wrap {
          height: 30px;
          width: 30px; }
          #header #social-media .wrap img {
            width: 100%;
            height: 100%; }
      #header #header-options {
        display: none; } }
  @media (max-width: 800px) {
    #header {
      grid-template-columns: 70px 1fr 50px 1fr 50px 20px;
      grid-template-areas: "f f f    f f      f" ". . .    . .      ." ". . logo . option ." ". . .    . .      ."; }
      #header #funnel {
        padding: 0 70px; }
      #header #navigation {
        display: none; }
      #header #social-media {
        display: none; }
      #header #header-options {
        grid-area: option;
        position: relative; }
        #header #header-options.expanded div:nth-child(1) {
          transform: rotate(45deg);
          top: 25px; }
        #header #header-options.expanded div:nth-child(2) {
          opacity: 0; }
        #header #header-options.expanded div:nth-child(3) {
          transform: rotate(-45deg);
          top: 25px; }
        #header #header-options.expanded #menu {
          max-width: 300px; }
        #header #header-options .bar {
          position: absolute;
          left: 12.5px;
          width: 25px;
          height: 3px;
          transition: transform 0.25s linear, opacity 0.12s linear, top 0.25s linear; }
          #header #header-options .bar:nth-child(1) {
            top: 15px; }
          #header #header-options .bar:nth-child(2) {
            top: 23.5px; }
          #header #header-options .bar:nth-child(3) {
            top: 33px; }
        #header #header-options #menu {
          position: fixed;
          top: 70px;
          right: 0;
          z-index: 1;
          max-width: 0;
          transition: max-width 0.25s ease;
          width: 300px;
          height: calc(100vh - 70px);
          display: grid;
          grid-template-columns: 50px repeat(3, 1fr) 50px;
          grid-template-rows: repeat(4, 50px) auto repeat(2, 50px);
          grid-template-areas: ". .      .        .        ." ". home   home     home     ." ". config config   config   ." ". cart   cart     cart     ." ". .      .        .        ." ". insta  linkedin facebook ." ". .      .        .        ."; }
          #header #header-options #menu a:nth-child(1) {
            grid-area: home; }
          #header #header-options #menu a:nth-child(2) {
            grid-area: config; }
          #header #header-options #menu a:nth-child(3) {
            grid-area: cart; }
          #header #header-options #menu a:nth-child(4) {
            grid-area: insta; }
          #header #header-options #menu a:nth-child(5) {
            grid-area: linkedin; }
          #header #header-options #menu a:nth-child(6) {
            grid-area: facebook; }
          #header #header-options #menu .wrap {
            width: 50px;
            height: 50px; }
            #header #header-options #menu .wrap img {
              width: 100%;
              height: 100%; } }
  #header #logo {
    grid-area: logo;
    max-height: 100%; }
    #header #logo img {
      width: 100%;
      height: 100%; }

/* STYLE */
#header {
  background-color: #000; }
  #header #funnel, #header #cookie-banner {
    background-color: #0a0a0a; }
    #header #funnel div, #header #cookie-banner div {
      text-align: center;
      color: white; }
    #header #funnel #cookie-agree, #header #funnel #cookie-disagree, #header #cookie-banner #cookie-agree, #header #cookie-banner #cookie-disagree {
      text-decoration: underline; }
    #header #funnel #funnel-close, #header #funnel #cookie-agree, #header #funnel #cookie-disagree, #header #cookie-banner #funnel-close, #header #cookie-banner #cookie-agree, #header #cookie-banner #cookie-disagree {
      cursor: pointer; }
  #header #navigation a {
    color: white;
    font-size: 16px; }
    #header #navigation a:hover, #header #navigation a.active {
      color: #9f72ff; }
  #header #social-media .wrap {
    overflow: hidden;
    border-radius: 50%; }
  #header #header-options {
    background-color: #9f72ff;
    border-radius: 50%;
    cursor: pointer; }
    #header #header-options .bar {
      background-color: white; }
    #header #header-options #menu {
      font-size: 26px;
      color: #9f72ff;
      background-color: black; }
      #header #header-options #menu .wrap {
        border-radius: 50%; }

/* LAYOUT */
#data-policy-page #data-policy-screen {
  padding: 25px 10vw 150px; }

/* STYLE */
#data-policy-page #data-policy-screen {
  font-size: 18px;
  font-family: "Seido Regular";
  color: white; }
  #data-policy-page #data-policy-screen h1 {
    font-family: inherit;
    font-size: 56px; }

/* LAYOUT */
#imprint-page #imprint-screen {
  padding: 25px 10vw 150px; }

/* STYLE */
#imprint-page #imprint-screen {
  font-size: 18px;
  font-family: "Seido Regular";
  color: white; }
  #imprint-page #imprint-screen h1 {
    font-family: inherit;
    font-size: 56px; }
