/* ============================================================
   FinSight — Responsive Design System v9.13.18
   ============================================================
   Breakpoints estratégicos:
   • XL  ≥1440px  — Desktop grande (4K, monitores externos)
   • L   1200-1439 — Desktop padrão / notebook grande
   • ML  1024-1199 — Notebook pequeno (13" / iPad Pro landscape)
   • M   768-1023  — Tablet landscape / portrait
   • S   480-767   — Celular landscape / tablet pequeno
   • XS  ≤479px    — Celular portrait

   Princípios:
   1. Nenhum corte de informação financeira
   2. Scroll horizontal SEM clip em tabelas
   3. Gráficos com height fluida e canvas max-width:100%
   4. Cards que se reorganizam (1/2/3/4 colunas conforme largura)
   5. Modais full-screen em telas <768px
   ============================================================ */

/* ────────────────────────────────────────────────────────────
   GLOBAL — base para todos os tamanhos
   ──────────────────────────────────────────────────────────── */

/* Imagens fluidas por padrão */
img, video, svg {
  max-width: 100%;
  height: auto;
}

/* Canvas de gráficos sempre fluidos sem distorção */
.chart-wrap,
.chart-container,
[id^="chart"],
canvas {
  max-width: 100%;
}

.chart-wrap {
  position: relative;
  width: 100%;
}

/* Wrapper universal de tabelas: scroll horizontal em qualquer tela menor */
.table-responsive,
.table-scroll,
[class*="overflow-x"] {
  overflow-x: auto;
  -webkit-overflow-scrolling: touch;
  scrollbar-width: thin;
}

/* Toda data-table que esteja num card-body recebe scroll automaticamente */
.card-body {
  overflow-x: auto;
  -webkit-overflow-scrolling: touch;
}

/* Indicador visual sutil de scroll horizontal */
.card-body::-webkit-scrollbar { height: 6px; }
.card-body::-webkit-scrollbar-thumb { background: var(--border); border-radius: 4px; }

/* Quebra forçada para textos longos em qualquer tela */
.card-title,
.kpi-label,
.breadcrumb {
  overflow-wrap: anywhere;
  word-wrap: break-word;
}

/* Botões nunca devem ter overflow horizontal indesejado */
.btn {
  white-space: nowrap;
}

/* ────────────────────────────────────────────────────────────
   XXL ≥ 1920px — Monitor Full HD/4K
   ──────────────────────────────────────────────────────────── */
@media (min-width: 1920px) {
  .page-container { padding: 32px 40px; max-width: 2200px; margin: 0 auto; }
  .kpi-grid { grid-template-columns: repeat(auto-fit, minmax(240px, 1fr)); gap: 20px; }
  .kpi-value { font-size: 26px; }
  html { font-size: 15px; }
}

/* ────────────────────────────────────────────────────────────
   XL 1440-1919px — Desktop grande
   ──────────────────────────────────────────────────────────── */
@media (min-width: 1440px) and (max-width: 1919px) {
  .page-container { padding: 28px 32px; max-width: 1800px; margin: 0 auto; }
  .kpi-grid { grid-template-columns: repeat(auto-fit, minmax(220px, 1fr)); gap: 18px; }
  .kpi-value { font-size: 24px; }
}

/* ────────────────────────────────────────────────────────────
   Notebook padrão 1366×768 (resolução mais comum)
   ──────────────────────────────────────────────────────────── */
@media (min-width: 1280px) and (max-width: 1399px) {
  :root { --sidebar-width: 232px; }
  .page-container { padding: 22px 24px; }
  .kpi-grid { grid-template-columns: repeat(auto-fit, minmax(200px, 1fr)); gap: 14px; }
  .kpi-value { font-size: 20px; }
  .kpi-card { padding: 16px; }
}

/* ────────────────────────────────────────────────────────────
   L 1200-1439px — Desktop padrão (regras já existem; reforço)
   ──────────────────────────────────────────────────────────── */
@media (max-width: 1399px) and (min-width: 1200px) {
  .global-filters .filter-select { font-size: 12.5px; padding: 0 8px; }
  .topbar { padding: 0 20px; }
}

/* ────────────────────────────────────────────────────────────
   ML 1024-1199px — Notebook 13" / iPad Pro landscape
   ──────────────────────────────────────────────────────────── */
@media (max-width: 1199px) {
  :root {
    --sidebar-width: 220px;
    --topbar-height: 58px;
  }

  .page-container { padding: 20px; }
  .page-header h1 { font-size: 19px; }

  .kpi-grid { grid-template-columns: repeat(auto-fit, minmax(180px, 1fr)); gap: 14px; }
  .kpi-card { padding: 16px; }
  .kpi-value { font-size: 20px; }
  .kpi-icon { width: 30px; height: 30px; font-size: 13px; }

  .grid-2 { gap: 14px; }
  .grid-3 { gap: 14px; }
  .grid-12, .grid-21 { gap: 14px; }

  .card-header { padding: 14px 16px 12px; }
  .card-body { padding: 16px; }

  .topbar { padding: 0 20px; }
  .global-filters .filter-select { font-size: 12px; padding: 0 8px; height: 34px; }
  .last-update { font-size: 11px; }
}

