/* ===== 🍔 햄버거 버튼 ===== */
.menu-btn {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 40px;   /* 고정 폭 */
  height: 40px;  /* 클릭 영역 확대 */
  font-size: 28px;
  cursor: pointer;
  transition: transform 0.3s ease;
  user-select: none;
}

/* ===== 모바일 메뉴 ===== */
.mobile-menu {
  position: fixed;
  top: 50px; /* ✅ 헤더 아래에서 시작 */
  right: -50px; /* ✅ 오른쪽에서 시작 */
  width: 0; /* ✅ 기본 상태에서는 가로 0 */
  height: calc(100vh - 100px);
  background: #fff;
  overflow-x: hidden;
  overflow-y: auto;
  box-shadow: -2px 0 15px rgba(0,0,0,0.2);
  transition: width 0.4s ease;
  z-index: 9999;
  padding: 25px;
  border-radius: 12px 0 0 0;
}

/* ✅ 열릴 때: 전체 화면 너비 */
.mobile-menu.open {
  width: 100%; /* 전체 화면 덮기 */
}

/* 닫기 버튼 */
.mobile-menu .close {
  text-align: right;
  font-size: 24px;
  cursor: pointer;
  margin-bottom: 20px;
}

/* 배경 오버레이 */
.overlay {
  display: none;
  position: fixed;
  top: 0; left: 0;
  width: 100%; height: 100%;
  background: rgba(0,0,0,0.4);
  z-index: 9998;
}

.overlay.open {
  display: block;
}

/* 반응형: 모바일 전용 */
@media (min-width: 961px) {
  .mobile-menu, .overlay { display: none !important; }
}




.mobile-menu .menu-list {
  list-style: none;
  margin: 0;
  padding: 0;
}

.mobile-menu .menu-list > li {
  margin-bottom: 10px;
}

.mobile-menu .menu-list > li > a {
  font-size: 17px;
  font-weight: 700;
  display: block;
  padding: 10px 0;
  border-bottom: 1px solid #eee;
  color: #111;
  text-decoration: none;
}

.mobile-menu .submenu {
  list-style: none;
  margin: 5px 0 10px 10px;
  padding: 0;
}

.mobile-menu .submenu a {
  font-size: 15px;
  color: #444;
  display: block;
  padding: 6px 0;
  text-decoration: none;
}

.mobile-menu .submenu a:hover {
  color: #1d64ff;
}