/* ═══════════════════════════════════════════════════════════════
   FLEETPRO — RESPONSIVE (mobile.css)
   Todas as regras são EXCLUSIVAMENTE dentro de @media queries.
   Nenhuma regra fora de @media — desktop não é afetado.
   Breakpoints:
     Tablet  → 769px – 1024px
     Mobile  → ≤ 768px
     Small   → ≤ 480px
   ═══════════════════════════════════════════════════════════════ */

/* ─────────────────────────────────────────────
   TABLET: 769px – 1024px
   Mesma estrutura do mobile — sidebar overlay
   ───────────────────────────────────────────── */
@media (min-width: 769px) and (max-width: 1024px) {

  /* Layout raiz igual mobile */
  body          { overflow: auto; height: auto; }
  #layer-app    { flex-direction: column; overflow: auto; height: auto; min-height: 100dvh; }

  /* Topbar compacta com hamburguer */
  .topbar        { padding: 0 16px; height: 56px; position: sticky; top: 0; z-index: 50; gap: 10px; }
  .topbar-search { display: none; }
  .topbar-right  { gap: 8px; }
  .page-title    { font-size: 15px; flex: 1; }
  #btn-hamburguer { display: flex !important; }

  /* Sidebar overlay — igual mobile */
  .sidebar {
    position: fixed;
    left: -300px;
    top: 0;
    z-index: 110;
    height: 100dvh;
    width: 280px;
    transition: left .28s cubic-bezier(.4,0,.2,1);
  }
  .sidebar.open { left: 0; box-shadow: 4px 0 32px rgba(0,0,0,.75); }

  /* Main ocupa tudo */
  .main    { width: 100%; height: auto; overflow: visible; }
  .content { padding: 16px 16px 80px; overflow: visible; height: auto; }
  .page    { overflow: visible; }

  /* Stats: 2×2 */
  .stats-grid       { grid-template-columns: repeat(2, 1fr) !important; gap: 12px; }
  .stats-grid.cols3 { grid-template-columns: repeat(2, 1fr); }
  .stat-card        { padding: 16px; }

  /* Grids */
  .grid2 { grid-template-columns: 1fr 1fr; gap: 14px; }
  .card  { overflow-x: auto; }

  /* Chat — mesma lógica mobile */
  .chat-layout {
    display: block;
    height: calc(100dvh - 56px);
    position: relative;
    overflow: hidden;
    border-radius: 0;
    border: none;
  }
  .chat-list {
    position: absolute;
    inset: 0;
    width: 100%;
    transform: translateX(0);
    transition: transform .28s cubic-bezier(.4,0,.2,1);
    z-index: 2;
  }
  .chat-window {
    position: absolute;
    inset: 0;
    width: 100%;
    transform: translateX(100%);
    transition: transform .28s cubic-bezier(.4,0,.2,1);
    z-index: 3;
  }
  .chat-layout.chat-open .chat-list   { transform: translateX(-100%); }
  .chat-layout.chat-open .chat-window { transform: translateX(0); }
  .chat-side       { display: none; }
  .chat-back-btn   { display: flex !important; }

  /* Modal bottom-sheet */
  .modal-overlay { align-items: flex-end; padding: 0; }
  .modal {
    width: 100vw;
    max-width: 100vw;
    max-height: 90dvh;
    border-radius: 20px 20px 0 0;
    padding: 24px 20px 36px;
    border-bottom: none;
  }
  .modal-footer         { flex-direction: column-reverse; gap: 8px; }
  .modal-footer .btn    { width: 100%; justify-content: center; }

  /* Formulários 2 colunas no tablet (mais espaço) */
  .form-grid { grid-template-columns: 1fr 1fr; gap: 12px; }
}

/* ─────────────────────────────────────────────
   MOBILE: ≤ 768px
   Complementa o que já existe em styles.css
   ───────────────────────────────────────────── */
