.custom-banner-layout {
  display: flex;
  flex-direction: column;
  min-height: 100vh;
}

.banner {
  background-size: contain;
  background-size: 100% auto;
  width: 100%;
}

/* Header banner */
.header-banner {
  background-image: url("/img/banner/h2_medium.webp");
  background-repeat: no-repeat;
  background-position: top center;
  background-size: contain;
  width: 250px;
  height: auto;
  aspect-ratio: 5 / 1;
  margin: 0 auto;
  min-height: 0;
  display: block;
  padding: 0;
}

/* Footer banner */
.footer-banner {
  background-image: url("/img/banner/h2_medium.webp");
  background-repeat: no-repeat;
  background-position: top center;
  background-size: contain;
  width: 250px;
  height: auto;
  aspect-ratio: 5 / 1;
  margin: 0 auto;
  min-height: 0;
  display: block;
  padding: 0;
}

.content-row {
  display: flex;
  flex-grow: 1;
}

/* Side banners that repeat vertically */
.side-banner {
  background-repeat: repeat-y;
  background-position: center top;
  flex-shrink: 0;
  width: 50px;
}

.left-banner {
  background-image: url("/img/banner/h3l_medium.webp");
}

.right-banner {
  background-image: url("/img/banner/h3r_medium.webp");
}

.main-content {
  flex-grow: 1;
  padding: 2rem;
  overflow: hidden;
}
