/* ============================================================
   IMOBINOW DESIGN TOKENS — v2
   CSS custom properties centralizadas. Não alterar ordem de carregamento.
   ============================================================ */
:root {
  /* --- Brand Colors --- */
  --color-primary:         #4f46e5;   /* indigo-600 */
  --color-primary-hover:   #4338ca;   /* indigo-700 */
  --color-primary-active:  #3730a3;   /* indigo-800 */
  --color-primary-subtle:  #eef2ff;   /* indigo-50 */
  --color-primary-muted:   #c7d2fe;   /* indigo-200 */
  --color-primary-text:    #3730a3;

  /* --- Surface Colors (light) --- */
  --surface-page:          #f8fafc;
  --surface-card:          #ffffff;
  --surface-card-hover:    #f9fafb;
  --surface-header:        #ffffff;
  --surface-input:         #ffffff;

  /* --- Border Colors (light) --- */
  --border-default:        #e5e7eb;   /* gray-200 */
  --border-subtle:         #f3f4f6;   /* gray-100 */
  --border-focus:          #6366f1;   /* indigo-500 */

  /* --- Text Colors (light) --- */
  --text-primary:          #111827;   /* gray-900 */
  --text-secondary:        #4b5563;   /* gray-600 */
  --text-muted:            #9ca3af;   /* gray-400 */
  --text-on-primary:       #ffffff;

  /* --- Status Colors --- */
  --color-success:         #16a34a;
  --color-success-subtle:  #dcfce7;
  --color-warning:         #d97706;
  --color-warning-subtle:  #fef9c3;
  --color-danger:          #dc2626;
  --color-danger-subtle:   #fee2e2;
  --color-info:            #2563eb;
  --color-info-subtle:     #dbeafe;

  /* --- Typography --- */
  --font-family: 'Geist', ui-sans-serif, system-ui, -apple-system, sans-serif;
  --font-size-xs:   0.75rem;    /* 12px */
  --font-size-sm:   0.875rem;   /* 14px */
  --font-size-base: 1rem;       /* 16px */
  --font-size-lg:   1.125rem;   /* 18px */
  --font-size-xl:   1.25rem;    /* 20px */
  --font-size-2xl:  1.5rem;     /* 24px */

  /* --- Spacing Scale --- */
  --space-1: 0.25rem;
  --space-2: 0.5rem;
  --space-3: 0.75rem;
  --space-4: 1rem;
  --space-5: 1.25rem;
  --space-6: 1.5rem;
  --space-8: 2rem;

  /* --- Border Radius --- */
  --radius-sm:   6px;
  --radius-md:   10px;
  --radius-lg:   14px;
  --radius-xl:   18px;
  --radius-full: 9999px;

  /* --- Shadows --- */
  --shadow-card:        0 1px 3px rgba(0,0,0,0.06), 0 1px 2px rgba(0,0,0,0.04);
  --shadow-card-hover:  0 8px 24px rgba(0,0,0,0.09), 0 2px 8px rgba(0,0,0,0.05);
  --shadow-dropdown:    0 4px 16px rgba(0,0,0,0.10), 0 1px 4px rgba(0,0,0,0.06);
  --shadow-modal:       0 20px 60px rgba(0,0,0,0.15), 0 4px 16px rgba(0,0,0,0.08);

  /* --- Input --- */
  --input-height:      2.5rem;
  --input-radius:      var(--radius-md);
  --input-focus-ring:  0 0 0 3px rgba(99, 102, 241, 0.18);

  /* --- Transitions --- */
  --transition-fast: 0.15s ease;
  --transition-base: 0.2s ease;
  --transition-slow: 0.3s ease;

  /* --- Sidebar --- */
  --sidebar-width:           16rem;
  --sidebar-collapsed-width: 5rem;
}

/* Dark mode token overrides */
html.dark {
  --surface-page:         #0f1117;
  --surface-card:         #1a1f2e;
  --surface-card-hover:   #1e2435;
  --surface-header:       #161b27;
  --surface-input:        #1e2435;

  --border-default:       #2d3748;
  --border-subtle:        #1e2435;
  --border-focus:         #818cf8;

  --text-primary:         #f1f5f9;
  --text-secondary:       #94a3b8;
  --text-muted:           #64748b;

  --color-primary-subtle: rgba(99, 102, 241, 0.12);
  --color-primary-muted:  rgba(99, 102, 241, 0.25);
  --color-primary-text:   #a5b4fc;

  --shadow-card:        0 1px 3px rgba(0,0,0,0.3), 0 1px 2px rgba(0,0,0,0.2);
  --shadow-card-hover:  0 8px 24px rgba(0,0,0,0.4), 0 2px 8px rgba(0,0,0,0.2);
  --shadow-modal:       0 20px 60px rgba(0,0,0,0.5), 0 4px 16px rgba(0,0,0,0.3);
}

/* Fonte e background global */
body {
  font-family: var(--font-family);
}

/* ============================================================
   FIM DOS TOKENS — código existente abaixo
   ============================================================ */

.sidebar {
     /* UX: animação suave; no mobile usamos off-canvas via transform */
     transition: transform 0.25s ease, width 0.2s ease;
     /* Rolagem independente tipo Jira: sidebar com altura limitada ao viewport */
     min-height: 0;
}


/* Barra de rolagem da sidebar: visual alinhado ao tema */
.sidebar-nav {
    scrollbar-width: thin;
    scrollbar-color: rgba(79, 70, 229, 0.2) transparent;
}
html.dark .sidebar-nav {
    scrollbar-color: rgba(129, 140, 248, 0.5) transparent;
}
.sidebar-nav::-webkit-scrollbar {
    width: 6px;
}
.sidebar-nav::-webkit-scrollbar-track {
    background: transparent;
}
.sidebar-nav::-webkit-scrollbar-thumb {
    background: rgba(79, 70, 229, 0.2);
    border-radius: 3px;
}
.sidebar-nav::-webkit-scrollbar-thumb:hover {
    background: rgba(79, 70, 229, 0.35);
}
html.dark .sidebar-nav::-webkit-scrollbar-thumb {
    background: rgba(129, 140, 248, 0.5);
}
html.dark .sidebar-nav::-webkit-scrollbar-thumb:hover {
    background: rgba(129, 140, 248, 0.7);
}

/* Dropdown do seletor de espaço: mesma barra de rolagem da sidebar */
.space-selector-dropdown {
    scrollbar-width: thin;
    scrollbar-color: rgba(129, 140, 248, 0.5) transparent;
}
.dark .space-selector-dropdown {
    scrollbar-color: rgba(156, 163, 175, 0.5) transparent;
}
.space-selector-dropdown::-webkit-scrollbar {
    width: 6px;
}
.space-selector-dropdown::-webkit-scrollbar-track {
    background: transparent;
}
.space-selector-dropdown::-webkit-scrollbar-thumb {
    background: rgba(129, 140, 248, 0.5);
    border-radius: 3px;
}
.space-selector-dropdown::-webkit-scrollbar-thumb:hover {
    background: rgba(129, 140, 248, 0.7);
}
.dark .space-selector-dropdown::-webkit-scrollbar-thumb {
    background: rgba(156, 163, 175, 0.5);
}
.dark .space-selector-dropdown::-webkit-scrollbar-thumb:hover {
    background: rgba(156, 163, 175, 0.7);
}

