/* Reset e namespace para componentes do menu */
.en-site-header * {
  box-sizing: border-box;
}

/* Variáveis de cores e tempos de animação*/
:root {
  --en-primary: #417bfd;
  --en-primary-hover: #4b7be2;
  --en-primary-dark: #4b7be2; 
  --en-success: #28a745;
  --en-success-light: #e3f9e5;
  --en-warning: #ffc107;
  --en-danger: #dc3545;
  --en-info: #17a2b8;
  --en-border: #dee2e6;
  --en-bg-light: #f8f9fa;
  --en-text-light: white;
  --en-text-dark: #343a40;
  --en-text-muted: #6c757d;
  --en-transition-fast: 150ms;
  --en-transition-normal: 300ms;
  --en-box-shadow: 0 0.125rem 0.25rem rgba(0, 0, 0, 0.075);
  --en-box-shadow-hover: 0 0.5rem 1rem rgba(0, 0, 0, 0.15);
}

/* Barra de anúncio no topo */
.en-announcement-bar {
  background: linear-gradient(90deg, var(--en-primary), var(--en-primary-dark));
  color: var(--en-text-light);
  padding: 8px 0;
  font-size: 14px;
  text-align: center;
}

.en-announcement-content {
  display: flex;
  justify-content: center;
  align-items: center;
}

.en-announcement-text {
  font-weight: 500;
}

.en-announcement-link {
  color: var(--en-text-light);
  margin-left: 6px;
  font-weight: 700;
  text-decoration: underline;
  position: relative;
  white-space: nowrap;
}

.en-announcement-link:hover {
  color: var(--en-text-light);
  text-decoration: none;
}

.en-announcement-link:after {
  content: "→";
  margin-left: 4px;
  display: inline-block;
  transition: transform var(--en-transition-fast) ease;
}

.en-announcement-link:hover:after {
  transform: translateX(3px);
}

/* Barra de navegação */
.en-navbar {
  transition: box-shadow var(--en-transition-normal) ease;
}

.en-navbar.shadow-sm {
  box-shadow: var(--en-box-shadow) !important;
}

/* Componentes do navbar */
.en-navbar-brand {
  padding: 0 !important;
  transition: transform var(--en-transition-normal) ease;
}

.en-navbar-brand:hover {
  transform: scale(1.02);
}

.en-navbar-search {
  max-width: 600px !important;
  flex-grow: 1 !important;
}

/* Grupo de busca */
.en-search-group {
  border: 1px solid var(--en-border) !important;
  border-radius: 30px !important;
  overflow: hidden !important;
  background: var(--en-bg-light) !important;
  display: flex !important;
  height: 46px !important; /* Altura aumentada para melhor interação */
  transition: all var(--en-transition-normal) ease !important;
  box-shadow: 0 2px 5px rgba(0,0,0,0.02) !important;
}

.en-search-group:focus-within {
  border-color: var(--en-primary) !important;
  box-shadow: 0 0 0 3px rgba(159, 200, 226, 0.25) !important;
  transform: translateY(-1px) !important;
}

.en-search-type {
  background: var(--en-bg-light) !important;
  border: none !important;
  border-right: 1px solid var(--en-border) !important;
  min-width: 100px !important;
  height: 100% !important;
  padding: 0 12px !important;
  cursor: pointer !important;
  font-size: 0.9rem !important;
  color: var(--en-text-dark) !important;
  font-weight: 500 !important;
}

.en-search-input {
  border: none !important;
  flex-grow: 1 !important;
  background: var(--en-bg-light) !important;
  height: 100% !important;
  padding: 0 15px !important;
  font-size: 0.95rem !important;
}

.en-search-input:focus {
  box-shadow: none !important;
  outline: none !important;
}

.en-search-input::placeholder {
  color: #adb5bd !important;
  font-style: italic !important;
}

.en-search-button {
  background: var(--en-primary) !important;
  border: none !important;
  color: var(--en-text-light) !important;
  min-width: 50px !important;
  height: 100% !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  padding: 0 15px !important;
  transition: background-color var(--en-transition-fast) ease !important;
}

.en-search-button:hover {
  background: var(--en-primary-hover) !important;
}

.en-search-button i {
  font-size: 1.1rem !important;
}

