/* ============================================================
   Bravva — Component Styles (v1.0)
   Tokens → tokens.css  |  Identidade: Alexandria + Navy / Violet / Teal
   ============================================================ */

/* Font loaded by tokens.css — não re-importar aqui */

/* ─────────────────────────────────────────────
   BOOTSTRAP OVERRIDES + COMPAT
   (tokens de design em tokens.css)
───────────────────────────────────────────── */
:root {
  /* Sobrescreve variáveis Bootstrap 5 */
  --bs-primary:            #0A4581;
  --bs-primary-rgb:        10, 69, 129;
  --bs-body-font-family:   'Alexandria', ui-sans-serif, system-ui, -apple-system, sans-serif;
  --bs-body-bg:            #FAFAF9;
  --bs-body-color:         #373643;
  --bs-border-radius:      8px;
  --bs-border-color:       #ECECE9;
  --bs-card-border-radius: 10px;
  --bs-link-color:         #0A4581;
  --bs-link-hover-color:   #073968;

  /* Mantém --tenant-color apontando para brand-navy (compat) */
  --tenant-color: #0A4581;
}

/* ─────────────────────────────────────────────
   SIDEBAR — navy gradient (Direção A)
───────────────────────────────────────────── */
.sidebar {
  width: var(--sidebar-w) !important;
  min-width: var(--sidebar-w) !important;
  flex-shrink: 0;
  background: linear-gradient(180deg, var(--navy-700) 0%, var(--navy-900) 100%) !important;
  color: rgba(255,255,255,.78);
  min-height: 100vh;
  display: flex;
  flex-direction: column;
}

/* área do logo */
.sidebar-logo-wrap {
  height: var(--topbar-h);
  padding: 0 20px;
  display: flex;
  align-items: center;
  gap: 10px;
  border-bottom: 1px solid rgba(255,255,255,.08);
  margin: 0 !important;
  border-radius: 0 !important;
  background: transparent !important;
  min-height: unset !important;
  justify-content: flex-start;
}
.sidebar-logo-wrap img {
  max-height: 30px;
  max-width: 140px;
  object-fit: contain;
}
/* Logos de tenants externos: em pill branca para ler bem em qualquer fundo */
.sidebar-logo-wrap .tenant-logo-wrap {
  background: white;
  border-radius: var(--radius-sm);
  padding: 3px 8px;
  display: flex;
  align-items: center;
}
.sidebar-logo-wrap .tenant-logo {
  max-height: 22px;
  max-width: 120px;
  object-fit: contain;
}
.bv-logo-text {
  display: flex; flex-direction: column;
  color: white; font-weight: 600; font-size: 17px; line-height: 1;
}
.bv-logo-text small {
  font-size: 8.5px; font-weight: 500;
  letter-spacing: 0.22em; opacity: 0.65; margin-top: 4px;
  text-transform: uppercase;
}

/* seções de grupo */
.nav-section {
  font-size: 10.5px !important;
  font-weight: 500 !important;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  color: rgba(255,255,255,0.4) !important;
  padding: 8px 12px 4px !important;
  margin-top: 12px;
  transition: opacity .15s, height .22s;
}

/* ── Sidebar recolhível ──────────────────────────────── */
.sidebar { transition: width .22s cubic-bezier(.4,0,.2,1); }

.sidebar.nav-collapsed { width: 64px !important; min-width: 64px !important; }

/* Logo */
.sidebar.nav-collapsed .bv-logo-text,
.sidebar.nav-collapsed .tenant-logo-wrap span { display: none; }
.sidebar.nav-collapsed .sidebar-logo-wrap {
  justify-content: center;
  padding: 0;
}

/* Seções: viram divisores finos */
.sidebar.nav-collapsed .nav-section {
  height: 1px; padding: 0 !important; margin: 8px 12px 2px !important;
  background: rgba(255,255,255,.08); overflow: hidden;
  color: transparent !important;
}

/* Links */
.sidebar.nav-collapsed a {
  justify-content: center;
  padding: 9px 0;
}
.sidebar.nav-collapsed a .nav-lbl { display: none; }
.sidebar.nav-collapsed a i {
  font-size: 18px;
  width: auto;
  margin: 0;
  opacity: .82;
}