/* Dropdown de notificações: mesma barra de rolagem da sidebar (padrão do sistema) */
.notifications-dropdown-list {
    scrollbar-width: thin;
    scrollbar-color: rgba(129, 140, 248, 0.5) transparent;
}
.dark .notifications-dropdown-list {
    scrollbar-color: rgba(156, 163, 175, 0.5) transparent;
}
.notifications-dropdown-list::-webkit-scrollbar {
    width: 6px;
}
.notifications-dropdown-list::-webkit-scrollbar-track {
    background: transparent;
}
.notifications-dropdown-list::-webkit-scrollbar-thumb {
    background: rgba(129, 140, 248, 0.5);
    border-radius: 3px;
}
.notifications-dropdown-list::-webkit-scrollbar-thumb:hover {
    background: rgba(129, 140, 248, 0.7);
}
.dark .notifications-dropdown-list::-webkit-scrollbar-thumb {
    background: rgba(156, 163, 175, 0.5);
}
.dark .notifications-dropdown-list::-webkit-scrollbar-thumb:hover {
    background: rgba(156, 163, 175, 0.7);
}

/* Primeiro paint jÃ¡ colapsado quando pending (setado no head); evita "refresh" da barra ao navegar */
@media (min-width: 769px) {
    html.sidebar-collapsed-pending .sidebar {
        width: 5rem !important;
        transition: none;
    }
    html.sidebar-collapsed-pending .sidebar .sidebar-text,
    html.sidebar-collapsed-pending .sidebar .logo-text { display: none; }
    html.sidebar-collapsed-pending .sidebar .sidebar-header-brand { display: none; }
    html.sidebar-collapsed-pending .sidebar .sidebar-header-row { justify-content: center; padding-left: 0.75rem; padding-right: 0.75rem; }
    html.sidebar-collapsed-pending .sidebar .nav-item { min-height: 2.5rem; }
    html.sidebar-collapsed-pending .sidebar .nav-group-header { min-height: 2.75rem; }
    html.sidebar-collapsed-pending .sidebar .nav-item,
    html.sidebar-collapsed-pending .sidebar .nav-group-header { justify-content: center; padding-left: 0.75rem; padding-right: 0.75rem; }
    html.sidebar-collapsed-pending .sidebar .nav-item .fa,
    html.sidebar-collapsed-pending .sidebar .nav-item i,
    html.sidebar-collapsed-pending .sidebar .nav-group-header > i.fa,
    html.sidebar-collapsed-pending .sidebar .nav-group-header > i:first-of-type { margin-left: 0 !important; margin-right: 0 !important; }
    html.sidebar-collapsed-pending .sidebar .sidebar-user-block { justify-content: center; padding-left: 0.75rem; padding-right: 0.75rem; }
    html.sidebar-collapsed-pending .sidebar .sidebar-user-block .ml-3 { margin-left: 0; }
    html.sidebar-collapsed-pending .sidebar .sidebar-user-chevron { display: none; }
    html.sidebar-collapsed-pending .sidebar .global-search-wrap { position: relative; display: flex; align-items: center; justify-content: center; min-height: 2.25rem; border-radius: 0.5rem; }
    html.sidebar-collapsed-pending .sidebar .global-search-wrap:hover { background-color: rgba(67, 56, 202, 1); }
    .dark html.sidebar-collapsed-pending .sidebar .global-search-wrap:hover { background-color: rgba(55, 65, 81, 1); }
    html.sidebar-collapsed-pending .sidebar .global-search-wrap input { width: 0; min-width: 0; padding: 0; border: none; opacity: 0; pointer-events: none; position: absolute; }
    html.sidebar-collapsed-pending .sidebar .global-search-wrap .global-search-icon { position: static; transform: none; pointer-events: auto; cursor: pointer; font-size: 1rem; }
    html.sidebar-collapsed-pending .sidebar .nav-item[data-nav-id="funnel-health"] { display: none; }
    html.sidebar-collapsed-pending .sidebar .space-selector-wrap { display: none; }
    html.sidebar-collapsed-pending .sidebar .admin-section-wrap { display: none; }
}
/* Suprime transiÃ§Ã£o de width ao restaurar colapso no carregamento (evita "grande depois diminui") */
.sidebar.sidebar-restore-no-transition {
     transition: transform 0.25s ease;
}
 .sidebar-collapsed .sidebar-text {
     display: none;
}
 .sidebar-collapsed .logo-text {
     display: none;
}
/* No desktop colapsado: esconder Ã­cone da casinha + texto para sidebar ficar menor */
 @media (min-width: 769px) {
     .sidebar.sidebar-collapsed .sidebar-header-brand {
         display: none;
     }
     .sidebar.sidebar-collapsed .sidebar-header-row {
         justify-content: center;
         padding-left: 0.75rem;
         padding-right: 0.75rem;
     }
 }
 .sidebar-collapsed .nav-item {
     justify-content: center;
}
/* Hover alinhado quando colapsado: Ã­cone centralizado (sem margem) e Ã¡rea de hover simÃ©trica */
 @media (min-width: 769px) {
     .sidebar.sidebar-collapsed .nav-item {
         min-height: 2.5rem;
     }
     .sidebar.sidebar-collapsed .nav-group-header {
         min-height: 2.75rem;
     }
     .sidebar.sidebar-collapsed .nav-item,
     .sidebar.sidebar-collapsed .nav-group-header {
         justify-content: center;
         padding-left: 0.75rem;
         padding-right: 0.75rem;
     }
     .sidebar.sidebar-collapsed .nav-item .fa,
     .sidebar.sidebar-collapsed .nav-item i,
     .sidebar.sidebar-collapsed .nav-group-header > i.fa,
     .sidebar.sidebar-collapsed .nav-group-header > i:first-of-type {
         margin-left: 0 !important;
         margin-right: 0 !important;
     }
     .sidebar.sidebar-collapsed .nav-group-header .nav-group-chevron {
         margin-left: 0;
     }
     .sidebar.sidebar-collapsed .nav-item[data-nav-id="funnel-health"] {
         display: none;
     }
     .sidebar.sidebar-collapsed .space-selector-wrap {
         display: none;
     }
     .sidebar.sidebar-collapsed .admin-section-wrap {
         display: none;
     }
     .sidebar.sidebar-collapsed .sidebar-user-block {
         justify-content: center;
         padding-left: 0.75rem;
         padding-right: 0.75rem;
     }
    .sidebar.sidebar-collapsed .sidebar-user-block .ml-3 {
        margin-left: 0;
    }
    .sidebar.sidebar-collapsed .sidebar-user-chevron {
        display: none;
    }
}
/* Pesquisa global colapsada: sÃ³ a lupa visÃ­vel; clique expande a sidebar */
 @media (min-width: 769px) {
     .sidebar.sidebar-collapsed .global-search-wrap {
         position: relative;
         display: flex;
         align-items: center;
         justify-content: center;
         min-height: 2.25rem;
         border-radius: 0.5rem;
         transition: background-color 0.15s ease;
     }
     .sidebar.sidebar-collapsed .global-search-wrap:hover {
         background-color: rgba(67, 56, 202, 1);
     }
     .dark .sidebar.sidebar-collapsed .global-search-wrap:hover {
         background-color: rgba(55, 65, 81, 1);
     }
     .sidebar.sidebar-collapsed .global-search-wrap input {
         width: 0;
         min-width: 0;
         padding: 0;
         border: none;
         opacity: 0;
         pointer-events: none;
         position: absolute;
     }
     .sidebar.sidebar-collapsed .global-search-wrap .global-search-icon {
         position: static;
         transform: none;
         right: auto;
         top: auto;
         pointer-events: auto;
         cursor: pointer;
         font-size: 1rem;
     }
 }

