.contacts {
  display: grid;
  gap: 20px;
  grid-template-columns: repeat(auto-fill, minmax(300px, 1fr));
}

.contacts-card {
  background: var(--color-neutral-0);
  border-radius: var(--border-radius);
  box-shadow: var(--shadow);
  padding: 15px;
  line-height: 1.5;
  position: relative;

  h2 .fa {
    font-size: 1.5em;
    color: var(--color-green-dark);
    right: 20px;
    position: absolute;
  }
}

.contacts-second {
  margin-top: 20px;
  display: grid;
  gap: 20px;
  grid-template-columns: repeat(auto-fill, minmax(500px, 1fr));
}

.contacts, .contacts-second {
  .fa { cursor: auto; }
}

.google-maps {
  text-align: center;
  position: relative;
  width: 100%;
  padding-bottom: 56.25%;
  height: 0;
  overflow: hidden;

  iframe {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    border: 0;
  }
}

@media (max-width: 550px) {
  .google-maps {
    padding-bottom: 100%;
  }
  .contacts-second {
    grid-template-columns: repeat(auto-fill, minmax(300px, 1fr));
  }
}
