.section-publication_banner_with_text {
  border-bottom: 1px solid var(--black);
}
.section-publication_banner_with_text .container {
  display: flex;
  flex-wrap: wrap;
}
.section-publication_banner_with_text .container .image {
  width: 50%;
  border-right: 1px solid var(--black);
  padding: 50px;
}
.section-publication_banner_with_text .container .image img {
  display: block;
  width: 100%;
  aspect-ratio: 0.9;
  -o-object-fit: cover;
     object-fit: cover;
}
.section-publication_banner_with_text .container .content {
  width: 50%;
  padding: 50px;
}
.section-publication_banner_with_text .container .content h1 {
  margin-bottom: 25px;
}
.section-publication_banner_with_text .container .content :not(.buttons) a {
  color: var(--primary);
  font-weight: 400;
  text-decoration: underline;
}
.section-publication_banner_with_text .container .content :not(.buttons) a:hover {
  color: var(--black) !important;
}
.section-publication_banner_with_text .container .content .buttons {
  margin-top: 25px;
}

@media (max-width: 820px) {
  .section-publication_banner_with_text .container .image {
    width: 100%;
    border-right: 0;
    border-bottom: 1px solid var(--black);
    padding: 25px;
  }
  .section-publication_banner_with_text .container .image img {
    max-height: 500px;
    width: unset;
  }
  .section-publication_banner_with_text .container .content {
    width: 100%;
    padding: 25px;
  }
}
@media (max-width: 600px) {
  .section-publication_banner_with_text .container .image, .section-publication_banner_with_text .container .content {
    padding: 20px 0;
  }
}
/*

Publication Styles

*/
main[pub_style=blue] .section-publication_banner_with_text h1 {
  color: var(--blue);
}
main[pub_style=blue] .section-publication_banner_with_text .content :not(.buttons) a {
  color: var(--blue);
}

main[pub_style=green] .section-publication_banner_with_text h1 {
  color: var(--green);
}
main[pub_style=green] .section-publication_banner_with_text .content :not(.buttons) a {
  color: var(--green);
}

main[pub_style=red] .section-publication_banner_with_text h1 {
  color: var(--red);
}
main[pub_style=red] .section-publication_banner_with_text .content :not(.buttons) a {
  color: var(--red);
}

/*

Scroll Animations

*/
.section-publication_banner_with_text .container {
  margin-top: -50px;
  opacity: 0;
  transition: all 1s;
}
.section-publication_banner_with_text.scrolled-to .container {
  margin-top: 0;
  opacity: 1;
}