/* Submenus do sidebar: filhos ocultos atÃ© o grupo estar expandido */
 .nav-group-children {
     max-height: 0;
     opacity: 0;
     transition: max-height 0.2s ease, opacity 0.15s ease;
 }
 .nav-group.nav-group-expanded .nav-group-children {
     max-height: 500px;
     opacity: 1;
 }
 /* Seção Relatórios: scroll para não cortar itens */
 .nav-group[data-nav-group="reports"].nav-group-expanded .nav-group-children {
     max-height: min(70vh, 420px);
     overflow-y: auto;
     overflow-x: hidden;
 }
 .nav-group .nav-group-chevron {
     transition: transform 0.2s ease;
 }
 .nav-group.nav-group-expanded .nav-group-chevron {
     transform: rotate(180deg);
 }
 .content-area {
     transition: padding 0.2s ease;
     /* Rolagem independente tipo Jira: área de conteúdo limitada ao viewport */
     min-height: 0;
 }
/* Permitir scroll no main em todas as páginas que usam content-area (Dashboard, Leads, etc.) */
.content-area main {
    min-height: 0;
}

/* PÃ¡gina especÃ­fica: Fila do Dia â€” fixa a Ã¡rea de conteÃºdo na viewport
   e mantÃ©m o scroll apenas dentro do <main> para nÃ£o afetar o sidebar */
.content-area.fila-do-dia-page {
    height: 100vh;
}
.content-area.fila-do-dia-page main {
    /* permitir que o main cresÃ§a/encolha dentro do container flex e
       que seu overflow funcione corretamente */
    flex: 1 1 auto;
    min-height: 0;
    overflow-y: auto;
}

 /* Em layout flex com sidebar fixo, nÃ£o precisamos de margin-left no conteÃºdo.
    Isso tambÃ©m evita bugs no mobile quando o sidebar vira overlay. */
 .content-expanded,
 .content-collapsed {
     margin-left: 0 !important;
 }

 /* Colapso no desktop: reduzir largura do sidebar (sem afetar o mobile) */
 .sidebar.sidebar-collapsed {
     width: 5rem !important;
 }

 /* Backdrop do sidebar (mobile) */
 .sidebar-backdrop {
     display: none;
     position: fixed;
     inset: 0;
     background: rgba(0, 0, 0, 0.45);
     backdrop-filter: blur(2px);
    /* precisa ficar ABAIXO do sidebar, senÃ£o bloqueia clique e â€œdesfocaâ€ o menu */
    z-index: 8990;
 }
 .sidebar-backdrop.active {
     display: block;
 }
 body.sidebar-open {
     overflow: hidden;
 }

 /* Sidebar off-canvas no mobile (regra global, independente da pÃ¡gina) */
 @media (max-width: 768px) {
     .sidebar {
         position: fixed !important;
         top: 0;
         left: 0;
         height: 100vh;
         height: 100dvh;
         transform: translateX(-110%);
         /* abaixo dos modais (normalmente z-[9999]) */
         z-index: 9000;
     }
     .sidebar.active {
         transform: translateX(0);
     }
     /* no mobile, colapso nÃ£o faz sentido: manter largura normal */
     .sidebar.sidebar-collapsed {
         width: 16rem !important;
     }
     /* Evita que barra inferior do Safari (e outros) tape o botão Sair */
     .sidebar-nav {
         padding-bottom: max(env(safe-area-inset-bottom), 80px);
     }
 }

 /* FAB para abrir menu no mobile em telas sem header */
 .mobile-menu-fab {
     position: fixed;
     left: 16px;
     bottom: 16px;
     width: 48px;
     height: 48px;
     border-radius: 9999px;
     display: flex;
     align-items: center;
     justify-content: center;
     background: rgba(79, 70, 229, 0.95);
     color: #fff;
     box-shadow: 0 10px 20px rgba(0,0,0,0.18);
     z-index: 8500;
 }
 .mobile-menu-fab:active { transform: scale(0.98); }
 @media (min-width: 769px) {
     .mobile-menu-fab { display: none !important; }
 }
input[type="password"]::-ms-reveal,
input[type="password"]::-ms-clear {
    display: none !important;
}

/* SweetAlert2 nos avisos do modal de assinatura: acima do modal (z-[100020]) */
.swal2-container.swal-assinaturas-aviso {
    z-index: 100030 !important;
}

/* SweetAlert2 de conflito de agenda: precisa ficar acima de modais empilhados (agenda/lead). */
.swal2-container.swal-agenda-conflito {
    z-index: 200000 !important;
}

/* ============================================================
   IMOBINOW COMPONENT LIBRARY — v2
   Classes semânticas reutilizáveis. Nenhuma regra existente foi removida.
   ============================================================ */

/* ----------------------------------------------------------
   BOTÕES
   ---------------------------------------------------------- */
.btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: var(--space-2);
  font-size: var(--font-size-sm);
  font-family: var(--font-family);
  font-weight: 500;
  line-height: 1.25;
  padding: 0.5rem 1rem;
  border-radius: var(--radius-md);
  border: 1px solid transparent;
  cursor: pointer;
  text-decoration: none;
  white-space: nowrap;
  transition:
    background-color var(--transition-base),
    border-color var(--transition-base),
    color var(--transition-base),
    box-shadow var(--transition-base),
    transform var(--transition-fast);
  user-select: none;
  vertical-align: middle;
}
.btn:focus-visible {
  outline: none;
  box-shadow: var(--input-focus-ring);
}
.btn:disabled,
.btn[aria-disabled="true"] {
  opacity: 0.5;
  cursor: not-allowed;
  pointer-events: none;
}
.btn-primary {
  background-color: var(--color-primary);
  color: var(--text-on-primary);
  border-color: var(--color-primary);
}
.btn-primary:hover {
  background-color: var(--color-primary-hover);
  border-color: var(--color-primary-hover);
  transform: translateY(-1px);
  box-shadow: 0 4px 12px rgba(79, 70, 229, 0.35);
}
.btn-primary:active { transform: translateY(0); box-shadow: none; }

.btn-secondary {
  background-color: var(--surface-card);
  color: var(--text-secondary);
  border-color: var(--border-default);
}
.btn-secondary:hover {
  background-color: var(--surface-card-hover);
  border-color: var(--color-primary-muted);
  color: var(--color-primary-text);
}

.btn-ghost {
  background-color: transparent;
  color: var(--text-secondary);
  border-color: transparent;
}
.btn-ghost:hover {
  background-color: var(--color-primary-subtle);
  color: var(--color-primary-text);
}
.btn-ghost.active {
  background-color: var(--color-primary-subtle);
  color: var(--color-primary-text);
  font-weight: 600;
}

.btn-danger {
  background-color: var(--color-danger);
  color: #fff;
  border-color: var(--color-danger);
}
.btn-danger:hover {
  background-color: #b91c1c;
  border-color: #b91c1c;
  transform: translateY(-1px);
}

