/* ===========================================================================
   MOBILE-FIRST RESET + FUNDAÇÃO
   ===========================================================================
   Todo o redesign mobile do Banco de Ideias BP (iPhone 13 Pro 390×844 alvo).
   Carregado DEPOIS de app.css + community.css pra sobrepor estilos legacy.
   Plano: docs/plans/groovy-yawning-tower.md (mobile-first, refs Steam +
   Instagram + 9gag).
   =========================================================================== */


/* ── 1. Box-sizing global ──────────────────────────────────────────────────
   Garante que padding/border não estouram width. Default já é content-box
   herdado, mas trocamos pra border-box em todos os elementos pra cálculos
   previsíveis. */
*,
*::before,
*::after {
  box-sizing: border-box;
}


/* ── 2. Containers raiz: nunca scroll horizontal ───────────────────────────
   Regra inegociável do redesign. O único scroll lateral aceito é DENTRO de
   um componente (carrossel/chips/tabs). Body com overflow-x:hidden bloqueia
   qualquer leak de elemento absolute/fixed estourando a viewport. */
html,
body {
  max-width: 100vw;
  overflow-x: clip;            /* `clip` é mais robusto que `hidden` (não cria scroll context) */
}


/* ── 3. Safe-area insets pra iPhone notch + home indicator ─────────────────
   Variáveis exportadas no :root pra qualquer componente usar. */
:root {
  --bp-safe-top:    env(safe-area-inset-top, 0px);
  --bp-safe-bottom: env(safe-area-inset-bottom, 0px);
  --bp-safe-left:   env(safe-area-inset-left, 0px);
  --bp-safe-right:  env(safe-area-inset-right, 0px);

  /* Alturas das chrome bars (top + bottom nav) — usado em padding-top/bottom
     dos scroll containers pra conteúdo não ficar coberto. */
  --bp-topbar-h:    56px;
  --bp-bottomnav-h: 60px;
}


/* ── 4. iOS Safari: input com font-size < 16px triggera zoom ───────────────
   Forçar 16px nos inputs evita o behavior. Aplicado em mobile (≤ 768px). */
@media (max-width: 768px) {
  input[type="text"],
  input[type="email"],
  input[type="number"],
  input[type="search"],
  input[type="url"],
  input[type="tel"],
  input[type="password"],
  textarea,
  select {
    font-size: 16px;
  }
}


/* ── 5. Touch targets ≥ 44px (Apple HIG) ───────────────────────────────────
   Botões e links em mobile precisam ser pelo menos 44×44 pra evitar tap
   errado. Aplicamos só em mobile pra não inflar desktop. */
@media (max-width: 768px) {
  button,
  a.bp-btn,
  .bp-btn,
  a[role="button"],
  [role="tab"] {
    min-height: 44px;
  }
}


/* ── 6. Hover → focus-visible em touch ─────────────────────────────────────
   Touch devices têm `:hover` "sticky" depois do tap (estado fica até tocar
   em outro lugar). Usar @media (hover: hover) pra restringir hover styles
   só pra mouse real. */
@media (hover: none) {
  /* Padrão atual de muitos componentes — desativa o hover quando não há
     mouse hovering. Override caso-a-caso quando o estilo for desejado. */
  .bp-btn:hover,
  .bp-nav-link:hover,
  .bp-side-item:hover,
  .hf-card:hover,
  .bp-feed-card:hover,
  .bp-gal-card:hover {
    /* No-op — mantém o estilo base do not-hover. */
  }
}


/* ── 7. Decorative orbs/grain só em telas largas ───────────────────────────
   `bp-fx-orb` e `bp-fx-grain` são decorations posicionadas absolute com
   `inset: 0` e width grande. Em desktop é bonito; em mobile só polui e
   pode causar overflow visual. Esconde abaixo de 768px. */
@media (max-width: 768px) {
  .bp-fx-orb,
  .bp-fx-grain {
    display: none !important;
  }
}


/* ── 7b. Atividade na Guilda (FAB + painel flutuante) — mobile ─────────────
   No desktop esse painel sticky/floating funciona; em mobile estava
   sobrepondo o conteúdo principal (drawer flutuante mal posicionado, era
   o problema reportado). Em ≤768px escondemos completamente — o conteúdo
   de atividade volta INLINE na landing/galeria como uma seção scroll
   vertical natural (Fase 2). Conflito com a regra desktop em
   `community.css @media 1280px` que tornava o painel `position: fixed`. */
@media (max-width: 768px) {
  .g-activity-fab,
  .g-activity-panel {
    display: none !important;
  }
}


/* ╔══════════════════════════════════════════════════════════════════════╗
   ║  GALLERY — mobile: sidebar vira chips horizontais (Steam-style)      ║
   ╚══════════════════════════════════════════════════════════════════════╝
   No desktop, `.g-side-clean` é uma sidebar 220px à esquerda com 3 blocks
   (Visualizar / Categoria / Ordenar por). No mobile vira uma barra
   horizontal de chips no TOPO do main — `.g-side-block`s ficam inline
   com scroll horizontal. Cada `.g-side-item` vira pill clicável. */
