@media (min-height: 950px) {
  footer {
    position: fixed;
    bottom: 0;
    width: 100%;
  }
}

main {
  width: calc(100% - 2rem);
  max-width: 1280px;
  margin-inline: auto;
  margin-bottom: 1rem;

  display: grid;
  grid-template-rows: repeat(40, 16px);
  grid-template-columns: repeat(auto-fill, 16px);
}

#headshot {
  aspect-ratio: 1 / 1;
  align-self: start;
  justify-self: center;

  grid-column: 1 / -1;
  grid-row: 2 / -1;
  border-radius: var(--radius-5);
  margin-inline: auto;
  box-shadow: var(--shadow-2);
}

.blob {
  display: flex;
  flex-direction: column;
  justify-content: center;

  font-size: var(--fs-3);
  text-align: center;

  border-radius: var(--radius-4);
  box-shadow: var(--shadow-2);
  padding-block: 0.5rem;

  &>* {
    margin: 0;
  }
}

.blob-1 {
  --width: span 18;
  --height: span 10;
  grid-column: 2 / var(--width);
  grid-row: 6 / var(--height);
}

.blob-2 {
  --width: span 15;
  --height: span 7;
  grid-column: var(--width) / -1;
  grid-row: 5 / var(--height);

  padding-inline: 0.5rem;
}

.blob-3 {
  --width: span 17;
  --height: span 9;

  z-index: -1;
  grid-column: var(--width) / -6;
  grid-row: 21 / var(--height);

  padding: 2rem;
}

.blob-4 {
  --width: span 16;
  --height: span 6;

  grid-column: 6 / var(--width);
  grid-row: 30 / var(--height);

  padding-inline: 2rem;
}

.blob-5 {
  --width: span 14;
  --height: span 7;

  grid-column: -28 / var(--width);
  grid-row: 1 / var(--height);
}

.blob-6 {
  --width: span 13;
  --height: span 7;

  grid-column: -34 / var(--width);
  grid-row: 32 / var(--height);
}

.blob-7 {
  --width: span 12;
  --height: span 9;

  grid-column: 17 / var(--width);
  grid-row: 20 / var(--height);
}

@media (max-width: 80rem) {
  .blob-3 {
    z-index: auto;
  }
}

@media (max-width: 63.5rem) {
  main {
    grid-template-rows: repeat(80, 16px);
  }

  .blob-1 {
    grid-column: 2 / span 12;
    grid-row: 26 / span 9;
  }

  .blob-2 {
    grid-column: -12 / -1;
    grid-row: 33 / var(--height);
  }

  .blob-3 {
    grid-row: 41 / var(--height);
  }

  .blob-4 {
    grid-column: 1 / 16;
    grid-row: 55 / var(--height);
  }


  .blob-5 {
    grid-column: -13 / var(--width);
    grid-row: 20 / var(--height);
  }

  .blob-6 {
    --height: span 7;
    z-index: -1;
    grid-column: -16 / span 14;
    grid-row: 49 / var(--height);
  }

  .blob-7 {
    --height: span 7;
    grid-column: 12 / span 14;
    grid-row: 60 / var(--height);
  }

}
