/* =====================================================
   RESPONSIVE.CSS — Academy Bets
   Responsividade profissional para todos os devices:
   iPhone / Android / Tablet / Desktop / Ultrawide
   
   ⚠️  Este arquivo é ADITIVO — NÃO modifica lógica,
       NÃO remove componentes, NÃO altera style.css.
       Apenas sobrescreve propriedades visuais/layout.
   ===================================================== */

/* =====================================================
   1. VARIÁVEIS CSS GLOBAIS RESPONSIVAS + SAFE AREAS
   ===================================================== */
:root {
  /* Alturas dinâmicas */
  --topbar-h: 60px;
  --bottom-nav-h: 68px;
  --sidebar-w: 240px;

  /* Safe area iOS (iPhone X+) */
  --safe-top:    env(safe-area-inset-top,    0px);
  --safe-bottom: env(safe-area-inset-bottom, 0px);
  --safe-left:   env(safe-area-inset-left,   0px);
  --safe-right:  env(safe-area-inset-right,  0px);

  /* Espaçamento fluido */
  --space-xs:  clamp(4px,  1vw, 8px);
  --space-sm:  clamp(8px,  1.5vw, 14px);
  --space-md:  clamp(12px, 2vw,  20px);
  --space-lg:  clamp(16px, 2.5vw, 28px);
  --space-xl:  clamp(20px, 3vw,  40px);

  /* Tipografia fluida */
  --text-xs:   clamp(0.6rem,  1.2vw, 0.72rem);
  --text-sm:   clamp(0.72rem, 1.4vw, 0.82rem);
  --text-base: clamp(0.82rem, 1.6vw, 0.9rem);
  --text-md:   clamp(0.88rem, 1.8vw, 1rem);
  --text-lg:   clamp(1rem,    2.2vw, 1.2rem);
  --text-xl:   clamp(1.1rem,  2.5vw, 1.4rem);
}

/* =====================================================
   2. BASE RESET RESPONSIVO — impede overflow horizontal
   ===================================================== */
html {
  overflow-x: hidden;
  /* Corrige altura em browsers mobile que ignoram 100vh */
  height: -webkit-fill-available;
}

body {
  min-height: 100dvh;
  min-height: -webkit-fill-available;
  overflow-x: hidden;
  /* Suaviza scroll em iOS */
  -webkit-overflow-scrolling: touch;
}

*,
*::before,
*::after {
  box-sizing: border-box;
}

/* Impede que imagens/canvas vazem do container */
img,
canvas,
video,
iframe {
  max-width: 100%;
}

/* =====================================================
   3. TOPBAR — responsiva com safe areas
   ===================================================== */

/* Topbar recebe padding-left do safe-area em modo landscape */
.topbar {
  padding-left:  max(18px, calc(18px + var(--safe-left)));
  padding-right: max(18px, calc(18px + var(--safe-right)));
  /* Garante que fique ACIMA da notch */
  padding-top: var(--safe-top);
  height: calc(var(--topbar-h) + var(--safe-top));
}

/* Ajusta o main-content para compensar topbar com safe-top */
.main-content {
  margin-top: calc(var(--topbar-h) + var(--safe-top));
}

/* =====================================================
   4. SIDEBAR — transições suaves + overlay
   ===================================================== */
.sidebar {
  /* Já tem position:fixed no style.css */
  will-change: transform;
  -webkit-overflow-scrolling: touch;
}

/* Scroll suave na navegação interna da sidebar */
.sidebar-nav {
  overscroll-behavior: contain;
}

/* =====================================================
   5. MAIN CONTENT — sem overflow, padding seguro
   ===================================================== */
.main-content {
  overflow-x: hidden;
  /* Evita que conteúdo fique por baixo de bottom-nav */
}

/* Tab contents nunca transbordam */
.tab-content {
  overflow-x: hidden;
  min-width: 0;
}

/* =====================================================
   6. GINGA GAME CONTAINER — iframe adaptável
   ===================================================== */

/*
  Desktop (> 1024px):
  - aspect-ratio 731/443 com max-height
*/
.ginga-iframe-wrap {
  position: relative;
  width: 100%;
  aspect-ratio: 731 / 443;
  max-height: clamp(360px, 50vw, 600px);
  background: #05050a;
  overflow: hidden;
  contain: layout style;
}

/* O iframe ocupa 100% do wrap em qualquer tamanho.
   Posição (top/height) é controlada pelo JS em _gingabetLoadIframe()
   para aplicar offset quando a URL da GingaBet é usada como fallback. */
#ginga-game-iframe {
  position: absolute;
  top: 0;       /* JS sobrescreve para -60px em URLs ginga.bet.br */
  left: 0;
  width: 100%;
  height: 100%; /* JS sobrescreve para calc(100% + 116px) em URLs ginga.bet.br */
  border: none;
}

/* =====================================================
   7. ULTRAWIDE (≥ 1600px) — limita expansão
   ===================================================== */
@media (min-width: 1600px) {
  .main-content {
    /* Evita que o conteúdo fique absurdamente largo */
    max-width: calc(100vw - var(--sidebar-w));
  }

  .ginga-iframe-wrap {
    max-height: 620px;
  }

  .dashboard-grid {
    grid-template-columns: repeat(3, 1fr);
    max-width: 1400px;
  }

  .live-layout {
    grid-template-columns: 1fr 380px;
  }

  .network-layout {
    grid-template-columns: 1fr 340px;
  }
}

/* =====================================================
   8. LARGE DESKTOP (1200px – 1599px) — sem mudanças críticas
   ===================================================== */
@media (min-width: 1200px) and (max-width: 1599px) {
  .live-layout {
    grid-template-columns: 1fr 340px;
  }
}

/* =====================================================
   9. TABLET LANDSCAPE / SMALL DESKTOP (901px – 1199px)
   ===================================================== */
@media (max-width: 1199px) {
  :root {
    --sidebar-w: 220px;
  }

  .sidebar {
    width: var(--sidebar-w);
  }

  .topbar {
    left: var(--sidebar-w);
  }

  .main-content {
    margin-left: var(--sidebar-w);
    width: calc(100% - var(--sidebar-w));
    max-width: calc(100vw - var(--sidebar-w));
    padding: var(--space-lg);
  }

  /* Topbar title mais compacto */
  .topbar-title {
    font-size: clamp(0.7rem, 1.3vw, 0.82rem);
  }

  /* Live layout: sidebar embaixo em tablet */
  .live-layout {
    grid-template-columns: 1fr;
  }

  .live-sidebar {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 14px;
  }

  /* Charts: 1 coluna */
  .charts-row {
    grid-template-columns: 1fr;
  }

  /* Calc: 1 coluna */
  .calc-layout {
    grid-template-columns: 1fr;
  }

  /* Admin: 1 coluna */
  .admin-grid {
    grid-template-columns: 1fr;
  }

  .admin-stats-row {
    grid-template-columns: repeat(2, 1fr);
  }

  /* Network */
  .network-layout {
    grid-template-columns: 1fr 260px;
  }

  /* Iframe do jogo: altura controlada em tablet */
  .ginga-iframe-wrap {
    max-height: clamp(300px, 45vw, 520px);
  }
}

/* =====================================================
   10. TABLET PORTRAIT (769px – 900px)
   ===================================================== */
@media (max-width: 900px) {
  .live-sidebar {
    grid-template-columns: repeat(2, 1fr);
  }

  .network-layout {
    grid-template-columns: 1fr;
  }

  .network-right {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 14px;
  }

  .calc-stats-row {
    grid-template-columns: repeat(2, 1fr);
  }
}

/* =====================================================
   11. MOBILE BREAK (≤ 768px) — sidebar oculta + bottom-nav
   ===================================================== */
@media (max-width: 768px) {

  /* ── Topbar zero-left (sidebar some) ── */
  .topbar {
    left: 0;
    padding-left:  max(12px, calc(12px + var(--safe-left)));
    padding-right: max(12px, calc(12px + var(--safe-right)));
    height: calc(var(--topbar-h) + var(--safe-top));
  }

  .main-content {
    margin-left: 0;
    margin-top: calc(var(--topbar-h) + var(--safe-top));
    width: 100%;
    max-width: 100vw;
    padding: var(--space-md) var(--space-sm) calc(var(--bottom-nav-h) + var(--safe-bottom) + 14px);
    overflow-x: hidden;
  }

  /* ── Bottom nav respeitando safe-area ── */
  .bottom-nav {
    height: calc(var(--bottom-nav-h) + var(--safe-bottom));
    padding-bottom: var(--safe-bottom);
    padding-left:  var(--safe-left);
    padding-right: var(--safe-right);
  }

  /* ── Toast acima do bottom-nav ── */
  #toast-container {
    bottom: calc(var(--bottom-nav-h) + var(--safe-bottom) + 12px);
  }

  /* ── Topbar compacta ── */
  .topbar-logo-img {
    height: 38px;
  }

  .topbar-title {
    font-size: clamp(0.68rem, 3vw, 0.82rem);
    max-width: 140px;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
  }

  .topbar-user-name {
    max-width: clamp(60px, 15vw, 90px);
  }

  /* ── Dashboard grid ── */
  .dashboard-grid {
    grid-template-columns: 1fr 1fr;
    gap: clamp(8px, 2vw, 14px);
  }

  .dash-card {
    padding: clamp(10px, 2.5vw, 16px);
    gap: clamp(8px, 2vw, 12px);
  }

  .dash-value {
    font-size: clamp(1rem, 4vw, 1.25rem);
  }

  .dash-label {
    font-size: var(--text-xs);
  }

  /* ── Live layout ── */
  .live-layout {
    grid-template-columns: 1fr;
    gap: 14px;
  }

  .live-sidebar {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 12px;
  }

  /* ── IFRAME DO JOGO — modo mobile ──
     Usa dvh (dynamic viewport height) para respeitar
     a barra de endereço retrátil do Chrome/Safari mobile.
     Desconta: topbar + safe-top + signal-bar(40px) + bottom-nav + safe-bottom
  */
  .ginga-iframe-wrap {
    /* Remove aspect-ratio em mobile — usa altura explícita */
    aspect-ratio: unset;
    width: 100%;
    height: calc(
      100dvh
      - var(--topbar-h)
      - var(--safe-top)
      - 40px
      - var(--bottom-nav-h)
      - var(--safe-bottom)
      - 8px
    );
    min-height: 280px;
    max-height: none;
  }

  /* Container do jogo sem bordas extras em mobile */
  .ginga-game-container {
    border-radius: 10px;
    margin-bottom: 14px;
  }

  .ginga-game-header {
    padding: 8px 12px;
  }

  .ginga-game-title {
    font-size: clamp(0.72rem, 3vw, 0.85rem);
  }

  /* ── Calc layout ── */
  .calc-layout {
    grid-template-columns: 1fr;
    gap: 14px;
  }

  /* ── Chat ── */
  .chat-layout {
    grid-template-columns: 1fr;
    height: calc(
      100dvh
      - var(--topbar-h)
      - var(--safe-top)
      - var(--bottom-nav-h)
      - var(--safe-bottom)
      - 48px
    );
    min-height: 380px;
  }

  /* ── Network ── */
  .network-layout {
    grid-template-columns: 1fr;
  }

  .network-right {
    grid-template-columns: 1fr 1fr;
    gap: 12px;
  }

  /* ── Admin ── */
  .admin-stats-row {
    grid-template-columns: 1fr 1fr;
    gap: 10px;
  }

  .admin-grid {
    grid-template-columns: 1fr;
  }

  /* Neutraliza span 2 quando grid é 1 coluna */
  .admin-grid .admin-card[style*="grid-column"] {
    grid-column: span 1 !important;
  }

  /* Garante que nenhum filho do admin vaze lateralmente */
  .admin-card,
  .admin-card * {
    max-width: 100%;
    min-width: 0;
  }

  /* patterns-layout colapsa para 1 coluna */
  .patterns-layout {
    grid-template-columns: 1fr;
    gap: 14px;
  }

  /* Legenda dos padrões quebra sem overflow */
  .patterns-legend {
    flex-wrap: wrap;
    gap: 6px;
    font-size: 0.7rem;
  }

  /* Input de padrão único não vaza */
  #pe-single-input {
    min-width: 0;
    width: 100%;
  }

  /* ── Aulas ── */
  .aulas-header {
    flex-direction: column;
    align-items: stretch;
    gap: 10px;
  }

  .modules-grid {
    grid-template-columns: repeat(auto-fill, minmax(260px, 1fr));
  }

  /* ── Signal ticker ── */
  .signal-ticker {
    padding: 8px 12px;
  }

  /* ── Notif panel ── */
  .notif-panel {
    width: calc(100vw - 24px);
    right: 12px;
    left: 12px;
    max-height: calc(100dvh - var(--topbar-h) - var(--safe-top) - 70px);
    overflow-y: auto;
  }

  /* ── LOGIN MOBILE ── */
  .login-bg {
    align-items: stretch;
    min-height: 100dvh;
  }

  .login-wrapper {
    flex-direction: column;
    align-items: stretch;
    min-height: 100dvh;
    max-width: 100%;
    padding: 0;
  }

  /* Oculta o lado de branding (stats, badges) no mobile */
  .login-brand {
    display: none;
  }

  /* Form-side ocupa tela toda */
  .login-form-side {
    width: 100%;
    flex: 1;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 24px 20px;
    min-height: 100dvh;
  }

  /* Card ocupa quase toda a largura */
  .login-card {
    width: 100%;
    max-width: 440px;
    padding: 32px 24px;
    border-radius: 20px;
  }

  /* Logo maior no mobile */
  .login-card-logo img {
    height: 80px;
  }

  .login-card h2 {
    font-size: 1.55rem;
  }
}

