/*
 * BARRA LATERAL (navegação)
 * Fixa à esquerda no desktop, visível apenas quando logado. Contém o
 * nome do app, grupos de navegação e, na base, o perfil (conta/plano).
 * No mobile vira menu retrátil (etapa posterior).
 */

/* Estrutura geral: sidebar + área de conteúdo lado a lado. */
.layout {
  display: flex;
  min-height: 100vh;
}

.sidebar {
  display: flex;
  flex-direction: column;
  width: 16rem;
  flex-shrink: 0;
  background-color: var(--color-surface);
  border-right: var(--border-width) solid var(--color-border);
  /* Fixa: acompanha a rolagem, só o conteúdo rola. */
  position: sticky;
  top: 0;
  height: 100vh;
}

/* Área de navegação: cresce e empurra o rodapé para baixo. */
.sidebar__nav {
  flex: 1;
  padding: var(--space-2);
  overflow-y: auto;
}

/* Rótulo de um grupo (ex.: Cadastros). */
.sidebar__group-label {
  display: block;
  width: 100%;
  padding: var(--space-2) var(--space-3);
  font-size: var(--text-xs);
  font-weight: var(--weight-medium);
  text-transform: uppercase;
  letter-spacing: 0.03em;
  color: var(--color-text-muted);
  text-align: left;
  cursor: pointer;
}

/* Lista de itens de um grupo. */
.sidebar__items {
  display: flex;
  flex-direction: column;
  gap: 2px;
  margin-bottom: var(--space-3);
}

/* Item de navegação: hover de fundo sutil, texto estável. */
.sidebar__item {
  display: block;
  padding: var(--space-2) var(--space-3);
  border-radius: var(--radius-md);
  font-size: var(--text-sm);
  color: var(--color-text);
  text-decoration: none;
  transition: background-color 0.15s ease;
}

.sidebar__item:hover {
  background-color: var(--color-hover);
  text-decoration: none;
}

/* Item da página atual: destacado. */
.sidebar__item--active {
  background-color: var(--color-hover);
  font-weight: var(--weight-medium);
}

/* Rodapé: o perfil. */
.sidebar__footer {
  padding: var(--space-2);
  border-top: var(--border-width) solid var(--color-border);
}

/* Perfil no rodapé: avatar + nome + plano, abre menu ao clicar. Sobrescreve o
   display:inline-block do .dropdown para ocupar a largura toda do rodapé (senão
   o bloco encolhe ao conteúdo e fica "recuado"). */
.sidebar__profile {
  position: relative;
  display: block;
}

.sidebar__profile-trigger {
  display: flex;
  align-items: center;
  gap: var(--space-3);
  width: 100%;
  padding: var(--space-2) var(--space-3);
  border-radius: var(--radius-md);
  cursor: pointer;
  text-align: left;
  transition: background-color 0.15s ease;
}

.sidebar__profile-trigger:hover {
  background-color: var(--color-hover);
}

/* Avatar: círculo com a inicial. */
.sidebar__avatar {
  flex-shrink: 0;
  width: 2rem;
  height: 2rem;
  border-radius: var(--radius-full);
  background-color: var(--color-accent);
  color: var(--color-accent-text);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: var(--text-sm);
  font-weight: var(--weight-semibold);
  text-transform: uppercase;
}

/* Bloco de texto do perfil: nome em cima, papel embaixo (empilhados). */
.sidebar__profile-info {
  min-width: 0;
  flex: 1;
  display: flex;
  flex-direction: column;
}

.sidebar__profile-name {
  font-size: var(--text-sm);
  color: var(--color-text);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.sidebar__profile-plan {
  font-size: var(--text-xs);
  color: var(--color-text-muted);
}

/* O menu do perfil abre para cima (está no rodapé). */
.sidebar__profile .dropdown__menu {
  bottom: calc(100% + var(--space-1));
  top: auto;
  left: 0;
  right: 0;
}

/* Área de conteúdo à direita da sidebar. */
.content {
  flex: 1;
  min-width: 0;
}

/* Plano numa linha só (não quebrar). */
.sidebar__profile-plan {
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

/* Setas (chevron) indicando que o perfil abre um menu. */
.sidebar__profile-chevron {
  flex-shrink: 0;
  color: var(--color-text-muted);
  font-size: var(--text-xs);
  line-height: 1;
}

/* Item do menu com ícone + texto lado a lado. */
.sidebar__item {
  display: flex;
  align-items: center;
  gap: var(--space-3);
}

.sidebar__icon {
  flex-shrink: 0;
  width: 1.125rem;
  height: 1.125rem;
}

/* ===== ESTADO RECOLHIDO ===== */
/* Quando recolhida, a sidebar vira uma faixa estreita só com ícones. */
.sidebar--collapsed {
  width: 4rem;
}

/* Esconde os textos dos itens. */
.sidebar--collapsed .sidebar__item-text,
.sidebar--collapsed .sidebar__group-label,
.sidebar--collapsed .sidebar__profile-info,
.sidebar--collapsed .sidebar__profile-chevron {
  display: none;
}

/* Centraliza ícones e avatar na faixa estreita. */
.sidebar--collapsed .sidebar__item,
.sidebar--collapsed .sidebar__profile-trigger {
  justify-content: center;
}

/* Recolhida, o menu do perfil não cabe na faixa de 4rem: dá largura própria
   e deixa extravasar para a direita (em vez de espremer o seletor de tema). */
.sidebar--collapsed .sidebar__profile .dropdown__menu {
  right: auto;
  left: 0;
  min-width: 14rem;
}

/* Cabeçalho da sidebar: nome do sistema à esquerda + botão de recolher à direita. */
.sidebar__header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--space-2);
  padding: var(--space-3) var(--space-4);
}