/* Dropdown headers e footers */
.en-dropdown-header {
  display: block;
  padding: 8px 16px;
  margin-bottom: 0;
  font-size: 0.8rem;
  color: var(--en-text-muted);
  white-space: nowrap;
  text-transform: uppercase;
  letter-spacing: 0.03em;
  font-weight: 600;
}

.en-dropdown-footer {
  padding: 8px 16px;
  background-color: var(--en-bg-light);
  border-top: 1px solid var(--en-border);
  font-size: 0.85rem;
  border-bottom-left-radius: inherit;
  border-bottom-right-radius: inherit;
  text-align: center;
}

/* Avatar e ícones de notificação */
.en-user-avatar {
  width: 36px;
  height: 36px;
  border-radius: 50%;
  overflow: hidden;
  display: flex;
  align-items: center;
  justify-content: center;
  background-color: var(--en-bg-light);
  border: 1px solid var(--en-border);
}

.en-user-avatar img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.en-avatar-placeholder {
  width: 36px !important;
  height: 36px !important;
  background-color: var(--en-primary) !important;
  color: white !important;
  border-radius: 50% !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  font-weight: bold !important;
  font-size: 1.1rem !important;
}

.en-notification-icon {
  width: 38px;
  height: 38px;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  background-color: var(--en-bg-light);
  color: var(--en-text-dark);
  transition: all var(--en-transition-normal) ease;
  position: relative;
  text-decoration: none !important;
}

.en-notification-icon i {
  font-size: 1.2rem;
}

.en-notification-icon:hover {
  background-color: var(--en-primary);
  color: var(--en-text-light);
  transform: translateY(-2px);
}

.en-notification-badge {
  position: absolute;
  top: -5px;
  right: -5px;
  background-color: var(--en-success);
  color: white;
  border-radius: 10px;
  padding: 2px 6px;
  font-size: 0.7rem;
  font-weight: 600;
  box-shadow: 0 2px 5px rgba(0,0,0,0.1);
  animation: pulse 2s infinite;
}

/* Botões */
.en-btn-outline-primary {
  color: var(--en-primary) !important;
  border-color: var(--en-primary) !important;
  border-radius: 20px !important;
  padding: 8px 18px !important;
  height: auto !important;
  font-weight: 500 !important;
  transition: all var(--en-transition-normal) ease !important;
}

.en-btn-outline-primary:hover {
  color: var(--en-text-light) !important;
  background: var(--en-primary) !important;
  box-shadow: var(--en-box-shadow) !important;
  transform: translateY(-1px) !important;
}

.en-btn-primary {
  background-color: var(--en-primary) !important;
  border-color: var(--en-primary) !important;
  border-radius: 20px !important;
  color: var(--en-text-light) !important;
  padding: 8px 18px !important;
  height: auto !important;
  font-weight: 500 !important;
  transition: all var(--en-transition-normal) ease !important;
  position: relative !important;
  overflow: hidden !important;
}

.en-btn-primary:hover {
  background-color: var(--en-primary-hover) !important;
  box-shadow: var(--en-box-shadow-hover) !important;
  transform: translateY(-2px) !important;
}

.en-btn-primary:before {
  content: "";
  position: absolute;
  top: 0;
  left: -100%;
  width: 100%;
  height: 100%;
  background: linear-gradient(
    90deg,
    transparent,
    rgba(255, 255, 255, 0.2),
    transparent
  );
  transition: left 0.7s ease;
}

.en-btn-primary:hover:before {
  left: 100%;
}

/* Animação de pulso para CTA principal */
.pulse-animation {
  animation: pulse 2s infinite;
}

@keyframes pulse {
  0% {
    box-shadow: 0 0 0 0 rgba(159, 200, 226, 0.7);
  }
  70% {
    box-shadow: 0 0 0 6px rgba(159, 200, 226, 0);
  }
  100% {
    box-shadow: 0 0 0 0 rgba(159, 200, 226, 0);
  }
}

/* Dropdowns - NAMESPACE ISOLADO */
.en-site-header .en-dropdown-menu {
  position: absolute !important;
  z-index: 1000 !important;
  background-color: white !important;
  border: 1px solid var(--en-border) !important;
  border-radius: 8px !important;
  box-shadow: 0 5px 15px rgba(0,0,0,0.1) !important;
  min-width: 240px !important;
  padding: 8px 0 !important;
  margin-top: 10px !important;
  opacity: 0;
  transform-origin: top right;
  transform: scale(0.9);
  transition: opacity var(--en-transition-normal) ease, 
              transform var(--en-transition-normal) ease;
  overflow: hidden !important;
}