.btn-sm {
  padding: 0.375rem 0.75rem;
  font-size: var(--font-size-xs);
}
.btn-lg {
  padding: 0.625rem 1.25rem;
  font-size: var(--font-size-base);
}

/* Spinner dentro de botão (estado loading) */
.btn-loading {
  position: relative;
  color: transparent !important;
  pointer-events: none;
}
.btn-loading::after {
  content: '';
  position: absolute;
  width: 1rem;
  height: 1rem;
  top: 50%;
  left: 50%;
  margin-top: -0.5rem;
  margin-left: -0.5rem;
  border: 2px solid rgba(255,255,255,0.35);
  border-top-color: #fff;
  border-radius: 50%;
  animation: imb-spin 0.6s linear infinite;
}
.btn-secondary.btn-loading::after,
.btn-ghost.btn-loading::after {
  border-color: rgba(99, 102, 241, 0.25);
  border-top-color: var(--color-primary);
}
@keyframes imb-spin { to { transform: rotate(360deg); } }

/* ----------------------------------------------------------
   CARDS
   ---------------------------------------------------------- */
.card {
  background: var(--surface-card);
  border: 1px solid var(--border-default);
  border-radius: var(--radius-lg);
  box-shadow: var(--shadow-card);
}
.card-hover {
  transition: box-shadow var(--transition-slow), transform var(--transition-slow), border-color var(--transition-slow);
}
.card-hover:hover {
  box-shadow: var(--shadow-card-hover);
  transform: translateY(-2px);
  border-color: #d1d5db;
}
html.dark .card-hover:hover { border-color: #374151; }

.card-body {
  padding: var(--space-6);
}
.card-header {
  padding: var(--space-4) var(--space-6);
  border-bottom: 1px solid var(--border-default);
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--space-3);
}

/* ----------------------------------------------------------
   STAT CARDS
   ---------------------------------------------------------- */
