:root{
  --muted:#8ea0c4;
  --text:#eaf0ff;
  --accent:#ffd100;
  --ok:#38d39f;
  --warn:#ffb020;
  --bad:#ff5d5d;
  --input:#0e1730;
}

*{box-sizing:border-box}

body{
  margin:0;
  background:linear-gradient(180deg,#071029 0%, #050816 100%);
  color:var(--text);
  font-family: ui-sans-serif, system-ui, -apple-system, Segoe UI, Roboto, Arial, "Noto Sans", "Helvetica Neue", sans-serif;
}

.topbar{
  padding:18px 20px;
  border-bottom:1px solid rgba(255,255,255,0.06);
  background:rgba(0,0,0,0.15);
  position:sticky; top:0; backdrop-filter: blur(8px);
  z-index:10;
}

.container{
  padding:18px 20px;
  max-width: 1400px; /* ou remove totalmente */
  min-width: 1000px;
  margin: 0 auto;
}

.row{display:flex; gap:12px; flex-wrap:wrap; align-items:center}

.brand{
  display:flex; gap:10px; align-items:center; margin-right:auto;
  font-weight:700; letter-spacing:.2px;
}
.brandDot{
  width:14px;height:14px;border-radius:5px;
  background:var(--accent);
  box-shadow:0 0 0 3px rgba(255,209,0,0.18)
}
.brandDot.small{width:12px;height:12px;border-radius:4px; box-shadow:none}

.badge{
  font-size:12px; color:#111; background:var(--accent);
  padding:3px 8px; border-radius:999px; font-weight:800;
}

.statusPill{
  font-size:12px;
  padding:6px 10px;
  border-radius:999px;
  border:1px solid rgba(255,255,255,0.12);
  background:rgba(255,255,255,0.06);
  color:var(--muted);
}

.btn{
  border:1px solid rgba(255,255,255,0.12);
  background:rgba(255,255,255,0.06);
  color:var(--text);
  padding:10px 12px;
  border-radius:12px;
  cursor:pointer;
  transition:.15s ease;
  font-weight:650;
}
.btn:hover{transform:translateY(-1px); border-color:rgba(255,255,255,0.2)}
.btn.primary{background:rgba(255,209,0,0.16); border-color:rgba(255,209,0,0.5)}
.btn.danger{background:rgba(255,93,93,0.12); border-color:rgba(255,93,93,0.35)}
.btn.ok{background:rgba(56,211,159,0.12); border-color:rgba(56,211,159,0.35)}

.card{
  border: 1px solid rgba(255,255,255,0.12);
  border-radius: 14px;

  /* mais respiro lateral */
  padding: 16px 22px;

  background: rgba(255,255,255,0.04);
}


.field{display:flex; flex-direction:column; gap:6px; min-width:0}
label{font-size:12px; color:var(--muted)}

input, select, textarea{
  width:100%;
  border-radius:12px;
  border:1px solid rgba(255,255,255,0.12);
  background:var(--input);
  color:var(--text);
  outline:none;
}

input, select{
  height:42px;
  padding:10px 12px;
}

textarea{
  min-height:80px;
  resize:vertical;
  padding:10px 12px;
}

input::placeholder{opacity:.7}

.grid{
  display:grid;
  grid-template-columns: 1fr 1fr;
  gap:14px;
}
/* ESSENCIAL: impede que conteúdo largo (tabelas) estoure a coluna do grid */
.grid2 > .panel{
  min-width: 0;
}

@media (max-width: 980px){
  .grid{grid-template-columns:1fr}
}

/* filtros alinhados */
.filters{
  padding:12px;
  display:grid;
  grid-template-columns:
    2.4fr   /* Busca */
    1fr     /* Corretor */
    1fr     /* Tipo de venda */
    1.2fr   /* Empreendimento */
    0.8fr   /* Status */
    0.9fr   /* De */
    0.9fr;  /* Até */
  gap:10px;
  margin-bottom:14px;
  align-items:end;
}

.filters label{
  min-height:32px;
  display:flex;
  align-items:flex-end;
  line-height:1.15;
}
@media (max-width: 980px){
  .filters{grid-template-columns:1fr 1fr; align-items:end;}
  .filters label{min-height:32px;}
}

.statsRow{
  margin:12px 2px 10px 2px;
  justify-content:space-between;
}

.muted{color:var(--muted)}
.small{font-size:12px}
.mono{font-family: ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", monospace;}

.card .top{
  padding:14px 14px 10px 14px;
  border-bottom:1px dashed rgba(255,255,255,0.12);
  display:flex; gap:10px; align-items:flex-start; flex-wrap:wrap;
}
.title{font-weight:850; letter-spacing:.2px; font-size:16px}
.sub{color:var(--muted); font-size:12px}

.chips{display:flex; gap:8px; flex-wrap:wrap; margin-left:auto}
.chip{
  background:rgba(255,255,255,0.06);
  border:1px solid rgba(255,255,255,0.10);
  color:var(--text);
  padding:6px 9px;
  border-radius:999px;
  font-size:12px;
  font-weight:650;
}
.chip.ok{border-color:rgba(56,211,159,0.35); background:rgba(56,211,159,0.08)}
.chip.warn{border-color:rgba(255,176,32,0.35); background:rgba(255,176,32,0.08)}
.chip.bad{border-color:rgba(255,93,93,0.35); background:rgba(255,93,93,0.08)}

.body{padding:12px 14px 14px 14px}

.kv{
  display:grid;
  grid-template-columns: 1fr 1fr;
  gap:10px;
  margin-bottom:12px;
}
.kv .box{
  background:rgba(0,0,0,0.18);
  border:1px solid rgba(255,255,255,0.08);
  border-radius:14px;
  padding:10px;
}
.k{font-size:11px; color:var(--muted)}
.v{font-size:14px; font-weight:750; margin-top:2px}
.money{font-variant-numeric: tabular-nums}

.section{
  margin-top:10px;
  border-top:1px solid rgba(255,255,255,0.08);
  padding-top:10px;
}
.section h4{
  margin:0 0 8px 0;
  font-size:13px;
  color:#d7e1ff;
  letter-spacing:.2px;
}

table{
  width:100%;
  border-collapse:collapse;
  font-size:12.5px;
  overflow:hidden;
  border-radius:12px;
}
th, td{
  border-bottom:1px solid rgba(255,255,255,0.08);
  padding:8px;
  text-align:left;
  vertical-align:top;
}
th{color:var(--muted); font-weight:800}
tr:last-child td{border-bottom:none}
.right{text-align:right}

.actions{display:flex; gap:8px; flex-wrap:wrap; margin-top:10px}

.modal-backdrop{
  position:fixed; inset:0;
  background:rgba(0,0,0,0.55);
  display:none;
  align-items:center; justify-content:center;
  padding:18px;
  z-index:50;
}
.modal{
  width:min(980px, 100%);
  background:linear-gradient(180deg, #0b1430, #08102a);
  border:1px solid rgba(255,255,255,0.12);
  border-radius:18px;
  box-shadow: 0 25px 60px rgba(0,0,0,0.55);
  overflow:hidden;
}
.modalHeader{
  border-bottom:1px solid rgba(255,255,255,0.08);
  background:rgba(255,255,255,0.03);
  padding:18px 20px;
}
.modalBrand{margin-right:auto}
.content{padding:14px}

.form-grid{
  display:grid;
  grid-template-columns: 1fr 1fr 1fr;
  gap:10px;
}
@media (max-width:980px){ .form-grid{grid-template-columns:1fr} }

.two{grid-column: span 2}
.three{grid-column: span 3}
.linesGrid{margin-bottom:10px}

.footer{
  margin-top:12px;
  display:flex; gap:10px; flex-wrap:wrap; align-items:center; justify-content:space-between;
  border-top:1px solid rgba(255,255,255,0.08);
  padding-top:12px;
}

/* ====== Checklist de documentação (modal) ====== */
.docsSection{
  margin-top:12px;
  border:1px solid rgba(255,255,255,0.10);
  border-radius:14px;
  background:rgba(255,255,255,0.03);
  padding:12px;
}
.docsHead{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:10px;
  margin-bottom:10px;
}
.docsTitle{
  font-weight:700;
  color:#d7e1ff;
}
.docsList{
  display:grid;
  grid-template-columns: 1fr 1fr;
  gap:8px 14px;
}
@media (max-width:980px){
  .docsList{grid-template-columns:1fr}
}
.docsItem{
  display:flex;
  align-items:center;
  gap:12px;
  padding:8px 12px;
  border:1px solid rgba(255,255,255,0.08);
  border-radius:12px;
  background:rgba(0,0,0,0.12);
}

/* Checkbox menor e mais discreto */
.docsItem input[type="checkbox"]{
  width:14px;
  height:14px;
  margin:0;
  accent-color:#7da6ff; /* mantém coerência com o tema */
  flex:0 0 auto;
}

/* Texto do documento ganha protagonismo */
.docsItem .small{
  font-size:13px;
  line-height:1.25;
  color:#e7ecff;
}

.docsItem:hover{
  background:rgba(125,166,255,0.08);
  border-color:rgba(125,166,255,0.25);
}


/* Status + indicador de docs pendentes */
.statusStack{
  display:inline-flex;
  gap:6px;
  align-items:center;
  justify-content:center;
  flex-wrap:wrap;
}
.docsPendChip{white-space:nowrap}


/* select compacto dentro da tabela */
table select{
  height:32px;
  padding:6px 10px;
  border-radius:10px;
}

.note{margin-top:10px}

/* ====== LISTA RESUMIDA (accordion) ====== */
.listWrap{
  display:flex;
  flex-direction:column;
  gap:10px;
}

.listHeader, .listRow{
  display:grid;
  grid-template-columns:
    90px          /* Nº */
    1.3fr         /* Empreendimento */
    1fr           /* Unidade */
    160px         /* Valor venda */
    170px         /* Comissão bruta */
    140px         /* Corretor */
    140px         /* Cliente */
    170px         /* Fonte */
    150px         /* Repasses */
    120px;        /* Status venda */
  gap:10px;
  align-items:center;
}

.listHeader{
  padding:10px 12px;
  border-radius:14px;
  border:1px solid rgba(255,255,255,0.10);
  background:rgba(255,255,255,0.04);
  color:var(--muted);
  font-size:12px;
  font-weight:800;
}

.listRow{
  padding:12px 12px;
  border-radius:16px;
  border:1px solid rgba(255,255,255,0.10);
  background:rgba(255,255,255,0.04);
  cursor:pointer;
  transition:.12s ease;
}
.listRow:hover{
  transform:translateY(-1px);
  border-color:rgba(255,255,255,0.18);
}

.listCell{
  min-width:0;
  overflow:hidden;
  text-overflow:ellipsis;
  white-space:nowrap;
  font-size:13px;
}

.listMoney{
  text-align:right;
  font-variant-numeric: tabular-nums;
  font-weight:750;
}

.expandPanel{
  margin-top:10px;
  padding:12px;
  border-radius:16px;
  border:1px solid rgba(255,255,255,0.10);
  background:linear-gradient(180deg, rgba(255,255,255,0.05), rgba(255,255,255,0.03));
}

.expandTop{
  display:flex;
  justify-content:flex-end;
  margin-bottom:8px;
}

@media (max-width: 1200px){
  .listHeader, .listRow{
  grid-template-columns: 90px 1.3fr 1fr 160px 170px 140px 140px 170px 150px 150px;
}

}

@media (max-width: 980px){
  /* no mobile vira “duas linhas” de grid simplificado */
  .listHeader{ display:none; }
  .listRow{
    grid-template-columns: 1fr 1fr;
    gap:8px 10px;
    align-items:start;
  }
  .listCell{ white-space:normal; }
  .listMoney{ text-align:left; }
}

/* Evita chip estourar as colunas na lista */
.listRow .listCell{
  min-width: 0;               /* essencial p/ grid cortar corretamente */
  overflow: hidden;
}

.listRow .chip,
.listRow [class*="chip"]{
  max-width: 100% !important;
  min-width: 0 !important;
  overflow: hidden !important;
  text-overflow: ellipsis !important;
  white-space: nowrap !important;
  display: inline-block !important;  /* troca inline-flex se existir no tema */
}


.listRow .listCell:nth-child(9) .chip,
.listRow .listCell:nth-child(10) .chip{
  max-width: 100%;
}



/* ====== LISTA EM TABELA (Opção B) ====== */
.tableWrap {
  width: 100%;
  max-width: 90vw;          /* 👈 limite visual */
  margin: 0 auto;
  overflow-x: auto;         /* 👈 scroll só se passar */
  padding-bottom: 4px;      /* evita cortar sombra */
}

.tableWrapY .salesTable thead th{
  top: 0;
}

.salesTable{
  width: max-content;     /* ✅ cresce conforme o conteúdo */
  min-width: 100%;        /* ✅ nunca menor que o container */
  border-collapse:separate;
  border-spacing:0 10px;  /* espaçamento entre linhas */
  font-size:13px;
}


.salesTable thead th{
  position:sticky;
  top:0;
  z-index:2;
  text-align:left;
  padding:10px 12px;
  color:var(--muted);
  font-weight:800;
  background:rgba(255,255,255,0.04);
  border:1px solid rgba(255,255,255,0.10);
}

.salesTable thead th.sortable{
  cursor: pointer;
  user-select: none;
}

.salesTable thead th.sortable:hover{
  border-color: rgba(255,255,255,0.22);
  background: rgba(255,255,255,0.06);
}


.salesTable thead th:first-child{border-top-left-radius:14px; border-bottom-left-radius:14px;}
.salesTable thead th:last-child{border-top-right-radius:14px; border-bottom-right-radius:14px;}

.salesTable tbody tr.dataRow td{
  padding:14px 12px;
  background:rgba(255,255,255,0.04);
  border-top:1px solid rgba(255,255,255,0.10);
  border-bottom:1px solid rgba(255,255,255,0.10);
  vertical-align:middle;
}

.salesTable tbody tr.dataRow td:first-child{
  border-left:1px solid rgba(255,255,255,0.10);
  border-top-left-radius:16px;
  border-bottom-left-radius:16px;
  font-weight:850;
}
.salesTable tbody tr.dataRow td:last-child{
  border-right:1px solid rgba(255,255,255,0.10);
  border-top-right-radius:16px;
  border-bottom-right-radius:16px;
}

.salesTable tbody tr.dataRow{
  cursor:pointer;
  transition:.12s ease;
}
.salesTable tbody tr.dataRow:hover td{
  border-color:rgba(255,255,255,0.18);
  transform:translateY(-1px);
}

.salesTable .nowrap{white-space:nowrap}
@media (max-width: 1200px){
  .salesTable .ellipsis{ max-width: 260px; }
}
@media (min-width: 1201px){
  .salesTable .ellipsis{ max-width: 520px; }
}

.salesTable .money{
  text-align:right;
  font-variant-numeric:tabular-nums;
  font-weight:750;
}
.salesTable .center{text-align:center}

.salesTable .chip{
  max-width: 140px;
  overflow:hidden;
  text-overflow:ellipsis;
  white-space:nowrap;
  display:inline-block;
}

/* Linha expandida */
.salesTable tr.expandRow td{
  padding:0;
  border:none;
}
.salesExpandPanel{
  margin-top:-2px;
  padding:12px;
  border-radius:16px;
  border:1px solid rgba(255,255,255,0.10);
  background:linear-gradient(180deg, rgba(255,255,255,0.05), rgba(255,255,255,0.03));
}

.salesExpandTop{
  display:flex;
  justify-content:flex-end;
  margin-bottom:8px;
}

/* ===== Modal: limitar altura e permitir scroll interno ===== */
.modal-backdrop{
  align-items: center;          /* garante centralização vertical */
  justify-content: center;
  overflow: hidden;             /* evita scroll no backdrop */
}

/* Limita altura total da modal */
.modal{
  max-height: calc(100vh - 32px);  /* margem em cima/baixo */
  display: flex;
  flex-direction: column;
}

/* Header e footer sempre visíveis (não somem com o scroll) */
.modalHeader{
  flex: 0 0 auto;
}

/* O miolo rola */
.modal .content{
  flex: 1 1 auto;
  overflow-y: auto;
  overscroll-behavior: contain;
}

/* Deixa o rodapé “fixo” no fim da modal */
.modal .footer{
  flex: 0 0 auto;
  position: sticky;
  bottom: 0;
  background: linear-gradient(180deg, rgba(11,20,48,0.65), rgba(8,16,42,0.95));
  backdrop-filter: blur(8px);
  padding: 12px 14px;
  margin-top: 0;
  border-top: 1px solid rgba(255,255,255,0.08);
}

/* ===== Dropdown técnico (oculto) ===== */
.dropdown{
  position: relative;
}

.dropdown-menu{
  position: absolute;
  top: 110%;
  right: 0;
  min-width: 180px;
  display: none;
  flex-direction: column;
  gap: 6px;
  padding: 8px;
  border-radius: 12px;
  background: linear-gradient(180deg, #0b1430, #08102a);
  border: 1px solid rgba(255,255,255,0.12);
  box-shadow: 0 10px 30px rgba(0,0,0,0.4);
  z-index: 20;
}

.dropdown-menu hr{
  border: none;
  height: 1px;
  background: rgba(255,255,255,0.08);
  margin: 6px 0;
}

.dropdown.open .dropdown-menu{
  display: flex;
}

/* ===== Relatórios (relatorios.html) ===== */

/* painel (usado como “card” com padding) */
.panel{
  background:linear-gradient(180deg, rgba(255,255,255,0.05), rgba(255,255,255,0.03));
  border:1px solid rgba(255,255,255,0.10);
  border-radius:18px;
  box-shadow: 0 10px 30px rgba(0,0,0,0.25);
  padding:14px;
  min-width: 0;
}

/* título de painéis */
.panelTitle{
  font-weight:850;
  letter-spacing:.2px;
  margin-bottom:10px;
}

/* KPIs */
.big{
  font-size:22px;
  font-weight:800;
  margin-top:6px;
}

/* grids específicos dos relatórios (não mexe na sua .grid atual) */
#kpis.grid{
  display:grid;
  grid-template-columns: repeat(4, minmax(200px, 1fr));
  gap:12px;
}

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

/* inputs/labels usados em relatorios.html */
.label{
  font-size:12px;
  color:var(--muted);
  margin-bottom:6px;
}
.input{
  width:100%;
  border-radius:12px;
  border:1px solid rgba(255,255,255,0.12);
  background:var(--input);
  color:var(--text);
  outline:none;
  height:42px;
  padding:10px 12px;
}

/* responsivo */
@media (max-width: 1100px){
  #kpis.grid{ grid-template-columns: repeat(2, minmax(200px, 1fr)); }
  .grid2{ grid-template-columns: 1fr; }
}

/* Scroll interno (altura FIXA para alinhar as scrollbars) */
.tableWrapY{
  height: 360px;              /* <- FIXO: alinha as barras entre tabelas */
  overflow-y: hidden;
  padding-bottom: 0 !important;
  scrollbar-gutter: stable;
  border-radius: 12px;
}

/* Ativa o scroll interno só quando “armado” */
.tableWrapY.isScrollActive{
  overflow: auto;
}

/* ===== Estética Evolução mensal ===== */

/* Scrollbar “dark” (Chrome/Edge/Safari) */
#wrapEvolucaoMensal.tableWrapY::-webkit-scrollbar{
  width: 10px;
}
#wrapEvolucaoMensal.tableWrapY::-webkit-scrollbar-track{
  background: rgba(255,255,255,0.06);
  border-radius: 999px;
}
#wrapEvolucaoMensal.tableWrapY::-webkit-scrollbar-thumb{
  background: rgba(0, 200, 255, 0.28);
  border-radius: 999px;
  border: 2px solid rgba(0,0,0,0.35);
}
#wrapEvolucaoMensal.tableWrapY::-webkit-scrollbar-thumb:hover{
  background: rgba(0, 200, 255, 0.40);
}

