html,
  body {
    min-height: 100%;
  }

  body {
    min-height: 100vh;
    display: flex;
    flex-direction: column;
  }

  body > main {
    flex: 1 0 auto;
  }

  body > .source-footer {
    flex-shrink: 0;
  }

  body > .source-footer,
  .source-footer {
    margin: 5px 0 0 !important;
    padding: 5px 0 !important;
  }

  .source-footer * {
    box-sizing: border-box;
  }

  .source-footer-main {
    width: 80vw !important;
    max-width: 1280px !important;
    min-width: 960px !important;
    margin: 0 auto !important;
    padding: 0 5px !important;
    display: flex !important;
    align-items: flex-start !important;
    justify-content: space-between !important;
    gap: 5px !important;
  }

  .source-footer-brand,
  .source-footer-links,
  .source-footer-links > div,
  .source-footer-icons {
    margin: 0 !important;
    padding: 0 !important;
  }

  .source-footer-brand {
    max-width: 360px !important;
  }

  .source-footer-brand span,
  .source-footer-links h4 {
    display: block !important;
    margin: 0 0 5px !important;
    padding: 0 !important;
  }

  .source-footer-brand p,
  .source-footer-copy p {
    margin: 0 !important;
    padding: 0 !important;
  }

  .source-footer-links {
    display: grid !important;
    grid-template-columns: repeat(3, minmax(0, 1fr)) !important;
    gap: 5px !important;
  }

  .source-footer-links ul {
    margin: 0 !important;
    padding: 0 !important;
    list-style: none !important;
  }

  .source-footer-links li {
    margin: 0 0 5px !important;
    padding: 0 !important;
  }

  .source-footer-links li:last-child {
    margin-bottom: 0 !important;
  }

  .source-footer-links a {
    display: inline-flex !important;
    align-items: center !important;
    margin: 0 !important;
    padding: 0 !important;
    min-height: 0 !important;
  }

  .source-footer-icons {
    display: flex !important;
    gap: 5px !important;
  }

  .source-footer-icons > div {
    margin: 0 !important;
    padding: 0 !important;
  }

  .source-footer-copy {
    width: 80vw !important;
    max-width: 1280px !important;
    min-width: 960px !important;
    margin: 5px auto 0 !important;
    padding: 5px 5px 0 !important;
  }

  @media (max-width: 767px) {
    .source-footer-main,
    .source-footer-copy {
      width: 100% !important;
      min-width: 0 !important;
      max-width: none !important;
    }

    .source-footer-main {
      flex-direction: column !important;
    }

    .source-footer-brand {
      width: 100% !important;
      max-width: none !important;
    }

    .source-footer-links {
      width: 100% !important;
      grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
    }
  }
