/* ═══════════════════════════════════════════════════════════════
   RUGA MOBILE — fase 2 (densidade · 2026-06-12)
   Carregado por ÚLTIMO no dashboard.html.
   Contém SOMENTE @media (max-width: 768px) → zero efeito no desktop.
   (!important onde compete com <style> injetado por módulos JS)
   ═══════════════════════════════════════════════════════════════ */

/* ── menu hamburger: painel fixo com scroll próprio (bug: rolava a página, não o menu) ── */
@media (max-width: 860px) {
  #topNav.mobile-open {
    position: fixed; top: 0; left: 0; right: 0; bottom: 0;
    overflow-y: auto; -webkit-overflow-scrolling: touch;
    background: var(--bg, #0A0A0A); z-index: 1000;
    padding: 14px 16px 48px 16px;
  }
  /* botão ☰ vira "fechar" fixo no canto — sempre acessível com o painel aberto */
  #topNav.mobile-open .nav-burger {
    position: fixed; top: 10px; right: 14px; z-index: 1001;
    background: var(--surface, #141414); margin: 0;
  }
  #topNav.mobile-open { padding-top: 56px; }
}

@media (max-width: 768px) {

  /* ── trava overflow horizontal global ── */
  html, body { overflow-x: hidden; }
  #sectionContainer { max-width: 100%; overflow-x: hidden; }

  /* ── topbar 1: brand + ticker ── */
  .topbar-1 { padding: 10px 12px; gap: 8px; }
  .topbar-1 .brand { gap: 8px; }
  .topbar-1 .brand-text { font-size: 14px; white-space: nowrap; }
  .topbar-1 .utility { gap: 8px; }
  .ticker-pill { padding: 4px 10px; gap: 8px; }
  .ticker-pill .btc-kpi { white-space: nowrap; }
  .ticker-pill #btc15d, .ticker-pill #btc30d { display: none; }
  .topbar-1 .avatar { display: none; }

  /* ── page head ── */
  .main-content { padding-left: 12px; padding-right: 12px; }
  .page-head h1 { font-size: 24px; }

  /* ── Control: kicker / drill deeper (taglines itálicas saem) ── */
  .head-tag { display: none; }
  .qn-sub { display: none; }

  /* ── Control: Drill Deeper em 1 coluna (links em 1 linha, toque maior) ── */
  .qn-grid { grid-template-columns: 1fr !important; }
  .qn-col { padding: 12px 14px; }
  .qn-link {
    font-size: 14px; padding: 8px 0;
    white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
  }

  /* ── Control: rodapé do hero card (rotation + botões) ── */
  .rsps-foot { flex-direction: column; align-items: stretch; gap: 10px; }
  .rsps-foot .activity { flex: none; }
  .rsps-foot a { display: block; }
  .rsps-foot .btn-outline,
  .rsps-foot .btn-accent { width: 100%; white-space: nowrap; padding: 12px 0; }

  /* ── Control: tape vira faixa rolável (sem scrollbar) ── */
  .tape-track {
    overflow-x: auto; -webkit-overflow-scrolling: touch;
    scrollbar-width: none; padding-left: 12px; gap: 18px;
  }
  .tape-track::-webkit-scrollbar { display: none; }
  .tape-item { flex: 0 0 auto; }

  /* ── Divergence Fan (CLI/GLI) ── */
  .dfan-card { padding: 14px 12px !important; }
  .dfan-toprow { flex-wrap: wrap; gap: 6px; }
  .dfan-kicker { font-size: 11px !important; letter-spacing: 0.12em !important; }
  .dfan-legend { gap: 10px !important; flex-wrap: wrap; }
  .dfan-legend > span { white-space: nowrap; }
  .dfan-ruler-lbl { display: none !important; }
  .dfan-chips { gap: 5px !important; }
  .dfan-chip { padding: 4px 8px !important; }

  /* ── GEX ── */
  .gex-topbar { flex-direction: column !important; align-items: stretch !important; gap: 12px !important; }
  .gex-topbar-left { min-width: 0 !important; }
  .gex-name { flex-wrap: wrap !important; }
  .gex-name-text { white-space: nowrap; }
  .gex-sub { width: 100%; }
  .gex-tags { display: flex !important; flex-wrap: wrap !important; gap: 6px !important; }
  .gex-tag { white-space: nowrap; }
  .gex-topbar-right { flex-wrap: wrap !important; row-gap: 8px; justify-content: flex-start !important; }
  .gex-hero { grid-template-columns: 1fr !important; }
  .gex-chart-frame { overflow-x: auto; -webkit-overflow-scrolling: touch; }
  .gex-shell { max-width: 100%; overflow: hidden; }
  .gex-legend { flex-wrap: wrap !important; gap: 8px !important; }

  /* ── Cohorts: Smart Money matrix (estourava o card) ── */
  .sm-wrap { padding: 0 12px !important; }
  .sm-matrix { grid-template-columns: minmax(86px, 1.2fr) repeat(3, 1fr) !important; gap: 4px !important; }
  .sm-matrix-label { padding: 6px 4px !important; font-size: 10px !important; }
  .sm-matrix-label-sub { font-size: 8px !important; }
  .sm-matrix-cell { padding: 8px 3px !important; font-size: 10px !important; }
  .sm-matrix-head { flex-wrap: wrap !important; gap: 4px; }
  .sm-matrix-card { overflow-x: auto; -webkit-overflow-scrolling: touch; }

  /* ── VAMS: régua de 7 estados virava corte — agora rola na horizontal ── */
  .vams-wrap { padding: 0 12px !important; }
  .vams-pills-strip {
    display: flex !important; overflow-x: auto; -webkit-overflow-scrolling: touch;
    scrollbar-width: none; gap: 4px !important;
  }
  .vams-pills-strip::-webkit-scrollbar { display: none; }
  .vams-pills-strip > * { flex: 0 0 auto; }
  .vams-timeline-legend { flex-wrap: wrap !important; row-gap: 3px; }

  /* ── RSPS (página de detalhe) ── */
  .rsps-hdr, .rsps-subhdr { flex-wrap: wrap !important; row-gap: 8px; }
  .rsps-strategy-bar { flex-wrap: wrap !important; row-gap: 8px; }
  .rsps-grid { grid-template-columns: 1fr !important; }
  .rsps-card { max-width: 100%; min-width: 0 !important; overflow-x: auto; -webkit-overflow-scrolling: touch; }
  .rsps-ranking-table { min-width: 560px; } /* a tabela rola DENTRO do card, não a página */
}