/* Scrollbar (Firefox) */
#wrapEvolucaoMensal.tableWrapY{
  scrollbar-width: thin;
  scrollbar-color: rgba(0, 200, 255, 0.28) rgba(255,255,255,0.06);
}

/* Linha do mês atual */
.salesTable tbody tr.isCurrentMonth td{
  background: rgba(0, 200, 255, 0.08);
}

/* Apenas a CÉLULA de Previsto quando > 0 */
.salesTable tbody td.hasPrevistoCell{
  background: rgba(255, 180, 0, 0.10);
  border-radius: 10px;
}

/* Se for mês atual, mantém a linha azul, e o previsto ganha um pouco mais de contraste */
.salesTable tbody tr.isCurrentMonth td.hasPrevistoCell{
  background: rgba(255, 180, 0, 0.14);
}

/* Scrollbar “dark” também nas novas tabelas */
#wrapReceberMeses.tableWrapY::-webkit-scrollbar,
#wrapParcelasAbertas.tableWrapY::-webkit-scrollbar{
  width: 10px;
}
#wrapReceberMeses.tableWrapY::-webkit-scrollbar-track,
#wrapParcelasAbertas.tableWrapY::-webkit-scrollbar-track{
  background: rgba(255,255,255,0.06);
  border-radius: 999px;
}
#wrapReceberMeses.tableWrapY::-webkit-scrollbar-thumb,
#wrapParcelasAbertas.tableWrapY::-webkit-scrollbar-thumb{
  background: rgba(0, 200, 255, 0.28);
  border-radius: 999px;
  border: 2px solid rgba(0,0,0,0.35);
}
#wrapReceberMeses.tableWrapY::-webkit-scrollbar-thumb:hover,
#wrapParcelasAbertas.tableWrapY::-webkit-scrollbar-thumb:hover{
  background: rgba(0, 200, 255, 0.40);
}