/* Rodapé */
.sidebar.nav-collapsed .nav-footer-lbl { display: none; }
.sidebar.nav-collapsed .nav-footer-row {
  justify-content: center !important;
}

/* Tooltip dinâmico (injetado via JS) */
.nav-tooltip {
  position: fixed;
  background: #1a2535;
  color: rgba(255,255,255,.92);
  padding: 5px 12px;
  border-radius: 8px;
  font-size: 12.5px;
  font-weight: 500;
  pointer-events: none;
  z-index: 99999;
  white-space: nowrap;
  box-shadow: 0 4px 16px rgba(0,0,0,.4);
  transform: translateY(-50%);
}

/* Botão toggle */
.nav-toggle-btn {
  background: rgba(255,255,255,.1);
  border: none;
  color: rgba(255,255,255,.6);
  border-radius: 50%;
  width: 28px; height: 28px;
  display: flex; align-items: center; justify-content: center;
  cursor: pointer;
  transition: background .15s, color .15s, transform .22s;
  flex-shrink: 0;
}
.nav-toggle-btn:hover {
  background: rgba(255,255,255,.2);
  color: #fff;
}
.sidebar.nav-collapsed .nav-toggle-btn { transform: rotate(180deg); }

/* links */
.sidebar a {
  color: rgba(255,255,255,0.78) !important;
  text-decoration: none;
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 7px 12px;
  border-radius: 7px;
  font-size: 13px;
  font-weight: 500;
  transition: background var(--t-fast), color var(--t-fast);
  margin: 1px 0;
}
.sidebar a:hover {
  background: rgba(255,255,255,0.06) !important;
  color: white !important;
}
.sidebar a.active {
  background: rgba(255,255,255,.10) !important;
  color: white !important;
  box-shadow: inset 2px 0 0 var(--brand-teal);
}
.sidebar a i {
  font-size: 14px;
  width: 16px;
  text-align: center;
  opacity: .72;
  flex-shrink: 0;
}
.sidebar a.active i {
  color: var(--brand-teal);
  opacity: 1;
}

/* ─────────────────────────────────────────────
   TOPBAR
───────────────────────────────────────────── */
.topbar {
  height: var(--topbar-h) !important;
  background: var(--surface) !important;
  border-bottom: 1px solid var(--border) !important;
  padding: 0 24px !important;
}
.bv-crumb {
  display: flex; align-items: center; gap: 10px;
  font-size: 13px; color: var(--text-soft);
}
.bv-crumb-sep  { color: var(--text-faint); }
.bv-crumb-here { color: var(--text); font-weight: 500; }

