.contact,
.contact-flex {
  display: flex;
  flex: 1;
  column-gap: 1.5rem;
  justify-content: flex-start;
  align-items: center;
}

.contact-section {
  grid-template-columns: 1fr 1fr;
  grid-template-areas:
    "contact-image"
    "contact-details"
}

.contact-title-mobile {
  display: none;
}

@media (min-width: 1000px) {
  .contact-section {
    grid-template-columns: 1fr 1fr;
    grid-template-areas:
      "contact-image contact-details"
  }
}

.contact-text {
  grid-area: contact-text;
}

.contact-details {
  display: flex;
  flex-direction: column;
  align-items: start;
  justify-content: start;
  grid-area: contact-details;
}

.contact-details-text {
  width: 100%;
  text-align: start;
}

.contact-image {
  margin-bottom: 20px;
  margin-right: 1.5rem;
  justify-self: right;
  grid-area: contact-image;
}

.contact-image-footer {
  justify-self: left;
  grid-area: contact-image-footer;
}

.contact-details-footer {
  display: flex;
  flex-direction: column;
  align-items: end;
  justify-content: end;
  grid-area: contact-details;
}

.contact-martin {
  grid-template-columns: 1fr;
  grid-template-areas:
    "contact-text"
    "contact-button"
    "contact-details";
}

@media (min-width: 1000px) {
  .contact-martin {
    grid-template-columns: 1fr 1fr;
    grid-template-areas:
      "contact-text   contact-details"
      "contact-button contact-details";
  }
}

.drm-link {
  width: 60%;
}

@media (min-width: 1000px) {
  .drm-link {
    width: 100%;
  }
}

.drm-image {
  width: 100%;
  border-radius: 4px;
}

img.contact-image {
  width: 200px;
  height: 200px;
  border-radius: 50%;
  object-fit: cover;
}

img.contact-image-footer {
  width: 190px;
  height: 190px;
  border-radius: 50%;
  object-fit: cover;
}

.contact-button {
  justify-self: center;
  grid-area: contact-button;
}

@media (min-width: 550px) and (max-width: 999px) {
  .contact {
    flex-direction: column;
    row-gap: 2rem;
    align-items: flex-start;
  }

}

@media (max-width: 549px) {
  #kontakt>.grid {
    margin-bottom: 0;
  }

  .contact,
  .contact-flex {
    flex-direction: column;
    width: 100%;
  }

  .contact {
    grid-gap: 2rem;
  }

  .contact-title-mobile {
    display: block;
    padding-bottom: 1rem;
  }

  .contact-title {
    display: none;
  }

  .contact-image {
    margin-right: 0;
  }

  .contact-details {
    align-items: center;
    width: 100%;
  }

  .contact-details p {
    text-align: center;
  }
}