.site-footer {
  background: #000;
  color: var(--color-white);
  font-size: 0.8rem;

  a {
    color: var(--color-blue);
    text-decoration: none;
    &:is(:hover, :focus) {
      color: var(--color-blue);
      text-decoration: underline;
    }
  }

  h2 {
    font-size: 1rem;
  }
}

.site-footer-main {
  padding-top: var(--vertical-padding);
  display: grid;
  grid-gap: 1rem;

  .block-system-menu-block--footer {
    grid-area: menu;
    a {
      padding-left: 0;
      padding-right: 0;
    }
  }

  .block-social-links-block {
    grid-area: socials;
  }

  #block-pi-theme-copyrightblock {
    grid-area: support;
    font-size: .7rem;
  }

  #block-pi-theme-footercontactus {
    grid-area: contact;
  }
}

@media (min-width: 960px) {
  .site-footer-main {
    grid-template-columns: repeat(4, 1fr);
    grid-gap: 1rem 2rem;
    grid-template-areas:
      "branding contact menu socials"
      "support contact menu socials";

    .site-branding {
      grid-area: branding;
    }

    h2 {
      margin-bottom: 1.2rem;
    }
  }
}

@media (max-width: 960px) {
  .site-footer-main {
    grid-template-rows: repeat(4, minmax(2rem, auto));
    grid-template-columns: 1fr 1fr;
    grid-template-areas:
      "branding branding"
      "contact contact"
      "menu socials"
      "support support";

    .site-branding {
      margin: 1rem 0;
    }
  }


}

.site-footer-logos {
  display: flex;
  align-items: center;
  gap: 0.5rem;
  margin: 0 auto;
  max-width: var(--max-width);
  padding: 2rem var(--responsive-padding) 3rem;
  img {
    width: 5rem;
  }
}

.site-footer-bottom {
  background: #000;
  border-top: 1px solid var(--color-grey-dk);
  padding: 1rem var(--responsive-padding);

  .block {
    max-width: var(--max-width);
    margin: 0 auto;
  }

  a {
    text-decoration: none;
  }
}
