/* ─────────────────────────────────────────────
   PeçaRadar — Sidebar
   
   ATENÇÃO: Os botões de categoria aqui usam .sidebar-cat-btn
   para não conflitar com .cat-btn definido em topbar.css.
   Atualize o JS/HTML que renderiza os botões da sidebar
   para usar a classe .sidebar-cat-btn.
───────────────────────────────────────────── */

#sidebar {
  width: var(--sidebar-w, 240px);
  background: var(--bg-dark);
  border-right: 1px solid rgba(255, 255, 255, 0.05);
  display: flex;
  flex-direction: column;
  overflow-y: auto;
  color: #fff;

  /* Sidebar fixa enquanto o conteúdo scrolla */
  position: fixed;
  top: 0;
  left: 0;
  height: 100vh;
  z-index: 900; /* abaixo do topbar (z-index: 1000) */
}

/* ── Seções ── */

.sidebar-section { padding: 14px 12px 6px; }

.sidebar-section-label {
  font-size: 10px;
  font-weight: 500;
  letter-spacing: 1px;
  text-transform: uppercase;
  color: rgba(255, 255, 255, 0.4);
  padding: 0 8px;
  margin-bottom: 6px;
}

/* ── Botões de categoria da sidebar ──
   Classe isolada para não conflitar com .cat-btn do topbar.css
── */

.sidebar-cat-btn {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 9px 10px;
  border-radius: var(--r-md, 8px);
  font-size: 13.5px;
  color: rgba(255, 255, 255, 0.7);
  background: transparent;
  border: none;
  width: 100%;
  text-align: left;
  cursor: pointer;
  transition: all var(--t, 0.15s ease);
}

.sidebar-cat-btn:hover  { background: rgba(255, 255, 255, 0.05); color: #fff; }
.sidebar-cat-btn.active { background: var(--tag-bg); color: var(--accent); }

.sidebar-cat-btn .icon {
  font-size: 16px;
  width: 22px;
  text-align: center;
  flex-shrink: 0;
}

.sidebar-cat-btn .badge {
  margin-left: auto;
  background: var(--accent);
  color: #fff;
  font-size: 10px;
  font-weight: 600;
  padding: 2px 6px;
  border-radius: 20px;
  display: none;
}

.sidebar-cat-btn.active .badge,
.sidebar-cat-btn:hover  .badge { display: inline; }

/* ── Stats footer ──
   Seletores isolados com prefixo .sidebar- para não
   conflitar com .stat-row/.stat-label/.stat-val do topbar.css
── */

.sidebar-stats {
  padding: 12px 20px 18px;
  margin-top: auto;
  border-top: 1px solid rgba(255, 255, 255, 0.05);
}

.sidebar-stat-row {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-bottom: 8px;
}

.sidebar-stat-label { font-size: 11px; color: var(--muted); }
.sidebar-stat-val   { font-size: 13px; color: #fff; font-weight: 500; }

/* ── Responsividade ── */

/* Em tablet/mobile a sidebar fica oculta — pages.css controla via state */
@media (max-width: 950px) {
  #sidebar {
    /* Sidebar some em telas menores.
       pages.css já faz display:none via body.state-landing,
       mas em state-dashboard em mobile também deve sumir. */
    display: none;
  }
}