.stat-card {
  background: var(--surface-card);
  border: 1px solid var(--border-default);
  border-radius: var(--radius-lg);
  box-shadow: var(--shadow-card);
  padding: var(--space-5) var(--space-6);
  transition: box-shadow var(--transition-slow), transform var(--transition-slow);
}
.stat-card:hover {
  box-shadow: var(--shadow-card-hover);
  transform: translateY(-2px);
}
.stat-icon-box {
  width: 44px;
  height: 44px;
  border-radius: var(--radius-md);
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
  font-size: 1.125rem;
}
.stat-icon-box-indigo { background-color: var(--color-primary-subtle); color: var(--color-primary); }
.stat-icon-box-green  { background-color: var(--color-success-subtle); color: var(--color-success); }
.stat-icon-box-amber  { background-color: var(--color-warning-subtle); color: var(--color-warning); }
.stat-icon-box-red    { background-color: var(--color-danger-subtle);  color: var(--color-danger);  }
.stat-icon-box-blue   { background-color: var(--color-info-subtle);    color: var(--color-info);    }
.stat-icon-box-gray   { background-color: #f3f4f6; color: #6b7280; }
html.dark .stat-icon-box-gray { background-color: #374151; color: #9ca3af; }

.stat-label {
  font-size: var(--font-size-sm);
  color: var(--text-secondary);
  font-weight: 500;
  margin-bottom: var(--space-1);
  line-height: 1.3;
}
.stat-value {
  font-size: var(--font-size-2xl);
  font-weight: 700;
  color: var(--text-primary);
  line-height: 1.2;
  letter-spacing: -0.01em;
}
.stat-meta {
  font-size: var(--font-size-xs);
  color: var(--text-muted);
  margin-top: var(--space-1);
  line-height: 1.4;
}

/* ----------------------------------------------------------
   BADGES
   ---------------------------------------------------------- */
.badge {
  display: inline-flex;
  align-items: center;
  gap: 3px;
  padding: 0.2rem 0.55rem;
  border-radius: var(--radius-sm);
  font-size: var(--font-size-xs);
  font-weight: 600;
  line-height: 1;
  white-space: nowrap;
  letter-spacing: 0.01em;
}
.badge-indigo { background: var(--color-primary-subtle); color: var(--color-primary-text); }
.badge-green  { background: var(--color-success-subtle); color: #15803d; }
.badge-amber  { background: var(--color-warning-subtle); color: #92400e; }
.badge-red    { background: var(--color-danger-subtle);  color: #991b1b; }
.badge-blue   { background: var(--color-info-subtle);    color: #1d4ed8; }
.badge-gray   { background: #f3f4f6; color: #374151; }
html.dark .badge-gray   { background: #374151; color: #d1d5db; }
html.dark .badge-green  { background: rgba(22,163,74,0.15);  color: #86efac; }
html.dark .badge-amber  { background: rgba(217,119,6,0.15);  color: #fcd34d; }
html.dark .badge-red    { background: rgba(220,38,38,0.15);  color: #fca5a5; }
html.dark .badge-blue   { background: rgba(37,99,235,0.15);  color: #93c5fd; }
html.dark .badge-indigo { background: rgba(99,102,241,0.15); color: #a5b4fc; }

/* ----------------------------------------------------------
   FORMULÁRIOS
   ---------------------------------------------------------- */
.form-label {
  display: block;
  font-size: var(--font-size-sm);
  font-weight: 500;
  color: var(--text-secondary);
  margin-bottom: var(--space-1);
  line-height: 1.4;
}
.form-group {
  display: flex;
  flex-direction: column;
  gap: var(--space-1);
}
.form-input,
.form-select,
.form-textarea {
  display: block;
  width: 100%;
  min-height: var(--input-height);
  padding: 0.5rem 0.75rem;
  font-size: var(--font-size-sm);
  font-family: var(--font-family);
  color: var(--text-primary);
  background-color: var(--surface-input);
  border: 1px solid var(--border-default);
  border-radius: var(--input-radius);
  transition: border-color var(--transition-base), box-shadow var(--transition-base);
  appearance: none;
  -webkit-appearance: none;
}
.form-select {
  background-image: url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' fill='none' viewBox='0 0 20 20'%3e%3cpath stroke='%236b7280' stroke-linecap='round' stroke-linejoin='round' stroke-width='1.5' d='m6 8 4 4 4-4'/%3e%3c/svg%3e");
  background-position: right 0.5rem center;
  background-repeat: no-repeat;
  background-size: 1.25em 1.25em;
  padding-right: 2.25rem;
  cursor: pointer;
}
.form-textarea { min-height: 5rem; resize: vertical; }
.form-input:focus,
.form-select:focus,
.form-textarea:focus {
  outline: none;
  border-color: var(--border-focus);
  box-shadow: var(--input-focus-ring);
}
.form-input::placeholder,
.form-textarea::placeholder { color: var(--text-muted); }
/* Estado de erro */
.form-input.error,
.form-select.error,
.form-textarea.error {
  border-color: var(--color-danger);
  box-shadow: 0 0 0 3px rgba(220,38,38,0.12);
}
.form-error-msg {
  font-size: var(--font-size-xs);
  color: var(--color-danger);
  margin-top: var(--space-1);
  display: flex;
  align-items: center;
  gap: 0.25rem;
  line-height: 1.3;
}

/* ----------------------------------------------------------
   PAGE HEADER (top bar padrão)
   ---------------------------------------------------------- */
.page-header {
  background: var(--surface-header);
  border-bottom: 1px solid var(--border-default);
  padding: 1rem 1.5rem;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--space-3);
  flex-shrink: 0;
  min-height: 88px;
  flex-wrap: wrap;
}
.page-header-left {
  display: flex;
  align-items: center;
  gap: var(--space-3);
  min-width: 0;
}
.page-header-title {
  font-size: var(--font-size-lg);
  font-weight: 600;
  color: var(--text-primary);
  line-height: 1.3;
  white-space: nowrap;
}
.page-header-actions {
  display: flex;
  align-items: center;
  gap: var(--space-2);
  flex-wrap: wrap;
}

/* ----------------------------------------------------------
   SECTION HEADER (dentro do conteúdo)
   ---------------------------------------------------------- */
.section-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--space-3);
  margin-bottom: var(--space-4);
}
.section-title {
  font-size: var(--font-size-base);
  font-weight: 600;
  color: var(--text-primary);
  line-height: 1.3;
}
.section-action {
  font-size: var(--font-size-sm);
  color: var(--color-primary);
  font-weight: 500;
  text-decoration: none;
  transition: color var(--transition-base);
}
.section-action:hover { color: var(--color-primary-hover); text-decoration: underline; }

/* ----------------------------------------------------------
   TABELAS
   ---------------------------------------------------------- */
.table-container {
  background: var(--surface-card);
  border: 1px solid var(--border-default);
  border-radius: var(--radius-lg);
  overflow: hidden;
  box-shadow: var(--shadow-card);
}
.data-table {
  width: 100%;
  border-collapse: separate;
  border-spacing: 0;
}
.data-table th {
  font-size: var(--font-size-xs);
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.05em;
  color: var(--text-muted);
  padding: var(--space-3) var(--space-4);
  border-bottom: 1px solid var(--border-default);
  text-align: left;
  background: var(--surface-page);
  white-space: nowrap;
}
.data-table td {
  padding: var(--space-3) var(--space-4);
  border-bottom: 1px solid var(--border-subtle);
  font-size: var(--font-size-sm);
  color: var(--text-primary);
  vertical-align: middle;
}
.data-table tr:last-child td { border-bottom: none; }
.data-table tbody tr { transition: background-color var(--transition-fast); }
.data-table tbody tr:hover td { background-color: var(--surface-card-hover); }

/* ----------------------------------------------------------
   FILTER PANEL (unifica filter-section de leads.css e imoveis.css)
   ---------------------------------------------------------- */
.filter-panel {
  background: var(--surface-header);
  border-bottom: 1px solid var(--border-default);
  max-height: 0;
  overflow: hidden;
  transition: max-height 0.3s ease;
}
.filter-panel.active { max-height: 600px; }
.filter-panel-inner {
  padding: var(--space-4) var(--space-6);
}
.filter-panel-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
  gap: var(--space-4);
}
@media (max-width: 640px) {
  .filter-panel-grid { grid-template-columns: 1fr 1fr; }
}
.filter-panel-actions {
  display: flex;
  align-items: center;
  justify-content: flex-end;
  gap: var(--space-2);
  margin-top: var(--space-4);
  padding-top: var(--space-4);
  border-top: 1px solid var(--border-subtle);
}

/* ----------------------------------------------------------
   MODAL SHELL
   ---------------------------------------------------------- */
.modal-overlay {
  position: fixed;
  inset: 0;
  background: rgba(0,0,0,0.38);
  backdrop-filter: blur(3px);
  -webkit-backdrop-filter: blur(3px);
  z-index: 9999;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: var(--space-4);
}
.modal-panel {
  background: var(--surface-card);
  border-radius: var(--radius-xl);
  box-shadow: var(--shadow-modal);
  width: 100%;
  max-width: 56rem;
  max-height: calc(100dvh - 2rem);
  display: flex;
  flex-direction: column;
  overflow: hidden;
  border: 1px solid var(--border-default);
}
.modal-panel-sm  { max-width: 28rem; }
.modal-panel-md  { max-width: 38rem; }
.modal-header {
  padding: var(--space-4) var(--space-5);
  border-bottom: 1px solid var(--border-subtle);
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--space-3);
  flex-shrink: 0;
}
.modal-header-title {
  font-size: var(--font-size-lg);
  font-weight: 600;
  color: var(--text-primary);
  line-height: 1.3;
  flex: 1;
  min-width: 0;
}
.modal-body {
  flex: 1;
  overflow-y: auto;
  padding: var(--space-5);
}
.modal-footer {
  padding: var(--space-3) var(--space-5);
  border-top: 1px solid var(--border-subtle);
  display: flex;
  align-items: center;
  justify-content: flex-end;
  gap: var(--space-2);
  flex-shrink: 0;
}

/* Tabs dentro de modais */
.modal-tabs {
  display: flex;
  gap: 0;
  border-bottom: 1px solid var(--border-default);
  padding: 0 var(--space-6);
  flex-shrink: 0;
  overflow-x: auto;
  scrollbar-width: none;
}
.modal-tabs::-webkit-scrollbar { display: none; }
.modal-tab {
  padding: var(--space-3) var(--space-4);
  font-size: var(--font-size-sm);
  font-weight: 500;
  color: var(--text-muted);
  border-bottom: 2px solid transparent;
  cursor: pointer;
  white-space: nowrap;
  transition: color var(--transition-base), border-color var(--transition-base);
  background: none;
  border-top: none;
  border-left: none;
  border-right: none;
  margin-bottom: -1px;
}
.modal-tab:hover { color: var(--text-primary); }
.modal-tab.active {
  color: var(--color-primary);
  border-bottom-color: var(--color-primary);
  font-weight: 600;
}
.modal-tab-panel { display: none; }
.modal-tab-panel.active { display: block; }

/* ----------------------------------------------------------
   ALERTS (inline)
   ---------------------------------------------------------- */
.alert {
  display: flex;
  align-items: flex-start;
  gap: var(--space-3);
  padding: var(--space-3) var(--space-4);
  border-radius: var(--radius-md);
  font-size: var(--font-size-sm);
  margin-bottom: var(--space-4);
  border: 1px solid transparent;
  line-height: 1.5;
}
.alert-success { background: var(--color-success-subtle); color: #15803d; border-color: #bbf7d0; }
.alert-warning { background: var(--color-warning-subtle); color: #92400e; border-color: #fde68a; }
.alert-danger  { background: var(--color-danger-subtle);  color: #991b1b; border-color: #fecaca; }
.alert-info    { background: var(--color-info-subtle);    color: #1d4ed8; border-color: #bfdbfe; }
html.dark .alert-success { background: rgba(22,163,74,0.12);  color: #86efac; border-color: rgba(22,163,74,0.3);  }
html.dark .alert-warning { background: rgba(217,119,6,0.12);  color: #fcd34d; border-color: rgba(217,119,6,0.3);  }
html.dark .alert-danger  { background: rgba(220,38,38,0.12);  color: #fca5a5; border-color: rgba(220,38,38,0.3);  }
html.dark .alert-info    { background: rgba(37,99,235,0.12);  color: #93c5fd; border-color: rgba(37,99,235,0.3);  }

/* ----------------------------------------------------------
   LOADING — Skeleton shimmer
   ---------------------------------------------------------- */
.skeleton {
  background: linear-gradient(
    90deg,
    var(--border-subtle) 25%,
    var(--border-default) 50%,
    var(--border-subtle) 75%
  );
  background-size: 200% 100%;
  animation: imb-skeleton 1.5s infinite;
  border-radius: var(--radius-md);
}
@keyframes imb-skeleton {
  0%   { background-position: 200% 0; }
  100% { background-position: -200% 0; }
}
.skeleton-row {
  height: 48px;
  margin-bottom: var(--space-2);
}
.skeleton-text { height: 1rem; }
.skeleton-text-sm { height: 0.75rem; }

/* Spinner standalone */
.spinner {
  width: 2rem;
  height: 2rem;
  border: 3px solid var(--color-primary-muted);
  border-top-color: var(--color-primary);
  border-radius: 50%;
  animation: imb-spin 0.7s linear infinite;
  flex-shrink: 0;
}
.spinner-sm { width: 1.25rem; height: 1.25rem; border-width: 2px; }
.spinner-lg { width: 3rem; height: 3rem; border-width: 4px; }

/* ----------------------------------------------------------
   TOAST NOTIFICATIONS
   ---------------------------------------------------------- */
#toast-container {
  position: fixed;
  top: 1.25rem;
  right: 1.5rem;
  z-index: 110000;
  display: flex;
  flex-direction: column;
  gap: 0.5rem;
  pointer-events: none;
  max-width: 400px;
  width: calc(100vw - 2rem);
}
.toast {
  pointer-events: auto;
  display: flex;
  align-items: flex-start;
  gap: var(--space-3);
  padding: 0.875rem 1rem 0.875rem 1.25rem;
  border-radius: var(--radius-lg);
  font-size: var(--font-size-sm);
  font-family: var(--font-family);
  font-weight: 500;
  background: var(--surface-card);
  border: 1px solid var(--border-default);
  box-shadow: var(--shadow-modal);
  animation: toast-in 0.25s ease forwards;
  position: relative;
  overflow: hidden;
  line-height: 1.4;
}
.toast::before {
  content: '';
  position: absolute;
  left: 0; top: 0; bottom: 0;
  width: 4px;
  border-radius: var(--radius-lg) 0 0 var(--radius-lg);
}
.toast-success::before { background: var(--color-success); }
.toast-error::before   { background: var(--color-danger); }
.toast-warning::before { background: var(--color-warning); }
.toast-info::before    { background: var(--color-info); }
.toast-icon {
  flex-shrink: 0;
  width: 1.25rem;
  font-size: 0.875rem;
  padding-top: 0.1rem;
}
.toast-success .toast-icon { color: var(--color-success); }
.toast-error   .toast-icon { color: var(--color-danger); }
.toast-warning .toast-icon { color: var(--color-warning); }
.toast-info    .toast-icon { color: var(--color-info); }
.toast-content { flex: 1; min-width: 0; }
.toast-message { color: var(--text-primary); }
.toast-close {
  flex-shrink: 0;
  background: none;
  border: none;
  cursor: pointer;
  color: var(--text-muted);
  padding: 0.25rem;
  font-size: 1rem;
  line-height: 1;
  transition: color var(--transition-fast);
  align-self: flex-start;
  margin-top: -0.1rem;
}
.toast-close:hover { color: var(--text-secondary); }
.toast.toast-out { animation: toast-out 0.2s ease forwards; }
@keyframes toast-in  { from { opacity: 0; transform: translateX(12px); } to { opacity: 1; transform: none; } }
@keyframes toast-out { from { opacity: 1; transform: none; } to { opacity: 0; transform: translateX(12px); } }

/* ----------------------------------------------------------
   SIDEBAR ACTIVE STATE & TOOLTIPS
   ---------------------------------------------------------- */
.sidebar .nav-item[data-active="true"],
.sidebar .nav-group-header[data-active="true"] {
  background-color: rgba(255,255,255,0.15) !important;
  font-weight: 500;
}
/* Tooltips no modo colapsado desktop */
@media (min-width: 769px) {
  .sidebar.sidebar-collapsed .nav-item {
    position: relative;
  }
  .sidebar.sidebar-collapsed .nav-item[data-tooltip]::after {
    content: attr(data-tooltip);
    position: absolute;
    left: calc(100% + 10px);
    top: 50%;
    transform: translateY(-50%);
    background: #1e293b;
    color: #f8fafc;
    font-size: 12px;
    font-weight: 500;
    padding: 5px 10px;
    border-radius: 6px;
    white-space: nowrap;
    pointer-events: none;
    opacity: 0;
    transition: opacity 0.15s ease;
    z-index: 9200;
    box-shadow: 0 2px 8px rgba(0,0,0,0.25);
    font-family: var(--font-family);
  }
  .sidebar.sidebar-collapsed .nav-item:hover[data-tooltip]::after {
    opacity: 1;
  }
}

/* ============================================================
   SIDEBAR REDESIGN — icon pills, active accent, section labels
   ============================================================ */

/* Sidebar — light mode: slightly off-white for contrast against white content area */
.sidebar.sidebar-themed {
  background: #f8fafc;
  border-right: 1px solid #d1d5db;
}
html.dark .sidebar.sidebar-themed {
  background: var(--surface-card);
  border-right: 1px solid var(--border-default);
  box-shadow: none;
}
.sidebar.sidebar-themed .sidebar-nav {
  background: transparent !important;
}
.sidebar.sidebar-themed .sidebar-user-block {
  background: transparent !important;
  border-bottom: 1px solid #d1d5db;
}
.sidebar.sidebar-themed .sidebar-header-row {
  border-color: #d1d5db !important;
}

/* Header: logo icon, logo text, toggle button */
.sidebar.sidebar-themed .sidebar-header-icon { color: var(--color-primary); }
.sidebar.sidebar-themed .logo-text { color: var(--text-primary); }
.sidebar.sidebar-themed #toggleSidebar { color: var(--text-muted); }
html.dark .sidebar.sidebar-themed .sidebar-header-icon { color: #a5b4fc; }
html.dark .sidebar.sidebar-themed .logo-text { color: white; }
html.dark .sidebar.sidebar-themed #toggleSidebar { color: rgba(255,255,255,0.6); }

/* User block: name + role text */
.sidebar.sidebar-themed .sidebar-user-block .user-name-text { color: var(--text-primary); }
.sidebar.sidebar-themed .sidebar-user-block .user-role-text { color: var(--text-muted); }

/* Nav item text + hover (overrides Tailwind text-white hover:bg-white/10) */
.sidebar.sidebar-themed .sidebar-nav .nav-item,
.sidebar.sidebar-themed .sidebar-nav .nav-group-header {
  color: var(--text-secondary);
}
html.dark .sidebar.sidebar-themed .sidebar-nav .nav-item,
html.dark .sidebar.sidebar-themed .sidebar-nav .nav-group-header {
  color: white;
}
.sidebar.sidebar-themed .sidebar-nav .nav-item:hover,
.sidebar.sidebar-themed .sidebar-nav .nav-group-header:hover {
  background: rgba(79, 70, 229, 0.05);
}
html.dark .sidebar.sidebar-themed .sidebar-nav .nav-item:hover,
html.dark .sidebar.sidebar-themed .sidebar-nav .nav-group-header:hover {
  background: rgba(255,255,255,0.08);
}

/* Nav group chevron */
.sidebar.sidebar-themed .sidebar-nav .nav-group-chevron { color: var(--text-muted); }
html.dark .sidebar.sidebar-themed .sidebar-nav .nav-group-chevron { color: rgba(165, 180, 252, 0.6); }

/* HR separators and internal dividers */
.sidebar.sidebar-themed .sidebar-nav hr {
  border-color: var(--border-default);
}
html.dark .sidebar.sidebar-themed .sidebar-nav hr {
  border-color: rgba(255,255,255,0.08);
}
.sidebar.sidebar-themed .sidebar-nav .border-t {
  border-color: var(--border-default);
}
html.dark .sidebar.sidebar-themed .sidebar-nav .border-t {
  border-color: rgba(255,255,255,0.08);
}

/* Nav icons: no pill background, only color + spacing */
.sidebar-nav .nav-item i:first-child,
.sidebar-nav .nav-group-header > i:first-child {
  width: 1.25rem;
  display: inline-flex !important;
  align-items: center;
  justify-content: center;
  color: var(--text-secondary);
  margin-right: 0.625rem !important;
  flex-shrink: 0;
  font-size: 0.9375rem;
  transition: color 0.15s ease;
}
html.dark .sidebar-nav .nav-item i:first-child,
html.dark .sidebar-nav .nav-group-header > i:first-child {
  color: rgba(255,255,255,0.7);
}
.sidebar-nav .nav-item:hover i:first-child,
.sidebar-nav .nav-group-header:hover > i:first-child {
  color: var(--color-primary);
}
html.dark .sidebar-nav .nav-item:hover i:first-child,
html.dark .sidebar-nav .nav-group-header:hover > i:first-child {
  color: #a5b4fc;
}
/* Span-wrapped icons */
.sidebar-nav .nav-item .w-5.flex.shrink-0.justify-center {
  width: 1.25rem !important;
  display: inline-flex !important;
  align-items: center;
  justify-content: center;
  margin-right: 0.625rem !important;
  flex-shrink: 0;
}

/* Active nav item — replaces bg-indigo-700 */
.sidebar-nav .nav-item.nav-item-active {
  position: relative;
  background: var(--color-primary-subtle) !important;
  color: var(--color-primary-text) !important;
  font-weight: 600;
}
html.dark .sidebar-nav .nav-item.nav-item-active {
  background: rgba(165, 180, 252, 0.14) !important;
  color: white !important;
}
.sidebar-nav .nav-item.nav-item-active::before {
  content: '';
  position: absolute;
  left: 0;
  top: 50%;
  transform: translateY(-50%);
  height: 55%;
  width: 3px;
  background: var(--color-primary);
  border-radius: 0 3px 3px 0;
}
html.dark .sidebar-nav .nav-item.nav-item-active::before {
  background: #818cf8;
}
.sidebar-nav .nav-item.nav-item-active i:first-child,
.sidebar-nav .nav-item.nav-item-active .w-5.flex.shrink-0.justify-center {
  color: var(--color-primary) !important;
}
html.dark .sidebar-nav .nav-item.nav-item-active i:first-child,
html.dark .sidebar-nav .nav-item.nav-item-active .w-5.flex.shrink-0.justify-center {
  color: #a5b4fc !important;
}

/* Collapsed sidebar: hide all submenu children (avoids scrollbar cramping the 5rem width) */
@media (min-width: 769px) {
  .sidebar.sidebar-collapsed .nav-group-children,
  html.sidebar-collapsed-pending .sidebar .nav-group-children {
    max-height: 0 !important;
    opacity: 0 !important;
    overflow: hidden !important;
  }
}

/* Flyout submenu panel — portal appended to <body> to escape sidebar overflow clipping */

/* Show nav-group-children content inside flyout (base CSS hides it with opacity:0) */
#sidebar-collapsed-flyout .nav-group-children {
  max-height: none !important;
  opacity: 1 !important;
  overflow: visible !important;
}

/* Flyout container */
#sidebar-collapsed-flyout {
  position: fixed;
  width: 240px;
  border-radius: 0.5rem;
  z-index: 9300;
  padding: 4px 0;
  overflow-y: auto;
  overflow-x: hidden;
  background-color: rgb(55, 48, 163); /* matches bg-indigo-800 */
  box-shadow: 0 8px 24px rgba(0, 0, 0, 0.35);
  scrollbar-width: thin;
  scrollbar-color: rgba(255, 255, 255, 0.2) transparent;
}
#sidebar-collapsed-flyout::-webkit-scrollbar { width: 6px; }
#sidebar-collapsed-flyout::-webkit-scrollbar-track { background: transparent; }
#sidebar-collapsed-flyout::-webkit-scrollbar-thumb { background: rgba(255, 255, 255, 0.2); border-radius: 3px; }
#sidebar-collapsed-flyout::-webkit-scrollbar-thumb:hover { background: rgba(255, 255, 255, 0.35); }
html.dark #sidebar-collapsed-flyout {
  background-color: rgb(17, 24, 39); /* matches dark:bg-gray-900 */
  box-shadow: 0 8px 24px rgba(0, 0, 0, 0.55);
}
/* Themed sidebar scrollbar — identical to .sidebar-nav */
#sidebar-collapsed-flyout.sidebar-themed {
  scrollbar-color: rgba(79, 70, 229, 0.2) transparent;
}
#sidebar-collapsed-flyout.sidebar-themed::-webkit-scrollbar-thumb { background: rgba(79, 70, 229, 0.2); border-radius: 3px; }
#sidebar-collapsed-flyout.sidebar-themed::-webkit-scrollbar-thumb:hover { background: rgba(79, 70, 229, 0.35); }
html.dark #sidebar-collapsed-flyout.sidebar-themed { scrollbar-color: rgba(129, 140, 248, 0.5) transparent; }
html.dark #sidebar-collapsed-flyout.sidebar-themed::-webkit-scrollbar-thumb { background: rgba(129, 140, 248, 0.5); }
html.dark #sidebar-collapsed-flyout.sidebar-themed::-webkit-scrollbar-thumb:hover { background: rgba(129, 140, 248, 0.7); }
/* Themed (light) sidebar — mirrors .sidebar.sidebar-themed exactly */
#sidebar-collapsed-flyout.sidebar-themed {
  background: #f8fafc;
  border: 1px solid #d1d5db;
  box-shadow: 4px 4px 16px rgba(0, 0, 0, 0.10);
}
html.dark #sidebar-collapsed-flyout.sidebar-themed {
  background: var(--surface-card);
  border: 1px solid var(--border-default);
  box-shadow: 4px 4px 16px rgba(0, 0, 0, 0.35);
}

/* Remove pl-8 submenu indentation — not needed in standalone flyout */
#sidebar-collapsed-flyout .nav-item {
  padding-left: 1rem !important;
  white-space: nowrap;
  overflow: hidden;
}
/* Graceful text truncation */
#sidebar-collapsed-flyout .sidebar-text {
  display: inline !important;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

/* Divider inside flyout */
#sidebar-collapsed-flyout .border-t {
  border-color: rgba(255, 255, 255, 0.12) !important;
  margin: 4px 8px;
}

/* Lead count badge */
#sidebar-collapsed-flyout .nav-item span[class*="bg-indigo"],
#sidebar-collapsed-flyout .nav-item span[class*="bg-white"] {
  background-color: rgba(255, 255, 255, 0.2) !important;
  color: white !important;
}

/* Themed sidebar: dark text (mirrors .sidebar.sidebar-themed .sidebar-nav rules) */
#sidebar-collapsed-flyout.sidebar-themed .nav-item,
#sidebar-collapsed-flyout.sidebar-themed .nav-group-header {
  color: var(--text-secondary) !important;
}
html.dark #sidebar-collapsed-flyout.sidebar-themed .nav-item,
html.dark #sidebar-collapsed-flyout.sidebar-themed .nav-group-header {
  color: white !important;
}
#sidebar-collapsed-flyout.sidebar-themed .nav-item:hover,
#sidebar-collapsed-flyout.sidebar-themed .nav-group-header:hover {
  background: rgba(79, 70, 229, 0.05) !important;
}
html.dark #sidebar-collapsed-flyout.sidebar-themed .nav-item:hover,
html.dark #sidebar-collapsed-flyout.sidebar-themed .nav-group-header:hover {
  background: rgba(255, 255, 255, 0.08) !important;
}
#sidebar-collapsed-flyout.sidebar-themed .nav-item i,
#sidebar-collapsed-flyout.sidebar-themed .nav-item .w-5.flex.shrink-0.justify-center {
  color: var(--text-muted) !important;
}
#sidebar-collapsed-flyout.sidebar-themed .nav-item:hover i,
#sidebar-collapsed-flyout.sidebar-themed .nav-item:hover .w-5.flex.shrink-0.justify-center {
  color: var(--color-primary) !important;
}
#sidebar-collapsed-flyout.sidebar-themed .border-t {
  border-color: var(--border-default) !important;
}
html.dark #sidebar-collapsed-flyout.sidebar-themed .border-t {
  border-color: rgba(255, 255, 255, 0.08) !important;
}
#sidebar-collapsed-flyout.sidebar-themed .nav-item span[class*="bg-indigo"],
#sidebar-collapsed-flyout.sidebar-themed .nav-item span[class*="bg-white"] {
  background-color: rgba(79, 70, 229, 0.1) !important;
  color: var(--color-primary) !important;
}