.en-site-header .en-dropdown-menu.show {
  display: block !important;
  opacity: 1 !important;
  transform: scale(1) !important;
}

.en-site-header .en-dropdown-item {
  display: block !important;
  width: 100% !important;
  padding: 10px 16px !important;
  clear: both !important;
  font-weight: 400 !important;
  color: var(--en-text-dark) !important;
  text-align: inherit !important;
  white-space: nowrap !important;
  background-color: transparent !important;
  border: 0 !important;
  border-left: 3px solid transparent !important;
  transition: all var(--en-transition-fast) ease !important;
}

.en-site-header .en-dropdown-item:hover,
.en-site-header .en-dropdown-item.item-hover {
  background-color: var(--en-bg-light) !important;
  text-decoration: none !important;
  border-left-color: var(--en-primary) !important;
  transform: translateX(2px) !important;
}

.en-site-header .en-dropdown-item small {
  opacity: 0.8;
  font-size: 0.8rem;
}

.en-site-header .en-dropdown-item .badge {
  font-size: 0.7rem;
  padding: 3px 6px;
  font-weight: 600;
  transition: all var(--en-transition-fast) ease;
}

.en-site-header .en-dropdown-item:hover .badge {
  transform: scale(1.1);
}

.en-site-header .en-text-danger {
  color: var(--en-danger) !important;
}

.en-site-header .en-nav-link {
  color: #333 !important;
  padding: 8px 16px !important;
  display: flex !important;
  align-items: center !important;
  transition: all var(--en-transition-normal) ease !important;
}

.en-site-header .en-nav-link:hover {
  color: var(--en-primary) !important;
}

/* Fixar o comportamento de dropdown da biblioteca específico dentro do menu */
.en-site-header .dropdown-toggle::after {
  display: none !important;
}

/* Responsividade */
@media (max-width: 992px) {
  .en-navbar-search {
    max-width: 100% !important;
    margin: 15px 0 !important;
  }
  
  .en-search-group {
    flex-wrap: wrap !important;
    height: auto !important;
    border-radius: 15px !important;
  }
  
  .en-search-type {
    border-right: none !important;
    border-bottom: 1px solid var(--en-border) !important;
    width: 100% !important;
    padding: 10px !important;
    text-align: center !important;
  }
  
  .en-search-input {
    width: 100% !important; 
    padding: 10px 15px !important;
  }
  
  .en-search-button {
    width: 100% !important;
    padding: 10px 15px !important;
  }
  
  .en-notification-icon {
    margin-bottom: 10px;
  }
  
  .en-dropdown-menu {
    position: static !important;
    float: none !important;
    width: 100% !important;
    margin-top: 5px !important;
    background-color: var(--en-bg-light) !important;
  }
}

/* Preservar classes originais para compatibilidade */
.avatar-placeholder {
  width: 36px !important;
  height: 36px !important;
  background-color: var(--en-primary) !important;
  color: white !important;
  border-radius: 50% !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  font-weight: bold !important;
  font-size: 1.1rem !important;
}

.navbar-search {
  max-width: 600px !important;
}

.search-group {
  width: 100% !important;
  border: 1px solid var(--en-border) !important;
  border-radius: 30px !important;
  overflow: hidden !important;
  background: var(--en-bg-light) !important;
}

.search-type,
.search-state,
.search-city {
  background: var(--en-bg-light) !important;
  border: none !important;
  border-right: 1px solid var(--en-border) !important;
  min-width: 80px !important;
}

.search-input {
  border: none !important;
  flex-grow: 1 !important;
  background: var(--en-bg-light) !important;
}

.search-button {
  background: var(--en-primary) !important;
  border: none !important;
  color: white !important;
  min-width: 40px !important;
}

.btn-outline-primary {
  color: var(--en-primary) !important;
  border-color: var(--en-primary) !important;
  border-radius: 20px !important;
}

.btn-outline-primary:hover {
  color: white !important;
  background: var(--en-primary) !important;
}
.bg-primary {
  background-color: var(--en-primary)!important;
}
.text-primary {
  color: var(--en-primary)!important;
}
body {
  background-color: #f5f5f5 !important;
}