/* =====================================================
   12. MOBILE PEQUENO (≤ 580px)
   ===================================================== */
@media (max-width: 580px) {
  /* ── Layout ── */
  .main-content {
    padding: var(--space-sm) var(--space-xs) calc(var(--bottom-nav-h) + var(--safe-bottom) + 14px);
  }

  /* ── Dashboard ── */
  .dashboard-grid {
    grid-template-columns: 1fr 1fr;
    gap: 8px;
  }

  .dash-card {
    padding: 10px 8px;
    gap: 8px;
  }

  .dash-card-icon {
    width: 34px;
    height: 34px;
    font-size: 0.9rem;
  }

  .dash-value {
    font-size: clamp(0.9rem, 3.5vw, 1.1rem);
  }

  /* ── Live sidebar ── */
  .live-sidebar {
    grid-template-columns: 1fr;
  }

  /* ── Admin stats ── */
  .admin-stats-row {
    grid-template-columns: 1fr 1fr;
  }

  /* ── Iframe do jogo ── */
  .ginga-iframe-wrap {
    height: calc(
      100dvh
      - var(--topbar-h)
      - var(--safe-top)
      - 40px
      - var(--bottom-nav-h)
      - var(--safe-bottom)
      - 8px
    );
    min-height: 260px;
  }

  /* ── Network ── */
  .network-right {
    grid-template-columns: 1fr;
  }

  /* ── Topbar ── */
  .topbar-user-chip {
    padding: 4px 8px 4px 4px;
    gap: 6px;
  }

  .topbar-user-info {
    display: none; /* só avatar em telas muito pequenas */
  }

  .signal-alert-text {
    display: none;
  }

  .signal-alert {
    padding: 5px 8px;
  }

  /* ── Calc stats ── */
  .calc-stats-row {
    grid-template-columns: 1fr 1fr;
  }
}

/* =====================================================
   13. PHONE MUITO PEQUENO (≤ 390px) — iPhone SE, Android compact
   ===================================================== */
@media (max-width: 390px) {
  :root {
    --topbar-h: 54px;
    --bottom-nav-h: 62px;
  }

  .main-content {
    padding: 8px 8px calc(var(--bottom-nav-h) + var(--safe-bottom) + 12px);
  }

  .dashboard-grid {
    grid-template-columns: 1fr 1fr;
    gap: 6px;
  }

  .dash-card {
    padding: 8px 6px;
    gap: 6px;
  }

  .dash-card-icon {
    width: 30px;
    height: 30px;
    font-size: 0.8rem;
    border-radius: 8px;
  }

  .dash-value {
    font-size: clamp(0.85rem, 3.2vw, 1rem);
  }

  .dash-label {
    font-size: 0.58rem;
  }

  .topbar-logo-img {
    height: 24px;
  }

  .topbar-title {
    display: none; /* elimina título na topbar em phone muito pequeno */
  }

  /* ── Iframe ── */
  .ginga-iframe-wrap {
    height: calc(
      100dvh
      - var(--topbar-h)
      - var(--safe-top)
      - 40px
      - var(--bottom-nav-h)
      - var(--safe-bottom)
      - 4px
    );
    min-height: 240px;
  }

  /* ── Login ── */
  .login-card {
    padding: 20px 14px;
    border-radius: 14px;
  }

  .login-quick-row {
    grid-template-columns: 1fr;
  }

  /* ── Bottom nav ── */
  .bnav-item {
    font-size: 0.52rem;
    gap: 2px;
  }

  .bnav-item i {
    font-size: 0.95rem;
  }

  /* ── Admin ── */
  .admin-stats-row {
    grid-template-columns: 1fr 1fr;
    gap: 6px;
  }

  .admin-stat-card {
    padding: 10px 8px;
    gap: 6px;
  }

  .admin-stat-card strong {
    font-size: 1rem;
  }
}

/* =====================================================
   14. LANDSCAPE PHONE (altura ≤ 480px + largura > 568px)
       Ex: iPhone landscape, Android landscape
   ===================================================== */
@media (max-height: 480px) and (orientation: landscape) {
  :root {
    --topbar-h: 48px;
    --bottom-nav-h: 52px;
  }

  /* Topbar mais baixa em landscape */
  .topbar {
    height: calc(var(--topbar-h) + var(--safe-top));
  }

  .main-content {
    margin-top: calc(var(--topbar-h) + var(--safe-top));
    padding: 8px var(--space-sm) calc(var(--bottom-nav-h) + var(--safe-bottom) + 8px);
    /* Padding lateral seguro em landscape (safe-area notch) */
    padding-left:  max(var(--space-sm), calc(var(--space-sm) + var(--safe-left)));
    padding-right: max(var(--space-sm), calc(var(--space-sm) + var(--safe-right)));
  }

  /* Iframe do jogo em landscape phone */
  .ginga-iframe-wrap {
    aspect-ratio: unset;
    height: calc(
      100dvh
      - var(--topbar-h)
      - var(--safe-top)
      - 40px
      - var(--bottom-nav-h)
      - var(--safe-bottom)
      - 4px
    );
    min-height: 200px;
    max-height: 320px;
  }

  /* Live layout em 2 colunas em landscape */
  .live-layout {
    grid-template-columns: 1fr 280px;
    gap: 10px;
  }

  .live-sidebar {
    display: flex;
    flex-direction: column;
    gap: 8px;
    overflow-y: auto;
    max-height: calc(100dvh - var(--topbar-h) - var(--bottom-nav-h) - 60px);
  }

  /* Dashboard em landscape */
  .dashboard-grid {
    grid-template-columns: repeat(3, 1fr);
    gap: 8px;
  }

  /* Chat em landscape */
  .chat-layout {
    height: calc(
      100dvh
      - var(--topbar-h)
      - var(--safe-top)
      - var(--bottom-nav-h)
      - var(--safe-bottom)
      - 20px
    );
    min-height: 200px;
  }

  /* Sidebar do chat volta a aparecer em landscape */
  .chat-sidebar {
    display: flex !important;
    width: 180px;
  }

  .chat-layout {
    grid-template-columns: 180px 1fr;
  }

  /* Signal bar menor */
  .signal-bar {
    height: 34px;
  }
}

/* =====================================================
   15. TABLET (769px – 1024px) — portrait e landscape
   ===================================================== */
@media (min-width: 769px) and (max-width: 1024px) {
  :root {
    --sidebar-w: 220px;
  }

  .sidebar {
    width: var(--sidebar-w);
  }

  .topbar {
    left: var(--sidebar-w);
  }

  .main-content {
    margin-left: var(--sidebar-w);
    width: calc(100% - var(--sidebar-w));
    max-width: calc(100vw - var(--sidebar-w));
    padding: var(--space-lg);
  }

  /* Iframe do jogo em tablet */
  .ginga-iframe-wrap {
    aspect-ratio: 731 / 443;
    max-height: clamp(320px, 42vw, 480px);
  }

  /* Live sidebar: 2 colunas */
  .live-sidebar {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 14px;
  }

  /* Dashboard: 3 colunas */
  .dashboard-grid {
    grid-template-columns: repeat(3, 1fr);
  }

  /* Calc: 1 coluna */
  .calc-layout {
    grid-template-columns: 1fr;
  }
}

/* =====================================================
   16. DESKTOP PADRÃO (1025px – 1400px)
   ===================================================== */
@media (min-width: 1025px) and (max-width: 1400px) {
  /* Live sidebar visível ao lado */
  .live-layout {
    grid-template-columns: 1fr 300px;
  }

  .live-sidebar {
    display: flex;
    flex-direction: column;
  }

  /* Iframe normal */
  .ginga-iframe-wrap {
    aspect-ratio: 731 / 443;
    max-height: clamp(380px, 42vw, 560px);
  }
}

/* =====================================================
   17. TEXTOS FLUIDOS COM CLAMP()
   ===================================================== */

/* Títulos das seções */
.chart-card h3,
.recent-ops h3,
.signal-card-header,
.sequence-panel h4,
.win-rate-card h4,
.history-panel h4 {
  font-size: clamp(0.72rem, 1.5vw, 0.9rem);
}

/* Valores de dashboard */
.dash-value {
  font-size: clamp(0.95rem, 2.5vw, 1.4rem);
}

.dash-label {
  font-size: clamp(0.58rem, 1.2vw, 0.75rem);
}

/* Saldo Gingabet */
.gb-balance-val {
  font-size: clamp(1.1rem, 3vw, 1.4rem);
}

/* Admin stat numbers */
.admin-stat-card strong {
  font-size: clamp(1rem, 2.5vw, 1.4rem);
}

/* Títulos de módulos de aulas */
.module-body h4 {
  font-size: clamp(0.85rem, 1.8vw, 0.95rem);
}

/* Texto do chat */
.msg-text {
  font-size: clamp(0.78rem, 1.5vw, 0.85rem);
}

/* Botão principal Gingabet */
.goc-title {
  font-size: clamp(1.1rem, 3vw, 1.5rem);
}

.goc-sub {
  font-size: clamp(0.78rem, 1.6vw, 0.88rem);
}

/* =====================================================
   18. AJUSTES DE TOUCH — mínimo 44px em elementos clicáveis
   ===================================================== */
@media (hover: none) and (pointer: coarse) {
  /* Área mínima de toque para botões */
  .btn-gold,
  .btn-outline,
  .btn-green,
  .btn-red,
  .filter-btn,
  .mod-tab,
  .nav-item,
  .bnav-item,
  .ginga-url-btn,
  .ginga-refresh-btn,
  .ginga-expand-btn,
  .ginga-url-load-btn,
  .gb-login-btn,
  .goc-btn {
    min-height: 44px;
    touch-action: manipulation;
  }

  /* Inputs mais altos em touch */
  input[type="text"],
  input[type="email"],
  input[type="password"],
  input[type="number"],
  select,
  textarea {
    min-height: 44px;
    font-size: 16px; /* Previne zoom automático no iOS */
  }

  /* Remove hover delay em touch */
  .nav-item,
  .btn-gold,
  .btn-outline,
  .dash-card,
  .module-card,
  .post-card {
    -webkit-tap-highlight-color: transparent;
  }

  /* Scroll mais suave nos containers */
  .messages-area,
  .sidebar-nav,
  .notif-list,
  .history-list,
  .daily-log,
  .mod-list,
  .users-list,
  .patterns-saved-list,
  .patterns-preview-list,
  .bacbo-history-list,
  .online-list {
    -webkit-overflow-scrolling: touch;
    overscroll-behavior: contain;
  }
}

/* =====================================================
   19. PREFERS-REDUCED-MOTION — acessibilidade
   ===================================================== */
@media (prefers-reduced-motion: reduce) {
  /* Reduz animações decorativas gerais */
  *,
  *::before,
  *::after {
    animation-duration: 0.01ms !important;
    animation-iteration-count: 1 !important;
    transition-duration: 0.01ms !important;
  }
  /* ── EXCEÇÃO: animações funcionais da FSB (barra de sinais) ──
     Sem essas animações a barra parece "travada" mesmo funcionando */
  .fsb-scan-icon::before {
    animation-duration: 1.6s !important;
    animation-iteration-count: infinite !important;
    animation-name: fsbRadar !important;
    animation-timing-function: ease-out !important;
    animation-delay: 0s !important;
  }
  .fsb-scan-icon::after {
    animation-duration: 1.6s !important;
    animation-iteration-count: infinite !important;
    animation-name: fsbRadar !important;
    animation-timing-function: ease-out !important;
    animation-delay: .8s !important;
  }
  .fsb-bars span {
    animation-duration: 1.1s !important;
    animation-iteration-count: infinite !important;
    animation-name: fsbPulse !important;
    animation-timing-function: ease-in-out !important;
  }
  .fsb-dot.red,
  .fsb-dot.blue,
  .fsb-dot.orange,
  .fsb-dot.purple,
  .fsb-dot.green {
    animation-duration: 1.8s !important;
    animation-iteration-count: infinite !important;
    animation-name: fsbDotGlow !important;
    animation-timing-function: ease-in-out !important;
  }
}

/* =====================================================
   20. PRINT — oculta elementos desnecessários
   ===================================================== */
@media print {
  .sidebar,
  .topbar,
  .bottom-nav,
  #toast-container,
  .notif-panel,
  .ginga-game-container,
  .signal-bar,
  .btn-fullscreen {
    display: none !important;
  }

  .main-content {
    margin: 0;
    padding: 0;
    width: 100%;
    max-width: 100%;
  }
}

/* =====================================================
   21. CORREÇÕES ESPECÍFICAS DE COMPONENTES
   ===================================================== */