/* Nome do sistema (wordmark): texto, sem logo. Trunca se faltar espaço. */
.sidebar__wordmark {
  min-width: 0;
  font-size: var(--text-base);
  font-weight: var(--weight-semibold);
  color: var(--color-text);
  text-decoration: none;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.sidebar__wordmark:hover {
  text-decoration: none;
}

/* Recolhida: o nome some, sobra só o botão de expandir. */
.sidebar--collapsed .sidebar__wordmark {
  display: none;
}

.sidebar__toggle {
  flex-shrink: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  width: 2rem;
  height: 2rem;
  border-radius: var(--radius-md);
  color: var(--color-text-muted);
  cursor: pointer;
  transition: background-color 0.15s ease;
}

.sidebar__toggle:hover {
  background-color: var(--color-hover);
}

.sidebar__toggle svg {
  width: 1.125rem;
  height: 1.125rem;
}

/* Recolhida: o botão de expandir fica centralizado na faixa estreita. */
.sidebar--collapsed .sidebar__header {
  justify-content: center;
}

.sidebar--collapsed .sidebar__toggle svg {
  transform: rotate(180deg);
}

/* Recolhida: como o rótulo do grupo some, dá um respiro acima dos ícones. */
.sidebar--collapsed .sidebar__items {
  margin-top: var(--space-3);
}

/* ===== RESPONSIVO: MOBILE (< 1024px) ===== */
/* Abaixo do breakpoint, a sidebar vira off-canvas: escondida fora da tela,
   desliza por cima do conteúdo quando aberta, com overlay escuro atrás. */
@media (max-width: 1023px) {
  .sidebar {
    position: fixed;
    top: 0;
    left: 0;
    z-index: 50;
    transform: translateX(-100%);
    transition: transform 0.2s ease;
  }

  /* Aberta: desliza para dentro. */
  .sidebar--open {
    transform: translateX(0);
  }

  /* No mobile, ignoramos o estado recolhido (sempre largura cheia). */
  .sidebar--collapsed {
    width: 16rem;
  }

  .sidebar--collapsed .sidebar__item-text,
  .sidebar--collapsed .sidebar__group-label,
  .sidebar--collapsed .sidebar__profile-info,
  .sidebar--collapsed .sidebar__profile-chevron,
  .sidebar--collapsed .sidebar__wordmark {
    display: revert;
  }

  /* Overlay escuro atrás da sidebar aberta. */
  .sidebar-overlay {
    position: fixed;
    inset: 0;
    z-index: 40;
    background-color: rgba(0, 0, 0, 0.5);
  }
}

/* O overlay nunca aparece no desktop. */
@media (min-width: 1024px) {
  .sidebar-overlay {
    display: none;
  }
}

/* ===== TOPBAR (barra fixa: título + busca + ações) ===== */
/* Fixa no topo da área de conteúdo. Título à esquerda (via content_for
   :page_title, com fallback na marca), busca ao centro e ações à direita
   (via content_for :topbar_actions). O hambúrguer só aparece no mobile. */
.topbar {
  display: flex;
  align-items: center;
  gap: var(--space-4);
  padding: var(--space-3) var(--space-5);
  border-bottom: var(--border-width) solid var(--color-border);
  background-color: var(--color-surface);
  position: sticky;
  top: 0;
  z-index: 30;
}

/* Hambúrguer: escondido no desktop, visível no mobile. flex-shrink:0 para não
   ser espremido a zero pela busca/ações quando a topbar fica apertada. */
.topbar__toggle {
  display: none;
  flex-shrink: 0;
  align-items: center;
  justify-content: center;
  width: 2.25rem;
  height: 2.25rem;
  border-radius: var(--radius-md);
  color: var(--color-text);
  cursor: pointer;
  transition: background-color 0.15s ease;
}

.topbar__toggle:hover {
  background-color: var(--color-hover);
}

.topbar__toggle svg {
  width: 1.375rem;
  height: 1.375rem;
}

/* Título da página (ou marca, no fallback). */
.topbar__title {
  flex-shrink: 0;
  font-size: var(--text-lg);
  font-weight: var(--weight-semibold);
  color: var(--color-text);
}

.topbar__brand {
  color: var(--color-text);
  text-decoration: none;
}

/* Busca global: centralizada na topbar, ocupa o espaço livre até um teto.
   Só o posicionamento; o visual do campo vem do .search-box. O seletor composto
   vence o max-width:100% do .search-box para não esticar a largura toda. */
.search-box.topbar__search {
  flex: 1;
  max-width: 28rem;
  margin: 0 auto;
}

/* Ações à direita (botões da página). */
.topbar__actions {
  flex-shrink: 0;
  display: flex;
  align-items: center;
  gap: var(--space-2);
}

/* No mobile: hambúrguer aparece e a busca recolhe. Topbar mais compacta
   (menos padding/gap) e o título pode truncar — assim hambúrguer e ações não
   se atropelam na largura estreita. */
@media (max-width: 1023px) {
  .topbar {
    gap: var(--space-2);
    padding: var(--space-3);
  }

  .topbar__toggle {
    display: flex;
  }

  /* Seletor composto vence o .search-box { display:flex } de outro arquivo
     (mesma especificidade, mas carregado depois). */
  .search-box.topbar__search {
    display: none;
  }

  .topbar__title {
    flex-shrink: 1;
    min-width: 0;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
  }
}