/* In collapsed mode, reset icon pill margin */
@media (min-width: 769px) {
  .sidebar.sidebar-collapsed .sidebar-nav .nav-item i:first-child,
  .sidebar.sidebar-collapsed .sidebar-nav .nav-group-header > i:first-child {
    margin-right: 0 !important;
    margin-left: 0 !important;
  }
}
html.sidebar-collapsed-pending .sidebar .sidebar-nav .nav-item i:first-child,
html.sidebar-collapsed-pending .sidebar .sidebar-nav .nav-group-header > i:first-child {
  margin-right: 0 !important;
  margin-left: 0 !important;
}

/* Section labels with inline rule */
.nav-section-label {
  font-size: 0.62rem;
  font-weight: 600;
  letter-spacing: 0.09em;
  text-transform: uppercase;
  color: var(--text-muted);
  padding: 0.625rem 1rem 0.2rem;
  display: flex;
  align-items: center;
  gap: 0.5rem;
  margin-top: 0.25rem;
}
html.dark .nav-section-label {
  color: rgba(165, 180, 252, 0.42);
}
.nav-section-label::after {
  content: '';
  flex: 1;
  height: 1px;
  background: var(--border-default);
}
html.dark .nav-section-label::after {
  background: rgba(255,255,255,0.07);
}
/* Hide section labels when sidebar is collapsed (no room) */
.sidebar.sidebar-collapsed .nav-section-label { display: none; }
html.sidebar-collapsed-pending .sidebar .nav-section-label { display: none; }

