.footer__menu {
  position: relative;
}

.footer__menu-title {
  display: inline-flex;
  gap: 10px;
  align-items: center;
  justify-content: space-between;
  font-weight: bold;
}

.footer__menu-title .icon__arrow,
.footer__menu-title .icon__minus {
  display: none;
}

@media (max-width: 959px) {
  .footer__menu-title {
    padding-block-start: 15px;
  }

  .footer__menu-title .icon__arrow {
    display: inline;
  }

  .footer__menu-title .icon__minus {
    display: none;
  }
}

.footer__menu-item {
  padding-block-start: 15px;
}

.footer__menu-item a {
  display: block;
}

.footer__menu-item--active a {
  text-decoration: underline;
  text-underline-offset: 6px;
}

.footer__menu-item--active a:hover {
  text-decoration: underline;
}

@media (max-width: 959px) {
  .footer__menu-content {
    height: 0;
    padding-block-end: 15px;
    overflow: hidden;
    opacity: 0;
  }
}

.footer__menu::after {
  position: absolute;
  inset-block-end: 0;
  inset-inline-start: 0;
  display: none;
  width: 100%;
  height: 1px;
  content: "";
  background-color: rgba(var(--color-text), 0.1);
}

@media (max-width: 959px) {
  .footer__menu::after {
    display: block;
  }
}

@media (max-width: 959px) {
  .footer__menu[open] .footer__menu-title .icon__arrow {
    display: none;
  }

  .footer__menu[open] .footer__menu-title .icon__minus {
    display: inline;
  }
}

.footer__menu[open] .footer__menu-content {
  height: auto;
  opacity: 1;
}
.footer__custom-text-title {
  padding-block-end: 15px;
  font-weight: bold;
}
@media (max-width: 959px) {
  .footer__custom-text-title {
    padding-block-start: 15px;
  }
}
.footer__email-subscribe-title {
  margin-block-end: 15px;
  font-weight: bold;
}
@media (min-width: 960px) {
  .footer__email-subscribe--small .footer__email-subscribe-title {
    font-size: var(--body3-font-size);
  }

  .footer__email-subscribe--small .field__label {
    font-size: var(--body4-font-size);
  }

  .footer__email-subscribe--small .field__input {
    padding-block-start: 16px;
    font-size: var(--body3-font-size);
  }
  .footer__email-subscribe--middle .footer__email-subscribe-title {
    font-size: var(--body2-font-size);
  }

  .footer__email-subscribe--middle .field__label {
    font-size: var(--body3-font-size);
  }

  .footer__email-subscribe--middle .field__input {
    padding-block: 20px 2px;
    font-size: var(--body2-font-size);
  }
  .footer__email-subscribe--large .footer__email-subscribe-title {
    font-size: var(--body1-font-size);
  }

  .footer__email-subscribe--large .field__label {
    font-size: var(--body2-font-size);
  }

  .footer__email-subscribe--large .field__input {
    padding-block: 30px 19px;
    font-size: var(--body1-font-size);
  }

  .footer__email-subscribe--large .field__input:focus ~ .field__label,
  .footer__email-subscribe--large
    .field__input:not(:placeholder-shown)
    ~ .field__label,
  .footer__email-subscribe--large
    .field__input:-webkit-autofill
    ~ .field__label {
    transform: scale(0.7) translate(0, -150%);
  }
}
.footer__image img {
  width: 100%;
  max-width: 100%;
  height: 100%;
  max-height: 100%;
  vertical-align: bottom;
}
.footer__localization-form .localization__selector:nth-last-of-type(2) {
  margin-block-end: 10px;
  margin-inline-end: 15px;
}
.footer__localization-form form {
  display: contents;
}
@media (max-width: 959px) {
  .footer__localization-form .localization__selector {
    width: 100%;
  }

  .footer__localization-form .localization__selector:nth-last-of-type(2) {
    margin-block-end: 6px;
    margin-inline-end: 0;
  }
}
.footer__payment-icons > svg {
  width: auto;
  height: 22px;
}
.footer__social-media-title {
  padding-block-end: 20px;
  font-weight: bold;
}
.footer__social-media-content {
  display: inline-flex;
  flex-wrap: wrap;
  gap: 12px;
}
.footer__social-media-content svg,
.footer__social-media-content img {
  width: 24px;
  height: 24px;
}
.footer__social-media-content img {
  border-radius: 100%;
}
@media (min-width: 960px) {
  .footer__social-media--small .footer__social-media-title {
    font-size: var(--body3-font-size);
  }

  .footer__social-media--small .footer__social-media-content {
    gap: 8px;
  }

  .footer__social-media--small .footer__social-media-content svg,
  .footer__social-media--small .footer__social-media-content img {
    width: 28px;
    height: 28px;
  }
  .footer__social-media--middle .footer__social-media-title {
    font-size: var(--body2-font-size);
  }

  .footer__social-media--middle .footer__social-media-content {
    gap: 16px;
  }

  .footer__social-media--middle .footer__social-media-content svg,
  .footer__social-media--middle .footer__social-media-content img {
    width: 32px;
    height: 32px;
  }
  .footer__social-media--large .footer__social-media-title {
    font-size: var(--body1-font-size);
  }

  .footer__social-media--large .footer__social-media-content {
    gap: 16px;
  }

  .footer__social-media--large .footer__social-media-content svg,
  .footer__social-media--large .footer__social-media-content img {
    width: 64px;
    height: 64px;
  }
}
.footer__copyright-menu a {
  word-break: break-all;
}
.footer__copyright-menu span {
  padding: 0 10px;
}
.footer__copyright-menu span:last-child {
  display: none;
}
.footer {
  background-color: rgb(var(--color-background));
}

/* 데스크톱(960px 이상)에서 약관 및 메뉴 항목들을 가로 한 줄로 배치 */
@media (min-width: 960px) {
    .footer__menu-content {
        display: flex;
        flex-direction: row;
        flex-wrap: wrap;
        gap: 30px;
        /* 약관 사이의 간격입니다. 필요에 따라 숫자를 조절하세요 */
    }

    /* 기존 세로형 배치일 때 들어가던 위쪽 여백(15px) 초기화 */
    .footer__menu-item {
        padding-block-start: 0;
    }

    /* 이메일 등 텍스트가 들어가는 부분도 가로 흐름에 맞게 여백 조정 */
    .footer__custom-text-title,
    .footer__menu-title {
        padding-block-end: 10px;
    }

    /* 전체 푸터 내용을 가운데로 정렬 (선택사항) */
    .footer__inner {
        display: flex;
        flex-direction: column;
        align-items: center;
        text-align: center;
    }

    .footer__menu-content {
        justify-content: center;
    }
}

/* --- 모바일(959px 이하) 푸터 디자인 덮어쓰기 --- */
@media (max-width: 959px) {

    /* 1. 메뉴 내용을 항상 펼쳐진 상태로 고정 (열고 닫기 기능 무효화) */
    .footer__menu-content {
        height: auto !important;
        opacity: 1 !important;
        overflow: visible !important;
    }

    /* 2. 제목 옆에 붙어있던 열기(화살표)/닫기(마이너스) 아이콘 완전히 숨김 */
    .footer__menu-title .icon__arrow,
    .footer__menu-title .icon__minus {
        display: none !important;
    }

    /* 3. 모바일 메뉴 하단에 생기던 구분선(Divider) 제거 */
    .footer__menu::after {
        display: none !important;
    }
}