@media (max-width: 768px) {

  /* ── Layout raiz ── */
  body { overflow: auto; height: auto; }
  #layer-app { flex-direction: column; overflow: auto; height: auto; min-height: 100dvh; }

  /* ── Topbar ── */
  .topbar { padding: 0 12px; height: 54px; gap: 8px; position: sticky; top: 0; z-index: 50; }
  .topbar-search { display: none; }            /* esconde busca — abre via ícone */
  .topbar-right  { gap: 6px; }
  .page-title    { font-size: 14px; flex: 1; }

  /* Botão hamburguer */
  #btn-hamburguer { display: flex !important; }

  /* ── Sidebar overlay ── */
  .sidebar {
    position: fixed;
    left: -280px;
    top: 0;
    z-index: 110;
    height: 100dvh;
    width: 260px;
    transition: left .28s cubic-bezier(.4,0,.2,1);
  }
  .sidebar.open { left: 0; box-shadow: 4px 0 32px rgba(0,0,0,.75); }
  #sidebar-overlay {
    display: none;
    position: fixed;
    inset: 0;
    background: rgba(0,0,0,.55);
    z-index: 105;
    cursor: pointer;
  }

  /* ── Main ── */
  .main { width: 100%; height: auto; overflow: visible; }
  .content { padding: 12px 12px 80px; overflow: visible; height: auto; }
  .page { overflow: visible; }

  /* ── Stats cards ── */
  .stats-grid       { grid-template-columns: repeat(2, 1fr) !important; gap: 10px; margin-bottom: 12px; }
  .stats-grid.cols3 { grid-template-columns: repeat(2, 1fr); }
  .stat-val         { font-size: 20px; }
  .stat-card        { padding: 14px; }

  /* ── Cards e grids ── */
  .grid2  { grid-template-columns: 1fr; gap: 12px; }
  .card   { padding: 14px; overflow-x: auto; }

  /* ── Tabelas — scroll horizontal guiado ── */
  .card > table,
  .card > div > table { min-width: 560px; }
  .card { overflow-x: auto; -webkit-overflow-scrolling: touch; }
  th   { font-size: 9px; padding: 0 8px 8px; }
  td   { font-size: 12px; padding: 9px 8px; }

  /* ── Formulários ── */
  .form-grid           { grid-template-columns: 1fr !important; gap: 10px; }
  .form-group.full     { grid-column: 1; }
  .input-group         { flex-direction: column; align-items: stretch; }

  /* ── Botões ── */
  .btn { font-size: 12px; padding: 9px 14px; }

  /* ── Modais ── */
  .modal-overlay { align-items: flex-end; padding: 0; }
  .modal {
    width: 100vw;
    max-width: 100vw;
    max-height: 92dvh;
    border-radius: 20px 20px 0 0;
    padding: 20px 16px 32px;
    border-bottom: none;
  }
  .modal-header   { margin-bottom: 16px; }
  .modal-title    { font-size: 16px; }
  .modal-footer   { flex-direction: column-reverse; gap: 8px; }
  .modal-footer .btn { width: 100%; justify-content: center; }

  /* ── Badges ── */
  .badge { font-size: 10px; padding: 2px 8px; }

  /* ── Notificações ── */
  .notify { right: 12px; left: 12px; bottom: 16px; text-align: center; }

  /* ── Chat mobile — redesign completo ── */
  .chat-layout {
    display: block;
    height: calc(100dvh - 54px);
    position: relative;
    overflow: hidden;
    border-radius: 0;
    border: none;
  }

  /* Contacts list — ocupa tela toda por padrão */
  .chat-list {
    position: absolute;
    inset: 0;
    width: 100%;
    transform: translateX(0);
    transition: transform .28s cubic-bezier(.4,0,.2,1);
    z-index: 2;
    border-radius: 0;
  }

  /* Chat window — escondida para direita por padrão */
  .chat-window {
    position: absolute;
    inset: 0;
    width: 100%;
    transform: translateX(100%);
    transition: transform .28s cubic-bezier(.4,0,.2,1);
    z-index: 3;
  }

  /* Quando contato selecionado: desliza tudo para esquerda */
  .chat-layout.chat-open .chat-list   { transform: translateX(-100%); }
  .chat-layout.chat-open .chat-window { transform: translateX(0); }

  /* Painel direito: escondido no mobile */
  .chat-side { display: none; }

  /* Botão voltar no header do chat — aparece só no mobile */
  .chat-back-btn {
    display: flex !important;
    align-items: center;
    justify-content: center;
    background: none;
    border: none;
    color: #e9edef;
    cursor: pointer;
    padding: 6px 8px 6px 2px;
    font-size: 22px;
    flex-shrink: 0;
  }

  /* Mensagens: padding lateral menor */
  .chat-msgs { padding: 12px 4%; }
  .msg       { max-width: 80%; }

  /* ── Tab filters ── */
  .tab-filter { flex-wrap: wrap; gap: 6px; }
  .tab-btn    { font-size: 11px; padding: 5px 12px; }

  /* ── Card header com filtros ── */
  .card-header { flex-wrap: wrap; gap: 8px; }

  /* ── Login (já tratado em styles.css, reforço) ── */
  .login-left  { display: none; }
  .login-right { padding: 48px 20px 36px; min-height: 100dvh; justify-content: center; }
  .login-wrap  { grid-template-columns: 1fr; width: 100vw; min-height: 100dvh; border-radius: 0; border: none; }

  /* ── Setup ── */
  .setup-box { width: 100%; max-width: 100%; border-radius: 0; border: none; padding: 28px 16px; min-height: 100dvh; }

  /* ── Investidores ── */
  #page-investidores { padding-bottom: 80px !important; }
}

/* ─────────────────────────────────────────────
   SMALL MOBILE: ≤ 480px (phones menores)
   ───────────────────────────────────────────── */
@media (max-width: 480px) {

  .stat-val   { font-size: 18px; }
  .stat-label { font-size: 9px; }
  .stat-card  { padding: 12px; }

  .modal-title { font-size: 15px; }

  .page-title { font-size: 13px; }

  /* Stats em 1 coluna quando muito pequeno */
  .stats-grid { grid-template-columns: repeat(2, 1fr) !important; }

  /* Chat msgs largura máxima */
  .msg { max-width: 88%; font-size: 13px; }

  .topbar { height: 50px; }
}