/* Firefox */
#wrapReceberMeses.tableWrapY,
#wrapParcelasAbertas.tableWrapY{
  scrollbar-width: thin;
  scrollbar-color: rgba(0, 200, 255, 0.28) rgba(255,255,255,0.06);
}

/* Destaque parcelas próximas (3 dias) */
.salesTable tbody tr.dueSoon td{
  background: rgba(255, 80, 80, 0.10);
}

/* Parcelas vencidas */
.salesTable tbody tr.overdue td{
  background: rgba(255, 60, 60, 0.22);
  color: #ffd6d6;
}

/* reforça o valor */
.salesTable tbody tr.overdue td:last-child{
  font-weight: 900;
}


/* Tooltip de venda (parcelas em aberto) */
#saleTooltip{
  position: fixed;
  z-index: 9999;
  min-width: 260px;
  max-width: 340px;
  padding: 12px 12px;
  border-radius: 14px;
  border: 1px solid rgba(255,255,255,0.14);
  background: rgba(8, 12, 20, 0.94);
  box-shadow: 0 18px 45px rgba(0,0,0,0.45);
  backdrop-filter: blur(10px);
  pointer-events: none;
}

#saleTooltip .ttTitle{
  font-weight: 900;
  margin-bottom: 8px;
  color: rgba(255,255,255,0.95);
}

