body {
  background: black;
  box-sizing: border-box;
  font-family: Georgia;
  max-width: 1200px;
  margin: 0 auto;
  padding: 0 0;
}

.box {
  background: white;
  border-radius: 1rem;
  box-sizing: border-box;
  margin: 0 auto;
  padding: 1rem;
}

.box> :first-child {
  margin-top: 0;
}

.box> :last-child {
  margin-bottom: 0;
}

.col-1 {
  display: grid;
  grid-row-gap: 1rem;
}

.col-2 {
  display: grid;
  grid-row-gap: 1rem;
}

.col-3 {
  display: grid;
  grid-row-gap: 1rem;
}

.frame {
  background: lightskyblue;
  box-sizing: border-box;
  display: grid;
  grid-column-gap: 1rem;
  grid-row-gap: 1rem;
  grid-template-columns: minmax(auto, 35rem);
  margin: 0 auto;
  max-width: 37rem;
  padding: 1rem;
}

footer,
header,
nav {
  text-align: center;
}

ul {
  padding-left: 1rem;
}

@media (min-width: 56rem) {

  .frame {
    grid-template-columns: 18rem minmax(auto, 35rem);
    max-width: 56rem;
  }

  .col-1 {
    display: grid;
    grid-column: 1;
    grid-template-rows: auto auto auto;
  }

  .col-2 {
    display: block;
    grid-column: 2;
    grid-row: 1 / 4;
  }

  .col-3 {
    display: block;
    grid-column: 1;
    grid-row: 2;
  }

}

@media (min-width: 75rem) {

  .frame {
    grid-template-columns: 18rem minmax(auto, 35rem) 18rem;
    max-width: 75rem;
  }

  .col-1 {
    display: grid;
    grid-column: 1;
    grid-row: 1;
    grid-template-rows: auto auto auto 1fr;
  }

  .col-2 {
    display: block;
    grid-column: 2;
    grid-row: 1;
  }

  .col-3 {
    display: block;
    grid-column: 3;
    grid-row: 1;
  }

}