/* Logout button — subtle danger on hover instead of full red fill */
.sidebar-nav a.nav-item-logout:hover {
  background: rgba(220, 38, 38, 0.07) !important;
}
.sidebar-nav a.nav-item-logout:hover i:first-child {
  color: var(--color-danger) !important;
}
.sidebar-nav a.nav-item-logout:hover .sidebar-text {
  color: var(--color-danger);
}
html.dark .sidebar-nav a.nav-item-logout:hover {
  background: rgba(239, 68, 68, 0.12) !important;
}
html.dark .sidebar-nav a.nav-item-logout:hover i:first-child {
  color: #fca5a5 !important;
}
html.dark .sidebar-nav a.nav-item-logout:hover .sidebar-text {
  color: #fca5a5;
}

/* PAGE HEADER — ensure action buttons aren't too small */
.page-header-actions .btn {
  min-height: 2.25rem;
}

/* ============================================================
   PAGE LOADING BAR — top progress indicator for navigation
   ============================================================ */
#page-loading-bar {
  position: fixed;
  top: 0;
  left: 0;
  width: 0%;
  height: 3px;
  background: var(--color-primary);
  z-index: 99999;
  transition: width 0.2s ease;
  opacity: 0;
  pointer-events: none;
}
#page-loading-bar.is-loading {
  opacity: 1;
  animation: page-bar-indeterminate 1.4s ease-in-out infinite;
}
@keyframes page-bar-indeterminate {
  0%   { width: 0%;   margin-left: 0; }
  30%  { width: 50%;  margin-left: 0; }
  60%  { width: 35%;  margin-left: 55%; }
  100% { width: 0%;   margin-left: 100%; }
}