.bv-userchip {
  display: flex; align-items: center; gap: 10px;
  font-size: 13px; color: var(--text-soft);
}
.bv-avatar {
  width: 28px; height: 28px; border-radius: 50%;
  background: linear-gradient(135deg, #3D1ECC 0%, #2B5BFF 100%);
  color: white;
  display: flex; align-items: center; justify-content: center;
  font-size: 11px; font-weight: 600; flex-shrink: 0;
}
.bv-role {
  font-size: 10.5px; font-weight: 600;
  letter-spacing: 0.06em; text-transform: uppercase;
  padding: 3px 8px; border-radius: 4px;
  background: var(--bg-soft); border: 1px solid var(--border); color: var(--text-mute);
}
.bv-role-admin     { color: var(--violet-700); background: var(--violet-50); border-color: var(--violet-100); }
.bv-role-gerencial { color: var(--navy-700);   background: var(--navy-50);   border-color: var(--navy-100); }

/* User chip clicável */
.bv-userchip-btn {
  display: flex; align-items: center; gap: 10px;
  font-size: 13px; color: var(--text-soft);
  background: none !important;
  border: none !important;
  outline: none !important;
  box-shadow: none !important;
  padding: 5px 8px;
  border-radius: var(--radius-md);
  cursor: pointer;
  transition: background var(--t-fast);
}
.bv-userchip-btn:hover         { background: var(--bg-soft) !important; }
.bv-userchip-btn:focus         { background: none !important; outline: none !important; box-shadow: none !important; border: none !important; }
.bv-userchip-btn:focus-visible { outline: none !important; box-shadow: none !important; border: none !important; }
.bv-userchip-btn:active        { background: var(--bg-soft) !important; outline: none !important; box-shadow: none !important; border: none !important; }
.bv-userchip-btn.show          { background: var(--bg-soft) !important; outline: none !important; box-shadow: none !important; border: none !important; }
.bv-userchip-btn::after        { display: none !important; } /* remove seta Bootstrap */

/* Dropdown do usuário */
.bv-user-dropdown {
  min-width: 220px;
  border: 1px solid var(--border) !important;
  border-radius: var(--radius-lg) !important;
  box-shadow: var(--shadow-md) !important;
  padding: 6px 0 !important;
  background: var(--surface) !important;
}
.bv-user-dropdown .dropdown-header {
  padding: 10px 16px 8px;
  border-bottom: 1px solid var(--border);
  margin-bottom: 4px;
}
.bv-user-dropdown .dropdown-item {
  display: flex; align-items: center; gap: 10px;
  font-size: 13px; color: var(--text-soft) !important;
  padding: 8px 16px;
  border-radius: 0;
  transition: background var(--t-fast);
}
.bv-user-dropdown .dropdown-item:hover {
  background: var(--bg-soft) !important; color: var(--text) !important;
}
.bv-user-dropdown .dropdown-item.text-danger:hover {
  background: var(--status-red-bg) !important; color: var(--status-red-fg) !important;
}
.bv-user-dropdown .dropdown-item i {
  width: 16px; text-align: center; opacity: .65; font-size: 14px; flex-shrink: 0;
}
.bv-user-dropdown .dropdown-divider {
  border-color: var(--border) !important; margin: 4px 0 !important;
}

/* ─────────────────────────────────────────────
   MAIN CONTENT
───────────────────────────────────────────── */
.main-content { background: var(--bg) !important; }

/* ─────────────────────────────────────────────
   CARDS
───────────────────────────────────────────── */
.card {
  border: 1px solid var(--border) !important;
  border-radius: var(--radius-lg) !important;
  box-shadow: var(--shadow-sm) !important;
}

/* ─────────────────────────────────────────────
   TABELAS
───────────────────────────────────────────── */
.table-light th,
.table thead th {
  background: var(--bg-soft) !important;
  color: var(--text-mute) !important;
  font-size: 11px !important;
  font-weight: 500 !important;
  text-transform: uppercase;
  letter-spacing: .06em;
  border-bottom: 1px solid var(--border) !important;
  padding: 12px 16px !important;
}
.table td {
  padding: 10px 16px !important;
  color: var(--text-soft);
  border-color: var(--border) !important;
  font-size: 13px;
  vertical-align: middle;
}
.table-hover tbody tr:hover td { background: rgba(10,69,129,.025) !important; }

/* ─────────────────────────────────────────────
   STATUS PILLS (tint + dot — padrão Bravva)
───────────────────────────────────────────── */
.bv-pill {
  display: inline-flex; align-items: center; gap: 6px;
  padding: 3px 9px 3px 8px;
  border-radius: var(--radius-pill);
  font-size: 11.5px; font-weight: 500; line-height: 1.4;
  white-space: nowrap;
}
.bv-pill::before {
  content: ""; width: 6px; height: 6px; border-radius: 50%;
  background: currentColor; flex-shrink: 0;
}
.bv-pill-amber  { background: var(--status-amber-bg);  color: var(--status-amber-fg); }
.bv-pill-orange { background: var(--status-orange-bg); color: var(--status-orange-fg); }
.bv-pill-blue   { background: var(--status-blue-bg);   color: var(--status-blue-fg); }
.bv-pill-violet { background: var(--status-violet-bg); color: var(--status-violet-fg); }
.bv-pill-cyan   { background: var(--status-cyan-bg);   color: var(--status-cyan-fg); }
.bv-pill-green  { background: var(--status-green-bg);  color: var(--status-green-fg); }
.bv-pill-red    { background: var(--status-red-bg);    color: var(--status-red-fg); }
.bv-pill-slate  { background: var(--status-slate-bg);  color: var(--status-slate-fg); }

/* ─────────────────────────────────────────────
   BOTÕES
───────────────────────────────────────────── */
.btn {
  border-radius: var(--radius-md) !important;
  font-family: inherit;
  font-weight: 500;
  letter-spacing: -0.003em;
  transition: background var(--t-fast), border-color var(--t-fast), box-shadow var(--t-fast);
}
.btn-primary,
.btn[style*="background:var(--tenant-color)"] {
  background-color: var(--brand-navy) !important;
  border-color: var(--brand-navy) !important;
  color: white !important;
  box-shadow: var(--shadow-xs), inset 0 1px 0 rgba(255,255,255,.10);
}
.btn-primary:hover,
.btn[style*="background:var(--tenant-color)"]:hover {
  background-color: var(--navy-700) !important;
  border-color: var(--navy-700) !important;
}
.btn-outline-primary {
  color: var(--brand-navy) !important;
  border-color: var(--brand-navy) !important;
}
.btn-outline-primary:hover {
  background-color: var(--brand-navy) !important;
  color: white !important;
}
.btn-outline-secondary {
  color: var(--text-soft) !important;
  border-color: var(--border-strong) !important;
}
.btn-outline-secondary:hover {
  background: var(--bg-soft) !important;
  color: var(--text) !important;
  border-color: var(--border-strong) !important;
}

/* ─────────────────────────────────────────────
   FORMS
───────────────────────────────────────────── */
.form-control,
.form-select {
  border-color: var(--border-strong) !important;
  border-radius: var(--radius-md) !important;
  font-family: inherit;
  color: var(--text);
  font-size: 13.5px;
}
.form-control:focus,
.form-select:focus {
  border-color: var(--brand-navy) !important;
  box-shadow: var(--shadow-focus) !important;
}
.form-control-sm,
.form-select-sm {
  font-size: 12.5px !important;
  border-radius: var(--radius-sm) !important;
}
.form-label {
  font-size: 12px;
  font-weight: 500;
  color: var(--text-soft);
  margin-bottom: 5px;
}
.form-text { color: var(--text-mute); font-size: 11.5px; }

/* ─────────────────────────────────────────────
   KPI CARDS (dashboard)
───────────────────────────────────────────── */
.kpi-label {
  font-size: 11px; font-weight: 500;
  text-transform: uppercase; letter-spacing: .06em;
  color: var(--text-mute); margin: 0 0 10px;
}
.kpi-value {
  font-size: 32px; font-weight: 600;
  letter-spacing: -0.025em; color: var(--text);
  font-variant-numeric: tabular-nums; line-height: 1; margin: 0;
}
.kpi-delta { font-size: 12px; margin: 10px 0 0; color: var(--text-mute); }
.kpi-delta.up   { color: var(--status-green-fg); }
.kpi-delta.down { color: var(--status-red-fg); }

/* ─────────────────────────────────────────────
   FILTER CHIPS (barra de status na lista)
   Reutiliza as cores bv-pill-* sem o dot/padding do pill
───────────────────────────────────────────── */
.bv-status-chip {
  display: inline-flex; align-items: center; gap: 7px;
  padding: 5px 12px;
  border-radius: var(--radius-pill);
  font-size: 12px; font-weight: 500; line-height: 1.4;
  text-decoration: none; white-space: nowrap; cursor: pointer;
  border: 1.5px solid transparent;
  transition: border-color var(--t-fast), filter var(--t-fast);
}
.bv-status-chip:hover { filter: brightness(.94); text-decoration: none; }
.bv-status-chip.is-active { border-color: currentColor; }

/* "Todos" — neutral / navy ativo */
.bv-chip-all {
  background: var(--bg-soft); color: var(--text-soft);
  border-color: var(--border-strong);
}
.bv-chip-all.is-active {
  background: var(--brand-navy); color: white; border-color: var(--brand-navy);
}
.bv-chip-all.is-active .bv-chip-count { background: rgba(255,255,255,.18); }

/* Contagem */
.bv-chip-count {
  font-size: 10.5px; font-weight: 600;
  padding: 0 5px; border-radius: 3px;
  background: rgba(0,0,0,.09);
  font-variant-numeric: tabular-nums; line-height: 1.6;
}

/* ─────────────────────────────────────────────
   BADGES — não-status (tipo PF/PJ, etc.)
───────────────────────────────────────────── */
.badge { border-radius: var(--radius-xs) !important; font-weight: 500 !important; }
