@charset "UTF-8";

html {
  min-height: 100vh;
}

/* Desktop navbar (≥1400px) - horizontal layout */

@media (min-width: 1400px) {
  #nav-bar .container-fluid {
    padding: 0 2rem;
  }

  #nav-bar .navbar-collapse {
    display: flex !important;
    flex-basis: auto;
  }

  #nav-bar .navbar-toggler {
    display: none;
  }

  #nav-bar .navbar-nav {
    flex-direction: row;
  }

  /* Desktop nav list - horizontal spacing */

  .sidebar-nav-list {
    padding: 0;
    margin-top: 0;
  }

  #nav-bar .nav-item {
    margin-left: 0.3rem;
    margin-right: 0.3rem;
  }

  /* Ensure dropdowns float over content */

  #nav-bar .dropdown-menu {
    position: absolute;
  }
}

/* Sidebar behavior for smaller screens (<1400px) */

@media (max-width: 1399.98px) {
  #nav-bar .container-fluid {
    padding: 0.5rem 1rem;
  }

  .navbar {
    position: relative;
    z-index: 1010;
  }

  .navbar-collapse {
    display: block !important;
    position: fixed;
    top: 0;
    right: -100%;
    width: -moz-max-content;
    width: max-content;
    height: 100vh;
    padding: 3.5rem 2rem 1.5rem;
    background-color: #fff;
    box-shadow: 0 4px 6px rgba(0, 0, 0, 0.1);
    transition: right 0.3s ease-in-out;
    z-index: 1050;
    overflow-y: auto;
  }

  .navbar-collapse.show {
    right: 0;
  }

  .navbar-toggler {
    display: flex;
    z-index: 1060;
    border: none !important;
    position: relative;
  }

  .hamburger-icon,
  .close-icon {
    font-size: 1.5rem;
    transition: opacity 0.3s ease-in-out;
  }

  .hamburger-icon {
    display: inline;
  }

  .close-icon {
    display: inline;
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    opacity: 0;
    pointer-events: none;
  }

  .navbar-toggler.toggled .hamburger-icon {
    opacity: 0;
    pointer-events: none;
  }

  .navbar-toggler.toggled .close-icon {
    opacity: 1;
    pointer-events: auto;
  }

  /* Reverse nav items order in mobile/collapsed view */

  .navbar-collapse .navbar-nav {
    flex-direction: column-reverse;
  }

  /* Make badges align with other nav items in mobile view */

  .credits-badge-link,
  .subscription-badge-link {
    justify-content: flex-start;
    width: 100%;
  }

  /* Sidebar nav list - consistent padding */

  .sidebar-nav-list {
    padding: 0;
    margin-top: 0;
  }

  /* Dropdowns in sidebar */

  .navbar-collapse .dropdown-menu {
    position: absolute;
  }
}

/* Navbar Badge Variables */

/* Credits Badge Styles */

.credits-badge-link {
  display: flex;
  align-items: center;
}

.credits-badge-link .credits-badge {
  font-size: 0.8rem;
  font-weight: 600;
  padding: 0.4em 0.7em;
  border-radius: 20px;
  transition: all 0.2s ease-in-out;
  cursor: pointer;
}

.credits-badge-link .credits-badge i {
  margin-right: 0.3em;
}

.credits-badge-link .credits-badge.badge-primary {
  background: linear-gradient(135deg, #527FC8 0%, #3d5f9f 100%);
  box-shadow: 0 2px 6px rgba(82, 127, 200, 0.3);
}

.credits-badge-link .credits-badge.badge-secondary {
  background: linear-gradient(135deg, #6c757d 0%, #545b62 100%);
  box-shadow: 0 2px 6px rgba(108, 117, 125, 0.3);
}

.credits-badge-link:hover .credits-badge {
  transform: scale(1.05);
  box-shadow: 0 2px 8px rgba(0, 0, 0, 0.15);
}

.credits-badge-link:hover .badge-primary {
  background: linear-gradient(135deg, #3f71c2 0%, #36548d 100%);
}

.credits-badge-link:hover .badge-secondary {
  background: linear-gradient(135deg, #60686f 0%, #494f54 100%);
}

/* Loading Dots Animation */

@keyframes jump {
  0%, 60%, 100% {
    transform: translateY(0);
  }

  30% {
    transform: translateY(-4px);
  }
}

.subscription-badge .loading-dots {
  display: inline-block;
}

.subscription-badge .loading-dots .dot {
  display: inline-block;
  animation: jump 1s infinite ease-in-out;
}

.subscription-badge .loading-dots .dot:nth-child(1) {
  animation-delay: 0s;
}

.subscription-badge .loading-dots .dot:nth-child(2) {
  animation-delay: 0.15s;
}

.subscription-badge .loading-dots .dot:nth-child(3) {
  animation-delay: 0.3s;
}

/* Subscription Badge Styles */

.subscription-badge-link {
  display: flex;
  align-items: center;
}

.subscription-badge-link .subscription-badge {
  font-size: 0.8rem;
  font-weight: 600;
  padding: 0.4em 0.7em;
  border-radius: 20px;
  transition: all 0.2s ease-in-out;
  cursor: pointer;
}

.subscription-badge-link .subscription-badge i {
  margin-right: 0.3em;
}

.subscription-badge-link .subscription-badge.badge-info {
  background: linear-gradient(135deg, #17a2b8 0%, #117a8b 100%);
  box-shadow: 0 2px 6px rgba(23, 162, 184, 0.3);
}

.subscription-badge-link .subscription-badge.badge-success {
  background: linear-gradient(135deg, #28a745 0%, #1e7e34 100%);
  box-shadow: 0 2px 6px rgba(40, 167, 69, 0.3);
}

.subscription-badge-link .subscription-badge.badge-warning {
  background: linear-gradient(135deg, #ffc107 0%, #d39e00 100%);
  box-shadow: 0 2px 6px rgba(255, 193, 7, 0.3);
  color: #212529;
}

.subscription-badge-link:hover .subscription-badge {
  transform: scale(1.05);
  box-shadow: 0 2px 8px rgba(0, 0, 0, 0.15);
}

.subscription-badge-link:hover .badge-info {
  background: linear-gradient(135deg, #148ea1 0%, #0f6674 100%);
}

.subscription-badge-link:hover .badge-success {
  background: linear-gradient(135deg, #23923d 0%, #19692c 100%);
}

.subscription-badge-link:hover .badge-warning {
  background: linear-gradient(135deg, #edb100 0%, #ba8b00 100%);
}

