.h1, h2, h3, h4, h5, h6 {
    color: darkgreen;
}
/* Força cor branca no menu principal */
.dj-megamenu-wrapper .dj-up_a,
.dj-megamenu-wrapper .dj-up_a:link,
.dj-megamenu-wrapper .dj-up_a:visited {
    color: #ffffff !important;
    font-weight: 600 !important;
    font-size: 15px !important;
    background-color: transparent !important;
}

/* Hover e ativo com cor destaque */
.dj-megamenu-wrapper .dj-up_a:hover,
.dj-megamenu-wrapper .dj-up_a.active,
.dj-megamenu-wrapper .dj-up_a:focus {
    color: #FFD700 !important;
}
/* Remove bordas e margens do wrapper */
.component-content iframe {
  border: none !important;
  margin: 0 !important;
  padding: 0 !important;
  width: 100vw !important;
  height: 100vh !important;
  display: block !important;
  overflow: hidden !important;
}

/* Opcional: zera o container também */
.component-content {
  padding: 0 !important;
  margin: 0 !important;
  background: transparent !important;
}
/* ========== Sidebar Lateral Cassiopeia ==========
.app-sidebar {
  position: fixed;
  top: 0;
  left: 0;
  width: 250px;             /* ajuste a gosto 
  height: 100vh;
  background: #1c2742;      /* slate-900 
  color: #e2e8f0;           /* slate-200 
  padding-top: 64px;        /* compensa o header 
  overflow-y: auto;
  z-index: 1020;
  box-shadow: 1px 0 0 rgba(148,163,184,.15);
} */

/* empurra o conteúdo quando a sidebar existir 
body.has-sidebar-lateral .site-grid,
body.has-sidebar-lateral .header.container-header {
  margin-left: 250px;
}

#sidebarMenu ul {
  list-style: none;
  margin: 0;
  padding: 8px 0;
}
#sidebarMenu li {
  margin: 0;
}
#sidebarMenu a,
#sidebarMenu .nav-link {
  display: flex;
  align-items: center;
  gap: 10px;
  color: #e2e8f0;
  text-decoration: none;
  padding: 10px 16px;
  font-size: 14px;
  border-radius: 8px;
  transition: background .15s ease, color .15s ease;
}
#sidebarMenu a:hover,
#sidebarMenu .nav-link:hover {
  background: rgba(148,163,184,.12); /* hover 
  color: #fff;
}

/* seta para itens com submenu (classe "parent" vem do mod_menu) 
#sidebarMenu li.parent > a::after,
#sidebarMenu .nav-item.parent > .nav-link::after {
  content: "▸";
  margin-left: auto;
  opacity: .7;
  transition: transform .15s ease;
}

/* submenu fechado/aberto 
#sidebarMenu ul ul {
  display: none;
  padding-left: 8px;
  border-left: 1px solid rgba(148,163,184,.15);
  margin-left: 8px;
}
#sidebarMenu li.open > ul {
  display: block;
}
#sidebarMenu li.open > a::after,
#sidebarMenu li.open > .nav-link::after {
  transform: rotate(90deg);
}

/* itens de submenu 
#sidebarMenu ul ul a {
  font-size: 13px;
  padding: 8px 12px 8px 14px;
  color: #cbd5e1;
}

/* responsivo: colapsa em telas menores (opcional) 
@media (max-width: 992px) {
  .app-sidebar {
    transform: translateX(-100%);
    transition: transform .2s ease;
  }
  body.sidebar-open .app-sidebar {
    transform: translateX(0);
  }
  body.has-sidebar-lateral .site-grid,
  body.has-sidebar-lateral .header.container-header {
    margin-left: 0;
  }
}
*
 */

/* ========== Sidebar Lateral Modernizada ========== */
.app-sidebar {
  position: fixed;
  top: 0;
  left: 0;
  width: 260px;
  height: 100vh;
  background: linear-gradient(180deg, #1e293b 0%, #0f172a 100%);
  color: #e2e8f0;
  padding-top: 70px;
  overflow-y: auto;
  z-index: 1020;
  box-shadow: 4px 0 15px rgba(0, 0, 0, 0.1);
  border-right: 1px solid rgba(148, 163, 184, 0.1);
  transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1);
}