@media (max-width: 768px) {
  /* `bp-gallery-grid` em desktop é 220px-240px sidebar + 1fr main.
     Em mobile precisa ser 1 coluna pra sidebar empilhar acima do main.
     Conflito com regra @media 1280px em community.css linha 5076 que
     define `240px 1fr` — força 1 coluna com !important. */
  .bp-gallery-grid {
    grid-template-columns: minmax(0, 1fr) !important;
    gap: 12px !important;
    min-width: 0 !important;
  }
  /* Children do grid precisam permitir encolher abaixo do min-content,
     senão um card com texto longo nowrap estica a coluna toda. */
  .bp-gallery-grid > * {
    min-width: 0 !important;
  }
  .bp-gallery-main {
    min-width: 0 !important;
  }

  /* Sidebar deixa de ser coluna lateral e vira fluxo natural acima
     do main. Sem margin negativa — `.g-side-block` já tem padding
     lateral próprio (16px), e o gallery-main wrap tem 0 padding. */
  .g-side-clean {
    position: static !important;
    width: 100% !important;
    padding: 0 !important;
    margin: 0 0 8px !important;
    padding-bottom: 4px;
    display: block !important;
  }

  /* CTA "Nova Ideia" da sidebar some — bottom nav já tem o FAB ➕
     central destacado. Evita duplicação visual. */
  .g-side-cta-new {
    display: none !important;
  }

  /* Cada bloco (Visualizar / Categoria / Ordenar) vira uma linha de
     scroll horizontal com chips. Force flex-direction row + nowrap
     pra vencer estilos desktop que têm flex-direction: column. */
  .g-side-block {
    display: flex !important;
    flex-direction: row !important;
    flex-wrap: nowrap !important;
    align-items: center !important;
    overflow-x: auto !important;
    overflow-y: hidden !important;
    -webkit-overflow-scrolling: touch;
    scrollbar-width: none;
    padding: 8px 16px !important;
    gap: 8px !important;
    scroll-snap-type: x proximity;
    border-bottom: 1px solid var(--bp-line, rgba(255,255,255,0.06));
    width: 100% !important;
  }
  .g-side-block::-webkit-scrollbar { display: none; }

  /* Eyebrow ("VISUALIZAR", "CATEGORIA", "ORDENAR POR") fica sticky
     à esquerda do bloco — funciona como rótulo do filtro. */
  .g-side-eyebrow {
    flex-shrink: 0;
    margin: 0 4px 0 0;
    padding: 0;
    font-family: var(--bp-mono, monospace);
    font-size: 9.5px;
    font-weight: 700;
    letter-spacing: 0.14em;
    text-transform: uppercase;
    color: var(--bp-ink-dim, rgba(255,255,255,0.45));
    align-self: center;
    white-space: nowrap;
    border: none;
    background: none;
  }

  /* Items viram pills compactas */
  .g-side-item {
    flex: 0 0 auto;
    display: inline-flex;
    align-items: center;
    gap: 5px;
    padding: 7px 12px;
    background: rgba(255, 255, 255, 0.04);
    border: 1px solid rgba(255, 255, 255, 0.08);
    border-radius: 999px;
    font-size: 13px;
    font-weight: 500;
    color: var(--bp-ink-dim, rgba(255, 255, 255, 0.65));
    white-space: nowrap;
    cursor: pointer;
    scroll-snap-align: start;
    transition: all 160ms;
    /* Override do min-height de 44px global pra não estourar a chip bar */
    min-height: auto !important;
  }
  .g-side-item.on,
  .g-side-item:active {
    background: rgba(0, 153, 255, 0.18);
    border-color: rgba(0, 153, 255, 0.35);
    color: var(--bp-blue-hi, #38b0ff);
  }
  .g-side-item svg {
    flex-shrink: 0;
  }

  /* Sort dropdown (componente _SortSelect) fica como chip também,
     mas com largura própria. */
  .g-sort-select {
    flex: 0 0 auto;
    min-width: 200px;
  }
  .g-sort-trigger {
    height: 36px !important;
    padding: 7px 14px !important;
    font-size: 12.5px !important;
    border-radius: 999px !important;
    background: rgba(0, 153, 255, 0.10) !important;
    border-color: rgba(0, 153, 255, 0.25) !important;
    min-height: auto !important;
  }

  /* Hero da galeria + bp-gallery-bar em mobile */
  .bp-gallery-hero {
    padding: 16px 16px 12px;
  }
  .bp-gallery-wrap {
    padding: 12px 0 24px;
  }
  .bp-gallery-main {
    padding: 0 16px;
  }

  /* SearchBar interno da galeria some — top bar mobile já tem search.
     Evita duplicação visual e economiza ~80px de altura no header. */
  .bp-gallery-main > .g-search-block {
    display: none !important;
  }
}


/* ╔══════════════════════════════════════════════════════════════════════╗
   ║  DETAIL — coluna única em mobile (main em cima, sidebar embaixo)     ║
   ╚══════════════════════════════════════════════════════════════════════╝
   Desktop: layout 1fr + 320px (main + sidebar de score/voto direita).
   Mobile: 1 coluna empilhada. Ordem visual:
     1) Main (hero, pitch, scores chips, tags, apresentação, tabs)
     2) Sidebar (Seguir + scores card + Autor + ações do autor)
   Sem bottom action bar nesta iteração — fica em fase posterior. */
@media (max-width: 768px) {
  .bp-detail-wrap {
    padding: 8px 0 16px !important;
    max-width: 100% !important;
    /* Padding-bottom enxuto (16px) pq abaixo vem .bp-related-section-v2,
       que recebe a folga pra clear da bottom nav fixa. */
  }
  /* Folga pra bottom nav fica na ÚLTIMA seção da página. */
  .bp-related-section-v2 {
    padding-bottom: calc(var(--bp-bottomnav-h) + var(--bp-safe-bottom) + 24px) !important;
  }
  .bp-detail-grid {
    grid-template-columns: minmax(0, 1fr) !important;
    gap: 16px !important;
    min-width: 0 !important;
    padding: 0 16px !important;
  }
  /* Tabs wrap (Comentários / Ficha técnica / Avaliação / Arquivos) é
     IRMÃ do .bp-detail-grid — não herda o padding lateral dele. Sem
     padding próprio, conteúdo (ficha técnica, comentários, etc.)
     bate na borda da tela em mobile. */
  .bp-detail-tabs-wrap {
    padding: 0 16px !important;
    box-sizing: border-box !important;
  }
  /* Cards da ficha técnica afinam o padding interno em telas estreitas
     pra ganhar espaço útil sem o conteúdo encostar na borda. */
  .g-ficha-section {
    padding: 18px 16px !important;
  }
  .g-ficha-tecnica {
    margin-bottom: 32px !important;
  }
  /* Ordem explícita: main = 0 (vem primeiro), side = 1 (depois). Sem isso,
     o `order: 1` que tinha em main quebrava o flow visual no grid. */
  .bp-detail-grid > .bp-detail-main {
    min-width: 0 !important;
    order: 0 !important;
  }
  .bp-detail-side {
    order: 1 !important;
    width: 100% !important;
    position: static !important;
    flex-direction: column !important;
    flex-wrap: nowrap !important;
    max-height: none !important;
    overflow: visible !important;
    padding: 0 !important;
    gap: 12px !important;
  }
  .bp-detail-side > * {
    width: 100% !important;
    min-width: 0 !important;
  }
  .bp-side-box {
    width: 100% !important;
    min-width: 0 !important;
    padding: 16px !important;
    /* Desktop tem flex:1 1 260px (cresce pra preencher coluna). Em mobile,
       caixas pequenas ficavam com 160px de espaço vazio. flex:0 0 auto
       força altura igual ao conteúdo. */
    flex: 0 0 auto !important;
  }
  /* Bloco "Seguir esta ideia" — texto descritivo enxuto pra caber em uma
     linha curta. Helper só roda no detail (className = bp-side-box dentro
     da sidebar). */
  .bp-detail-side .bp-side-mute {
    margin-bottom: 12px !important;
  }
  /* Hero da apresentação — full-width sem padding lateral próprio
     (já tem do bp-detail-grid). */
  .bp-detail-hero {
    padding-left: 0 !important;
    padding-right: 0 !important;
  }
  /* Tabs do detalhe scrollam horizontal (Comentários/Avaliação/Arquivos/...) */
  .g-detail-tabs {
    overflow-x: auto;
    overflow-y: hidden;
    -webkit-overflow-scrolling: touch;
    scrollbar-width: none;
    flex-wrap: nowrap !important;
  }
  .g-detail-tabs::-webkit-scrollbar { display: none; }
  .g-detail-tabs > * {
    flex-shrink: 0;
  }
  /* Vote grid 5 cols mobile (ao invés de 10 numa só linha que não cabe).
     Botões de 1-10 em 2 linhas de 5, mais touch-friendly. */
  .bp-vote-grid-compact {
    grid-template-columns: repeat(5, 1fr) !important;
  }
  .bp-vote-num {
    min-height: 44px !important;
    font-size: 16px !important;
  }
}


/* ╔══════════════════════════════════════════════════════════════════════╗
   ║  GALLERY HERO — escondido em mobile                                  ║
   ╚══════════════════════════════════════════════════════════════════════╝
   Em desktop o hero "O que a Brasil Paralelo está pensando" + sub-copy
   ancora a página. Em mobile vira ruído visual: ocupa quase um viewport
   antes do conteúdo real. Esconde inteiro — o título da guilda já está
   no drawer e na bottom nav. */
@media (max-width: 768px) {
  .bp-gallery-hero {
    display: none !important;
  }
  /* O sub do trending também é redundante (description "Ideias da Guilda
     que mais mobilizaram votos…"). O eyebrow + ícone de chama já comunicam
     o conceito. */
  .bp-trending-sub {
    display: none !important;
  }
}


/* ╔══════════════════════════════════════════════════════════════════════╗
   ║  TRENDING HERO — 3 zonas empilhadas em mobile                        ║
   ╚══════════════════════════════════════════════════════════════════════╝
   Desktop: hero (imagem+overlay com texto sobreposto) | painel direito
   (stats + CTA), em grid 2 colunas.

   Mobile: 3 zonas empilhadas, ZERO texto sobre imagem (poluído):
     1) IMAGEM PURA — só o cover + rank #N + pill TRENDING (top corners)
     2) TEXTO — title + pitch + cluster/qual em fundo sólido escuro
     3) PAINEL — eyebrow + stats compactos + CTA com tech-grid mantido
   Setas prev/next escondidas (swipe + dots bastam). */
@media (max-width: 768px) {
  .bp-trending {
    margin: 0 12px 16px !important;
  }
  .bp-trending-head {
    flex-direction: column !important;
    align-items: flex-start !important;
    gap: 10px !important;
    margin-bottom: 12px !important;
  }
  .bp-trending-head-left {
    min-width: 0 !important;
    max-width: 100% !important;
  }
  .bp-trending-sub {
    font-size: 13px !important;
    line-height: 1.45 !important;
  }
  .bp-trending-period {
    align-self: flex-start;
    font-size: 10px !important;
    letter-spacing: 0.10em !important;
  }
  /* Botões do period: min-height 44 do reset estoura — chips devem ser
     pequenos. 32px ainda é tappable suficiente em row densa. */
  .bp-trending-period button {
    padding: 6px 10px !important;
    min-height: 32px !important;
    font-size: 10px !important;
    line-height: 1 !important;
  }
  /* Card vira coluna única: hero (img+texto) + painel empilhados. */
  .bp-trending-card {
    grid-template-columns: 1fr !important;
    grid-template-rows: auto auto !important;
    min-height: 0 !important;
    flex: 0 0 100% !important;
    width: 100% !important;
    /* Animation desktop dos cards (slideNext/Prev) não faz sentido aqui
       — agora é o TRACK que translada e leva o card junto. Sem isso
       elas conflitam com o transform do track. */
    animation: none !important;
  }
  .bp-trending-stage {
    min-height: 0 !important;
  }
  /* Setas prev/next escondidas. */
  .bp-trending-nav {
    display: none !important;
  }
  /* Viewport: overflow:hidden + border-radius. Track: flex strip com TODOS
     os cards lado a lado, translateX move pro current. */
  .bp-trending-viewport {
    position: relative;
    overflow: hidden;
    border-radius: var(--bp-r-xl, 16px);
  }
  .bp-trending-track {
    display: flex !important;
    flex-direction: row !important;
    width: 100% !important;
    will-change: transform;
    /* transição da volta ao soltar — quando is-dragging ativa, transição
       é desligada pra translação acompanhar o dedo sem lag. */
    transition: transform 320ms cubic-bezier(.2, .9, .25, 1);
    /* desktop tem flex:1 + min-width:0 — em mobile o track contém todos
       os cards então flex:1 não faz sentido. */
    flex: 1 1 auto !important;
    border-radius: 0 !important;
    overflow: visible !important;
  }
  .bp-trending-track.is-dragging {
    transition: none !important;
  }

  /* ── ZONA 1+2: hero vira block puro (imagem em cima, texto embaixo) ── */
  .bp-trending-hero {
    display: block !important;
    padding: 0 !important;
    min-height: 0 !important;
    aspect-ratio: auto !important;
    overflow: hidden;
  }
  /* Imagem ganha aspect-ratio fixo no fluxo do bloco (não absolute). */
  .bp-trending-cover {
    position: relative !important;
    inset: auto !important;
    width: 100% !important;
    height: auto !important;
    aspect-ratio: 16 / 10 !important;
    object-fit: cover !important;
    display: block !important;
    z-index: 0 !important;
  }
  /* Overlay desktop existe pra dar legibilidade ao texto sobre a img.
     Em mobile o texto NÃO está mais sobre a img — overlay sai. */
  .bp-trending-cover-overlay {
    display: none !important;
  }
  /* Fallback (sem cover): bg-gradient ocupa o espaço da img. */
  .bp-trending-hero:not(.has-cover) .bp-trending-hero-bg {
    position: relative !important;
    inset: auto !important;
    width: 100% !important;
    aspect-ratio: 16 / 10 !important;
    z-index: 0 !important;
  }
  /* Card todo clicável — feedback de press + focus ring. */
  .bp-trending-card {
    cursor: pointer;
    transition: transform 180ms ease, filter 180ms ease;
  }
  .bp-trending-card:active {
    transform: scale(0.985);
    filter: brightness(1.05);
  }
  .bp-trending-card:focus-visible {
    outline: 2px solid var(--bp-blue-hi, #38b0ff);
    outline-offset: 2px;
  }
  /* Rank grande em fade na imagem foi REMOVIDO — agora é uma pill
     glass no canto SUPERIOR ESQUERDO (community.css). */
  .bp-trending-rank {
    display: none !important;
  }
  /* TRENDING pill antiga (substituída pelo chip de categoria). */
  .bp-trending-tag {
    display: none !important;
  }
  /* Mobile: pills mais perto do canto (top 8 vs desktop 22). */
  .bp-trending-rank-pill {
    top: 8px !important;
    left: 8px !important;
  }
  .bp-trending-cluster-pill {
    top: 8px !important;
    right: 8px !important;
  }
  /* Conteúdo de texto vira block normal abaixo da imagem. Sem min-height
     fixa — pitch vai até 6 linhas e cards ficam consistentes via mesmo
     limite de truncação no backend (360 chars). */
  .bp-trending-hero-content {
    position: relative !important;
    background: rgba(10, 12, 16, 0.92);
    padding: 14px !important;
    max-width: 100% !important;
    display: flex;
    flex-direction: column;
  }
  .bp-trending-title {
    font-size: clamp(18px, 4.8vw, 22px) !important;
    line-height: 1.2 !important;
    margin-bottom: 8px !important;
    text-shadow: none !important;
  }
  .bp-trending-pitch {
    font-size: 13.5px !important;
    line-height: 1.5 !important;
    /* 6 linhas pra preencher o espaço disponível no card. Backend
       trunca em 360 chars — ~6 linhas de 60c. */
    -webkit-line-clamp: 6 !important;
    line-clamp: 6 !important;
    margin-bottom: 12px !important;
    text-shadow: none !important;
    color: rgba(255, 255, 255, 0.82) !important;
  }
  .bp-trending-meta {
    gap: 6px !important;
    margin-top: auto !important;
  }
  /* Chip "PRODUTO DE CONTEÚDO" — desktop usa font 11 + padding 5x11.
     Em mobile fica desproporcional ao lado do título. Reduz pra 9px
     + padding 3x8 — passa a ser uma metadata discreta. */
  .bp-trending-cluster {
    font-size: 9px !important;
    padding: 3px 8px !important;
    min-height: 0 !important;     /* Sobrescreve reset 44px */
    letter-spacing: 0.04em !important;
  }
  .bp-trending-qual {
    font-size: 9px !important;
    padding: 3px 8px !important;
    letter-spacing: 0.06em !important;
  }

  /* (Regras de is-dragging movidas pra cima junto com .bp-trending-track) */

  /* ── ZONA 3: painel ULTRA-COMPACTO — single stat inline + tech-grid
     escuro (estilo landing). Sem CTA (card todo é clicável agora) e
     sem stat de posição (#N virou pill na imagem). */
  .bp-trending-panel {
    display: flex !important;
    flex-direction: row !important;
    align-items: center !important;
    padding: 12px 14px !important;
    border-left: none !important;
    border-top: 1px solid rgba(255, 255, 255, 0.06);
    gap: 12px !important;
    background: rgba(6, 9, 13, 0.6) !important;
  }
  /* Tech-grid CLEAN + ESCURO igual landing.css:
     - Linhas 0.035 opacity (era 0.05)
     - Grid 48px (era 36px) — mais espaçado, menos ruidoso
     - Mask suave radial pra fade nas bordas */
  .bp-trending-panel::before {
    background-image:
      linear-gradient(rgba(255, 255, 255, 0.035) 1px, transparent 1px),
      linear-gradient(90deg, rgba(255, 255, 255, 0.035) 1px, transparent 1px) !important;
    background-size: 48px 48px !important;
    mask-image: radial-gradient(ellipse 90% 70% at 50% 50%, #000 30%, transparent 80%) !important;
    -webkit-mask-image: radial-gradient(ellipse 90% 70% at 50% 50%, #000 30%, transparent 80%) !important;
    opacity: 0.5 !important;
  }
  .bp-trending-panel-eyebrow {
    font-size: 9px !important;
    letter-spacing: 0.18em !important;
    color: var(--bp-ink-faint, rgba(255, 255, 255, 0.5)) !important;
    flex: 0 0 auto;
  }
  /* Esconde bloco desktop (votos+coment+score pill) — mobile usa stat
     única inline abaixo. */
  .bp-trending-stats-desktop { display: none !important; }
  .bp-trending-stats-mobile  { display: flex !important; }

  /* Stat única inline: número + label horizontal. */
  .bp-trending-stats {
    grid-template-columns: 1fr !important;
    display: flex !important;
    align-items: baseline !important;
    flex: 1;
  }
  .bp-trending-stat {
    background: transparent !important;
    border: none !important;
    box-shadow: none !important;
    padding: 0 !important;
    flex-direction: row !important;
    align-items: baseline !important;
    gap: 8px !important;
    border-radius: 0 !important;
  }
  .bp-trending-stat:hover {
    background: transparent !important;
    border: none !important;
  }
  .bp-trending-stat-num {
    font-size: 20px !important;
    line-height: 1 !important;
  }
  .bp-trending-stat-label {
    font-size: 11px !important;
    letter-spacing: 0.02em !important;
    line-height: 1.2 !important;
  }
  /* CTA não existe mais no mobile (removido do JSX), mas se vier de
     algum cache antigo, esconde. */
  .bp-trending-cta {
    display: none !important;
  }

  /* Dots: ENXUTOS — 6px, ativo vira pill 18px. min-height:44 do reset
     de touch target estoura altura — override aqui. */
  .bp-trending-dots {
    gap: 6px !important;
    margin-top: 10px !important;
  }
  .bp-trending-dot {
    width: 6px !important;
    height: 6px !important;
    min-height: 0 !important;
    border: 0 !important;
    background: rgba(255, 255, 255, 0.22) !important;
    box-shadow: none !important;
    padding: 0 !important;
  }
  .bp-trending-dot.active {
    width: 18px !important;
    border-radius: 3px !important;
    background: var(--bp-blue-hi, #38b0ff) !important;
  }
  /* Edge fades sutis. */
  .bp-trending-fade {
    width: 16px !important;
    opacity: 0.5;
  }
}


/* ╔══════════════════════════════════════════════════════════════════════╗
   ║  ADMIN — sidebar escondido em mobile (degraded experience)           ║
   ╚══════════════════════════════════════════════════════════════════════╝
   Plano: "Use desktop pra moderação completa. Aqui vão só ações rápidas."
   Sidebar admin desktop tem 12+ links. Em mobile fica gigante e empurra
   conteúdo. Solução: esconde sidebar; o nav principal (drawer ☰ + bottom
   nav) já leva pra Comunidade/Hall/Curador. Pra trocar de seção admin
   user usa o navegador (ex: digita /admin/usuarios) ou abre desktop. */
@media (max-width: 768px) {
  .bp-admin-sidebar {
    display: none !important;
  }
  .bp-admin-shell {
    grid-template-columns: minmax(0, 1fr) !important;
    padding: 0 !important;
  }
  .bp-admin-main {
    padding: 12px 12px calc(var(--bp-bottomnav-h) + var(--bp-safe-bottom) + 24px) !important;
    min-width: 0 !important;
  }
  .bp-admin-main-head {
    padding: 0 0 12px !important;
  }
  /* Tabelas largas viram scroll horizontal interno (não estoura page). */
  .bp-admin-main table,
  .bp-admin-table-wrap {
    display: block;
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
    max-width: 100%;
  }
}


/* ╔══════════════════════════════════════════════════════════════════════╗
   ║  SUBMIT WIZARD — formulário compacto + footer flutuante              ║
   ╚══════════════════════════════════════════════════════════════════════╝
   Desktop: shell tem padding 64px (clear fixed nav). Mobile já tem
   body padding-top do nosso topbar, então zera o padding extra. Stage
   sem max-width pra usar a viewport inteira. Stepper sticky ajusta o
   top pra encostar no topbar mobile. */
@media (max-width: 768px) {
  .bp-submit-shell {
    padding: 0 0 calc(var(--bp-bottomnav-h) + var(--bp-safe-bottom) + 16px) !important;
    min-height: auto !important;
  }
  .bp-submit-stage {
    padding: 0 !important;
    max-width: 100% !important;
  }
  /* Em mobile, type chooser perde padding gigante. */
  .bp-type-chooser {
    padding: 24px 16px 16px !important;
  }
  /* Stepper sticky encosta no topbar mobile (não no nav antigo de 64px). */
  .bp-stepper {
    top: var(--bp-topbar-h) !important;
    padding: 12px 16px 10px !important;
  }
  /* Form card: mais respiro lateral, menos vertical */
  .bp-submit-split {
    display: flex !important;
    flex-direction: column !important;
    gap: 16px !important;
    margin-top: 16px !important;
    padding: 0 12px !important;
  }
  /* Form footer (Voltar / Próximo) — sticky no bottom (acima do bottomnav) */
  .bp-form-foot {
    position: sticky !important;
    bottom: calc(var(--bp-bottomnav-h) + var(--bp-safe-bottom)) !important;
    background: rgba(8, 11, 16, 0.92);
    backdrop-filter: blur(16px);
    -webkit-backdrop-filter: blur(16px);
    border-top: 1px solid var(--bp-line, rgba(255,255,255,.08));
    padding: 12px 16px !important;
    z-index: 4;
    margin: 0 -12px !important;
  }
}


/* ╔══════════════════════════════════════════════════════════════════════╗
   ║  CURADOR — chat full-screen no mobile (sidebar e citadas escondidas) ║
   ╚══════════════════════════════════════════════════════════════════════╝
   Desktop: grid 3-col (280px chats + 1fr chat + 320px citadas).
   Mobile: única coluna = chat. Sidebars escondidas por hora.
   - Drawer global (☰) já dá acesso ao "Curador" via nav.
   - Histórico de chats e ideias citadas ficam acessíveis num próximo
     iter por botão dedicado no header do Curador. */
@media (max-width: 768px) {
  .curador-app {
    grid-template-columns: minmax(0, 1fr) !important;
    /* Body já tem padding-top=topbar e padding-bottom=bottomnav. Aqui zeramos
       a margin-top inline (64px do desktop) e dimensionamos pra preencher
       exatamente a área visível entre as duas chrome bars.
       100dvh > 100vh em iOS Safari (acomoda barra URL dinâmica). */
    margin-top: 0 !important;
    height: calc(100dvh - var(--bp-topbar-h) - var(--bp-bottomnav-h) - var(--bp-safe-bottom) - var(--bp-safe-top)) !important;
  }
  /* Painel de "ideias citadas" continua escondido em mobile (preview
     de ideia agora abre via tap+bottom-sheet — Fase 4 do plano). */
  .bp-curador-citadas {
    display: none !important;
  }
  /* Sidebar wrap vira drawer slide-in pela esquerda. Por padrão fica
     fora da tela (translateX -100%); abre quando o React aplica
     `is-open`. z-index 300 cobre o top-bar fixo do app (z-index 200). */
  .bp-curador-side-wrap {
    display: block !important;
    position: fixed;
    top: 0; bottom: 0; left: 0;
    width: min(85vw, 320px);
    z-index: 300;
    transform: translateX(-100%);
    transition: transform 280ms var(--bp-ease);
    background: var(--bp-bg-elev, #131722);
    box-shadow: 12px 0 40px -8px rgba(0,0,0,0.6);
    overflow: hidden;
  }
  .bp-curador-side-wrap.is-open {
    transform: translateX(0);
  }
  .bp-curador-side {
    display: flex !important;
    height: 100%;
    width: 100%;
    overflow-y: auto;
    padding-top: max(12px, env(safe-area-inset-top)) !important;
    padding-bottom: max(12px, env(safe-area-inset-bottom)) !important;
  }
  .bp-curador-side-backdrop {
    display: block !important;
    position: fixed; inset: 0;
    z-index: 299;
    background: rgba(0,0,0,0.5);
    opacity: 0;
    pointer-events: none;
    transition: opacity 220ms var(--bp-ease);
  }
  .bp-curador-side-backdrop.is-open {
    opacity: 1;
    pointer-events: auto;
  }
  /* Hamburger + nova-conversa: visíveis em mobile. */
  .bp-curador-header-menu,
  .bp-curador-header-new {
    display: inline-flex !important;
  }
  .bp-curador-chat {
    height: 100% !important;
    min-height: 0 !important;
  }
  .bp-curador-chat-header {
    padding: 8px 12px !important;
    gap: 4px;
  }
  /* Título do chat: oculto no mobile (2026-05-02). O user já vê o
     título completo na lista do drawer; mostrar truncado no header
     ficava confuso e poluia o espaço.  Mantemos o div ocupando o
     `flex: 1` pra empurrar as actions pra direita. */
  .bp-curador-chat-header-title {
    flex: 1 !important;
    min-width: 0 !important;
  }
  .bp-curador-chat-title-btn {
    display: none !important;
  }
  /* Action "Compartilhar" vira icon-only no mobile pra ganhar espaço. */
  .bp-curador-action-label {
    display: none !important;
  }
  .bp-curador-chat-header-actions .bp-curador-action-btn {
    width: 40px; height: 40px;
    padding: 0 !important;
    border-radius: 50% !important;
    justify-content: center !important;
  }
  .bp-curador-input-wrap {
    padding: 8px 12px calc(8px + var(--bp-safe-bottom)) !important;
  }
  /* Composer pill mobile — `+` esquerda + textarea + ↑ direita. */
  .bp-curador-input {
    border-radius: 24px !important;
    padding: 4px 4px 4px 6px !important;
    min-height: 48px !important;
  }
  .bp-curador-thread {
    padding: 12px !important;
  }
  /* Quick prompts (botões rápidos) — chips horizontais scrolláveis. */
  .bp-curador-quick-prompts {
    overflow-x: auto;
    flex-wrap: nowrap !important;
    scrollbar-width: none;
    scroll-snap-type: x proximity;
    padding-bottom: 4px;
  }
  .bp-curador-quick-prompts::-webkit-scrollbar { display: none; }
  .bp-curador-quick-btn {
    flex-shrink: 0;
    scroll-snap-align: start;
  }
}


/* ╔══════════════════════════════════════════════════════════════════════╗
   ║  PROFILE — header compacto + tabs scrolláveis + bottom padding       ║
   ╚══════════════════════════════════════════════════════════════════════╝
   profile.css já tem @media 640px com header empilhado. Aqui ajustamos:
   - top padding pra encostar logo abaixo do top bar mobile
   - bottom padding pra não ser coberto pela bottom nav
   - tabs com scroll horizontal mais visíveis (já tem overflow-x:auto) */
@media (max-width: 768px) {
  .bp-profile-page {
    padding: 12px 12px 0 !important;
    margin: 0 auto calc(var(--bp-bottomnav-h) + var(--bp-safe-bottom) + 24px) !important;
    max-width: 100% !important;
  }
  .bp-profile-header {
    padding: 20px 16px !important;
    margin-bottom: 16px !important;
    text-align: center;
  }
  /* Header empilha vertical no mobile e centraliza tudo. Avatar acima,
     nome+meta+ações abaixo, todos centralizados. (2026-05-02) */
  .bp-profile-header-top {
    flex-direction: column !important;
    align-items: center !important;
    gap: 14px !important;
  }
  .bp-profile-header-meta {
    width: 100% !important;
    text-align: center !important;
  }
  .bp-profile-name {
    justify-content: center !important;
    text-align: center !important;
  }
  .bp-profile-since,
  .bp-profile-bio-inline {
    text-align: center !important;
    margin-left: auto !important;
    margin-right: auto !important;
  }
  .bp-profile-header-actions {
    width: 100% !important;
    justify-content: center !important;
  }
  .bp-profile-header-actions .bp-btn,
  .bp-profile-header-actions button {
    min-width: 200px;
    justify-content: center !important;
  }
  /* Mostra a thumb das ideias no perfil mobile (era display:none).
     Vira capa-topo full-width acima do conteúdo do card; layout
     vertical pra caber em 390px sem cortar título. */
  .bp-mine-card {
    grid-template-columns: 1fr !important;
    padding: 0 !important;
    overflow: hidden;
  }
  .bp-mine-card-thumb {
    display: flex !important;
    position: relative !important;
    inset: auto !important;
    width: 100% !important;
    aspect-ratio: 16 / 10;
    height: auto !important;
  }
  .bp-mine-card-thumb::after {
    /* Linha vertical não faz sentido em layout empilhado. */
    display: none !important;
  }
  .bp-mine-card-left {
    padding: 14px 16px 4px;
  }
  .bp-mine-card-right {
    padding: 0 16px 14px;
    align-items: flex-start !important;
    text-align: left !important;
  }
  .bp-profile-tabs {
    margin-left: -12px;
    margin-right: -12px;
    padding-left: 12px;
    padding-right: 12px;
  }
  .bp-profile-tabs button {
    padding: 12px 14px !important;
    font-size: 13px !important;
    flex-shrink: 0;
  }
  /* Filter pills (Todas / Publicadas / Rascunhos) — full width row scrolláveis */
  .bp-profile-status-pills,
  .bp-profile-type-pills {
    flex-wrap: nowrap !important;
    overflow-x: auto;
    scrollbar-width: none;
    margin: 0 -12px 12px;
    padding: 0 12px;
  }
  .bp-profile-status-pills::-webkit-scrollbar,
  .bp-profile-type-pills::-webkit-scrollbar { display: none; }
  .bp-profile-status-pills > *,
  .bp-profile-type-pills > * { flex-shrink: 0; }
}


/* ╔══════════════════════════════════════════════════════════════════════╗
   ║  HALL DA FAMA — hero compacto + card vertical (poster em cima)       ║
   ╚══════════════════════════════════════════════════════════════════════╝
   community.css já tem @media 720px com 110px+1fr no card. No iPhone 13
   Pro (390px) isso fica muito apertado pra metadata (Direção/Roteiro/
   Plataforma). Empilhamos poster acima da info e dimensionamos hero. */
@media (max-width: 768px) {
  .hf-page {
    padding: 12px 12px calc(var(--bp-bottomnav-h) + var(--bp-safe-bottom) + 24px) !important;
  }
  /* Hero compacto: padding menor + trophy menor + título escala. */
  .hf-hero {
    padding: 24px 18px !important;
  }
  .hf-hero-icon {
    width: 56px !important;
    height: 56px !important;
  }
  .hf-trophy {
    width: 36px !important;
    height: 36px !important;
  }
  .hf-hero-title {
    font-size: clamp(24px, 6.5vw, 32px) !important;
    line-height: 1.15 !important;
  }
  .hf-hero-sub {
    font-size: 14px !important;
    line-height: 1.5 !important;
  }
  /* Card vertical: poster em cima full-width, info embaixo. */
  .hf-card {
    grid-template-columns: 1fr !important;
    gap: 16px !important;
    padding: 12px !important;
  }
  .hf-card-poster {
    width: 100% !important;
    aspect-ratio: 2 / 3;
    max-height: 340px;
  }
  .hf-card-poster img {
    width: 100% !important;
    height: 100% !important;
    object-fit: cover !important;
  }
  /* Eyebrow + crew rows: ajusta wrap pra não cortar. */
  .hf-card-eyebrow {
    flex-wrap: wrap !important;
  }
  .hf-card-format {
    white-space: normal !important;
    overflow: visible !important;
    text-overflow: clip !important;
  }
  .hf-card-crew-row {
    grid-template-columns: 80px 1fr !important;
    gap: 8px !important;
  }
  .hf-card-title {
    font-size: clamp(20px, 5vw, 26px) !important;
    line-height: 1.2 !important;
  }
}


/* ── 8. Scroll containers laterais (chips/carrosseis) ──────────────────────
   Helper class pra qualquer container que precisa de scroll horizontal
   interno (stories, tabs, mídia). Esconde scrollbar visual mas mantém
   funcional, e adiciona inertia scroll iOS. */
.bp-h-scroll {
  display: flex;
  flex-wrap: nowrap;
  overflow-x: auto;
  overflow-y: hidden;
  -webkit-overflow-scrolling: touch;
  scrollbar-width: none;
  /* Snap por item — UX 9gag/Instagram */
  scroll-snap-type: x mandatory;
  /* Padding lateral pra primeiro/último item ficar com respiro */
  padding-left: 12px;
  padding-right: 12px;
  /* Gap entre items */
  gap: 8px;
}
.bp-h-scroll::-webkit-scrollbar {
  display: none;
}
.bp-h-scroll > * {
  flex: 0 0 auto;
  scroll-snap-align: start;
}


/* ── 9. Tipografia escalada com clamp() (mobile-first) ─────────────────────
   Usado nos hero/títulos das páginas. Aplicado via classes que os
   componentes podem optar usar — não vou mudar todos os h1/h2 globalmente
   pra não quebrar desktop. */
.bp-fluid-hero  { font-size: clamp(28px, 7vw, 56px);  line-height: 1.1; }
.bp-fluid-title { font-size: clamp(20px, 5vw, 32px);  line-height: 1.2; }
.bp-fluid-body  { font-size: clamp(14px, 3.5vw, 16px); line-height: 1.55; }


/* ── 10. Padding-top + bottom global pra TopBar e BottomNav ────────────────
   TopBar e BottomNav são `position: fixed` — sem padding no body, conteúdo
   passa por trás deles. Aqui reservamos o espaço total das chrome bars +
   safe-areas. Telas full-screen (Curador, edit) podem opt-out via classe
   .bp-no-bottomnav OU .bp-no-topbar no body. */
@media (max-width: 768px) {
  body {
    padding-top:    calc(var(--bp-topbar-h)    + var(--bp-safe-top));
    padding-bottom: calc(var(--bp-bottomnav-h) + var(--bp-safe-bottom));
  }
  body.bp-no-bottomnav {
    padding-bottom: var(--bp-safe-bottom);
  }
  body.bp-no-topbar {
    padding-top: var(--bp-safe-top);
  }
}


/* ── 11. Padding lateral global em mobile ──────────────────────────────────
   Headers/sections que usam `.bp-section-pad` (já existente em desktop com
   ~80px) ficam com 16px lateral em mobile. Cobre também `.bp-hero`,
   `.bp-form-wrap`, etc — qualquer container "topo de seção" do projeto. */
@media (max-width: 768px) {
  .bp-section-pad,
  .bp-hero,
  .bp-mine-hero,
  .bp-proc-wrap,
  .bp-form-wrap,
  .bp-mine-list-wrap,
  .bp-section-projects {
    padding-left: 16px;
    padding-right: 16px;
  }
}


/* ── 12. Tipografia clamp() em headers/heroes default ──────────────────────
   Aplica clamp em h1/h2 dentro de `.bp-hero`, `.bp-section-pad`,
   `.bp-mine-hero` em mobile pra escalar fluidly sem quebrar desktop. */
@media (max-width: 768px) {
  .bp-hero h1,
  .bp-section-pad h1,
  .bp-mine-hero h1 {
    font-size: clamp(28px, 7.5vw, 48px);
    line-height: 1.1;
  }
  .bp-hero h2,
  .bp-section-pad h2,
  .bp-mine-hero h2 {
    font-size: clamp(22px, 5.5vw, 32px);
    line-height: 1.2;
  }
}


/* ── 11. Padding-top respeitando safe-area do notch ────────────────────────
   Top bars `position: fixed` precisam ter padding-top adicional na primeira
   chrome bar (status bar do iOS). */
@media (max-width: 768px) {
  .bp-nav {
    /* O bp-nav existente vira o top bar mobile (modificado no shared.jsx).
       Adiciona padding-top do notch + ajusta height total. */
    padding-top: var(--bp-safe-top);
    height: calc(var(--bp-topbar-h) + var(--bp-safe-top));
  }
}


/* ── 12. Esconde BpNav desktop em mobile (substituído pelo BpMobileTopBar) ─
   Em ≤768px o nav clássico (logo + links + bell + avatar) some COMPLETO
   e o BpMobileTopBar entra no lugar (☰ + search + lupa). Em desktop, o
   mobile-topbar está com display:none. Cobre todos os filhos pra evitar
   resíduos visuais (ex: bp-nav-right inline). */
@media (max-width: 768px) {
  .bp-nav {
    display: none;
  }
}
@media (min-width: 769px) {
  .bp-mtopbar,
  .bp-mdrawer,
  .bp-mdrawer-backdrop,
  .bp-mbnav,
  .bp-mptr {
    display: none !important;
  }
}


/* ╔══════════════════════════════════════════════════════════════════════╗
   ║  PULL-TO-REFRESH INDICATOR                                           ║
   ╚══════════════════════════════════════════════════════════════════════╝
   Indicador fixo no topo (acima do topbar) que aparece ao puxar a página
   pra baixo. Spinner anima o ícone enquanto o refresh roda. */
.bp-mptr {
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  z-index: 199;          /* Abaixo do topbar (200) — o topbar cobre o indicador */
  display: flex;
  justify-content: center;
  pointer-events: none;
  transition: opacity 200ms ease;
  padding-top: calc(var(--bp-safe-top) + 8px);
}
.bp-mptr-icon {
  width: 40px;
  height: 40px;
  display: flex;
  align-items: center;
  justify-content: center;
  border-radius: 999px;
  background: rgba(8, 11, 16, 0.92);
  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);
  border: 1px solid rgba(255, 255, 255, 0.12);
  box-shadow: 0 4px 14px rgba(0, 0, 0, 0.35);
  color: var(--bp-blue-hi, #38b0ff);
}
.bp-mptr-icon.is-spin {
  animation: bp-mptr-spin 700ms linear infinite;
}
@keyframes bp-mptr-spin {
  from { transform: rotate(0deg); }
  to   { transform: rotate(360deg); }
}


/* ╔══════════════════════════════════════════════════════════════════════╗
   ║  MOBILE TOP BAR (Steam-style)                                        ║
   ╚══════════════════════════════════════════════════════════════════════╝ */
.bp-mtopbar {
  position: fixed;
  top: 0; left: 0; right: 0;
  z-index: 200;
  height: calc(var(--bp-topbar-h) + var(--bp-safe-top));
  padding-top: var(--bp-safe-top);
  padding-left: 12px;
  padding-right: 12px;
  display: flex;
  align-items: center;
  gap: 10px;
  background: rgba(10, 12, 16, 0.85);
  backdrop-filter: blur(18px) saturate(140%);
  -webkit-backdrop-filter: blur(18px) saturate(140%);
  border-bottom: 1px solid var(--bp-line, rgba(255,255,255,0.06));
}

/* Hamburger button */
.bp-mtopbar-burger {
  flex-shrink: 0;
  width: 44px; height: 44px;
  display: inline-flex;
  align-items: center; justify-content: center;
  background: transparent;
  border: none;
  color: var(--bp-ink, #fff);
  cursor: pointer;
  border-radius: 8px;
  transition: background 180ms;
}
.bp-mtopbar-burger:active {
  background: rgba(255,255,255,0.08);
}

/* Search wrapper */
.bp-mtopbar-search {
  flex: 1 1 auto;
  display: flex;
  align-items: stretch;
  height: 40px;
  background: rgba(255,255,255,0.06);
  border: 1px solid rgba(255,255,255,0.08);
  border-radius: 8px;
  overflow: hidden;
  min-width: 0;        /* permite encolher */
}
.bp-mtopbar-search:focus-within {
  border-color: var(--bp-blue-hi, #38b0ff);
  background: rgba(255,255,255,0.10);
}
.bp-mtopbar-search-input {
  flex: 1 1 auto;
  min-width: 0;
  background: transparent;
  border: none;
  outline: none;
  color: var(--bp-ink, #fff);
  font-size: 14px;     /* nota: regra global força 16px em mobile, ok */
  padding: 0 12px;
  font-family: inherit;
}
.bp-mtopbar-search-input::placeholder {
  color: var(--bp-ink-dim, rgba(255,255,255,0.45));
}
.bp-mtopbar-search-btn {
  flex-shrink: 0;
  width: 44px;
  display: inline-flex;
  align-items: center; justify-content: center;
  background: var(--bp-blue, #2563eb);
  border: none;
  color: white;
  cursor: pointer;
  transition: filter 180ms;
}
.bp-mtopbar-search-btn:hover {
  filter: brightness(1.10);
}


/* ╔══════════════════════════════════════════════════════════════════════╗
   ║  MOBILE DRAWER (slide da esquerda)                                   ║
   ╚══════════════════════════════════════════════════════════════════════╝ */

/* Backdrop escuro clicável */
.bp-mdrawer-backdrop {
  position: fixed;
  inset: 0;
  z-index: 290;
  background: rgba(0, 0, 0, 0);
  pointer-events: none;
  transition: background 220ms ease;
}
.bp-mdrawer-backdrop.is-open {
  background: rgba(0, 0, 0, 0.55);
  pointer-events: auto;
}

/* O drawer em si */
.bp-mdrawer {
  position: fixed;
  top: 0; bottom: 0;
  left: 0;
  width: 280px;
  max-width: 84vw;
  z-index: 300;
  background: rgb(14, 18, 26);
  border-right: 1px solid var(--bp-line, rgba(255,255,255,0.08));
  transform: translateX(-100%);
  transition: transform 280ms cubic-bezier(.2,.8,.2,1);
  overflow-y: auto;
  overscroll-behavior: contain;
  padding-top: var(--bp-safe-top);
  padding-bottom: var(--bp-safe-bottom);
  display: flex;
  flex-direction: column;
}
.bp-mdrawer.is-open {
  transform: translateX(0);
}

/* Brand header */
.bp-mdrawer-brand {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 16px 18px;
  border-bottom: 1px solid var(--bp-line, rgba(255,255,255,0.06));
}
.bp-mdrawer-brand img {
  height: 28px;
  width: auto;
  display: block;
  flex-shrink: 0;
}
.bp-mdrawer-brand-title {
  font-family: var(--bp-mono, monospace);
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--bp-blue-hi, #38b0ff);
}
.bp-mdrawer-brand-sub {
  font-size: 13px;
  font-weight: 600;
  color: var(--bp-ink, #fff);
  margin-top: 2px;
}

/* User card */
.bp-mdrawer-user {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 14px 18px;
  background: transparent;
  border: none;
  border-bottom: 1px solid var(--bp-line, rgba(255,255,255,0.06));
  cursor: pointer;
  text-align: left;
  width: 100%;
  color: inherit;
  transition: background 180ms;
}
.bp-mdrawer-user:active {
  background: rgba(255,255,255,0.04);
}
.bp-mdrawer-user-avatar {
  flex-shrink: 0;
  width: 40px; height: 40px;
  border-radius: 50%;
  background: var(--bp-blue-glow, rgba(0,153,255,0.18));
  color: var(--bp-blue-hi, #38b0ff);
  display: inline-flex;
  align-items: center; justify-content: center;
  font-family: var(--bp-mono, monospace);
  font-size: 13px;
  font-weight: 700;
  overflow: hidden;
  border: 1px solid rgba(255,255,255,0.06);
}
.bp-mdrawer-user-avatar img {
  width: 100%; height: 100%; object-fit: cover;
}
.bp-mdrawer-user-meta { min-width: 0; flex: 1; overflow: hidden; }
.bp-mdrawer-user-name {
  font-size: 14px;
  font-weight: 600;
  color: var(--bp-ink, #fff);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.bp-mdrawer-user-role {
  font-family: var(--bp-mono, monospace);
  font-size: 10px;
  font-weight: 600;
  letter-spacing: 0.10em;
  text-transform: uppercase;
  color: var(--bp-ink-dim, rgba(255,255,255,0.55));
  margin-top: 2px;
}

/* Sections de itens */
.bp-mdrawer-section {
  display: flex;
  flex-direction: column;
  padding: 8px 0;
}
.bp-mdrawer-divider {
  height: 1px;
  background: var(--bp-line, rgba(255,255,255,0.06));
  margin: 0 18px;
}

/* Item */
.bp-mdrawer-item {
  display: flex;
  align-items: center;
  gap: 14px;
  width: 100%;
  padding: 12px 18px;
  background: transparent;
  border: none;
  cursor: pointer;
  color: var(--bp-ink, rgba(255,255,255,0.92));
  font-size: 14px;
  font-weight: 500;
  font-family: inherit;
  text-align: left;
  transition: background 160ms;
}
.bp-mdrawer-item:active {
  background: rgba(255,255,255,0.06);
}
.bp-mdrawer-item.is-active {
  background: rgba(0, 153, 255, 0.10);
  color: var(--bp-blue-hi, #38b0ff);
  border-left: 3px solid var(--bp-blue-hi, #38b0ff);
  padding-left: 15px;   /* compensa o border de 3px */
}
.bp-mdrawer-item-icon {
  flex-shrink: 0;
  width: 24px;
  display: inline-flex;
  justify-content: center;
  font-size: 18px;
  line-height: 1;
}
.bp-mdrawer-item-label {
  flex: 1 1 auto;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.bp-mdrawer-item-badge {
  flex-shrink: 0;
  background: var(--bp-red, #e85d5d);
  color: white;
  font-family: var(--bp-mono, monospace);
  font-size: 10px;
  font-weight: 700;
  padding: 2px 7px;
  border-radius: 99px;
  min-width: 20px;
  text-align: center;
}

/* Toggle pill (Modo admin) */
.bp-mdrawer-toggle-pill {
  flex-shrink: 0;
  font-family: var(--bp-mono, monospace);
  font-size: 9.5px;
  font-weight: 700;
  letter-spacing: 0.08em;
  padding: 3px 8px;
  border-radius: 99px;
  border: 1px solid currentColor;
}
.bp-mdrawer-toggle-pill.is-on  { color: var(--bp-teal, #25D5AB); }
.bp-mdrawer-toggle-pill.is-off { color: var(--bp-ink-dim, rgba(255,255,255,0.45)); }


/* ╔══════════════════════════════════════════════════════════════════════╗
   ║  MOBILE BOTTOM NAV (5 slots simétricos)                              ║
   ╚══════════════════════════════════════════════════════════════════════╝ */
.bp-mbnav {
  position: fixed;
  bottom: 0; left: 0; right: 0;
  z-index: 180;
  height: calc(var(--bp-bottomnav-h) + var(--bp-safe-bottom));
  padding-bottom: var(--bp-safe-bottom);
  display: flex;
  align-items: stretch;
  justify-content: space-around;
  background: rgba(10, 12, 16, 0.95);
  backdrop-filter: blur(18px) saturate(140%);
  -webkit-backdrop-filter: blur(18px) saturate(140%);
  border-top: 1px solid var(--bp-line, rgba(255,255,255,0.06));
  transform: translateY(0);
  transition: transform 220ms ease;
}
.bp-mbnav.is-hidden {
  transform: translateY(110%);
}

/* Slot regular */
.bp-mbnav-item {
  flex: 1 1 0;
  display: inline-flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 2px;
  padding: 6px 4px;
  background: transparent;
  border: none;
  color: var(--bp-ink-dim, rgba(255,255,255,0.55));
  cursor: pointer;
  font-family: inherit;
  transition: color 160ms;
  min-height: 44px;
}
.bp-mbnav-item:active {
  color: var(--bp-ink, #fff);
}
.bp-mbnav-item.is-active {
  color: var(--bp-blue-hi, #38b0ff);
}
.bp-mbnav-icon {
  display: inline-flex;
  align-items: center; justify-content: center;
}
.bp-mbnav-label {
  font-size: 10px;
  font-weight: 600;
  letter-spacing: 0.02em;
}

/* FAB descontinuado: "Nova ideia" virou um Item simétrico no canto direito.
   Decisão UX: submeter ideia não é ação cotidiana — não merece destaque
   tipo "post" de rede social. */
