/*
 * NOTIFICATIONS — sino da topbar + painel suspenso.
 * O sino reusa o .dropdown (position relative) e o dropdown_controller. O badge
 * fica ancorado no canto do botão. O painel reaproveita o .dropdown__menu para
 * flutuar/posicionar; aqui só largura e o conteúdo (lista de alertas/eventos).
 */
.notif {
  flex-shrink: 0;
}

/* Botão do sino: mesmo tamanho/afeto do hambúrguer da topbar. */
.notif__bell {
  position: relative;
  display: flex;
  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;
}

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

.notif__bell svg {
  width: 1.25rem;
  height: 1.25rem;
}

/* Contagem de não-lidos: pílula sobre o canto superior direito do sino. */
.notif__badge {
  position: absolute;
  top: 0.125rem;
  right: 0.125rem;
  min-width: 1.05rem;
  height: 1.05rem;
  padding: 0 0.25rem;
  display: flex;
  align-items: center;
  justify-content: center;
  border-radius: var(--radius-full);
  background-color: var(--color-danger);
  color: var(--color-danger-text);
  font-size: var(--text-xs);
  font-weight: var(--weight-semibold);
  line-height: 1;
}

/* Painel: largura própria; posição/sombra vêm do .dropdown__menu. */
.notif__panel {
  width: 20rem;
  max-width: calc(100vw - var(--space-5) * 2);
  padding: 0;
}

.notif__loading {
  padding: var(--space-4);
  color: var(--color-text-muted);
  font-size: var(--text-sm);
  text-align: center;
}

/* Conteúdo do painel (renderizado pela turbo-frame de notifications#index). */
.notif-list {
  display: flex;
  flex-direction: column;
}

.notif-list__heading {
  padding: var(--space-2) var(--space-3) var(--space-1);
  color: var(--color-text-muted);
  font-size: var(--text-xs);
  font-weight: var(--weight-semibold);
  text-transform: uppercase;
  letter-spacing: 0.04em;
}

.notif-list__empty {
  padding: var(--space-3);
  color: var(--color-text-muted);
  font-size: var(--text-sm);
}

.notif-list__footer {
  padding: var(--space-2) var(--space-3) var(--space-3);
  border-top: var(--border-width) solid var(--color-border);
}

/* Cada item: bloco clicável com hover discreto. */
.notif-item {
  display: flex;
  flex-direction: column;
  gap: 0.125rem;
  padding: var(--space-2) var(--space-3);
  border-radius: var(--radius-sm);
  color: var(--color-text);
  text-decoration: none;
  transition: background-color 0.15s ease;
}

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

.notif-item__title {
  font-size: var(--text-sm);
  font-weight: var(--weight-medium);
}

.notif-item__detail,
.notif-item__meta {
  font-size: var(--text-xs);
  color: var(--color-text-muted);
}

/* Alertas: linha com contagem em destaque à esquerda do rótulo. */
.notif-item--warning,
.notif-item--danger {
  flex-direction: row;
  align-items: center;
  gap: var(--space-2);
  font-size: var(--text-sm);
}

.notif-item__count {
  flex-shrink: 0;
  min-width: 1.5rem;
  text-align: center;
  font-weight: var(--weight-semibold);
}

.notif-item--warning .notif-item__count {
  color: var(--color-warning);
}

.notif-item--danger .notif-item__count {
  color: var(--color-danger);
}

/* ---------------------------------------------------------------------------
 * Página "ver todas": o mesmo _panel renderizado dentro de um .card.
 * Sem o footer "Ver todas" (link para si mesmo, escondido via in_panel=false).
 * Itens alinham às bordas do card (margem negativa compensa o padding do card),
 * para o hover ocupar a linha inteira; tipografia um pouco mais confortável.
 * ------------------------------------------------------------------------- */
.card .notif-list {
  gap: var(--space-1);
}

.card .notif-list__heading {
  padding-left: 0;
  padding-right: 0;
}

.card .notif-list__heading:not(:first-child) {
  margin-top: var(--space-3);
}

.card .notif-item {
  padding-left: var(--space-3);
  padding-right: var(--space-3);
  margin-left: calc(var(--space-3) * -1);
  margin-right: calc(var(--space-3) * -1);
}

.card .notif-item__title {
  font-size: var(--text-base);
}

/* ---------------------------------------------------------------------------
 * Mobile: o painel do sino vira uma folha de largura total ancorada ao topo,
 * em vez de uma caixinha estreita e cortada pela borda da tela.
 * ------------------------------------------------------------------------- */
@media (max-width: 640px) {
  .notif__panel {
    position: fixed;
    top: 3.5rem;
    left: var(--space-3);
    right: var(--space-3);
    width: auto;
    max-width: none;
    max-height: calc(100vh - 4.5rem);
    overflow-y: auto;
  }
}