/* Scrollbar customizada */
.app-sidebar::-webkit-scrollbar {
  width: 6px;
}

.app-sidebar::-webkit-scrollbar-track {
  background: transparent;
}

.app-sidebar::-webkit-scrollbar-thumb {
  background: rgba(148, 163, 184, 0.3);
  border-radius: 3px;
}

.app-sidebar::-webkit-scrollbar-thumb:hover {
  background: rgba(148, 163, 184, 0.5);
}

/* Empurra o conteúdo quando a sidebar existir */
body.has-sidebar-lateral .site-grid,
body.has-sidebar-lateral .header.container-header {
  margin-left: 260px;
  transition: margin-left 0.3s cubic-bezier(0.4, 0, 0.2, 1);
}

/* Lista principal */
#sidebarMenu ul {
  list-style: none;
  margin: 0;
  padding: 12px 8px;
}

#sidebarMenu li {
  margin: 0 0 4px 0;
}

/* Links principais */
#sidebarMenu a,
#sidebarMenu .nav-link {
  display: flex;
  align-items: center;
  gap: 12px;
  color: #cbd5e1;
  text-decoration: none;
  padding: 12px 16px;
  font-size: 14px;
  font-weight: 500;
  border-radius: 10px;
  margin: 0 4px;
  transition: all 0.2s cubic-bezier(0.4, 0, 0.2, 1);
  position: relative;
  overflow: hidden;
}

/* Efeito hover moderno */
#sidebarMenu a:hover,
#sidebarMenu .nav-link:hover {
  background: rgba(59, 130, 246, 0.15);
  color: #ffffff;
  transform: translateX(4px);
  box-shadow: 0 4px 12px rgba(59, 130, 246, 0.15);
}

/* Item ativo - apenas para páginas realmente ativas */
#sidebarMenu a.current,
#sidebarMenu .nav-link.current,
#sidebarMenu li.current > a,
#sidebarMenu li.current > .nav-link {
  background: linear-gradient(135deg, #3b82f6 0%, #1d4ed8 100%);
  color: #ffffff;
  box-shadow: 0 4px 15px rgba(59, 130, 246, 0.3);
}

/* Remove destaque automático de itens "active" do Joomla */
#sidebarMenu a.active,
#sidebarMenu .nav-link.active,
#sidebarMenu li.active > a,
#sidebarMenu li.active > .nav-link {
  background: transparent;
  color: #cbd5e1;
  box-shadow: none;
}

/* Efeito ripple no hover */
#sidebarMenu a::before,
#sidebarMenu .nav-link::before {
  content: '';
  position: absolute;
  top: 0;
  left: -100%;
  width: 100%;
  height: 100%;
  background: linear-gradient(90deg, transparent, rgba(255, 255, 255, 0.1), transparent);
  transition: left 0.5s;
}

#sidebarMenu a:hover::before,
#sidebarMenu .nav-link:hover::before {
  left: 100%;
}

/* Ícones nos links (se você quiser adicionar) */
#sidebarMenu a::after,
#sidebarMenu .nav-link::after {
  content: "";
  width: 20px;
  height: 20px;
  background: url('data:image/svg+xml,<svg xmlns="http://www.w3.org/2000/svg" fill="none" viewBox="0 0 24 24" stroke="currentColor"><path stroke-linecap="round" stroke-linejoin="round" stroke-width="2" d="M9 5l7 7-7 7"/></svg>') no-repeat center;
  background-size: 16px;
  opacity: 0.5;
  transition: all 0.2s ease;
}

