/* Sidebar Toggle Button */
.sidebar-toggle {
  position: fixed;
  top: 8px; /* align closer to top */
  /* place just outside the sidebar to the right of it, small gap */
  left: calc(var(--sidebar-width, 260px) + 6px);
  right: auto;
  background: rgba(255, 184, 77, 0.1);
  border: 1px solid rgba(255, 184, 77, 0.3);
  color: var(--accent);
  width: 36px;
  height: 36px;
  border-radius: 8px;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: all 0.3s ease;
  z-index: 1000;
}

.sidebar-toggle:hover {
  background: rgba(255, 184, 77, 0.2);
  transform: scale(1.1);
}

.toggle-icon {
  font-size: 20px;
  transition: transform 0.3s ease;
}

/* Sidebar menu items structure */
.sidebar-menu a {
  display: flex;
  align-items: center;
  gap: 12px;
}

.sidebar-menu a .icon {
  min-width: 24px;
  text-align: center;
  font-size: 1.2rem;
}

.sidebar-menu a .text {
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

/* Sidebar collapsed state */
.sidebar-collapsed .site-sidebar {
  width: 70px !important;
}

/* Ensure the main content inherits the smaller sidebar width when collapsed */
body.sidebar-collapsed {
  --sidebar-width: 70px;
}

/* Ensure main content uses the CSS variable for layout and aligns with header padding */
body.sidebar-collapsed main,
body.sidebar-collapsed .main-wrapper > main,
body.sidebar-collapsed #main {
  margin-left: var(--sidebar-width);
  width: calc(100% - var(--sidebar-width));
}

/* Reduce left padding inside admin container so content aligns with header */
body.sidebar-collapsed .admin-container {
  padding-left: 24px;
  padding-right: 32px;
}

/* Give calendar more space when collapsed */
body.sidebar-collapsed .calendar-container {
  grid-template-columns: 1fr 320px; /* bigger main column */
  width: 100%;
  max-width: none;
}

/* When collapsed: hide the legend and force the calendar grid to use full width */
/* Restore legend but reduce its width when sidebar is collapsed; give calendar main column more space */
body.sidebar-collapsed .calendar-container {
  grid-template-columns: 1fr 260px !important;
  gap: 16px;
}

body.sidebar-collapsed .calendar-legend {
  display: block !important;
  width: 260px !important;
  max-width: 260px !important;
  padding: 12px !important;
  box-sizing: border-box;
  max-height: calc(100vh - 220px);
  overflow-y: auto;
}

body.sidebar-collapsed .calendar-grid {
  width: 100% !important;
  max-width: none !important;
}

/* Ensure admin container padding aligns with header left edge when collapsed */
body.sidebar-collapsed .admin-container {
  padding-left: 32px;
}

/* Align calendar header and container with the top header area */
.calendar-nav,
.calendar-container,
.settings-card {
  margin-left: 0; /* rely on main padding for alignment */
}

/* In collapsed state, keep toggle just to the right of the smaller sidebar */
.sidebar-collapsed .sidebar-toggle {
  left: calc(var(--sidebar-width, 70px) + 6px);
}

/* Make sure the toggle is visually attached to the sidebar's top-right edge */
.sidebar-toggle {
  box-shadow: 0 6px 18px rgba(0,0,0,0.35);
  border-radius: 8px;
}

.sidebar-collapsed .sidebar-brand-text,
.sidebar-collapsed .sidebar-menu a .text,
.sidebar-collapsed .sidebar-auth-section .user-info,
.sidebar-collapsed .sidebar-auth-section button span:not(.icon) {
  display: none;
}

/* Hide user details (name/role) in collapsed state */
.sidebar-collapsed .sidebar-user-details,
.sidebar-collapsed .sidebar-user-name,
.sidebar-collapsed .sidebar-user-role,
.sidebar-collapsed .sidebar-auth-buttons,
.sidebar-collapsed .sidebar-login-text {
  display: none !important;
}

.sidebar-collapsed .sidebar-brand {
  justify-content: center;
  padding: 16px 8px;
}

.sidebar-collapsed .sidebar-logo {
  margin: 0;
}

.sidebar-collapsed .sidebar-menu a {
  justify-content: center;
  padding: 12px 8px;
}

.sidebar-collapsed .sidebar-toggle .toggle-icon {
  /* disable rotation when sidebar is collapsed */
  transform: none !important;
}

.sidebar-collapsed .sidebar-auth-section {
  padding: 12px 8px;
}

.sidebar-collapsed .sidebar-auth-section button {
  justify-content: center;
  padding: 10px;
}

/* Fix logo and avatar aspect ratio to avoid deformation when collapsed */
.sidebar-logo {
  display: block;
  height: 48px;
  width: auto;
  object-fit: contain;
}

.sidebar-user-avatar img,
.sidebar-user-avatar {
  width: 40px;
  height: 40px;
  border-radius: 50%;
  display: inline-block;
  object-fit: cover;
}

.sidebar-collapsed .sidebar-logo {
  height: 36px;
  width: 36px;
  object-fit: cover;
}

.sidebar-collapsed .sidebar-user-avatar img,
.sidebar-collapsed .sidebar-user-avatar {
  width: 36px;
  height: 36px;
}

/* Adjust main content when sidebar is collapsed */
.sidebar-collapsed .content-wrapper {
  margin-left: 70px;
}

.sidebar-collapsed .gallery_wrapper {
  width: calc(100vw - 70px - 40px);
}

/* When sidebar is collapsed, avoid adding extra left margin — main already shifts using --sidebar-width */
.sidebar-collapsed .admin-container,
.sidebar-collapsed .content-wrapper,
.sidebar-collapsed .calendar-container {
  margin-left: 0;
  width: auto;
}

/* If you want the calendar to take all space and hide the legend entirely when collapsed,
   uncomment the rules below */
/*
.sidebar-collapsed .calendar-container {
  grid-template-columns: 1fr;
}
.sidebar-collapsed .calendar-legend {
  display: none;
}
*/

/* Smooth transitions */
.site-sidebar,
.content-wrapper,
.gallery_wrapper {
  transition: all 0.3s ease;
}

.sidebar-brand-text,
.sidebar-menu a .text {
  transition: opacity 0.2s ease;
}
