* {
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale; }

.banner {
  display: flex;
  flex-direction: column;
  justify-content: flex-start;
  align-items: center;
  flex-wrap: nowrap;
  padding: 0 0;
  margin-bottom: 0; }
  .banner-title {
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: flex-start;
    flex-wrap: nowrap; }
    .banner-title h1 {
      font-size: 48px ;
      font-size: 3rem ;
      margin-bottom: 24px;
      line-height: 125%;
      color: #1D1D1B;
      font-weight: normal; }
    .banner-title h2 {
      font-size: 24px ;
      font-size: 1.5rem ;
      font-style: normal;
      font-weight: 400;
      color: rgba(29, 29, 27, 0.64);
      margin-bottom: 32px;
      line-height: 125%; }
  .banner-image {
    width: 50%;
    max-width: 50%;
    height: 700px;
    background-repeat: no-repeat;
    background-size: cover; }
    .banner-image img {
      width: 100%; }
    .banner-image--mobile {
      display: none; }

@media (max-width: 960px) {
  .banner {
    margin-top: 104px;
    height: auto; }
    .banner-title {
      align-items: center;
      order: 1;
      height: 100%;
      width: 100%; }
      .banner-title h1 {
        font-size: 28px ;
        font-size: 1.75rem ;
        width: 100%;
        text-align: center;
        margin-bottom: 16px; }
      .banner-title h2 {
        font-size: 20px ;
        font-size: 1.25rem ;
        text-align: center;
        margin-bottom: 32px; }
    .banner-content {
      display: flex;
      flex-direction: column;
      justify-content: center;
      align-items: center;
      flex-wrap: nowrap; }
    .banner-image {
      order: 0;
      margin-bottom: 32px;
      width: 100%;
      max-width: 100%;
      height: 100%; }
      .banner-image img {
        object-fit: cover; }
      .banner-image--mobile {
        display: block;
        width: 100%;
        object-fit: cover; } }