/* Seta para itens com submenu */
#sidebarMenu li.parent > a::after,
#sidebarMenu .nav-item.parent > .nav-link::after {
  content: "";
  width: 16px;
  height: 16px;
  background: url('data:image/svg+xml,<svg xmlns="http://www.w3.org/2000/svg" fill="none" viewBox="0 0 24 24" stroke="currentColor"><path stroke-linecap="round" stroke-linejoin="round" stroke-width="2" d="M9 5l7 7-7 7"/></svg>') no-repeat center;
  background-size: 14px;
  margin-left: auto;
  opacity: 0.7;
  transition: all 0.2s cubic-bezier(0.4, 0, 0.2, 1);
  transform-origin: center;
}

/* Submenu */
#sidebarMenu ul ul {
  display: none;
  padding: 8px 0 8px 0;
  margin: 8px 0 0 20px;
  border-left: 2px solid rgba(59, 130, 246, 0.3);
  position: relative;
}

/* Animação suave para abertura do submenu */
#sidebarMenu li.open > ul {
  display: block;
  animation: slideDown 0.3s cubic-bezier(0.4, 0, 0.2, 1);
}

@keyframes slideDown {
  from {
    opacity: 0;
    transform: translateY(-10px);
  }
  to {
    opacity: 1;
    transform: translateY(0);
  }
}

/* Rotação da seta quando aberto */
#sidebarMenu li.open > a::after,
#sidebarMenu li.open > .nav-link::after {
  transform: rotate(90deg);
  opacity: 1;
  background: url('data:image/svg+xml,<svg xmlns="http://www.w3.org/2000/svg" fill="none" viewBox="0 0 24 24" stroke="currentColor"><path stroke-linecap="round" stroke-linejoin="round" stroke-width="2" d="M19 9l-7 7-7-7"/></svg>') no-repeat center;
  background-size: 14px;
}

/* Itens de submenu */
#sidebarMenu ul ul li {
  margin: 2px 0;
}

#sidebarMenu ul ul a,
#sidebarMenu ul ul .nav-link {
  font-size: 13px;
  font-weight: 400;
  padding: 10px 16px 10px 20px;
  color: #94a3b8;
  margin: 0 8px 0 0;
  border-radius: 8px;
  position: relative;
}

#sidebarMenu ul ul a::before,
#sidebarMenu ul ul .nav-link::before {
  content: '';
  position: absolute;
  left: 8px;
  top: 50%;
  width: 6px;
  height: 6px;
  background: #64748b;
  border-radius: 50%;
  transform: translateY(-50%);
  transition: all 0.2s ease;
}

#sidebarMenu ul ul a:hover,
#sidebarMenu ul ul .nav-link:hover {
  background: rgba(59, 130, 246, 0.1);
  color: #e2e8f0;
  transform: translateX(6px);
}

#sidebarMenu ul ul a:hover::before,
#sidebarMenu ul ul .nav-link:hover::before {
  background: #3b82f6;
  transform: translateY(-50%) scale(1.2);
}

/* Separadores visuais entre seções */
#sidebarMenu > ul > li:not(:last-child) {
  margin-bottom: 8px;
  position: relative;
}

#sidebarMenu > ul > li:not(:last-child):after {
  content: '';
  position: absolute;
  bottom: -4px;
  left: 16px;
  right: 16px;
  height: 1px;
  background: linear-gradient(90deg, transparent, rgba(148, 163, 184, 0.2), transparent);
}

/* Responsivo melhorado */
@media (max-width: 992px) {
  .app-sidebar {
    transform: translateX(-100%);
    transition: transform 0.3s cubic-bezier(0.4, 0, 0.2, 1);
    box-shadow: none;
  }
  
  body.sidebar-open .app-sidebar {
    transform: translateX(0);
    box-shadow: 4px 0 25px rgba(0, 0, 0, 0.3);
  }
  
  body.has-sidebar-lateral .site-grid,
  body.has-sidebar-lateral .header.container-header {
    margin-left: 0;
  }
  
  /* Overlay para mobile */
  body.sidebar-open::before {
    content: '';
    position: fixed;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    background: rgba(0, 0, 0, 0.5);
    z-index: 1019;
    animation: fadeIn 0.3s ease;
  }
}

@keyframes fadeIn {
  from { opacity: 0; }
  to { opacity: 1; }
}

