@import url('https://fonts.googleapis.com/css?family=Roboto:400,700');

html,
body {
  margin: 0;
  padding: 0;
  font-family: 'Roboto', sans-serif;
}

h1 {
  margin-bottom: 0;
}

p {
  margin-top: 0;
}

img {
  display: block;
  width: 100%;
  padding-bottom: 1em;
}

.header,
.main,
.footer {
  max-width: 1200px;
  margin: 0 auto;
  padding: 1em;
}

.footer {
  display: grid;
  grid-template-columns: 1fr 80vw 1fr;
  grid-template-rows: repeat(2, auto);
}

.footer__image {
  grid-column: 2;
}

.footer__text {
  grid-column: 2;
  justify-self: center;
}

@media (min-width: 768px) {
  .main {
    display: grid;
    grid-gap: 1em;
    grid-template-columns: auto auto;
    grid-template-rows: repeat(3, auto);
  }

  .main__image {
    grid-column: 2;
    grid-row: 1 / span 3;

    display: grid;
    -webkit-box-align: end;
        -ms-flex-align: end;
            align-items: end;
  }

}

@media (min-width: 1028px) {
  .main {
    grid-template-columns: repeat(3, auto);
  }

  .main__image {
    grid-row: 1;
  }
}