.sidebar {
  position: fixed;
  top: 60px;
  /* 톱바 높이만큼 아래에서 시작 */
  left: 0;
  width: 200px;
  /* 사이드바 너비 */
  height: calc(100vh - 60px);
  background-color: #fff;
  border-right: 1px solid #e0e0e0;
  display: flex;
  flex-direction: column;
  z-index: 1000;
  transition: transform 0.3s ease-in-out;
  transform: translateX(0);
}

/* body에 .sidebar-collapsed 클래스가 있으면 사이드바를 왼쪽으로 숨김 */
body.sidebar-collapsed .sidebar {
  transform: translateX(-99%);
}

.sidebar-logo {
  height: 80px;
  /* 높이 조정 */
  display: flex;
  align-items: center;
  justify-content: center;
  border-bottom: 1px solid #e0e0e0;
  padding: 16px;
}

.sidebar-nav {
  list-style: none;
  margin-top: 16px;
  flex-grow: 1;
  overflow-y: auto;
  padding: 0 16px;
}

.sepline {
  border-color: #ffffff6b;
}

/*
.nav-item {
  margin-bottom: 8px; 
}
*/

.nav-link {
  display: flex;
  align-items: center;
  padding: 12px 16px;
  color: #333;
  text-decoration: none;
  border-radius: 8px;
  font-size: 14px;
  transition: background-color 0.2s ease, color 0.2s ease;
  margin-bottom: 5px;
}

.nav-link:hover {
  background-color: #f2f2f2;
}

.nav-link.active {
  background-color: #e8f0fe;
  color: #1a73e8;
}

.nav-icon {
  width: 20px;
  height: 20px;
  margin-right: 16px;
}

/* 모바일 메뉴 (기존 코드 유지) */
.sidebar-mobile-user-menu {
  display: block;
  margin-top: auto;
  padding: 4px;
  text-align: center;
  font-size: 9px;
  margin-bottom: 10px;
}

.sidebar-action-links {
  list-style: none;
  padding: 0;
  margin: 0;
}

.action-link {
  display: flex;
  align-items: center;
  padding: 12px 0;
  color: #333;
  text-decoration: none;
}

.action-icon {
  width: 20px;
  height: 20px;
  margin-right: 12px;
}



.sidebar-toggle {
  position: fixed;
  top: 225px;
  left: 182px;
  transform: translateY(-50%);
  z-index: 1001;
  width: 36px;
  height: 36px;
  background-color: #fff;
  border: 2px solid #8c9eff;
  border-radius: 50%;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 0;
  box-shadow: 0 2px 5px rgba(0, 0, 0, 0.1);
  transition: all 0.3s ease-in-out;
}

.sidebar-toggle:hover {
  background-color: #f2f2f2;
}

.sidebar-toggle svg {
  width: 30px;
  height: 30px;
  color: #2749ff;
  transition: transform 0.3s ease-in-out;
}

/* 사이드바가 닫혔을 때 (body.sidebar-collapsed) */
body.sidebar-collapsed .sidebar-toggle {
  left: -18px;
}

body.sidebar-collapsed .sidebar-toggle svg {
  transform: rotate(90deg);
}

@media (max-width: 768px) {
  .sidebar {
    transform: translateX(-100%);
    box-shadow: 1px 1px 5px rgb(0 14 249 / 23%);
    top: 50px;
    height: calc(100vh - 50px);
  }

  /* 모바일에서 body 클래스로 제어 (데스크탑과 동일) */
  body:not(.sidebar-collapsed) .sidebar {
    transform: translateX(0);
  }

  .sidebar-toggle {
    top: 215px;
  }
}