/* Notificações in-app — bell no header + dropdown + página /notificacoes.
   Tokens reusam --bp-* já definidos em tokens.css/app.css. */

/* ── Bell wrapper (no header) ──────────────────────────────────────────── */

.bp-notif-wrap {
  position: relative;
  display: inline-flex;
  align-items: center;
  margin: 0 4px 0 -2px;
}

.bp-notif-bell {
  position: relative;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 34px;
  height: 34px;
  padding: 0;
  margin: 0;
  background: transparent;
  border: 1px solid transparent;
  border-radius: var(--bp-r);
  cursor: pointer;
  color: var(--bp-ink-mute, rgba(255,255,255,.7));
  font-size: 16px;
  transition: background .15s ease, border-color .15s ease, color .15s ease;
}

.bp-notif-bell:hover,
.bp-notif-bell[aria-expanded="true"] {
  background: rgba(255,255,255,.04);
  border-color: rgba(255,255,255,.08);
  color: var(--bp-ink, #fff);
}

.bp-notif-bell.has-unread {
  color: var(--bp-ink, #fff);
}

.bp-notif-bell-icon {
  font-size: 16px;
  line-height: 1;
}

.bp-notif-bell-count {
  position: absolute;
  top: 2px;
  right: 2px;
  min-width: 16px;
  height: 16px;
  padding: 0 4px;
  background: #e74c3c;
  color: #fff;
  font-size: 10px;
  font-weight: 700;
  line-height: 16px;
  text-align: center;
  border-radius: var(--bp-r);
  pointer-events: none;
}

/* ── Dropdown ──────────────────────────────────────────────────────────── */

.bp-notif-dropdown {
  position: absolute;
  top: calc(100% + 8px);
  right: 0;
  width: 360px;
  max-width: calc(100vw - 24px);
  max-height: 70vh;
  display: flex;
  flex-direction: column;
  /* Mais opaco que glass-bg-strong (0.85) — dropdown não pode deixar conteúdo
     atrás "sangrar". Stack: cor base sólida + leve overlay azul subliminar. */
  background:
    linear-gradient(180deg, rgba(28, 32, 38, 0.96), rgba(20, 24, 28, 0.96)),
    var(--bp-blue-glow);
  background-blend-mode: normal, screen;
  backdrop-filter: var(--bp-glass-blur-strong);
  -webkit-backdrop-filter: var(--bp-glass-blur-strong);
  border: 1px solid var(--bp-line-strong);
  border-top-color: rgba(255,255,255,0.10);
  border-radius: var(--bp-r-lg);
  box-shadow: var(--bp-shadow-elevated);
  z-index: 1000;
  overflow: hidden;
  animation: bp-notif-pop .14s ease-out;
}

@keyframes bp-notif-pop {
  from { opacity: 0; transform: translateY(-4px); }
  to   { opacity: 1; transform: translateY(0); }
}

.bp-notif-dd-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 12px 14px;
  border-bottom: 1px solid var(--bp-line, rgba(255,255,255,.06));
}

.bp-notif-dd-title {
  font-size: 13px;
  font-weight: 700;
  color: var(--bp-ink, #fff);
  letter-spacing: .02em;
}

.bp-notif-dd-markall,
.bp-notif-page-markall {
  background: transparent;
  border: 0;
  color: var(--bp-teal, var(--bp-blue));
  font-size: 11px;
  text-transform: uppercase;
  letter-spacing: .08em;
  cursor: pointer;
  padding: 2px 4px;
  border-radius: var(--bp-r-sm);
}
.bp-notif-dd-markall:hover,
.bp-notif-page-markall:hover {
  background: rgba(0, 153, 255,.08);
}

.bp-notif-dd-body {
  flex: 1;
  overflow-y: auto;
  min-height: 80px;
  max-height: 56vh;
}

.bp-notif-dd-seeall {
  display: block;
  padding: 10px 14px;
  text-align: center;
  font-size: 12px;
  color: var(--bp-ink-mute, rgba(255,255,255,.65));
  text-decoration: none;
  border-top: 1px solid var(--bp-line, rgba(255,255,255,.06));
  background: rgba(255,255,255,.02);
  letter-spacing: .02em;
}
.bp-notif-dd-seeall:hover {
  color: var(--bp-ink, #fff);
  background: rgba(255,255,255,.04);
}

/* ── Notification item ─────────────────────────────────────────────────── */

.bp-notif-item {
  position: relative;
  display: flex;
  align-items: flex-start;
  gap: 10px;
  padding: 10px 14px;
  text-decoration: none;
  color: var(--bp-ink, #fff);
  border-bottom: 1px solid var(--bp-line, rgba(255,255,255,.04));
  transition: background .12s ease;
  cursor: pointer;
}
.bp-notif-item:last-child {
  border-bottom: 0;
}
.bp-notif-item:hover {
  background: rgba(255,255,255,.025);
}

.bp-notif-item.is-unread {
  background: rgba(0, 153, 255,.04);
}
.bp-notif-item.is-unread:hover {
  background: rgba(0, 153, 255,.06);
}

.bp-notif-item.is-compact {
  padding: 8px 14px;
}

.bp-notif-icon {
  flex: 0 0 auto;
  width: 24px;
  height: 24px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border-radius: 50%;
  background: rgba(255,255,255,.06);
  font-size: 13px;
  margin-top: 2px;
}

.bp-notif-body {
  flex: 1;
  min-width: 0;
}

.bp-notif-text {
  font-size: 13px;
  line-height: 1.45;
  color: var(--bp-ink, #fff);
}
.bp-notif-text strong {
  font-weight: 600;
  color: var(--bp-ink, #fff);
}
.bp-notif-text em {
  font-style: normal;
  color: var(--bp-teal, var(--bp-blue));
  font-weight: 500;
}

.bp-notif-meta {
  display: flex;
  align-items: center;
  gap: 10px;
  margin-top: 4px;
  font-size: 11px;
  color: var(--bp-ink-faint, rgba(255,255,255,.45));
}

.bp-notif-meta time {
  white-space: nowrap;
}

.bp-notif-markread {
  background: transparent;
  border: 0;
  color: var(--bp-ink-faint, rgba(255,255,255,.5));
  font-size: 11px;
  cursor: pointer;
  padding: 0;
  text-decoration: underline dotted;
}
.bp-notif-markread:hover {
  color: var(--bp-teal, var(--bp-blue));
}

.bp-notif-dot {
  flex: 0 0 auto;
  width: 8px;
  height: 8px;
  margin-top: 8px;
  background: var(--bp-teal, var(--bp-blue));
  border-radius: 50%;
  box-shadow: 0 0 0 2px rgba(0, 153, 255,.18);
}

.bp-notif-empty {
  padding: 28px 14px;
  text-align: center;
  font-size: 13px;
  color: var(--bp-ink-faint, rgba(255,255,255,.45));
}

/* ── Página /notificacoes ──────────────────────────────────────────────── */

.bp-notif-page {
  max-width: 760px;
  margin: 24px auto 80px;
  padding: 0 20px;
}

.bp-notif-page-header {
  margin-bottom: 16px;
}

.bp-notif-page-title {
  font-size: 22px;
  font-weight: 700;
  letter-spacing: -0.01em;
  margin: 0 0 12px;
  color: var(--bp-ink, #fff);
}

.bp-notif-page-tools {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  flex-wrap: wrap;
}

.bp-notif-filter {
  display: inline-flex;
  background: var(--bp-bg-elev, #14181c);
  border: 1px solid var(--bp-line, rgba(255,255,255,.08));
  border-radius: var(--bp-r);
  padding: 2px;
}
.bp-notif-filter button {
  background: transparent;
  border: 0;
  color: var(--bp-ink-mute, rgba(255,255,255,.65));
  padding: 6px 14px;
  font-size: 12px;
  font-weight: 500;
  cursor: pointer;
  border-radius: 6px;
  transition: background .12s ease, color .12s ease;
}
.bp-notif-filter button.is-active {
  background: var(--bp-teal, var(--bp-blue));
  color: #062018;
}
.bp-notif-filter-count {
  display: inline-block;
  margin-left: 6px;
  padding: 1px 6px;
  background: rgba(0,0,0,.18);
  color: inherit;
  font-size: 10px;
  font-weight: 700;
  border-radius: var(--bp-r);
}

.bp-notif-page-list {
  background: var(--bp-bg-elev, #14181c);
  border: 1px solid var(--bp-line, rgba(255,255,255,.06));
  border-radius: var(--bp-r-lg);
  overflow: hidden;
}
.bp-notif-page-list .bp-notif-item:last-child {
  border-bottom: 0;
}

.bp-notif-page-more {
  text-align: center;
  margin-top: 16px;
}

/* ── BpNav user link (clica pra ir pro próprio perfil) ─────────────────── */

.bp-nav-user-link {
  text-decoration: none;
  cursor: pointer;
  padding: 4px 8px;
  border-radius: var(--bp-r);
  transition: background .12s ease;
}
.bp-nav-user-link:hover {
  background: rgba(255,255,255,.04);
}
.bp-nav-user-link:hover .bp-nav-user-name {
  color: var(--bp-teal, var(--bp-blue));
}

/* ── Mobile ────────────────────────────────────────────────────────────── */

@media (max-width: 640px) {
  .bp-notif-dropdown {
    position: fixed;
    top: 56px;
    right: 8px;
    left: 8px;
    width: auto;
    max-height: calc(100vh - 80px);
  }
  .bp-notif-page {
    padding: 0 12px;
    margin-top: 16px;
  }
}
