Componentes
Navegação
Bottom Navigation com 5 itens: 4 tabs (Início, Feed, Coleção, Perfil) e um FAB central de adição. Ativo em branco, inativo em cinza com opacity-40.
Visão geral
Anatomia
Container
fixed bottom-0 inset-x-0 bg-[#0f0f0f] border-t border-[#1a1a1a] pb-safe z-20
Tab item
flex flex-col items-center gap-1 flex-1 · ícone 22×22 + label 9px · tap target 48×48
Estado ativo
Ícone stroke="#f5f5f5" + label text-[#f5f5f5]. Sem underline ou ponto — cor é o único diferenciador.
FAB de adição
bg-[#C8F53C] rounded-[14px] w-12 h-10 · ícone + stroke="#0f0f0f" · sem label · abre fluxo de Adicionar disco
Tab de Perfil
Avatar do usuário logado (não ícone Lucide) · w-[22px] rounded-full · label exibe display_name truncado
Itens
Home. Destino: tela Home com Feed dos seguidos e destaques.AlignLeft. Feed global de postagens recentes de toda a comunidade.Grid2x2. Coleção pessoal do usuário logado + Listas.display_name truncado. Destino: Perfil, seguidores e notificações.Badge de notificação
Badge com número
absolute -top-1 -right-1.5
w-4 h-4 bg-[#C8F53C] text-[#0f0f0f]
text-[9px] font-bold rounded-full
flex items-center justify-center
Badge ponto
absolute top-0 right-0
w-[9px] h-[9px] bg-[#C8F53C]
rounded-full border-[1.5px] border-[#0f0f0f]
Estados
stroke="#f5f5f5" · text-[#f5f5f5] font-semibold · sem opacity modifieropacity-40 no container do item · stroke="#888" · text-[#888]active:opacity-60 — feedback tátil no toqueactive:bg-[#a8cf1e] — verde ligeiramente mais escuro no toqueDo / Don't
FAB abre modal/sheet de adição
Não navega para uma rota fixa
FAB navega para /adicionar
FAB fica ativo como tab
Specs
| Propriedade | Valor |
|---|---|
| Posição | fixed bottom-0 inset-x-0 |
| Background | #0f0f0f |
| Border top | 1px solid #1a1a1a |
| Padding | py-2 px-3 |
| Padding bottom | pb-safe → env(safe-area-inset-bottom) |
| z-index | z-20 |
| Ícone das tabs | Lucide · 22×22 px · stroke 2 |
| Label das tabs | text-[9px] font-medium (ativo: font-semibold) |
| Tab ativa | stroke="#f5f5f5" text-[#f5f5f5] · sem opacity |
| Tab inativa | stroke="#888" text-[#888] opacity-40 |
| Avatar (Perfil) | w-[22px] h-[22px] rounded-full |
| FAB background | #C8F53C · pressed: #a8cf1e |
| FAB dimensões | w-12 h-10 rounded-[14px] (48×40px) |
| FAB ícone | + Lucide · 22×22 · stroke="#0f0f0f" · strokeWidth 2.5 |
| Badge (notificação) | w-4 h-4 bg-[#C8F53C] text-[#0f0f0f] rounded-full text-[9px] font-bold |