/* ────────────────────────────────────────────────────────────
   M 768-1023px — Tablet (portrait + landscape pequeno)
   ──────────────────────────────────────────────────────────── */
@media (max-width: 1023px) {
  /* Sidebar vira off-canvas */
  .sidebar {
    transform: translateX(-100%);
    width: 260px !important;
    box-shadow: 8px 0 32px rgba(0,0,0,.18);
  }
  .sidebar.mobile-open { transform: translateX(0); }
  .sidebar.collapsed { width: 260px !important; }
  .sidebar.collapsed .logo-text,
  .sidebar.collapsed .nav-item span,
  .sidebar.collapsed .nav-section-title,
  .sidebar.collapsed .status-text,
  .sidebar.collapsed .sidebar-user-info,
  .sidebar.collapsed .sidebar-logout-btn { display: initial; }

  .main-wrapper,
  .main-wrapper.collapsed { margin-left: 0 !important; }

  .mobile-toggle { display: flex !important; }
  .sidebar-toggle { display: none; }

  /* Overlay quando sidebar mobile aberta */
  .sidebar-overlay {
    display: none;
    position: fixed;
    inset: 0;
    background: rgba(17,15,26,.55);
    z-index: 99;
    backdrop-filter: blur(2px);
  }
  .sidebar-overlay.active { display: block; }

  /* Topbar reorganizada: filtros vão para uma 2ª linha */
  .topbar {
    height: auto;
    min-height: var(--topbar-height);
    padding: 8px 16px;
    flex-wrap: wrap;
    gap: 8px;
    align-items: center;
  }
  .topbar-left { gap: 10px; flex: 0 0 auto; }
  .topbar-right {
    width: 100%;
    order: 3;
    flex-wrap: wrap;
    gap: 6px;
    margin-top: 4px;
  }
  .global-filters {
    width: 100%;
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
    padding-bottom: 4px;
    flex-wrap: nowrap;
    scrollbar-width: thin;
  }
  .global-filters::-webkit-scrollbar { height: 4px; }
  .global-filters::-webkit-scrollbar-thumb { background: var(--border); border-radius: 4px; }

  .filter-select {
    font-size: 12px;
    padding: 0 8px;
    height: 32px;
    flex: 0 0 auto;
    min-width: 120px;
  }
  .last-update { display: none; }

  /* Grids reorganizados */
  .grid-2,
  .grid-12,
  .grid-21 { grid-template-columns: 1fr; gap: 14px; }
  .grid-3 { grid-template-columns: 1fr 1fr; gap: 14px; }

  /* KPIs em 2 colunas */
  .kpi-grid { grid-template-columns: repeat(2, 1fr); gap: 12px; }
  .kpi-card { padding: 14px; }
  .kpi-value { font-size: 19px; }

  /* Cards com padding reduzido */
  .card-header {
    padding: 12px 14px 10px;
    flex-wrap: wrap;
    gap: 8px;
  }
  .card-body { padding: 14px; }

  .page-container { padding: 14px; }
  .page-header h1 { font-size: 18px; }
  .page-header p { font-size: 12px; }

  /* Tabelas: scroll horizontal sempre disponível */
  .data-table { font-size: 12px; }
  .data-table th { padding: 8px 10px; font-size: 10.5px; }
  .data-table td { padding: 8px 10px; font-size: 12px; }

  /* Modais ocupam quase toda a tela */
  .modal-overlay > div,
  #drillModal > div {
    width: 96vw !important;
    max-width: 96vw !important;
    max-height: 92vh !important;
  }
  .sync-modal-card {
    width: 96vw;
    padding: 22px 20px;
  }

  /* Drill-down nav e KPIs em telas médias */
  #drillKpis { padding: 10px 16px !important; gap: 8px !important; }
  #drillNav  { padding: 8px 16px !important; }

  /* Tabs / segments podem virar scroll horizontal */
  .segment-tabs {
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
    flex-wrap: nowrap;
  }
  .seg-tab { flex: 0 0 auto; }
}

/* ────────────────────────────────────────────────────────────
   S 480-767px — Celular landscape / tablet pequeno
   ──────────────────────────────────────────────────────────── */