#saleTooltip .ttRow{
  display: flex;
  gap: 8px;
  align-items: baseline;
  line-height: 1.35;
  margin-top: 4px;
}

#saleTooltip .ttRow span{
  color: rgba(255,255,255,0.65);
  min-width: 120px;
}

#saleTooltip .ttRow b{
  color: rgba(255,255,255,0.92);
}

/* só pra dar “cara” de interativo */
.salesTable tbody tr.parcelRow:hover td{
  background: rgba(255,255,255,0.05);
}

/* ===== Alinhamento vertical das scrollbars ===== */

/* Painéis que possuem tabela com scroll */
.panel{
  display: flex;
  flex-direction: column;
}

/* Título sempre ocupa a mesma altura */
.panelTitle{
  min-height: 34px;
  display: flex;
  align-items: center;
}

/* Wrapper da tabela NÃO encolhe (mantém a altura fixa e alinha scrollbars) */
.panel .tableWrapY{
  flex: 0 0 360px;
}

/* Texto auxiliar (ex.: destaque) não empurra a scrollbar */
.panel .muted{
  min-height: 22px;
  margin-top: 6px;
}

/* ===== Cabeçalho fixo (sticky) nas tabelas com scroll vertical ===== */
.tableWrapY .salesTable thead th{
  position: sticky;
  top: 0;
  z-index: 5;
  background: rgba(10, 16, 28, 0.98);  /* combina com seu tema */
  backdrop-filter: blur(10px);
}

