main {
  display: grid;
  grid-template-rows: 1fr auto;
}

.hero {
  display: flex;
  flex-direction: column;
  align-items: center;

  background-color: var(--color-primary-300);
  color: var(--color-on-primary);

  padding: var(--p-8);

  text-align: center;
}

.hero .content {
  display: grid;
  justify-items: center;
  width: min(100%, 580px);
  margin: auto 0;
}

.hero .content h1 {
  font-size: 3rem;
  font-weight: 7000;
  margin-top: 0;
  margin-bottom: var(--p-4);
}

.hero .content p {
  margin-top: 0;
  margin-bottom: var(--p-8);
}

.hero .content .button-holder {
  display: flex;
  align-items: center;
  gap: var(--p-2);
}