@media (max-width: 767px) {
  html { font-size: 13px; }

  /* Topbar mais compacta */
  .topbar { padding: 6px 12px; }
  .breadcrumb { font-size: 14px; }
  .mobile-toggle { font-size: 16px; padding: 4px 6px; }

  /* Sidebar full-width em telas muito pequenas */
  .sidebar {
    width: 88vw !important;
    max-width: 320px !important;
  }

  /* Page container */
  .page-container { padding: 12px; }
  .page-header { margin-bottom: 16px; }
  .page-header h1 { font-size: 17px; }
  .page-header p { font-size: 11.5px; }

  /* KPIs em 1 ou 2 colunas dependendo do conteúdo */
  .kpi-grid { grid-template-columns: 1fr 1fr; gap: 10px; }
  .kpi-card { padding: 12px; gap: 6px; }
  .kpi-value { font-size: 17px; }
  .kpi-label { font-size: 11px; }
  .kpi-icon { width: 28px; height: 28px; font-size: 12px; }
  .kpi-change { font-size: 10.5px; padding: 2px 6px; }

  /* Grids: tudo em uma coluna */
  .grid-2,
  .grid-3,
  .grid-12,
  .grid-21 { grid-template-columns: 1fr !important; gap: 12px; }

  /* Cards com sombras mais leves */
  .card { border-radius: 12px; }
  .card-header {
    padding: 10px 12px 8px;
    flex-direction: column;
    align-items: flex-start;
  }
  .card-header > * { width: 100%; }
  .card-title { font-size: 13px; }
  .card-body { padding: 12px; }

  /* Tabelas — fonte e padding mínimos legíveis */
  .data-table { font-size: 11.5px; min-width: 520px; }
  .data-table th { padding: 7px 8px; font-size: 10px; letter-spacing: .3px; }
  .data-table td { padding: 7px 8px; font-size: 11.5px; }
  .data-table .total-row td { font-size: 12px; }

  /* Forçar wrapper de tabela ter scroll com indicador */
  .card-body > .data-table,
  .card-body table {
    display: block;
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
    white-space: nowrap;
  }

  /* Filtros — virtualmente em scroll horizontal */
  .filter-select {
    height: 30px;
    font-size: 11.5px;
    padding: 0 7px;
    min-width: 110px;
  }

  /* Botões */
  .btn { height: 34px; padding: 0 14px; font-size: 12px; }
  .btn-sm { height: 28px; padding: 0 10px; font-size: 11px; }
  .btn-sync { padding: 0 12px; height: 34px; }
  .btn-sync span { display: none; }

  /* Forms */
  .form-input, .form-select { height: 36px; font-size: 12.5px; }
  .form-label { font-size: 12px; }

  /* Modais — full screen em telas pequenas */
  .modal-overlay {
    padding: 0 !important;
    align-items: flex-start !important;
  }
  .modal-overlay > div,
  #drillModal > div,
  #rateioModal > div,
  #userModal > div,
  #overridesModal > div {
    width: 100vw !important;
    max-width: 100vw !important;
    height: 100vh !important;
    max-height: 100vh !important;
    border-radius: 0 !important;
    margin: 0 !important;
  }

  .sync-modal-card {
    width: 96vw;
    padding: 18px 16px;
    gap: 14px;
  }
  .sync-modal-icon { width: 40px; height: 40px; font-size: 18px; }
  .sync-modal-title { font-size: 14px; }
  .sync-steps-box { max-height: 120px; font-size: 11px; }

  /* Drill-down em mobile */
  #drillKpis {
    padding: 8px 12px !important;
    gap: 6px !important;
    flex-wrap: wrap;
  }
  #drillKpis > * { flex: 1 1 calc(50% - 6px); min-width: 0; }
  #drillNav { padding: 6px 12px !important; font-size: 11px; }
  #drillTitle { font-size: 14px !important; }
  #drillSub { font-size: 11px !important; }

  /* Toast */
  .toast-container { right: 12px; left: 12px; bottom: 12px; }
  .toast { min-width: 0; width: 100%; font-size: 12.5px; }

  /* Insight cards mais compactos */
  .insight-card { padding: 12px 14px; gap: 10px; }
  .insight-body h4 { font-size: 12.5px; }
  .insight-body p { font-size: 11.5px; }

  /* Badges */
  .badge { font-size: 10.5px; padding: 2px 7px; }

  /* Segment tabs com fonte menor */
  .seg-tab { padding: 5px 10px; font-size: 11.5px; }

  /* Temporal widget */
  .temporal-widget-header { padding: 10px 12px; flex-wrap: wrap; gap: 6px; }
  .temporal-widget-body { padding: 10px 12px 12px; }
  .temporal-chart-wrap { height: 240px; }
  .temporal-matrix-table { font-size: 11px; }
  .temporal-matrix-table th,
  .temporal-matrix-table td { padding: 6px 8px; }
}

/* ────────────────────────────────────────────────────────────
   XS ≤ 479px — Celular portrait
   ──────────────────────────────────────────────────────────── */