/* linha separadora do cabeçalho (pra ficar bem definido) */
.tableWrapY .salesTable thead tr{
  box-shadow: 0 1px 0 rgba(255,255,255,0.10);
}

/* ===== Cabeçalho fixo (sticky) dentro dos wrappers com scroll ===== */
.tableWrapY{
  position: relative; /* cria referência estável pro sticky */
}

.tableWrapY .salesTable thead{
  position: sticky;
  top: 0;
  z-index: 20;
}

.tableWrapY .salesTable thead th{
  position: sticky;
  top: 0;
  z-index: 21;
  background: rgba(255,255,255,0.04); /* mesmo background que você já usa hoje */
}

.tableWrapY .salesTable{
  border-spacing: 0; /* melhora compatibilidade do sticky */
}
.tableWrapY .salesTable tbody tr td{
  /* mantém o “respiro” entre linhas sem border-spacing */
  padding-top: 14px;
  padding-bottom: 14px;
}


/* ===== Drill-down (detalhes) ===== */
.drillRow{
  cursor: pointer;
}
.drillRow:hover td{
  background: rgba(255,255,255,0.05);
}

.drilldownBox{
  margin-top: 10px;
  padding: 12px;
  border-radius: 14px;
  border: 1px solid rgba(255,255,255,0.10);
  background: rgba(255,255,255,0.03);
}

