
.footer {
  background-color: var(--ac);
}
.footer a:hover {
  opacity: 0.5;
}
.footer__img {
  display: none;
  width: 45%;
}
@media (min-width: 992px) {
  .footer__img {
    display: block;
  }
}
.footer__img img {
  height: 100%;
}
.footer__inner {
  flex: 1;
  padding-block: 60px 20px;
  padding-inline: clamp(20px, 6vw, 80px);
}
.footer__logo {
  margin-bottom: 15px;
}
.footer__logo a {
  flex-direction: column;
  align-items: center;
  text-align: center;
}
@media (min-width: 576px) {
  .footer__logo a {
    flex-direction: row;
    align-items: baseline;
    text-align: left;
  }
}
.footer__logo a h2 {
  font-size: clamp(1.5rem, 1.014rem + 2.1vw, 3rem);
}
.footer__logo a > p {
  font-size: clamp(1rem, 0.838rem + 0.7vw, 1.5rem);
}
.footer__wrap {
  max-width: 700px;
  margin-inline: auto;
  flex-direction: column;
  gap: 40px;
  margin-bottom: 22px;
}
@media (min-width: 576px) {
  .footer__wrap {
    flex-direction: row;
    gap: 55px;
  }
}
.footer__left, .footer__right {
  flex: 1;
}
.footer .dl:not(:last-child) {
  margin-bottom: 40px;
}
@media (min-width: 576px) {
  .footer .dl:not(:last-child) {
    margin-bottom: 50px;
  }
}
.footer .dt {
  display: flex;
  align-items: center;
  gap: 10px;
  font-size: clamp(1.125rem, 1.004rem + 0.53vw, 1.5rem);
  line-height: 1.7;
  margin-bottom: 5px;
}
.footer .dt::after {
  content: "";
  display: block;
  width: 100%;
  height: 1px;
  flex: 1;
  background-color: var(--txt);
}
.footer .dd {
  line-height: 1.4;
}
.footer__nav {
  display: flex;
  flex-direction: column;
  gap: 15px;
}
.footer .btn-wrap a:hover {
  opacity: 1;
}
.footer .copyright {
  margin-top: auto;
  font-size: 0.875rem;
  text-align: center;
}
@media (min-width: 576px) {
  .footer .copyright {
    text-align: right;
  }
}