/*
 * Navigation Component Styles
 * Styles for the top navigation bar and user dropdown
 */

/* User Avatar Styling */
.photo {
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
}

.photo img.avatar {
  width: 40px !important;
  height: 40px !important;
  border-radius: 50% !important;
  object-fit: cover !important;
  border: 2px solid var(--bs-primary) !important;
  cursor: pointer !important;
  transition: all 0.3s ease !important;
}

.photo img.avatar:hover {
  border-color: var(--bs-light) !important;
  transform: scale(1.05) !important;
  box-shadow: 0 4px 8px rgba(var(--bs-primary-rgb), 0.3) !important;
}

/* Dark theme avatar styling */
[data-bs-theme="dark"] .photo img.avatar {
  border-color: var(--bs-info) !important;
}

[data-bs-theme="dark"] .photo img.avatar:hover {
  border-color: var(--bs-light) !important;
  box-shadow: 0 4px 8px rgba(var(--bs-info-rgb), 0.3) !important;
}

/* Dropdown Navigation Styling */
.navbar .dropdown.nav-item {
  position: relative !important;
}

.navbar .dropdown-navbar {
  border-radius: var(--bs-border-radius-lg) !important;
  box-shadow: var(--bs-box-shadow-lg) !important;
  margin-top: 5px !important;
  min-width: 150px !important;
  background-color: var(--bs-body-bg) !important;
  border: 1px solid var(--bs-border-color) !important;
  position: absolute !important;
  top: 100% !important;
  right: 0 !important;
  left: auto !important;
  z-index: 1050 !important;
  display: none !important;
}

.navbar .dropdown-navbar.show {
  display: block !important;
}

.dropdown-navbar .dropdown-item {
  padding: 10px 20px !important;
  display: flex !important;
  align-items: center !important;
  gap: 10px !important;
  transition: background-color 0.2s ease !important;
  color: var(--bs-body-color) !important;
  text-decoration: none !important;
  font-size: 14px !important;
}

.dropdown-navbar .dropdown-item:hover {
  background-color: var(--bs-secondary-bg) !important;
  color: var(--bs-primary) !important;
  text-decoration: none !important;
}

.dropdown-navbar .dropdown-item i {
  width: 16px !important;
  text-align: center !important;
}

/* Remove default Bootstrap dropdown-toggle arrow */
.dropdown-toggle::after {
  display: none !important;
}

.dropdown.nav-item {
  position: relative !important;
}

/* Theme Toggle Button */
.theme-toggle {
  background: none;
  border: none;
  color: var(--bs-body-color);
  padding: 0.5rem;
  border-radius: var(--bs-border-radius);
  transition: all 0.3s ease;
  cursor: pointer;
}

.theme-toggle:hover {
  background-color: var(--bs-secondary-bg);
  color: var(--bs-primary);
}

.theme-toggle i {
  font-size: 1.2rem;
}

/* Navbar Brand */
.navbar-brand {
  font-weight: 600;
  color: var(--bs-body-color) !important;
  text-decoration: none;
}

.navbar-brand:hover {
  color: var(--bs-primary) !important;
}

/* Search Input */
.navbar-search {
  position: relative;
  max-width: 300px;
}

.navbar-search input {
  background-color: var(--bs-secondary-bg);
  border: 1px solid var(--bs-border-color);
  border-radius: var(--bs-border-radius-pill);
  padding: 0.5rem 1rem;
  font-size: 0.875rem;
  transition: all 0.3s ease;
}

.navbar-search input:focus {
  border-color: var(--bs-primary);
  box-shadow: 0 0 0 0.2rem rgba(var(--bs-primary-rgb), 0.25);
  outline: none;
}

/* Sidebar Toggle Button */
.sidebar-toggle {
  background: none;
  border: 1px solid var(--bs-border-color);
  color: var(--bs-body-color);
  padding: 0.5rem;
  border-radius: var(--bs-border-radius);
  transition: all 0.3s ease;
  cursor: pointer;
  min-width: 44px;
  min-height: 44px;
  display: flex;
  align-items: center;
  justify-content: center;
}

.sidebar-toggle:hover {
  background-color: var(--bs-secondary-bg);
  color: var(--bs-primary);
  border-color: var(--bs-primary);
}

.sidebar-toggle:focus {
  outline: 2px solid var(--bs-primary);
  outline-offset: 2px;
}

.sidebar-toggle i {
  font-size: 1.2rem;
}

/* Responsive Design */
@media (max-width: 768px) {
  .navbar {
    padding: 0.5rem 1rem;
  }
  
  .navbar-search {
    max-width: 200px;
  }
  
  .navbar-search input {
    font-size: 0.8rem;
    padding: 0.4rem 0.8rem;
  }
  
  .photo img.avatar {
    width: 35px !important;
    height: 35px !important;
  }
  
  .dropdown-navbar {
    min-width: 120px !important;
  }
  
  .dropdown-navbar .dropdown-item {
    padding: 8px 15px !important;
    font-size: 13px !important;
  }
  
  .sidebar-toggle {
    padding: 0.4rem;
    min-width: 40px;
    min-height: 40px;
  }
  
  .sidebar-toggle i {
    font-size: 1.1rem;
  }
  
  /* Improve touch targets */
  .theme-toggle {
    padding: 0.4rem;
    min-width: 40px;
    min-height: 40px;
    display: flex;
    align-items: center;
    justify-content: center;
  }
  
  .navbar-nav .nav-link {
    padding: 0.5rem 0.75rem;
  }
}

@media (max-width: 576px) {
  .navbar {
    padding: 0.5rem 0.75rem;
    /* Ensure navbar is above sidebar */
    z-index: 1042;
    position: relative;
  }
  
  .navbar-search {
    display: none;
  }
  
  .photo img.avatar {
    width: 36px !important;
    height: 36px !important;
  }
  
  .sidebar-toggle {
    padding: 0.5rem;
    min-width: 44px;
    min-height: 44px;
    /* Improve touch responsiveness */
    touch-action: manipulation;
    -webkit-tap-highlight-color: rgba(0, 0, 0, 0.1);
  }
  
  .sidebar-toggle:active {
    transform: scale(0.95);
    transition: transform 0.1s ease;
  }
  
  .theme-toggle {
    padding: 0.5rem;
    min-width: 44px;
    min-height: 44px;
    touch-action: manipulation;
    -webkit-tap-highlight-color: rgba(0, 0, 0, 0.1);
  }
  
  .theme-toggle:active {
    transform: scale(0.95);
    transition: transform 0.1s ease;
  }
  
  .navbar-brand {
    font-size: 1rem;
    /* Prevent text selection on touch */
    -webkit-user-select: none;
    user-select: none;
  }
  
  /* Improve dropdown positioning on mobile */
  .dropdown-navbar {
    position: fixed !important;
    top: auto !important;
    right: 0.75rem !important;
    left: auto !important;
    transform: translateY(-100%) !important;
    margin-top: -5px !important;
  }
  
  /* Improve navbar collapse behavior */
  .navbar-collapse {
    margin-top: 0.5rem;
    padding-top: 0.5rem;
    border-top: 1px solid var(--bs-border-color);
  }
}