/* ── Charts: canvas nunca vaza ── */
.chart-card {
  min-width: 0;
  overflow: hidden;
}

.chart-card canvas {
  max-width: 100% !important;
  height: auto !important;
}

/* ── Tabelas: scroll horizontal suave ── */
.ops-table-wrap {
  overflow-x: auto;
  -webkit-overflow-scrolling: touch;
  /* Scrollbar visível em mobile */
  scrollbar-width: thin;
  scrollbar-color: rgba(201,168,76,0.3) transparent;
}

/* ── Gingabet card em mobile ── */
@media (max-width: 480px) {
  .gingabet-card {
    padding: 12px;
    margin-top: 12px;
  }

  .gb-form-row {
    flex-direction: column;
    gap: 10px;
  }

  .gb-form-row .form-group {
    min-width: unset;
    width: 100%;
  }

  .gb-login-btn {
    width: 100%;
    justify-content: center;
    height: 46px;
  }

  .gb-info-row {
    flex-direction: column;
  }

  .gb-info-box {
    min-width: unset;
  }

  .gb-logout-btn {
    width: 100%;
    justify-content: center;
    display: flex;
  }

  .gb-deposit-row {
    flex-direction: column;
  }

  .gb-deposit-row input {
    width: 100%;
  }

  .gb-deposit-row .btn-gold {
    width: 100%;
    justify-content: center;
  }
}

/* ── Sequence balls não vazam ── */
.sequence-balls {
  flex-wrap: wrap;
  max-width: 100%;
}

/* ── Bacbo stats em mobile ── */
@media (max-width: 480px) {
  .bacbo-stats-row {
    grid-template-columns: repeat(2, 1fr);
    gap: 6px;
  }
}

/* ── Auto-signal: grid correto ── */
@media (max-width: 480px) {
  .auto-signal-btns {
    grid-template-columns: 1fr;
  }

  .auto-ctrl-row {
    flex-direction: column;
    align-items: stretch;
  }

  .auto-apply-btn {
    width: 100%;
  }
}

/* ── Signal bar mobile ── */
@media (max-width: 480px) {
  .signal-bar {
    height: 36px;
  }

  .fsb-live {
    padding: 0 8px 0 10px;
  }

  .fsb-item {
    padding: 0 6px;
  }

  .fsb-lbl {
    font-size: 0.55rem;
  }

  .fsb-val {
    font-size: 0.60rem;
  }

  .fsb-result-title {
    font-size: 0.62rem;
  }

  .fsb-actions {
    padding: 0 8px 0 4px;
  }
}

/* ── Live header ── */
.live-header {
  flex-wrap: wrap;
  gap: 6px;
}

/* ── Modules grid: sempre responsivo ── */
.modules-grid {
  grid-template-columns: repeat(auto-fill, minmax(min(280px, 100%), 1fr));
}

/* ── Calc result items ── */
@media (max-width: 480px) {
  .calc-result-item {
    padding: 7px 10px;
    font-size: var(--text-sm);
  }

  .calc-result-item strong {
    font-size: 0.9rem;
  }
}

/* ── Profile overview ── */
@media (max-width: 480px) {
  .progress-overview {
    flex-direction: column;
    align-items: flex-start;
    gap: 8px;
  }

  .prog-bar-outer {
    width: 100%;
    min-width: unset;
  }
}

/* ── Aulas filters ── */
@media (max-width: 580px) {
  .aulas-filters {
    flex-wrap: wrap;
    gap: 6px;
  }

  .filter-btn {
    font-size: 0.75rem;
    padding: 5px 10px;
    min-height: 34px;
  }
}

/* ── Post footer em mobile ── */
@media (max-width: 480px) {
  .post-footer {
    gap: 6px;
    flex-wrap: wrap;
  }

  .post-action {
    font-size: 0.75rem;
    padding: 4px 6px;
  }

  .post-text {
    font-size: var(--text-sm);
  }
}

/* ── Admin patterns em mobile ── */
@media (max-width: 480px) {
  .patterns-import-btns {
    flex-direction: column;
  }

  .patterns-import-btns button {
    width: 100%;
  }

  .patterns-legend {
    font-size: 0.72rem;
    gap: 8px;
    padding: 8px 10px;
  }

  .send-signal-box {
    padding: 10px;
  }
}

/* ── Daily btns em mobile ── */
@media (max-width: 768px) {
  .daily-btns {
    flex-direction: column;
    gap: 8px;
  }

  .daily-btns button {
    width: 100%;
  }
}

/* ── Network feed ── */
@media (max-width: 480px) {
  .create-post-footer {
    flex-wrap: wrap;
    gap: 8px;
  }

  .create-post-footer .btn-gold {
    margin-left: 0;
    width: 100%;
    justify-content: center;
  }
}

/* ── Sidebar overlay (previne scroll do body quando aberta) ── */
body.sidebar-open {
  overflow: hidden;
  position: fixed;
  width: 100%;
}

/* ── Iframe input wrap ── */
@media (max-width: 480px) {
  .iframe-input-wrap {
    flex-direction: column;
    gap: 8px;
    padding: 0 12px;
  }

  .iframe-url-input {
    width: 100%;
  }
}

/* =====================================================
   22. CORREÇÃO: sem overflow na tab live em mobile
   ===================================================== */
@media (max-width: 768px) {
  /* O container da live tab não deve criar scroll horizontal */
  #tab-live {
    overflow-x: hidden;
  }

  /* Signal ticker: evita que texto vaze */
  .signal-ticker {
    overflow: hidden;
  }

  /* Bacbo live card: sem overflow */
  .bacbo-live-card {
    overflow: hidden;
  }

  /* Live latest wrap: texto compacto */
  .live-latest-result {
    font-size: clamp(0.78rem, 3.5vw, 0.95rem);
  }
}

/* =====================================================
   23. FULLSCREEN APRIMORADO
   ===================================================== */
.ginga-game-container:fullscreen,
.ginga-game-container:-webkit-full-screen {
  background: #000;
}

.ginga-game-container:fullscreen .ginga-iframe-wrap,
.ginga-game-container:-webkit-full-screen .ginga-iframe-wrap {
  aspect-ratio: unset;
  width: 100vw;
  height: 100dvh;
  max-height: none;
  border-radius: 0;
}

/* =====================================================
   24. SCROLLBAR GLOBAL CUSTOMIZADA (desktop)
   ===================================================== */
@media (min-width: 769px) {
  ::-webkit-scrollbar {
    width: 5px;
    height: 5px;
  }

  ::-webkit-scrollbar-track {
    background: transparent;
  }

  ::-webkit-scrollbar-thumb {
    background: rgba(201,168,76,0.25);
    border-radius: 10px;
  }

  ::-webkit-scrollbar-thumb:hover {
    background: rgba(201,168,76,0.45);
  }
}

/* =====================================================
   25. DASHBOARD PREMIUM 2026
   ===================================================== */

/* ── Animações globais da dash ── */
@keyframes dashCardGlow {
  0%,100% { box-shadow: 0 0 20px rgba(0,0,0,0.5); }
  50%      { box-shadow: 0 0 32px rgba(var(--card-glow-rgb), 0.18); }
}
@keyframes dashPulse {
  0%,100% { opacity: 1; transform: scale(1); }
  50%      { opacity: .7; transform: scale(1.06); }
}
@keyframes radarSpin {
  from { transform: rotate(0deg); }
  to   { transform: rotate(360deg); }
}
@keyframes radarPing {
  0%   { transform: scale(1); opacity:.7; }
  100% { transform: scale(2.6); opacity:0; }
}
@keyframes signalBlink {
  0%,100% { opacity:1; }
  50%      { opacity:.35; }
}
@keyframes shimmer {
  0%   { background-position: -200% center; }
  100% { background-position:  200% center; }
}
@keyframes barLoad {
  from { transform: scaleY(0); }
  to   { transform: scaleY(1); }
}

/* ── Grid principal ── */
.dashboard-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: clamp(10px, 2vw, 18px);
  margin-bottom: clamp(16px, 3vw, 28px);
}

/* ── Cards premium ── */
.dash-card {
  background: linear-gradient(145deg, rgba(22,22,32,.95) 0%, rgba(14,14,22,.98) 100%);
  border: 1px solid rgba(255,255,255,.07);
  border-radius: 18px;
  padding: clamp(14px,2.5vw,22px) clamp(12px,2vw,20px);
  display: flex;
  align-items: center;
  gap: clamp(10px,1.5vw,16px);
  position: relative;
  overflow: hidden;
  min-width: 0;
  cursor: default;
  transition: transform .22s ease, box-shadow .22s ease, border-color .22s ease;
  backdrop-filter: blur(10px);
}

/* brilho de canto interno */
.dash-card::after {
  content:'';
  position:absolute;
  inset:0;
  border-radius:inherit;
  background: radial-gradient(ellipse at 20% 20%, rgba(255,255,255,.04) 0%, transparent 60%);
  pointer-events:none;
}