/* Estados especiais para diferentes tipos de links - REMOVIDO para evitar bordas automáticas */
/* #sidebarMenu a[href*="powerbi"],
#sidebarMenu a[href*="dashboard"] {
  border-left: 3px solid #f59e0b;
}

#sidebarMenu a[href*="monitor"] {
  border-left: 3px solid #10b981;
}

#sidebarMenu a[href*="financeiro"] {
  border-left: 3px solid #8b5cf6;
} */

/* Destaque manual apenas quando necessário */
#sidebarMenu .nav-link.manually-active {
  background: linear-gradient(135deg, #3b82f6 0%, #1d4ed8 100%);
  color: #ffffff;
  box-shadow: 0 4px 15px rgba(59, 130, 246, 0.3);
}

/* Remove qualquer destaque do item Login após login */
#sidebarMenu a[href*="login"],
#sidebarMenu .nav-link[href*="login"] {
  background: transparent !important;
  color: #cbd5e1 !important;
  box-shadow: none !important;
}

#sidebarMenu a[href*="login"]:hover,
#sidebarMenu .nav-link[href*="login"]:hover {
  background: rgba(59, 130, 246, 0.15) !important;
  color: #ffffff !important;
}

/* Melhorias para acessibilidade */
#sidebarMenu a:focus,
#sidebarMenu .nav-link:focus {
  outline: 2px solid #3b82f6;
  outline-offset: 2px;
}

/* Loading state para links que demoram (opcional) */
#sidebarMenu a.loading {
  pointer-events: none;
  opacity: 0.6;
}

#sidebarMenu a.loading::after {
  content: '';
  width: 16px;
  height: 16px;
  border: 2px solid transparent;
  border-top: 2px solid currentColor;
  border-radius: 50%;
  animation: spin 1s linear infinite;
  margin-left: auto;
}

@keyframes spin {
  to { transform: rotate(360deg); }
}

/* ========== CORREÇÕES ESPECÍFICAS ========== */

/* Remove TODOS os destaques automáticos do Joomla */
#sidebarMenu li.active > a,
#sidebarMenu li.active > .nav-link,
#sidebarMenu a.active,
#sidebarMenu .nav-link.active {
  background: transparent !important;
  color: #cbd5e1 !important;
  box-shadow: none !important;
}

/* Aplica destaque apenas onde queremos */
#sidebarMenu .manually-active {
  background: linear-gradient(135deg, #3b82f6 0%, #1d4ed8 100%) !important;
  color: #ffffff !important;
  box-shadow: 0 4px 15px rgba(59, 130, 246, 0.3) !important;
}

/* Força remoção de destaque do Login */
#sidebarMenu a[href*="com_user"],
#sidebarMenu a[href*="login"],
#sidebarMenu a[href*="index.php"]:not([href*="option"]) {
  background: transparent !important;
  color: #cbd5e1 !important;
  box-shadow: none !important;
}

/* Específico para Analíticos e outros itens pai */
#sidebarMenu li.parent > a,
#sidebarMenu .nav-item.parent > .nav-link {
  background: transparent !important;
  color: #cbd5e1 !important;
}

/* Hover funciona normalmente */
#sidebarMenu a:hover,
#sidebarMenu .nav-link:hover {
  background: rgba(59, 130, 246, 0.15) !important;
  color: #ffffff !important;
  transform: translateX(4px);
  box-shadow: 0 4px 12px rgba(59, 130, 246, 0.15) !important;
}

/* Garantir que submenus não herdem estilos problemáticos */
#sidebarMenu ul ul a,
#sidebarMenu ul ul .nav-link {
  background: transparent !important;
  color: #94a3b8 !important;
  box-shadow: none !important;
}

/* Brand no topo da sidebar */
.app-sidebar .sidebar-brand {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 12px 16px 10px 16px;
  margin: 0 0 6px 0;
  border-bottom: 1px solid rgba(148,163,184,.15);
}
.app-sidebar .sidebar-brand img {
  max-width: 180px; /* ajuste conforme gosto */
  height: auto;
  display: block;
}
