#campaign-timeline .event {
  position: relative;
  padding-block: 1rem;
  padding-inline-start: 3rem;
}
#campaign-timeline .event::before {
  content: "";
  position: absolute;
  width: 2px;
  top: 0;
  bottom: 0;
  left: 1.5rem;
  transform: translateX(-50%);
  background-color: var(--gold);
}
#campaign-timeline .event::after {
  content: "";
  position: absolute;
  width: 0.5rem;
  height: 0.5rem;
  top: 50%;
  left: 1.5rem;
  transform: translate(-50%, -50%);
  background-color: var(--gold);
  border-radius: 50%;
  outline: 2px solid var(--gold);
  outline-offset: 2px;
}
#campaign-timeline .event .h5 {
  max-width: 30ch;
}
#campaign-timeline .gold-bar {
  margin: 1rem 5rem;
  padding-inline-start: 1rem;
  border-inline-start: 0.5rem solid var(--gold);
}
@media (width >= 48em) {
  #campaign-timeline .event {
    padding-inline-start: 0;
  }
  #campaign-timeline .event::before {
    left: 50%;
  }
  #campaign-timeline .event::after {
    left: 50%;
  }
  #campaign-timeline :nth-child(odd of .event) {
    flex-direction: row-reverse;
    text-align: right;
  }
  #campaign-timeline :nth-child(odd of .event) .h5 {
    margin-inline-start: auto;
  }
}