/* linha topo neon */
.dash-card::before {
  content:'';
  position:absolute;
  top:0; left:16px; right:16px;
  height:1.5px;
  border-radius:2px;
  opacity:.9;
}
.card-green::before { background: linear-gradient(90deg,transparent,#4ade80,transparent); box-shadow:0 0 8px rgba(74,222,128,.7); }
.card-gold::before  { background: linear-gradient(90deg,transparent,#f0c040,transparent); box-shadow:0 0 8px rgba(240,192,64,.7); }
.card-blue::before  { background: linear-gradient(90deg,transparent,#60a5fa,transparent); box-shadow:0 0 8px rgba(96,165,250,.7); }

.dash-card:hover {
  transform: translateY(-3px);
  border-color: rgba(255,255,255,.13);
}
.card-green:hover { box-shadow: 0 8px 32px rgba(74,222,128,.15),  0 2px 8px rgba(0,0,0,.5); }
.card-gold:hover  { box-shadow: 0 8px 32px rgba(240,192,64,.15),  0 2px 8px rgba(0,0,0,.5); }
.card-blue:hover  { box-shadow: 0 8px 32px rgba(96,165,250,.15),  0 2px 8px rgba(0,0,0,.5); }

/* ícone premium */
.dash-card-icon {
  width: clamp(38px,7vw,52px);
  height: clamp(38px,7vw,52px);
  border-radius: 14px;
  display: flex; align-items: center; justify-content: center;
  font-size: clamp(.95rem,2.5vw,1.25rem);
  flex-shrink: 0;
  position: relative;
  z-index: 1;
}
.card-green .dash-card-icon {
  background: rgba(74,222,128,.12);
  border: 1px solid rgba(74,222,128,.25);
  color: #4ade80;
  box-shadow: 0 0 16px rgba(74,222,128,.2), inset 0 0 8px rgba(74,222,128,.07);
}
.card-gold .dash-card-icon {
  background: rgba(240,192,64,.12);
  border: 1px solid rgba(240,192,64,.25);
  color: #f0c040;
  box-shadow: 0 0 16px rgba(240,192,64,.2), inset 0 0 8px rgba(240,192,64,.07);
}
.card-blue .dash-card-icon {
  background: rgba(96,165,250,.12);
  border: 1px solid rgba(96,165,250,.25);
  color: #60a5fa;
  box-shadow: 0 0 16px rgba(96,165,250,.2), inset 0 0 8px rgba(96,165,250,.07);
}

/* pulse no ícone */
.dash-card-icon i {
  animation: dashPulse 3s ease-in-out infinite;
}
.card-gold  .dash-card-icon i { animation-delay: .4s; }
.card-blue  .dash-card-icon i { animation-delay: .8s; }

.dash-card-info { display: flex; flex-direction: column; gap: 5px; min-width: 0; flex: 1; position: relative; z-index: 1; }

.dash-label {
  font-size: clamp(.6rem,1.4vw,.72rem);
  color: rgba(160,160,185,.6);
  text-transform: uppercase;
  letter-spacing: .08em;
  font-weight: 600;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.dash-value {
  font-size: clamp(1.1rem,3.5vw,1.5rem);
  font-weight: 900;
  font-family: 'Rajdhani', 'Inter', sans-serif;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  letter-spacing: .02em;
  line-height: 1.1;
}
.card-green .dash-value { color: #4ade80; text-shadow: 0 0 12px rgba(74,222,128,.5); }
.card-gold  .dash-value { color: #f0c040; text-shadow: 0 0 12px rgba(240,192,64,.5); }
.card-blue  .dash-value { color: #60a5fa; text-shadow: 0 0 12px rgba(96,165,250,.5); }

/* mini bar decorativa debaixo do valor */
.dash-card-info::after {
  content:'';
  display:block;
  height:2px;
  border-radius:2px;
  margin-top:4px;
  width:40%;
  opacity:.5;
}
.card-green .dash-card-info::after { background: linear-gradient(90deg,#4ade80,transparent); }
.card-gold  .dash-card-info::after { background: linear-gradient(90deg,#f0c040,transparent); }
.card-blue  .dash-card-info::after { background: linear-gradient(90deg,#60a5fa,transparent); }

/* ── ÚLTIMO SINAL — Hero area premium ── */
.last-signal-banner {
  position: relative;
  background: linear-gradient(135deg, rgba(10,10,18,1) 0%, rgba(16,14,8,1) 100%);
  border: 1px solid rgba(240,192,64,.2);
  border-radius: 20px;
  padding: clamp(16px,3vw,24px) clamp(16px,3vw,24px);
  margin-bottom: clamp(16px,3vw,24px);
  overflow: hidden;
  display: flex;
  align-items: center;
  gap: 16px;
  flex-wrap: wrap;
}

/* brilho de fundo dourado suave */
.last-signal-banner::before {
  content:'';
  position:absolute;
  top:-40%; left:50%;
  transform:translateX(-50%);
  width:60%;
  height:100%;
  background: radial-gradient(ellipse at center top, rgba(240,192,64,.07) 0%, transparent 70%);
  pointer-events:none;
}

/* grade de pontos futurista */
.last-signal-banner::after {
  content:'';
  position:absolute;
  inset:0;
  background-image:
    radial-gradient(circle, rgba(255,255,255,.04) 1px, transparent 1px);
  background-size: 22px 22px;
  pointer-events:none;
  opacity:.6;
}

.signal-label {
  font-size: clamp(.62rem,1.5vw,.75rem);
  font-weight: 800;
  color: #f0c040;
  text-transform: uppercase;
  letter-spacing: .1em;
  display: flex;
  align-items: center;
  gap: 8px;
  white-space: nowrap;
  position: relative;
  z-index: 1;
}

/* radar animado ao lado do label */
.signal-label::before {
  content:'';
  width:8px; height:8px;
  border-radius:50%;
  background:#f0c040;
  box-shadow: 0 0 8px #f0c040;
  animation: signalBlink 1.4s ease-in-out infinite;
  flex-shrink:0;
}

.signal-info {
  display:flex; align-items:center; gap:clamp(10px,2vw,20px);
  flex:1; flex-wrap:wrap;
  position:relative; z-index:1;
}
.signal-pattern { font-weight:700; font-size:clamp(.8rem,2vw,.95rem); color:var(--text); }
.signal-entry   { font-weight:900; color:#f0c040; font-size:clamp(.85rem,2vw,1.05rem); text-shadow:0 0 10px rgba(240,192,64,.5); }
.signal-status  {
  font-size:clamp(.7rem,1.8vw,.85rem);
  font-weight:800;
  letter-spacing:.06em;
  padding:3px 10px;
  border-radius:20px;
  background:rgba(240,192,64,.1);
  border:1px solid rgba(240,192,64,.25);
  color:#f0c040;
}
.signal-time { font-size:clamp(.65rem,1.5vw,.8rem); color:rgba(160,160,185,.5); white-space:nowrap; position:relative; z-index:1; }

/* ── Charts premium ── */
.charts-row {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: clamp(12px,2vw,20px);
  margin-bottom: clamp(16px,3vw,24px);
}

.chart-card {
  background: linear-gradient(145deg, rgba(18,18,28,.98) 0%, rgba(12,12,20,1) 100%);
  border: 1px solid rgba(255,255,255,.06);
  border-radius: 20px;
  padding: clamp(14px,2.5vw,22px);
  overflow: hidden;
  min-width: 0;
  position: relative;
  backdrop-filter: blur(8px);
  transition: border-color .22s ease, transform .22s ease;
}
.chart-card:hover {
  border-color: rgba(240,192,64,.15);
  transform: translateY(-2px);
}

/* brilho interno top-left */
.chart-card::before {
  content:'';
  position:absolute;
  top:0; left:0;
  width:50%; height:50%;
  background: radial-gradient(ellipse at 0% 0%, rgba(240,192,64,.04) 0%, transparent 70%);
  pointer-events:none;
}

.chart-card h3 {
  font-size: clamp(.72rem,1.8vw,.88rem);
  font-weight: 800;
  color: rgba(200,200,220,.75);
  display: flex;
  align-items: center;
  gap: 8px;
  margin-bottom: 16px;
  text-transform: uppercase;
  letter-spacing: .07em;
  position: relative;
  z-index: 1;
}
.chart-card h3 i {
  color: #f0c040;
  font-size: .85em;
  filter: drop-shadow(0 0 4px rgba(240,192,64,.5));
}

/* tag live nos gráficos */
.chart-card h3::after {
  content:'LIVE';
  font-size:.55rem;
  font-weight:800;
  letter-spacing:.08em;
  padding:2px 6px;
  border-radius:6px;
  background:rgba(74,222,128,.1);
  border:1px solid rgba(74,222,128,.25);
  color:#4ade80;
  margin-left:auto;
}

/* ── Mobile: stack cards 2+1 ── */
@media (max-width: 640px) {
  .dashboard-grid {
    grid-template-columns: 1fr 1fr;
    gap: 10px;
  }
  .dashboard-grid .dash-card:nth-child(3) {
    grid-column: span 2;
  }
  .charts-row {
    grid-template-columns: 1fr;
    gap: 12px;
  }
}

/* ── Phone SE pequeno ── */
@media (max-width: 380px) {
  .dashboard-grid {
    grid-template-columns: 1fr;
  }
  .dashboard-grid .dash-card:nth-child(3) {
    grid-column: span 1;
  }
  .dash-card { padding: 12px; gap: 10px; }
  .dash-card-icon { width: 36px; height: 36px; font-size: .9rem; }
}

/* =====================================================
   26. BOTTOM NAV PREMIUM 2026
       Glassmorphism · Neon per-tab · Fluida · iOS safe
   ===================================================== */

/* ── Variáveis de cor por aba ── */
:root {
  --bnav-dashboard : #f0c040;
  --bnav-live      : #4ade80;
  --bnav-calc      : #60a5fa;
  --bnav-aulas     : #a78bfa;
  --bnav-chat      : #f472b6;
  --bnav-network   : #22d3ee;
  --bnav-admin     : #f0c040;
  --bnav-h         : 68px;
}

/* ── Container ── */
.bottom-nav {
  position: fixed !important;
  bottom: 0;
  left: 0;
  right: 0;
  height: calc(var(--bnav-h) + env(safe-area-inset-bottom, 0px)) !important;
  padding-bottom: env(safe-area-inset-bottom, 0px);
  display: flex !important;
  align-items: stretch;
  justify-content: space-around;
  z-index: 500;

  /* Glassmorphism premium */
  background: rgba(6, 6, 12, 0.88) !important;
  backdrop-filter: blur(24px) saturate(180%);
  -webkit-backdrop-filter: blur(24px) saturate(180%);

  /* Borda superior luminosa */
  border-top: 1px solid rgba(255, 255, 255, 0.07) !important;
  border-radius: 22px 22px 0 0;

  /* Sombra para cima */
  box-shadow:
    0 -1px 0 rgba(255,255,255,0.04),
    0 -8px 40px rgba(0, 0, 0, 0.65),
    0 -2px 16px rgba(0, 0, 0, 0.45) !important;

  /* Sem overflow em nenhum device */
  overflow: hidden;
}

/* ── Item base ── */
.bnav-item {
  display: flex !important;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  flex: 1;
  gap: 4px;
  min-width: 0;
  padding: 6px 4px 4px;
  color: rgba(160, 160, 185, 0.65);
  font-size: clamp(0.52rem, 1.5vw, 0.62rem);
  font-weight: 600;
  font-family: 'Inter', sans-serif;
  letter-spacing: 0.02em;
  text-decoration: none !important;
  position: relative;
  -webkit-tap-highlight-color: transparent;
  transition:
    color 0.22s ease,
    transform 0.18s cubic-bezier(0.34, 1.56, 0.64, 1);
  will-change: transform;
  cursor: pointer;
}

/* ── Wrapper do ícone (pill de fundo) ── */
.bnav-icon-wrap {
  position: relative;
  width: 38px;
  height: 30px;
  display: flex;
  align-items: center;
  justify-content: center;
  border-radius: 10px;
  transition:
    background 0.22s ease,
    box-shadow  0.22s ease;
  flex-shrink: 0;
}

/* ── Ícone ── */
.bnav-item i {
  font-size: clamp(1rem, 3.5vw, 1.15rem) !important;
  line-height: 1;
  transition:
    color      0.22s ease,
    filter     0.22s ease,
    transform  0.18s cubic-bezier(0.34, 1.56, 0.64, 1);
  position: relative;
  z-index: 1;
}

/* ── Label ── */
.bnav-item > span:not(.bnav-badge) {
  line-height: 1;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  max-width: 100%;
  transition: color 0.22s ease;
}

/* ── Badge ── */
.bnav-badge {
  position: absolute !important;
  top: -3px;
  right: -5px;
  background: var(--red) !important;
  color: #fff !important;
  font-size: 0.5rem !important;
  font-weight: 800 !important;
  width: 14px !important;
  height: 14px !important;
  border-radius: 50% !important;
  display: flex !important;
  align-items: center;
  justify-content: center;
  border: 1.5px solid rgba(6,6,12,0.9);
  z-index: 2;
}

/* ── Hover (dispositivos com mouse) ── */
@media (hover: hover) {
  .bnav-item:hover {
    transform: translateY(-2px);
    color: rgba(200, 200, 220, 0.9);
  }
  .bnav-item:hover .bnav-icon-wrap {
    background: rgba(255,255,255,0.06);
  }
}

/* ── Press tap ── */
.bnav-item:active {
  transform: scale(0.9);
}

/* ════════════════════════════════════════
   ESTADO ATIVO — cor neon por aba
   ════════════════════════════════════════ */

/* Dashboard — amarelo neon */
.bnav-item[data-tab="dashboard"].active {
  color: var(--bnav-dashboard);
}
.bnav-item[data-tab="dashboard"].active i {
  color: var(--bnav-dashboard);
  filter: drop-shadow(0 0 8px rgba(240,192,64,0.8)) drop-shadow(0 0 16px rgba(240,192,64,0.4));
}
.bnav-item[data-tab="dashboard"].active .bnav-icon-wrap {
  background: rgba(240,192,64,0.14);
  box-shadow: 0 0 16px rgba(240,192,64,0.2), inset 0 0 8px rgba(240,192,64,0.08);
}
.bnav-item[data-tab="dashboard"].active > span:not(.bnav-badge) {
  color: var(--bnav-dashboard);
}

/* Ao Vivo — verde neon */
.bnav-item[data-tab="live"].active {
  color: var(--bnav-live);
}
.bnav-item[data-tab="live"].active i {
  color: var(--bnav-live);
  filter: drop-shadow(0 0 8px rgba(74,222,128,0.8)) drop-shadow(0 0 16px rgba(74,222,128,0.4));
}
.bnav-item[data-tab="live"].active .bnav-icon-wrap {
  background: rgba(74,222,128,0.13);
  box-shadow: 0 0 16px rgba(74,222,128,0.2), inset 0 0 8px rgba(74,222,128,0.07);
}
.bnav-item[data-tab="live"].active > span:not(.bnav-badge) {
  color: var(--bnav-live);
}

/* Calc — azul neon */
.bnav-item[data-tab="calc"].active {
  color: var(--bnav-calc);
}
.bnav-item[data-tab="calc"].active i {
  color: var(--bnav-calc);
  filter: drop-shadow(0 0 8px rgba(96,165,250,0.8)) drop-shadow(0 0 16px rgba(96,165,250,0.4));
}
.bnav-item[data-tab="calc"].active .bnav-icon-wrap {
  background: rgba(96,165,250,0.13);
  box-shadow: 0 0 16px rgba(96,165,250,0.2), inset 0 0 8px rgba(96,165,250,0.07);
}
.bnav-item[data-tab="calc"].active > span:not(.bnav-badge) {
  color: var(--bnav-calc);
}

/* Aulas — roxo neon */
.bnav-item[data-tab="aulas"].active {
  color: var(--bnav-aulas);
}
.bnav-item[data-tab="aulas"].active i {
  color: var(--bnav-aulas);
  filter: drop-shadow(0 0 8px rgba(167,139,250,0.8)) drop-shadow(0 0 16px rgba(167,139,250,0.4));
}
.bnav-item[data-tab="aulas"].active .bnav-icon-wrap {
  background: rgba(167,139,250,0.13);
  box-shadow: 0 0 16px rgba(167,139,250,0.2), inset 0 0 8px rgba(167,139,250,0.07);
}
.bnav-item[data-tab="aulas"].active > span:not(.bnav-badge) {
  color: var(--bnav-aulas);
}

/* Chat — rosa neon */
.bnav-item[data-tab="chat"].active {
  color: var(--bnav-chat);
}
.bnav-item[data-tab="chat"].active i {
  color: var(--bnav-chat);
  filter: drop-shadow(0 0 8px rgba(244,114,182,0.8)) drop-shadow(0 0 16px rgba(244,114,182,0.4));
}
.bnav-item[data-tab="chat"].active .bnav-icon-wrap {
  background: rgba(244,114,182,0.13);
  box-shadow: 0 0 16px rgba(244,114,182,0.2), inset 0 0 8px rgba(244,114,182,0.07);
}
.bnav-item[data-tab="chat"].active > span:not(.bnav-badge) {
  color: var(--bnav-chat);
}

/* Network — cyan neon */
.bnav-item[data-tab="network"].active {
  color: var(--bnav-network);
}
.bnav-item[data-tab="network"].active i {
  color: var(--bnav-network);
  filter: drop-shadow(0 0 8px rgba(34,211,238,0.8)) drop-shadow(0 0 16px rgba(34,211,238,0.4));
}
.bnav-item[data-tab="network"].active .bnav-icon-wrap {
  background: rgba(34,211,238,0.13);
  box-shadow: 0 0 16px rgba(34,211,238,0.2), inset 0 0 8px rgba(34,211,238,0.07);
}
.bnav-item[data-tab="network"].active > span:not(.bnav-badge) {
  color: var(--bnav-network);
}

/* Admin — dourado neon */
.bnav-item[data-tab="admin"].active {
  color: var(--bnav-admin);
}
.bnav-item[data-tab="admin"].active i {
  color: var(--bnav-admin);
  filter: drop-shadow(0 0 8px rgba(240,192,64,0.8)) drop-shadow(0 0 16px rgba(240,192,64,0.4));
}
.bnav-item[data-tab="admin"].active .bnav-icon-wrap {
  background: rgba(240,192,64,0.14);
  box-shadow: 0 0 16px rgba(240,192,64,0.2), inset 0 0 8px rgba(240,192,64,0.08);
}
.bnav-item[data-tab="admin"].active > span:not(.bnav-badge) {
  color: var(--bnav-admin);
}

/* ── Indicador de ponto ativo (linha no topo do ícone) ── */
.bnav-item.active .bnav-icon-wrap::after {
  content: '';
  position: absolute;
  top: -1px;
  left: 50%;
  transform: translateX(-50%);
  width: 18px;
  height: 2px;
  border-radius: 2px;
  opacity: 0.9;
}
.bnav-item[data-tab="dashboard"].active .bnav-icon-wrap::after { background: var(--bnav-dashboard); box-shadow: 0 0 6px var(--bnav-dashboard); }
.bnav-item[data-tab="live"].active      .bnav-icon-wrap::after { background: var(--bnav-live);      box-shadow: 0 0 6px var(--bnav-live); }
.bnav-item[data-tab="calc"].active      .bnav-icon-wrap::after { background: var(--bnav-calc);      box-shadow: 0 0 6px var(--bnav-calc); }
.bnav-item[data-tab="aulas"].active     .bnav-icon-wrap::after { background: var(--bnav-aulas);     box-shadow: 0 0 6px var(--bnav-aulas); }
.bnav-item[data-tab="chat"].active      .bnav-icon-wrap::after { background: var(--bnav-chat);      box-shadow: 0 0 6px var(--bnav-chat); }
.bnav-item[data-tab="network"].active   .bnav-icon-wrap::after { background: var(--bnav-network);   box-shadow: 0 0 6px var(--bnav-network); }
.bnav-item[data-tab="admin"].active     .bnav-icon-wrap::after { background: var(--bnav-admin);     box-shadow: 0 0 6px var(--bnav-admin); }

/* ── Ícones com cor suave mesmo inativos (identidade) ── */
.bnav-item[data-tab="dashboard"] i { color: rgba(240,192,64,  0.38); }
.bnav-item[data-tab="live"]      i { color: rgba(74,222,128,  0.38); }
.bnav-item[data-tab="calc"]      i { color: rgba(96,165,250,  0.38); }
.bnav-item[data-tab="aulas"]     i { color: rgba(167,139,250, 0.38); }
.bnav-item[data-tab="chat"]      i { color: rgba(244,114,182, 0.38); }
.bnav-item[data-tab="network"]   i { color: rgba(34,211,238,  0.38); }
.bnav-item[data-tab="admin"]     i { color: rgba(240,192,64,  0.38); }

/* ── Responsividade extra‑pequena (≤ 360px — iPhone SE, etc.) ── */
@media (max-width: 360px) {
  :root { --bnav-h: 62px; }

  .bnav-item {
    font-size: 0.48rem;
    gap: 2px;
    padding: 5px 2px 3px;
  }

  .bnav-icon-wrap {
    width: 32px;
    height: 26px;
    border-radius: 8px;
  }

  .bnav-item i {
    font-size: 0.92rem !important;
  }
}

/* ── Tablet / desktop: bottom-nav oculta (sidebar cuida da nav) ── */
@media (min-width: 769px) {
  .bottom-nav {
    display: none !important;
  }
}

/* =====================================================
   27. SIDEBAR PREMIUM 2026
       Glassmorphism · Logo header · Neon per-tab
       Card nav-items · Hover sofisticado · Ativo glow
   ===================================================== */

/* ── Variáveis de cor por aba (sidebar) ── */
:root {
  --snav-dashboard : #f0c040;   /* amarelo/dourado */
  --snav-live      : #4ade80;   /* verde neon      */
  --snav-calc      : #60a5fa;   /* azul neon       */
  --snav-aulas     : #a78bfa;   /* roxo neon       */
  --snav-chat      : #f472b6;   /* rosa neon       */
  --snav-network   : #22d3ee;   /* cyan neon       */
  --snav-admin     : #f0c040;   /* dourado         */
  --snav-logout    : #f87171;   /* vermelho elegan.*/
}

/* ── Keyframes exclusivos da sidebar ── */
@keyframes snavLivePulse {
  0%,100% { box-shadow: 0 0 6px rgba(239,68,68,.9),  0 0 12px rgba(239,68,68,.5); opacity:1; }
  50%      { box-shadow: 0 0 14px rgba(239,68,68,.5), 0 0 24px rgba(239,68,68,.2); opacity:.6; }
}
@keyframes snavGlowIn {
  from { opacity:0; transform:scale(.8) translateX(-4px); }
  to   { opacity:1; transform:scale(1)  translateX(0);    }
}
@keyframes snavIconFloat {
  0%,100% { transform:translateY(0); }
  50%      { transform:translateY(-2px); }
}
@keyframes snavShimmer {
  0%   { background-position:-200% center; }
  100% { background-position: 200% center; }
}
@keyframes snavScanline {
  0%   { transform:translateY(-100%); opacity:.18; }
  100% { transform:translateY(200%);  opacity:0;   }
}

/* ── Sidebar container premium ── */
.sidebar {
  background:
    linear-gradient(180deg,
      rgba(8, 8, 16, 0.98) 0%,
      rgba(6, 6, 12, 0.99) 60%,
      rgba(4, 4, 10, 1.00) 100%
    ) !important;
  border-right: 1px solid rgba(255,255,255,0.055) !important;
  box-shadow:
    4px 0 32px rgba(0,0,0,0.7),
    1px 0 0 rgba(255,255,255,0.04) !important;
  backdrop-filter: blur(20px) saturate(160%);
  -webkit-backdrop-filter: blur(20px) saturate(160%);
  overflow: hidden;
}

/* Linha vertical neon decorativa à esquerda da sidebar */
.sidebar::before {
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  width: 1px;
  height: 100%;
  background: linear-gradient(
    180deg,
    transparent 0%,
    rgba(240,192,64,0.35) 20%,
    rgba(74,222,128,0.25) 40%,
    rgba(96,165,250,0.20) 60%,
    rgba(240,192,64,0.15) 80%,
    transparent 100%
  );
  pointer-events: none;
  z-index: 0;
}

/* Efeito scanline animada (sutil, futurista) */
.sidebar::after {
  content: '';
  position: absolute;
  top: 0; left: 0;
  width: 100%;
  height: 40%;
  background: linear-gradient(
    180deg,
    rgba(240,192,64,0.015) 0%,
    transparent 100%
  );
  animation: snavScanline 8s linear infinite;
  pointer-events: none;
  z-index: 0;
}

/* ── Logo header premium ── */
.sidebar-logo {
  padding: 22px 18px 18px;
  border-bottom: 1px solid rgba(255,255,255,0.06) !important;
  text-align: center;
  position: relative;
  z-index: 1;
  background: linear-gradient(
    180deg,
    rgba(240,192,64,0.05) 0%,
    transparent 100%
  );
  overflow: hidden;
}

/* brilho dourado atrás do logo */
.sidebar-logo::before {
  content: '';
  position: absolute;
  top: -20px;
  left: 50%;
  transform: translateX(-50%);
  width: 80%;
  height: 80px;
  background: radial-gradient(ellipse at center,
    rgba(240,192,64,0.12) 0%,
    transparent 70%
  );
  pointer-events: none;
}

.sidebar-logo img {
  width: 130px;
  filter:
    drop-shadow(0 0 12px rgba(240,192,64,0.45))
    drop-shadow(0 2px 6px rgba(0,0,0,0.6));
  position: relative;
  z-index: 1;
  transition: filter .3s ease, transform .3s ease;
}

.sidebar-logo img:hover {
  filter:
    drop-shadow(0 0 20px rgba(240,192,64,0.7))
    drop-shadow(0 2px 8px rgba(0,0,0,0.7));
  transform: scale(1.04);
}

/* ── Nav container ── */
.sidebar-nav {
  padding: 14px 10px 10px;
  gap: 5px !important;
  position: relative;
  z-index: 1;
}

/* ── NAV-ITEM: card moderno base ── */
.nav-item {
  display: flex !important;
  align-items: center;
  gap: 0 !important;
  padding: 0 !important;
  border-radius: 14px !important;
  color: rgba(150,150,175,0.65) !important;
  font-size: clamp(0.78rem, 1.5vw, 0.875rem) !important;
  font-weight: 500 !important;
  transition:
    background    0.22s ease,
    border-color  0.22s ease,
    color         0.22s ease,
    box-shadow    0.22s ease,
    transform     0.18s cubic-bezier(0.34,1.56,0.64,1) !important;
  position: relative;
  overflow: hidden;
  border: 1px solid transparent !important;
  text-decoration: none !important;
  -webkit-tap-highlight-color: transparent;
  will-change: transform, box-shadow;
  min-height: 46px;
}

/* ícone wrapper interno (pill dentro do card) */
.nav-item .nav-icon-wrap {
  width: 40px;
  height: 40px;
  flex-shrink: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  border-radius: 10px;
  margin: 0 0 0 6px;
  transition:
    background  0.22s ease,
    box-shadow  0.22s ease;
}

.nav-item .nav-icon-wrap i {
  font-size: clamp(0.92rem, 1.8vw, 1.05rem) !important;
  line-height: 1;
  transition:
    color   0.22s ease,
    filter  0.22s ease,
    transform 0.22s cubic-bezier(0.34,1.56,0.64,1);
}

/* label */
.nav-item > span.nav-label {
  flex: 1;
  padding: 0 10px 0 10px;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  font-size: inherit;
  font-weight: inherit;
  transition: color 0.22s ease;
  min-width: 0;
}

/* Fallback: se não tiver .nav-label, o span direto */
.nav-item > span:not(.nav-badge):not(.nav-label):not(.bnav-badge) {
  flex: 1;
  padding: 0 10px 0 10px;
}

/* ── Badge (LIVE / número) ── */
.nav-badge {
  margin-left: auto !important;
  margin-right: 10px;
  font-size: 0.62rem !important;
  font-weight: 800 !important;
  padding: 2px 7px !important;
  border-radius: 20px !important;
  flex-shrink: 0;
  position: relative;
  z-index: 2;
}

/* Badge LIVE — pulse vermelho */
.live-badge {
  background: linear-gradient(135deg, #ef4444, #dc2626) !important;
  color: #fff !important;
  animation: snavLivePulse 1.6s ease-in-out infinite !important;
  border: none !important;
  letter-spacing: 0.06em;
}

/* Badge contador (chat) */
.nav-badge:not(.live-badge) {
  background: rgba(248,113,113,0.18) !important;
  border: 1px solid rgba(248,113,113,0.35) !important;
  color: #f87171 !important;
}

/* ── Linha brilhante no topo do card (inativa — sutil) ── */
.nav-item::before {
  content: '';
  position: absolute;
  top: 0; left: 20%; right: 20%;
  height: 1px;
  background: transparent;
  border-radius: 2px;
  transition: background 0.28s ease, opacity 0.28s ease, box-shadow 0.28s ease;
  opacity: 0;
  z-index: 2;
}

/* ── Reflexo interno top-left ── */
.nav-item::after {
  content: '';
  position: absolute;
  inset: 0;
  border-radius: inherit;
  background: radial-gradient(ellipse at 15% 15%,
    rgba(255,255,255,0.03) 0%, transparent 55%
  );
  pointer-events: none;
  z-index: 0;
}

/* ── HOVER — sofisticado ── */
@media (hover: hover) {
  .nav-item:hover {
    transform: translateX(3px) !important;
    background: rgba(255,255,255,0.04) !important;
    border-color: rgba(255,255,255,0.08) !important;
    color: rgba(200,200,220,0.9) !important;
  }

  /* hover por cor de aba */
  .nav-item[data-tab="dashboard"]:hover { background: rgba(240,192,64,0.06) !important; border-color: rgba(240,192,64,0.15) !important; }
  .nav-item[data-tab="live"]:hover      { background: rgba(74,222,128,0.06) !important; border-color: rgba(74,222,128,0.15) !important; }
  .nav-item[data-tab="calc"]:hover      { background: rgba(96,165,250,0.06) !important; border-color: rgba(96,165,250,0.15) !important; }
  .nav-item[data-tab="aulas"]:hover     { background: rgba(167,139,250,0.06) !important; border-color: rgba(167,139,250,0.15) !important; }
  .nav-item[data-tab="chat"]:hover      { background: rgba(244,114,182,0.06) !important; border-color: rgba(244,114,182,0.15) !important; }
  .nav-item[data-tab="network"]:hover   { background: rgba(34,211,238,0.06) !important; border-color: rgba(34,211,238,0.15) !important; }

  /* ícone flutua no hover */
  .nav-item:hover .nav-icon-wrap i {
    animation: snavIconFloat 1s ease-in-out infinite;
  }

  /* ícone neon suave no hover */
  .nav-item[data-tab="dashboard"]:hover .nav-icon-wrap i { color: rgba(240,192,64,0.75) !important; filter: drop-shadow(0 0 5px rgba(240,192,64,0.4)); }
  .nav-item[data-tab="live"]:hover      .nav-icon-wrap i { color: rgba(74,222,128,0.75) !important; filter: drop-shadow(0 0 5px rgba(74,222,128,0.4)); }
  .nav-item[data-tab="calc"]:hover      .nav-icon-wrap i { color: rgba(96,165,250,0.75) !important; filter: drop-shadow(0 0 5px rgba(96,165,250,0.4)); }
  .nav-item[data-tab="aulas"]:hover     .nav-icon-wrap i { color: rgba(167,139,250,0.75) !important; filter: drop-shadow(0 0 5px rgba(167,139,250,0.4)); }
  .nav-item[data-tab="chat"]:hover      .nav-icon-wrap i { color: rgba(244,114,182,0.75) !important; filter: drop-shadow(0 0 5px rgba(244,114,182,0.4)); }
  .nav-item[data-tab="network"]:hover   .nav-icon-wrap i { color: rgba(34,211,238,0.75) !important; filter: drop-shadow(0 0 5px rgba(34,211,238,0.4)); }
  .nav-item-logout:hover                .nav-icon-wrap i { color: rgba(248,113,113,0.75) !important; filter: drop-shadow(0 0 5px rgba(248,113,113,0.4)); }
}

/* ── Press ── */
.nav-item:active {
  transform: scale(0.97) translateX(1px) !important;
}

/* ── Ícones inativos com cor identidade suave ── */
.nav-item[data-tab="dashboard"] .nav-icon-wrap i { color: rgba(240,192,64,  0.40); }
.nav-item[data-tab="live"]      .nav-icon-wrap i { color: rgba(74,222,128,  0.40); }
.nav-item[data-tab="calc"]      .nav-icon-wrap i { color: rgba(96,165,250,  0.40); }
.nav-item[data-tab="aulas"]     .nav-icon-wrap i { color: rgba(167,139,250, 0.40); }
.nav-item[data-tab="chat"]      .nav-icon-wrap i { color: rgba(244,114,182, 0.40); }
.nav-item[data-tab="network"]   .nav-icon-wrap i { color: rgba(34,211,238,  0.40); }
.nav-item[data-tab="admin"]     .nav-icon-wrap i { color: rgba(240,192,64,  0.40); }
.nav-item-logout                .nav-icon-wrap i { color: rgba(248,113,113, 0.40); }

/* ════════════════════════════════════════════════════
   ESTADO ATIVO — cor neon individual por aba
   ════════════════════════════════════════════════════ */

/* ── Dashboard — amarelo/dourado ── */
.nav-item[data-tab="dashboard"].active {
  background: linear-gradient(135deg,
    rgba(240,192,64,0.13) 0%,
    rgba(240,192,64,0.05) 100%
  ) !important;
  border-color: rgba(240,192,64,0.28) !important;
  box-shadow:
    0 0 0 1px rgba(240,192,64,0.10) inset,
    0 4px 20px rgba(240,192,64,0.12),
    4px 0 0 rgba(240,192,64,0.55) !important;
  color: var(--snav-dashboard) !important;
}
.nav-item[data-tab="dashboard"].active::before {
  background: linear-gradient(90deg, transparent, #f0c040, transparent);
  box-shadow: 0 0 8px rgba(240,192,64,0.7);
  opacity: 1;
}
.nav-item[data-tab="dashboard"].active .nav-icon-wrap {
  background: rgba(240,192,64,0.15);
  box-shadow: 0 0 14px rgba(240,192,64,0.25), inset 0 0 6px rgba(240,192,64,0.10);
}
.nav-item[data-tab="dashboard"].active .nav-icon-wrap i {
  color: var(--snav-dashboard) !important;
  filter: drop-shadow(0 0 8px rgba(240,192,64,0.9)) drop-shadow(0 0 16px rgba(240,192,64,0.4));
  animation: snavIconFloat 2s ease-in-out infinite;
}
.nav-item[data-tab="dashboard"].active > span { color: var(--snav-dashboard) !important; }

/* ── Ao Vivo — verde neon ── */
.nav-item[data-tab="live"].active {
  background: linear-gradient(135deg,
    rgba(74,222,128,0.12) 0%,
    rgba(74,222,128,0.04) 100%
  ) !important;
  border-color: rgba(74,222,128,0.28) !important;
  box-shadow:
    0 0 0 1px rgba(74,222,128,0.10) inset,
    0 4px 20px rgba(74,222,128,0.12),
    4px 0 0 rgba(74,222,128,0.55) !important;
  color: var(--snav-live) !important;
}
.nav-item[data-tab="live"].active::before {
  background: linear-gradient(90deg, transparent, #4ade80, transparent);
  box-shadow: 0 0 8px rgba(74,222,128,0.7);
  opacity: 1;
}
.nav-item[data-tab="live"].active .nav-icon-wrap {
  background: rgba(74,222,128,0.14);
  box-shadow: 0 0 14px rgba(74,222,128,0.25), inset 0 0 6px rgba(74,222,128,0.10);
}
.nav-item[data-tab="live"].active .nav-icon-wrap i {
  color: var(--snav-live) !important;
  filter: drop-shadow(0 0 8px rgba(74,222,128,0.9)) drop-shadow(0 0 16px rgba(74,222,128,0.4));
  animation: snavIconFloat 2s ease-in-out infinite;
}
.nav-item[data-tab="live"].active > span { color: var(--snav-live) !important; }

/* ── Calculadora — azul neon ── */
.nav-item[data-tab="calc"].active {
  background: linear-gradient(135deg,
    rgba(96,165,250,0.12) 0%,
    rgba(96,165,250,0.04) 100%
  ) !important;
  border-color: rgba(96,165,250,0.28) !important;
  box-shadow:
    0 0 0 1px rgba(96,165,250,0.10) inset,
    0 4px 20px rgba(96,165,250,0.12),
    4px 0 0 rgba(96,165,250,0.55) !important;
  color: var(--snav-calc) !important;
}
.nav-item[data-tab="calc"].active::before {
  background: linear-gradient(90deg, transparent, #60a5fa, transparent);
  box-shadow: 0 0 8px rgba(96,165,250,0.7);
  opacity: 1;
}
.nav-item[data-tab="calc"].active .nav-icon-wrap {
  background: rgba(96,165,250,0.14);
  box-shadow: 0 0 14px rgba(96,165,250,0.25), inset 0 0 6px rgba(96,165,250,0.10);
}
.nav-item[data-tab="calc"].active .nav-icon-wrap i {
  color: var(--snav-calc) !important;
  filter: drop-shadow(0 0 8px rgba(96,165,250,0.9)) drop-shadow(0 0 16px rgba(96,165,250,0.4));
  animation: snavIconFloat 2s ease-in-out infinite;
}
.nav-item[data-tab="calc"].active > span { color: var(--snav-calc) !important; }

/* ── Aulas — roxo neon ── */
.nav-item[data-tab="aulas"].active {
  background: linear-gradient(135deg,
    rgba(167,139,250,0.12) 0%,
    rgba(167,139,250,0.04) 100%
  ) !important;
  border-color: rgba(167,139,250,0.28) !important;
  box-shadow:
    0 0 0 1px rgba(167,139,250,0.10) inset,
    0 4px 20px rgba(167,139,250,0.12),
    4px 0 0 rgba(167,139,250,0.55) !important;
  color: var(--snav-aulas) !important;
}
.nav-item[data-tab="aulas"].active::before {
  background: linear-gradient(90deg, transparent, #a78bfa, transparent);
  box-shadow: 0 0 8px rgba(167,139,250,0.7);
  opacity: 1;
}
.nav-item[data-tab="aulas"].active .nav-icon-wrap {
  background: rgba(167,139,250,0.14);
  box-shadow: 0 0 14px rgba(167,139,250,0.25), inset 0 0 6px rgba(167,139,250,0.10);
}
.nav-item[data-tab="aulas"].active .nav-icon-wrap i {
  color: var(--snav-aulas) !important;
  filter: drop-shadow(0 0 8px rgba(167,139,250,0.9)) drop-shadow(0 0 16px rgba(167,139,250,0.4));
  animation: snavIconFloat 2s ease-in-out infinite;
}
.nav-item[data-tab="aulas"].active > span { color: var(--snav-aulas) !important; }

/* ── Chat — rosa neon ── */
.nav-item[data-tab="chat"].active {
  background: linear-gradient(135deg,
    rgba(244,114,182,0.12) 0%,
    rgba(244,114,182,0.04) 100%
  ) !important;
  border-color: rgba(244,114,182,0.28) !important;
  box-shadow:
    0 0 0 1px rgba(244,114,182,0.10) inset,
    0 4px 20px rgba(244,114,182,0.12),
    4px 0 0 rgba(244,114,182,0.55) !important;
  color: var(--snav-chat) !important;
}
.nav-item[data-tab="chat"].active::before {
  background: linear-gradient(90deg, transparent, #f472b6, transparent);
  box-shadow: 0 0 8px rgba(244,114,182,0.7);
  opacity: 1;
}
.nav-item[data-tab="chat"].active .nav-icon-wrap {
  background: rgba(244,114,182,0.14);
  box-shadow: 0 0 14px rgba(244,114,182,0.25), inset 0 0 6px rgba(244,114,182,0.10);
}
.nav-item[data-tab="chat"].active .nav-icon-wrap i {
  color: var(--snav-chat) !important;
  filter: drop-shadow(0 0 8px rgba(244,114,182,0.9)) drop-shadow(0 0 16px rgba(244,114,182,0.4));
  animation: snavIconFloat 2s ease-in-out infinite;
}
.nav-item[data-tab="chat"].active > span { color: var(--snav-chat) !important; }

/* ── Network — cyan neon ── */
.nav-item[data-tab="network"].active {
  background: linear-gradient(135deg,
    rgba(34,211,238,0.12) 0%,
    rgba(34,211,238,0.04) 100%
  ) !important;
  border-color: rgba(34,211,238,0.28) !important;
  box-shadow:
    0 0 0 1px rgba(34,211,238,0.10) inset,
    0 4px 20px rgba(34,211,238,0.12),
    4px 0 0 rgba(34,211,238,0.55) !important;
  color: var(--snav-network) !important;
}
.nav-item[data-tab="network"].active::before {
  background: linear-gradient(90deg, transparent, #22d3ee, transparent);
  box-shadow: 0 0 8px rgba(34,211,238,0.7);
  opacity: 1;
}
.nav-item[data-tab="network"].active .nav-icon-wrap {
  background: rgba(34,211,238,0.14);
  box-shadow: 0 0 14px rgba(34,211,238,0.25), inset 0 0 6px rgba(34,211,238,0.10);
}
.nav-item[data-tab="network"].active .nav-icon-wrap i {
  color: var(--snav-network) !important;
  filter: drop-shadow(0 0 8px rgba(34,211,238,0.9)) drop-shadow(0 0 16px rgba(34,211,238,0.4));
  animation: snavIconFloat 2s ease-in-out infinite;
}
.nav-item[data-tab="network"].active > span { color: var(--snav-network) !important; }

/* ── Admin — dourado ── */
.nav-item[data-tab="admin"].active {
  background: linear-gradient(135deg,
    rgba(240,192,64,0.13) 0%,
    rgba(240,192,64,0.05) 100%
  ) !important;
  border-color: rgba(240,192,64,0.28) !important;
  box-shadow:
    0 0 0 1px rgba(240,192,64,0.10) inset,
    0 4px 20px rgba(240,192,64,0.12),
    4px 0 0 rgba(240,192,64,0.55) !important;
  color: var(--snav-admin) !important;
}
.nav-item[data-tab="admin"].active::before {
  background: linear-gradient(90deg, transparent, #f0c040, transparent);
  box-shadow: 0 0 8px rgba(240,192,64,0.7);
  opacity: 1;
}
.nav-item[data-tab="admin"].active .nav-icon-wrap {
  background: rgba(240,192,64,0.15);
  box-shadow: 0 0 14px rgba(240,192,64,0.25), inset 0 0 6px rgba(240,192,64,0.10);
}
.nav-item[data-tab="admin"].active .nav-icon-wrap i {
  color: var(--snav-admin) !important;
  filter: drop-shadow(0 0 8px rgba(240,192,64,0.9)) drop-shadow(0 0 16px rgba(240,192,64,0.4));
  animation: snavIconFloat 2s ease-in-out infinite;
}
.nav-item[data-tab="admin"].active > span { color: var(--snav-admin) !important; }

/* ── Botão Sair — vermelho elegante ── */
.nav-item-logout {
  color: rgba(248,113,113,0.55) !important;
  margin-top: 2px;
}
.nav-item-logout .nav-icon-wrap i {
  color: rgba(248,113,113,0.42) !important;
}

@media (hover: hover) {
  .nav-item-logout:hover {
    background: rgba(248,113,113,0.09) !important;
    border-color: rgba(248,113,113,0.22) !important;
    color: var(--snav-logout) !important;
    box-shadow:
      0 4px 16px rgba(248,113,113,0.10),
      4px 0 0 rgba(248,113,113,0.40) !important;
  }
  .nav-item-logout:hover .nav-icon-wrap i {
    color: var(--snav-logout) !important;
    filter: drop-shadow(0 0 7px rgba(248,113,113,0.75));
  }
}

/* ── Divider premium ── */
.sidebar-nav-divider {
  height: 1px !important;
  background: linear-gradient(
    90deg,
    transparent,
    rgba(255,255,255,0.07) 20%,
    rgba(255,255,255,0.07) 80%,
    transparent
  ) !important;
  margin: 6px 8px !important;
}

/* ── Footer do usuário premium ── */
.sidebar-footer {
  padding: 12px 10px 14px;
  border-top: 1px solid rgba(255,255,255,0.055);
  background: linear-gradient(
    180deg,
    transparent 0%,
    rgba(240,192,64,0.03) 100%
  );
  position: relative;
  z-index: 1;
}

.user-info {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 10px 10px;
  border-radius: 12px;
  background: rgba(255,255,255,0.03);
  border: 1px solid rgba(255,255,255,0.06);
  transition: background .22s ease, border-color .22s ease;
}

@media (hover: hover) {
  .user-info:hover {
    background: rgba(240,192,64,0.06);
    border-color: rgba(240,192,64,0.14);
  }
}

.user-avatar {
  width: 34px;
  height: 34px;
  border-radius: 10px;
  background: linear-gradient(135deg, rgba(240,192,64,0.25), rgba(240,192,64,0.10)) !important;
  border: 1px solid rgba(240,192,64,0.3) !important;
  box-shadow: 0 0 10px rgba(240,192,64,0.18) !important;
  color: #f0c040 !important;
  font-weight: 800;
  font-size: 0.85rem;
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
}

.user-name {
  font-size: 0.8rem;
  font-weight: 700;
  color: rgba(220,220,235,0.88) !important;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  display: block;
}

.user-role {
  font-size: 0.65rem;
  color: rgba(240,192,64,0.55) !important;
  font-weight: 600;
  letter-spacing: 0.05em;
  text-transform: uppercase;
  display: block;
}

/* ── Sidebar largura compacta (1025–1199px) ── */
@media (min-width: 1025px) and (max-width: 1199px) {
  .nav-item .nav-icon-wrap {
    width: 36px;
    height: 36px;
    margin-left: 5px;
  }
  .nav-item {
    min-height: 42px;
  }
}

/* =====================================================
   GAME SELECTOR — Tela de seleção de jogos (aba Live)
   ===================================================== */

/* Mobile: empilha o card Bac Bo verticalmente */
@media (max-width: 600px) {
  #game-card-bacbo {
    flex-direction: column !important;
    align-items: flex-start !important;
    gap: 16px !important;
    padding: 20px 16px !important;
  }
  #game-card-bacbo > div:first-of-type {
    width: 70px !important;
    height: 70px !important;
    font-size: 2rem !important;
  }
  /* Grid 3 colunas → 1 coluna em telas muito pequenas */
  #game-selector [style*="grid-template-columns:repeat(3"] {
    grid-template-columns: 1fr !important;
  }
}

/* Tablet: grid 3 continua, mas com menos padding */
@media (max-width: 768px) {
  #game-card-bacbo {
    gap: 16px !important;
  }
}

/* Anima entrada do seletor */
#game-selector {
  animation: fadeInUp 0.3s ease;
}
@keyframes fadeInUp {
  from { opacity: 0; transform: translateY(12px); }
  to   { opacity: 1; transform: translateY(0); }
}

/* ── Mobile drawer: sidebar com overlay animada ── */
@media (max-width: 768px) {
  .sidebar {
    /* Quando fechada: esconde com transform (já existe no style.css) */
    transition: transform 0.3s cubic-bezier(0.4, 0, 0.2, 1),
                box-shadow 0.3s ease !important;
  }

  /* Quando aberta no mobile */
  .sidebar.open {
    box-shadow:
      8px 0 40px rgba(0,0,0,0.8),
      2px 0 0 rgba(240,192,64,0.12) !important;
  }

  .sidebar-logo img {
    width: 110px;
  }

  .nav-item {
    min-height: 48px; /* conforto touch */
  }

  .nav-item .nav-icon-wrap {
    width: 38px;
    height: 38px;
  }
}

/* ── Overrides: neutraliza style.css herdado ── */

/* Remove width fixo do ícone antigo — agora usa nav-icon-wrap */
.nav-item i {
  width: auto !important;
  font-size: inherit !important;
}

/* Garante que o hover genérico do style.css não sobreponha o neon */
.nav-item:hover {
  background: transparent;
  color: inherit;
}

/* Garante que .active genérico do style.css não sobreponha o neon por aba */
.nav-item.active {
  background: transparent;
  color: inherit;
  border: 1px solid transparent;
}
.nav-item.active i {
  color: inherit !important;
}

/* sidebar-footer: remove padding duplo do style.css */
.sidebar-footer {
  padding: 0 !important;
  border-top: none !important;
  display: block !important;
}

/* user-avatar: borda arredondada (square radius em vez de círculo) */
.user-avatar {
  border-radius: 10px !important;
  background: linear-gradient(135deg, rgba(240,192,64,0.22), rgba(240,192,64,0.08)) !important;
  color: #f0c040 !important;
}

/* ── Bottom nav: tablet / desktop oculta ── */
@media (min-width: 769px) {
  .bottom-nav {
    display: none !important;
  }
}

/* =====================================================
   28. TOPBAR PREMIUM 2026
       Glassmorphism · Glow dourado · Botões premium
       Animações fluidas · iOS safe-area · Responsiva
   ===================================================== */

/* ── Keyframes exclusivos da topbar ── */
@keyframes tbarNotifPulse {
  0%,100% { box-shadow: 0 0 0 0   rgba(239,68,68,0.75); }
  50%      { box-shadow: 0 0 0 5px rgba(239,68,68,0);    }
}
@keyframes tbarSignalGlow {
  0%,100% {
    box-shadow: 0 0 6px rgba(240,192,64,0.25), inset 0 0 6px rgba(240,192,64,0.06);
    border-color: rgba(240,192,64,0.45);
  }
  50% {
    box-shadow: 0 0 18px rgba(240,192,64,0.55), inset 0 0 10px rgba(240,192,64,0.12);
    border-color: rgba(240,192,64,0.85);
  }
}
@keyframes tbarBoltFlash {
  0%,100% { opacity:1;   filter: drop-shadow(0 0 3px rgba(240,192,64,0.8)); }
  50%      { opacity:.35; filter: none; }
}
@keyframes tbarShimmer {
  0%   { background-position: -300% center; }
  100% { background-position:  300% center; }
}
@keyframes tbarFadeIn {
  from { opacity:0; transform:translateY(-8px); }
  to   { opacity:1; transform:translateY(0);    }
}

/* ── Container principal premium ── */
.topbar {
  background:
    linear-gradient(
      180deg,
      rgba(10, 10, 18, 0.97) 0%,
      rgba(7,  7,  14, 0.99) 100%
    ) !important;
  backdrop-filter: blur(28px) saturate(180%) !important;
  -webkit-backdrop-filter: blur(28px) saturate(180%) !important;

  /* Borda inferior neon dourada ultra-sutil */
  border-bottom: 1px solid rgba(240,192,64,0.13) !important;

  /* Sombra tecnológica profunda */
  box-shadow:
    0 1px 0  rgba(255,255,255,0.04),
    0 4px 32px rgba(0,0,0,0.65),
    0 0  48px rgba(240,192,64,0.04) !important;

  animation: tbarFadeIn 0.45s ease both;
  overflow: visible;
}

/* Linha glow dourada no topo */
.topbar::before {
  content: '';
  position: absolute;
  top: 0; left: 15%; right: 15%;
  height: 1px;
  background: linear-gradient(
    90deg,
    transparent,
    rgba(240,192,64,0.28) 30%,
    rgba(240,192,64,0.60) 50%,
    rgba(240,192,64,0.28) 70%,
    transparent
  );
  pointer-events: none;
  z-index: 0;
}

/* Brilho radial atmosférico dourado */
.topbar::after {
  content: '';
  position: absolute;
  top: 0; left: 50%;
  transform: translateX(-50%);
  width: 70%;
  height: 100%;
  background: radial-gradient(
    ellipse at 50% 0%,
    rgba(240,192,64,0.05) 0%,
    transparent 70%
  );
  pointer-events: none;
  z-index: 0;
}

/* Todo conteúdo acima dos pseudo-elementos */
.topbar > * { position: relative; z-index: 1; }

/* ── Botão menu hamburguer — premium ── */
.menu-toggle {
  width: 38px  !important;
  height: 38px !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  background: rgba(255,255,255,0.055) !important;
  border: 1px solid rgba(255,255,255,0.10) !important;
  border-radius: 12px !important;
  color: rgba(180,180,210,0.75) !important;
  font-size: 0.9rem !important;
  cursor: pointer;
  transition:
    background   0.22s ease,
    border-color 0.22s ease,
    color        0.22s ease,
    transform    0.18s cubic-bezier(0.34,1.56,0.64,1),
    box-shadow   0.22s ease !important;
  flex-shrink: 0;
  -webkit-tap-highlight-color: transparent;
}

@media (hover: hover) {
  .menu-toggle:hover {
    background:    rgba(240,192,64,0.10) !important;
    border-color:  rgba(240,192,64,0.30) !important;
    color:         #f0c040 !important;
    transform:     scale(1.07);
    box-shadow:    0 0 14px rgba(240,192,64,0.20) !important;
  }
}

.menu-toggle:active {
  transform: scale(0.92) !important;
}

/* ── Logo premium ── */
.topbar-logo {
  display: flex;
  align-items: center;
  text-decoration: none;
  transition: filter 0.3s ease, transform 0.3s ease;
}

.topbar-logo-img {
  height: 32px;
  width: auto;
  object-fit: contain;
  display: block;
  filter:
    drop-shadow(0 0 10px rgba(240,192,64,0.40))
    drop-shadow(0 2px 5px rgba(0,0,0,0.55)) !important;
  transition: filter 0.3s ease, transform 0.28s ease;
}

@media (hover: hover) {
  .topbar-logo:hover .topbar-logo-img {
    filter:
      drop-shadow(0 0 20px rgba(240,192,64,0.72))
      drop-shadow(0 2px 8px rgba(0,0,0,0.65)) !important;
    transform: scale(1.05);
  }
}

/* ── Centro — título shimmer premium ── */
.topbar-title {
  font-size: clamp(0.72rem, 1.5vw, 0.85rem) !important;
  font-weight: 700 !important;
  font-family: 'Rajdhani', 'Inter', sans-serif !important;
  letter-spacing: 0.14em !important;
  text-transform: uppercase !important;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;

  /* Shimmer dourado animado */
  background: linear-gradient(
    90deg,
    rgba(200,200,225,0.55) 0%,
    rgba(240,192,64,0.85)  38%,
    rgba(255,224,110,1.00) 50%,
    rgba(240,192,64,0.85)  62%,
    rgba(200,200,225,0.55) 100%
  );
  background-size: 300% auto;
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
  animation: tbarShimmer 5s linear infinite;
}

/* ── Signal alert pill ── */
.signal-alert {
  display: flex;
  align-items: center;
  gap: 6px;
  background: rgba(240,192,64,0.10) !important;
  border: 1px solid rgba(240,192,64,0.45) !important;
  border-radius: 12px !important;
  color: #f0c040 !important;
  font-size: 0.67rem !important;
  font-weight: 800 !important;
  padding: 6px 12px !important;
  letter-spacing: 0.12em !important;
  animation: tbarSignalGlow 1.5s ease-in-out infinite !important;
  white-space: nowrap;
  flex-shrink: 0;
  backdrop-filter: blur(8px);
  -webkit-backdrop-filter: blur(8px);
}

.signal-alert i {
  font-size: 0.72rem !important;
  animation: tbarBoltFlash 0.9s ease-in-out infinite !important;
}

/* ── Sino de notificações premium ── */
.notif-bell {
  position: relative;
  width: 38px  !important;
  height: 38px !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  background: rgba(255,255,255,0.055) !important;
  border: 1px solid rgba(255,255,255,0.10) !important;
  border-radius: 12px !important;
  color: rgba(180,180,210,0.75) !important;
  font-size: 0.92rem !important;
  cursor: pointer;
  transition:
    background   0.22s ease,
    border-color 0.22s ease,
    color        0.22s ease,
    transform    0.18s cubic-bezier(0.34,1.56,0.64,1),
    box-shadow   0.22s ease !important;
  flex-shrink: 0;
  -webkit-tap-highlight-color: transparent;
}

@media (hover: hover) {
  .notif-bell:hover {
    background:   rgba(240,192,64,0.10) !important;
    border-color: rgba(240,192,64,0.30) !important;
    color:        #f0c040 !important;
    box-shadow:   0 0 16px rgba(240,192,64,0.22) !important;
    transform:    scale(1.07);
  }
}

.notif-bell:active {
  transform: scale(0.91) !important;
}

/* ── Badge notificação — neon vermelho pulse ── */
.notif-count {
  position: absolute !important;
  top:   -5px !important;
  right: -5px !important;
  width:  18px !important;
  height: 18px !important;
  border-radius: 50% !important;
  background: linear-gradient(135deg, #ef4444, #dc2626) !important;
  color: #fff !important;
  font-size: 0.56rem !important;
  font-weight: 900 !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  border: 2px solid rgba(8,8,16,0.95) !important;
  line-height: 1;
  animation: tbarNotifPulse 1.8s ease-in-out infinite !important;
  z-index: 2;
  box-shadow: 0 0 8px rgba(239,68,68,0.55) !important;
}

/* ── User chip premium ── */
.topbar-user-chip {
  display: flex;
  align-items: center;
  gap: 8px;
  background: rgba(255,255,255,0.045) !important;
  border: 1px solid rgba(255,255,255,0.09) !important;
  border-radius: 14px !important;
  padding: 4px 12px 4px 4px !important;
  cursor: pointer;
  transition:
    background   0.22s ease,
    border-color 0.22s ease,
    box-shadow   0.22s ease,
    transform    0.18s cubic-bezier(0.34,1.56,0.64,1) !important;
  min-width: 0;
  max-width: 200px;
  position: relative;
  overflow: hidden;
  -webkit-tap-highlight-color: transparent;
}

/* Reflexo interno sutil */
.topbar-user-chip::before {
  content: '';
  position: absolute;
  inset: 0;
  border-radius: inherit;
  background: radial-gradient(
    ellipse at 20% 30%,
    rgba(255,255,255,0.04) 0%,
    transparent 60%
  );
  pointer-events: none;
  z-index: 0;
}

.topbar-user-chip > * { position: relative; z-index: 1; }

@media (hover: hover) {
  .topbar-user-chip:hover {
    background:   rgba(240,192,64,0.09) !important;
    border-color: rgba(240,192,64,0.26) !important;
    box-shadow:   0 0 20px rgba(240,192,64,0.13), 0 4px 16px rgba(0,0,0,0.4) !important;
    transform:    translateY(-1px);
  }
}

.topbar-user-chip:active {
  transform: scale(0.96) !important;
}

/* ── Avatar premium — quadrado com glow dourado ── */
.topbar-avatar {
  width:  30px !important;
  height: 30px !important;
  border-radius: 9px !important;
  background: linear-gradient(
    135deg,
    rgba(240,192,64,0.92) 0%,
    rgba(184,147,62,0.96) 100%
  ) !important;
  color: #060610 !important;
  font-size: 0.84rem !important;
  font-weight: 900 !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  flex-shrink: 0;
  font-family: 'Rajdhani', sans-serif;
  box-shadow:
    0 0 12px rgba(240,192,64,0.42),
    0 2px 6px rgba(0,0,0,0.55),
    inset 0 1px 0 rgba(255,255,255,0.22) !important;
}

/* ── Nome e role ── */
.topbar-user-name {
  font-size: 0.78rem !important;
  font-weight: 700 !important;
  color: rgba(220,220,240,0.92) !important;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  max-width: 100px;
}

.topbar-user-role {
  font-size: 0.60rem !important;
  color: rgba(240,192,64,0.72) !important;
  font-weight: 600 !important;
  display: flex;
  align-items: center;
  gap: 3px;
  white-space: nowrap;
  letter-spacing: 0.03em;
  opacity: 1 !important;
}

.topbar-user-role i {
  font-size: 0.55rem;
  filter: drop-shadow(0 0 3px rgba(240,192,64,0.65));
}

/* ── Notification panel — premium glassmorphism ── */
.notif-panel {
  background: linear-gradient(
    145deg,
    rgba(14,14,24,0.98) 0%,
    rgba(10,10,18,0.99) 100%
  ) !important;
  border: 1px solid rgba(255,255,255,0.08) !important;
  border-radius: 18px !important;
  box-shadow:
    0 8px 40px rgba(0,0,0,0.72),
    0 0  0 1px rgba(240,192,64,0.07),
    inset 0 1px 0 rgba(240,192,64,0.08) !important;
  backdrop-filter: blur(24px) !important;
  -webkit-backdrop-filter: blur(24px) !important;
  overflow: hidden;
  position: relative;
}

.notif-panel::before {
  content: '';
  position: absolute;
  top: 0; left: 12%; right: 12%;
  height: 1px;
  background: linear-gradient(
    90deg, transparent,
    rgba(240,192,64,0.38) 40%,
    rgba(240,192,64,0.38) 60%,
    transparent
  );
  pointer-events: none;
  z-index: 1;
}

/* ── Responsividade premium ── */

/* Tablet landscape 769–1024px */
@media (min-width: 769px) and (max-width: 1024px) {
  .topbar-user-name { max-width: 78px; }
  .topbar-logo-img  { height: 28px !important; }
}

/* Mobile ≤ 768px */
@media (max-width: 768px) {
  .topbar-logo-img {
    height: 28px !important;
  }

  .menu-toggle {
    width: 36px  !important;
    height: 36px !important;
    border-radius: 11px !important;
  }

  .notif-bell {
    width: 36px  !important;
    height: 36px !important;
    border-radius: 11px !important;
  }

  .topbar-user-chip {
    padding: 4px 8px 4px 4px !important;
    border-radius: 12px !important;
  }

  /* oculta infos de texto no chip — só avatar */
  .topbar-user-info {
    display: none !important;
  }

  .topbar-title {
    font-size: clamp(0.67rem, 3.2vw, 0.80rem) !important;
    max-width: 130px;
  }

  .signal-alert {
    padding: 5px 8px !important;
    border-radius: 10px !important;
  }

  .signal-alert-text {
    display: none !important;
  }
}

/* Phone ≤ 480px */
@media (max-width: 480px) {
  .topbar-right { gap: 6px; }

  .menu-toggle {
    width: 34px  !important;
    height: 34px !important;
    border-radius: 10px !important;
    font-size: 0.85rem !important;
  }

  .notif-bell {
    width: 34px  !important;
    height: 34px !important;
    border-radius: 10px !important;
  }

  .topbar-user-chip {
    padding: 3px !important;
    border-radius: 10px !important;
    max-width: 40px;
  }

  .topbar-avatar {
    width: 28px  !important;
    height: 28px !important;
    border-radius: 8px !important;
    font-size: 0.76rem !important;
  }
}

/* Phone SE / XS ≤ 390px */
@media (max-width: 390px) {
  .topbar-logo-img { height: 24px !important; }
  .topbar-title    { display: none !important; }
  .topbar-right    { gap: 5px; }
}

/* =====================================================
   SEÇÃO 29 — CATÁLOGO DE PADRÕES (Admin)
   ===================================================== */

/* Caixas de resumo */
.cat-stat-box {
  background: rgba(255,255,255,0.03);
  border: 1px solid rgba(255,255,255,0.07);
  border-radius: 10px;
  padding: 12px 14px;
  display: flex;
  flex-direction: column;
  gap: 5px;
}
.cat-stat-box.cat-stat-green { border-color: rgba(74,222,128,0.2); background: rgba(74,222,128,0.04); }
.cat-stat-box.cat-stat-red   { border-color: rgba(248,113,113,0.2); background: rgba(248,113,113,0.04); }

.cat-stat-label {
  font-size: 0.68rem;
  font-weight: 600;
  color: var(--text-dim);
  text-transform: uppercase;
  letter-spacing: 0.05em;
  display: flex;
  align-items: center;
  gap: 5px;
}
.cat-stat-value {
  font-size: 1.5rem;
  font-weight: 800;
  color: var(--text);
  line-height: 1;
}
.cat-stat-green .cat-stat-value { color: var(--green); }
.cat-stat-red   .cat-stat-value { color: var(--danger, #f87171); }

/* Tabs */
.cat-tab-btn {
  background: rgba(255,255,255,0.04);
  border: 1px solid rgba(255,255,255,0.08);
  border-radius: 8px;
  padding: 7px 14px;
  font-size: 0.72rem;
  font-weight: 700;
  color: var(--text-dim);
  cursor: pointer;
  font-family: inherit;
  transition: all 0.18s ease;
  display: flex;
  align-items: center;
  gap: 5px;
}
.cat-tab-btn:hover { border-color: rgba(201,168,76,0.3); color: var(--gold); }
.cat-tab-btn.cat-tab-active {
  background: rgba(201,168,76,0.12);
  border-color: rgba(201,168,76,0.4);
  color: var(--gold);
}

/* Tabela do catálogo */
.catalog-table {
  width: 100%;
  border-collapse: collapse;
  font-size: 0.78rem;
}
.catalog-table thead th {
  text-align: left;
  padding: 8px 12px;
  font-size: 0.65rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.07em;
  color: var(--text-dim);
  border-bottom: 1px solid rgba(255,255,255,0.08);
  white-space: nowrap;
}
.catalog-table tbody tr {
  border-bottom: 1px solid rgba(255,255,255,0.04);
  transition: background 0.15s;
}
.catalog-table tbody tr:hover { background: rgba(255,255,255,0.03); }
.catalog-table tbody td {
  padding: 9px 12px;
  vertical-align: middle;
}

/* Rank badge */
.cat-rank {
  width: 24px;
  height: 24px;
  border-radius: 50%;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-size: 0.68rem;
  font-weight: 800;
  flex-shrink: 0;
}
.cat-rank-1 { background: rgba(255,215,0,0.18);  color: #ffd700; border: 1px solid rgba(255,215,0,0.35); }
.cat-rank-2 { background: rgba(192,192,192,0.15); color: #c0c0c0; border: 1px solid rgba(192,192,192,0.3); }
.cat-rank-3 { background: rgba(205,127,50,0.15);  color: #cd7f32; border: 1px solid rgba(205,127,50,0.3); }
.cat-rank-n { background: rgba(255,255,255,0.05); color: var(--text-dim); border: 1px solid rgba(255,255,255,0.08); }

/* Código do padrão */
.cat-pattern-raw {
  font-family: 'Courier New', monospace;
  font-size: 0.78rem;
  font-weight: 700;
  color: var(--text);
  background: rgba(255,255,255,0.05);
  border: 1px solid rgba(255,255,255,0.08);
  border-radius: 5px;
  padding: 2px 7px;
  white-space: nowrap;
}

/* Badge de entrada */
.cat-entry-badge {
  font-size: 0.65rem;
  font-weight: 700;
  padding: 2px 8px;
  border-radius: 10px;
  white-space: nowrap;
}
.cat-entry-player  { background: rgba(96,165,250,0.15);  color: #60a5fa; border: 1px solid rgba(96,165,250,0.3); }
.cat-entry-banker  { background: rgba(248,113,113,0.15); color: #f87171; border: 1px solid rgba(248,113,113,0.3); }
.cat-entry-tie     { background: rgba(167,139,250,0.15); color: #a78bfa; border: 1px solid rgba(167,139,250,0.3); }

/* Barra de assertividade */
.cat-bar-wrap {
  display: flex;
  align-items: center;
  gap: 7px;
  min-width: 100px;
}
.cat-bar-bg {
  flex: 1;
  height: 6px;
  background: rgba(255,255,255,0.07);
  border-radius: 3px;
  overflow: hidden;
}
.cat-bar-fill {
  height: 100%;
  border-radius: 3px;
  transition: width 0.4s ease;
}
.cat-bar-pct {
  font-size: 0.7rem;
  font-weight: 700;
  min-width: 32px;
  text-align: right;
}

/* Contador Green/Red */
.cat-count-g { color: #4ade80; font-weight: 700; }
.cat-count-r { color: #f87171; font-weight: 700; }
.cat-count-sep { color: var(--text-dim); margin: 0 2px; }

/* Último resultado badge */
.cat-last-result {
  font-size: 0.65rem;
  font-weight: 700;
  padding: 2px 7px;
  border-radius: 6px;
}
.cat-last-green   { background: rgba(74,222,128,0.12); color: #4ade80; }
.cat-last-red     { background: rgba(248,113,113,0.12); color: #f87171; }
.cat-last-pending { background: rgba(255,255,255,0.06); color: var(--text-dim); }

/* Estado vazio */
.cat-empty {
  text-align: center;
  padding: 36px 20px;
  color: var(--text-dim);
  font-size: 0.82rem;
}
.cat-empty i {
  font-size: 2rem;
  display: block;
  margin-bottom: 10px;
  opacity: 0.3;
}

/* Responsivo */
@media (max-width: 600px) {
  #catalog-summary { grid-template-columns: repeat(2, 1fr) !important; }
  .catalog-table thead th:nth-child(6),
  .catalog-table tbody td:nth-child(6) { display: none; }
}