@media (max-width: 479px) {
  html { font-size: 12.5px; }

  /* KPIs sempre 1 coluna */
  .kpi-grid { grid-template-columns: 1fr; gap: 10px; }
  .kpi-card { padding: 14px; }
  .kpi-value { font-size: 18px; }

  /* Topbar minimalista */
  .topbar { padding: 6px 10px; }
  .breadcrumb { font-size: 13px; }
  .topbar-right { gap: 4px; }

  .filter-select {
    height: 30px;
    font-size: 11px;
    padding: 0 6px;
    min-width: 100px;
  }

  /* Page */
  .page-container { padding: 10px; }
  .page-header h1 { font-size: 16px; letter-spacing: 0; }
  .page-header p { font-size: 11px; }

  /* Cards */
  .card { border-radius: 10px; }
  .card-header { padding: 10px; }
  .card-body { padding: 10px; }
  .card-title { font-size: 12.5px; }
  .card-title i { font-size: 12px; }

  /* Tabelas — fonte mínima legível com scroll */
  .data-table { font-size: 11px; }
  .data-table th { padding: 6px 7px; font-size: 9.5px; }
  .data-table td { padding: 6px 7px; font-size: 11px; }

  /* Botões */
  .btn { height: 32px; padding: 0 12px; font-size: 11.5px; }
  .btn-sm { height: 26px; padding: 0 8px; font-size: 10.5px; }

  /* Forms — empilha grid-2 dentro de modais */
  .grid-2 { grid-template-columns: 1fr !important; }

  /* Modal mantém full-screen */
  .modal-overlay { padding: 0 !important; }

  /* Logo na sidebar */
  .logo-name { font-size: 14px; }
  .logo-sub { font-size: 8px; }
}

/* ────────────────────────────────────────────────────────────
   AJUSTES ESPECÍFICOS — gráficos e tabelas
   ──────────────────────────────────────────────────────────── */

/* Container de gráficos com height fluida — evita distorção */
@media (max-width: 1023px) {
  div[style*="height: 600px"],
  div[style*="height:600px"] { height: 420px !important; }
  div[style*="height: 500px"],
  div[style*="height:500px"] { height: 380px !important; }
  div[style*="height: 400px"],
  div[style*="height:400px"] { height: 340px !important; }
  div[style*="height: 350px"],
  div[style*="height:350px"] { height: 300px !important; }
}

@media (max-width: 767px) {
  div[style*="height: 600px"],
  div[style*="height:600px"] { height: 320px !important; }
  div[style*="height: 500px"],
  div[style*="height:500px"] { height: 280px !important; }
  div[style*="height: 400px"],
  div[style*="height:400px"] { height: 260px !important; }
  div[style*="height: 350px"],
  div[style*="height:350px"] { height: 240px !important; }
  div[style*="height: 320px"],
  div[style*="height:320px"] { height: 220px !important; }
  div[style*="height: 280px"],
  div[style*="height:280px"] { height: 220px !important; }
}

/* ────────────────────────────────────────────────────────────
   ACESSIBILIDADE — touch targets e foco
   ──────────────────────────────────────────────────────────── */
@media (hover: none) and (pointer: coarse) {
  /* Touch devices: aumentar áreas clicáveis */
  .nav-item { padding: 11px 12px; }
  .btn { min-height: 40px; }
  .btn-sm { min-height: 32px; }
  .filter-select { min-height: 36px; }
  .seg-tab { min-height: 34px; padding: 8px 14px; }

  /* Remover hover effects que ficam "presos" no touch */
  .kpi-card:hover,
  .card:hover { transform: none; }
}

/* ────────────────────────────────────────────────────────────
   ORIENTAÇÃO LANDSCAPE em celulares
   ──────────────────────────────────────────────────────────── */
@media (max-width: 900px) and (orientation: landscape) and (max-height: 500px) {
  .topbar { min-height: 50px; }
  .page-container { padding: 10px 12px; }
  .kpi-grid { grid-template-columns: repeat(3, 1fr); gap: 8px; }
  .kpi-card { padding: 10px; }
  .kpi-value { font-size: 16px; }
  .modal-overlay > div,
  #drillModal > div { max-height: 96vh !important; }
}

/* ────────────────────────────────────────────────────────────
   PRINT — relatórios financeiros impressos
   ──────────────────────────────────────────────────────────── */
@media print {
  .sidebar,
  .topbar,
  .mobile-toggle,
  .sidebar-overlay,
  #leFab,
  .toast-container,
  #topSyncBar,
  .btn,
  button { display: none !important; }

  .main-wrapper { margin-left: 0 !important; }
  .page-container { padding: 0 !important; }
  .card { box-shadow: none !important; border: 1px solid #ddd !important; page-break-inside: avoid; }
  .data-table { font-size: 10px !important; }
  body { background: #fff !important; }
}
