.footer {
  margin-top: 100px;
}

.footer-top {
  padding: 75px 0;
  background-color: var(--color-light);
  color: var(--color-primary);

  .container {
    display: flex;
    gap: 30px;
  }
}

.footer-top-brand {
  flex: 1 1 40%;
  img {
    width: 250px;
  }
}

.footer-top-opening-hours, .footer-top-contact {
  flex: 1 1 30%;

  font-size: 18px;
  line-height: 25px;

  h2 {
    font-size: 25px;
    margin-bottom: 15px;
  }
}

.footer-top-contact-details {
  display: flex;
  flex-direction: column;
  gap: 5px;

  a {
    display: flex;
    align-items: center;
    gap: 5px;
    text-decoration: none;

    svg {
      flex: 0 0 25px;
    }

    &:hover, &:focus {
      opacity: 0.7;
    }
  }
}

.footer-bottom {
  padding: 15px 0;
  font-size: 16px;

  .container {
    display: flex;
    justify-content: space-between;
  }

  a {
    text-decoration: none;

    &:hover, &:focus {
      color: var(--color-primary);
    }
  }
}

.footer-bottom-links {
  display: flex;
  gap: 15px;
}