/* ── User Menu Dropdown ─────────────────────────────────── */
.user-menu-wrap { position: relative; }

.user-menu-dropdown {
    position: fixed;
    background: var(--surface-card);
    border: 1px solid var(--border-default);
    border-radius: var(--radius-lg);
    box-shadow: var(--shadow-hover);
    opacity: 0;
    transform: translateY(-6px);
    transition: opacity var(--transition-fast), transform var(--transition-fast);
    pointer-events: none;
}

.user-menu-dropdown.user-menu-dropdown-open {
    opacity: 1;
    transform: translateY(0);
    pointer-events: auto;
}

.user-menu-dropdown.hidden {
    display: none !important;
}

.user-menu-section {
    padding: 0.375rem;
}

.user-menu-user-info {
    display: flex;
    align-items: center;
    gap: 0.625rem;
    padding: 0.75rem;
}

.user-menu-separator {
    height: 1px;
    background: var(--border-default);
    margin: 0;
}

.user-menu-item {
    display: flex;
    align-items: center;
    gap: 0.625rem;
    width: 100%;
    padding: 0.5rem 0.625rem;
    border-radius: var(--radius-md);
    font-size: 0.875rem;
    color: var(--text-primary);
    text-decoration: none;
    background: transparent;
    border: none;
    cursor: pointer;
    transition: background var(--transition-fast);
    text-align: left;
}

.user-menu-item:hover {
    background: rgba(0, 0, 0, 0.04);
    color: var(--text-primary);
}

html.dark .user-menu-item:hover {
    background: rgba(255, 255, 255, 0.06);
}

.user-menu-item-danger {
    color: #ef4444;
}

.user-menu-item-danger:hover {
    background: rgba(239, 68, 68, 0.08) !important;
    color: #ef4444 !important;
}

/* ============================================================
   FIM DA COMPONENT LIBRARY — v2
   ============================================================ */