.drilldownBox .drillTitle{
  font-weight: 900;
  margin-bottom: 10px;
}

.drilldownBox .tableWrap{
  overflow-x: auto;
}

/* ===== Botão fechar (drill-down) ===== */
.drilldownHeader{
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: 10px;
}

.drilldownHeader .drillTitle{
  margin: 0;
}

.drilldownClose{
  cursor: pointer;
  font-size: 18px;
  font-weight: 900;
  line-height: 1;
  padding: 4px 8px;
  border-radius: 8px;
  color: rgba(255,255,255,0.75);
}

.drilldownClose:hover{
  background: rgba(255,255,255,0.08);
  color: #fff;
}

/* ===== Drill-down: não estourar largura da tabela mãe ===== */
.drilldownBox{
  max-width: 100%;
  overflow-x: auto;          /* scroll horizontal SÓ no drill-down */
}

/* garante que a tabela interna possa ser maior sem quebrar o layout */
.drilldownBox .salesTable{
  min-width: 900px;          /* ajuste se quiser mais/menos colunas visíveis */
}

/* scrollbar horizontal dark (mesmo tema) */
.drilldownBox::-webkit-scrollbar{
  height: 10px;
}
.drilldownBox::-webkit-scrollbar-track{
  background: rgba(255,255,255,0.06);
  border-radius: 999px;
}
.drilldownBox::-webkit-scrollbar-thumb{
  background: rgba(0, 200, 255, 0.28);
  border-radius: 999px;
}
.drilldownBox::-webkit-scrollbar-thumb:hover{
  background: rgba(0, 200, 255, 0.40);
}

/* Firefox */
.drilldownBox{
  scrollbar-width: thin;
  scrollbar-color: rgba(0, 200, 255, 0.28) rgba(255,255,255,0.06);
}

.panel .tableWrap{
  max-width: 100%;
  overflow-x: auto;
}

/* Drilldown: wrapper deve respeitar o tamanho do painel, não 90vw */
.drilldownBox .tableWrap{
  max-width: 100% !important;
  margin: 0 !important;
  min-width: 0;
}

.btnFilter{
  padding:6px 10px;
  font-size:12px;
  font-weight:600;
  background:rgba(255,255,255,0.04);
  border:1px solid rgba(255,255,255,0.10);
}

.btnFilter:hover{
  background:rgba(255,255,255,0.08);
}

/* força largura mínima da aplicação */
body {
  min-width: 1000px;
}

/* garante scroll horizontal quando necessário */
html, body {
  overflow-x: auto;
}

.wrapper {
  min-width: 1000px;
}

.btnSoon{
  opacity: .55;
  filter: grayscale(.15);
}

.btnSoon:hover{
  transform: none;
  border-color: rgba(255,255,255,0.12);
}

.btnSoon::after{
  content: " • em breve";
  font-size: 11px;
  opacity: .9;
}