body {
  min-height: 100vh;
  display: flex;
  flex-direction: column;
}

main {
  flex: 1;
  overflow: hidden;
  padding: var(--spacing-6);
  position: relative;
}

.adress {
  position: absolute;
  top: var(--spacing-6);
  left: var(--spacing-6);
}

.links {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-0%, -50%);
  width: 38rem;
}

.text {
  font-family: var(--font-sans);
  font-size: var(--text-base);
  line-height: var(--leading-tight);

  margin-bottom: var(--spacing-3);
}

footer {
  width: 100%;
  height: 100%;
  pointer-events: none;
}

.svg-container {
  width: 100%;
  max-height: 30vh;
  pointer-events: auto;
}

.svg-desktop {
  display: block;
  position: absolute;
  bottom: var(--spacing-6);
  left: var(--spacing-6);
  right: var(--spacing-6);

  cursor: pointer;
}

.svg-desktop svg {
  display: block;
  width: 100%;
  height: 100%;
  max-height: 30vh;
  object-fit: contain;
}

.svg-mobile {
  display: none;
}

@media (hover: hover) and (min-width: 768px) {
  .svg-desktop .hover {
    opacity: 0;
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
  }

  .svg-desktop:hover .default {
    opacity: 0;
  }

  .svg-desktop:hover .hover {
    opacity: 1;
  }
}

@media screen and (max-width: 767px) {
  main {
    overflow-y: auto;
    margin: var(--spacing-4);
  }

  .adress {
    top: 0;
    left: 0;
  }

  .links {
    top: 25%;
    left: 0;
    transform: none;
    width: auto;
  }

  .svg-desktop {
    display: none;
  }

  .svg-mobile {
    display: block;
    position: absolute;
    top: 50%;
    left: 0;
    width: 100%;
    transform: translateY(-50%);

    z-index: -1;
  }

  .svg-mobile svg {
    max-width: 100%;
    max-height: 50vh;
    width: 100%;
    height: auto;
  }
}

/* Bio content */
.bio-content {
  display: none;
}

.bio-content .bio-text {
  position: absolute;
  top: var(--spacing-6);
  left: 50%;
  width: 38rem;
}

.bio-image {
  position: absolute;
  width: 400px;
  top: 12rem;
  left: var(--spacing-6);

  z-index: 10;
}

@media screen and (min-width: 768px) and (max-width: 1024px) {
  .bio-image {
    display: none;
  }
}

@media screen and (max-width: 45rem) {
  .bio-content .text {
    top: calc(50% + 3rem);
    left: 0;
    width: auto;
    transform: none;
  }

  .bio-image {
    display: none;
  }
}
