/**
 * Public website navigation – design system aligned.
 */
.navbar {
  background: var(--color-white);
  box-shadow: var(--shadow-md);
  padding: var(--space-4) 0;
  position: sticky;
  top: 0;
  z-index: 1000;
}

.navbar-brand {
  font-size: var(--font-size-xl);
  font-weight: var(--font-weight-extrabold);
  letter-spacing: 0.5px;
  color: var(--color-primary);
  text-decoration: none;
}
.navbar-brand:hover {
  color: var(--color-primary-hover);
}

.navbar-nav .nav-link {
  color: var(--color-neutral-text);
  font-weight: var(--font-weight-semibold);
  font-size: var(--font-size-sm);
  margin: 0 var(--space-3);
  padding: var(--space-2) 0;
  transition: color var(--transition-fast);
}
.navbar-nav .nav-link:hover,
.navbar-nav .nav-link.active {
  color: var(--color-secondary);
}

.auth-buttons {
  display: flex;
  align-items: center;
  gap: var(--space-3);
}

/* Nav buttons use design system variants */
.btn-login {
  padding: var(--space-3) var(--space-5);
  border: 2px solid var(--color-secondary);
  color: var(--color-secondary);
  background: transparent;
  border-radius: var(--radius-md);
  font-weight: var(--font-weight-semibold);
  font-size: var(--font-size-sm);
  transition: background-color var(--transition-base), color var(--transition-base), border-color var(--transition-base), transform var(--transition-base);
  text-decoration: none;
}
.btn-login:hover {
  background: var(--color-secondary);
  color: var(--color-white);
  border-color: var(--color-secondary);
  transform: translateY(-1px);
}

.btn-register {
  padding: var(--space-3) var(--space-5);
  background: var(--color-primary);
  color: var(--color-white);
  border: 2px solid var(--color-primary);
  border-radius: var(--radius-md);
  font-weight: var(--font-weight-semibold);
  font-size: var(--font-size-sm);
  transition: background-color var(--transition-base), border-color var(--transition-base), transform var(--transition-base);
  text-decoration: none;
}
.btn-register:hover {
  background: var(--color-primary-hover);
  border-color: var(--color-primary-hover);
  color: var(--color-white);
  transform: translateY(-1px);
  box-shadow: var(--shadow-md);
}

.cart-icon {
  color: var(--color-secondary) !important;
}
.cart-icon:hover {
  color: var(--color-secondary-hover) !important;
}
.cart-badge {
  font-size: var(--font-size-xs);
}

.navbar-toggler {
  border: none;
}
.navbar-toggler:focus {
  box-shadow: none;
  outline: none;
}

@media (max-width: 991px) {
  .auth-buttons {
    flex-direction: column;
    width: 100%;
    margin-top: var(--space-4);
  }
  .btn-login,
  .btn-register {
    width: 100%;
    text-align: center;
    display: block;
  }
}
