/* ==========================================================================
   Portal do Fornecedor — Mapa de Vendas
   Identidade visual: Grupo Nordeste (usa tokens var(--ne-*) de cores.css)
   Regra de dominância 60-30-10: navy (fundo/topbar) · branco (respiro) · verde (acento)
   ========================================================================== */

* { box-sizing: border-box; }

html, body {
  margin: 0;
  padding: 0;
}

body {
  background: var(--ne-bg);
  color: var(--ne-text);
  font-family: var(--ne-font-body);
  font-size: 15px;
  line-height: 1.45;
  min-height: 100vh;
  display: flex;
  flex-direction: column;
}

h1, h2, h3, label, th, .brand-title, .ne-btn {
  font-family: var(--ne-font-heading);
}

/* ----------------------------------------------------------------- topbar */
.topbar {
  background: var(--ne-primary);
  color: var(--ne-text-on-dark);
  box-shadow: var(--ne-shadow);
}
.topbar-inner {
  max-width: 1180px;
  margin: 0 auto;
  height: 64px;
  padding: 0 24px;
  display: flex;
  align-items: center;
}
.brand {
  display: flex;
  align-items: center;
  gap: 14px;
  text-decoration: none;
  color: inherit;
}
.brand-logo { height: 34px; width: auto; display: block; }
.brand-divider {
  width: 1px;
  height: 26px;
  background: rgba(186, 229, 246, .35);
}
.brand-title {
  font-weight: 700;
  font-size: 1.05rem;
  color: #fff;
  letter-spacing: .2px;
}
.topuser {
  display: flex;
  align-items: center;
  gap: 12px;
  margin-left: auto;   /* empurra usuário + Sair para a direita */
}
.topuser-nome {
  color: var(--ne-text-on-dark);
  font-size: .88rem;
  font-weight: 600;
  max-width: 200px;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}
.logout-form { margin: 0; }
.btn-sair {
  font-family: var(--ne-font-heading);
  font-weight: 700;
  font-size: .82rem;
  text-transform: none;
  letter-spacing: .2px;
  color: var(--ne-text-on-dark);
  background: transparent;
  border: 1px solid rgba(186, 229, 246, .4);
  border-radius: 999px;
  padding: 6px 14px;
  cursor: pointer;
  transition: background .15s, color .15s;
}
.btn-sair:hover { background: rgba(186, 229, 246, .14); color: #fff; }
.topnav {
  display: flex;
  align-items: center;
  gap: 6px;
  margin-left: 28px;   /* links logo após a marca (à esquerda) */
}
.topnav a {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  font-family: var(--ne-font-heading);
  font-weight: 700;
  font-size: .9rem;
  letter-spacing: .2px;
  color: var(--ne-text-on-dark);
  text-decoration: none;
  padding: 8px 14px;
  border-radius: 9px;   /* igual ao botão Consultar (.ne-btn) */
  transition: background .15s, color .15s;
}
.nav-ico { width: 18px; height: 18px; flex: 0 0 auto; }
.topnav a:hover {
  color: #fff;
  background: rgba(186, 229, 246, .14);
}
.topnav a.active {
  color: var(--ne-primary);
  background: var(--ne-accent);
}
.topnav a.active:hover {
  background: var(--ne-accent-dark);
}

/* --------------------------------------------------------------- container */
.container {
  flex: 1;
  width: 100%;
  max-width: 1180px;
  margin: 0 auto;
  padding: 28px 24px 48px;
}

.page-head h1 {
  margin: 0 0 4px;
  font-size: 1.7rem;
  color: var(--ne-primary);
}
.page-head .subtitle {
  margin: 0 0 22px;
  color: var(--ne-text-muted);
}

/* -------------------------------------------------------------------- card */
.card {
  background: var(--ne-surface);
  border: 1px solid var(--ne-borda);
  border-radius: var(--ne-radius);
  box-shadow: var(--ne-shadow);
  padding: 20px;
  margin-bottom: 22px;
}

/* ----------------------------------------------------------------- filtros */
.filtros {
  display: grid;
  grid-template-columns: 1.4fr 1.4fr .8fr .8fr auto;
  gap: 16px;
  align-items: end;
}
.filtros-cad {
  grid-template-columns: 2fr 1fr;
}
.filtros-mapa {
  grid-template-columns: 1.3fr 1.5fr 1.5fr auto;
}
.field { display: flex; flex-direction: column; gap: 6px; }
.field label {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  font-size: .78rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: .4px;
  color: var(--ne-text-muted);
}
.field-ico { width: 15px; height: 15px; flex: 0 0 auto; }
/* ícones nos títulos (KPIs, título de associações e cabeçalhos de tabela) */
.kpi-label, .assoc-title { display: inline-flex; align-items: center; gap: 6px; }
.table th .field-ico { margin-right: 6px; vertical-align: -3px; }
.field select,
.field input[type="date"],
.field input[type="search"],
.field input[type="text"],
.field input[type="email"],
.field input[type="tel"],
.field input[type="password"],
.field input[type="number"] {
  font-family: var(--ne-font-body);
  font-size: .95rem;
  color: var(--ne-text);
  background: #fff;
  border: 1px solid var(--ne-borda);
  border-radius: 9px;
  padding: 11px 12px;
  width: 100%;
  transition: border-color .15s, box-shadow .15s;
}
.field select:focus,
.field input[type="date"]:focus,
.field input[type="search"]:focus,
.field input[type="text"]:focus,
.field input[type="email"]:focus,
.field input[type="tel"]:focus,
.field input[type="password"]:focus,
.field input[type="number"]:focus {
  outline: none;
  border-color: var(--ne-accent);
  box-shadow: 0 0 0 2px rgba(22, 214, 58, .35);
}
.field select:disabled {
  background: #f1f4f9;
  color: var(--ne-text-muted);
  cursor: not-allowed;
}
.field-action { align-self: end; }

/* -------------------------------------------------------- form de cadastro */
.pessoa-grid {
  display: grid;
  grid-template-columns: 1.3fr 1.3fr 1fr 1fr;
  gap: 16px;
  align-items: start;
}
.pessoa-grid-3 { grid-template-columns: 1.3fr 1.3fr 1fr; }
.filtros-logs { grid-template-columns: 1.4fr auto; }
.field .req { color: var(--ne-accent-dark); }
.field-hint { color: var(--ne-text-muted); font-size: .76rem; }

.assoc-section {
  margin-top: 18px;
  padding-top: 16px;
  border-top: 1px dashed var(--ne-borda);
}
.assoc-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: 12px;
}
.assoc-title {
  font-family: var(--ne-font-heading);
  font-weight: 700;
  font-size: .82rem;
  text-transform: uppercase;
  letter-spacing: .4px;
  color: var(--ne-text-muted);
}
.assoc-row {
  display: grid;
  grid-template-columns: 1fr 1fr auto;
  gap: 12px;
  align-items: end;
  margin-bottom: 10px;
}
.btn-sm { padding: 7px 12px; font-size: .82rem; }
#btn-export:not([hidden]) { display: inline-flex; align-items: center; gap: 8px; }
.ico-excel { width: 18px; height: 18px; flex: 0 0 auto; }

.form-actions {
  display: flex;
  align-items: center;
  gap: 10px;
  margin-top: 18px;
}
.status.inline { padding: 0 4px; }

/* chips de associação na tabela */
.assoc-chips { list-style: none; margin: 0; padding: 0; display: flex; flex-direction: column; gap: 4px; }
.assoc-chips li {
  background: var(--ne-bg);
  border: 1px solid var(--ne-borda);
  border-radius: 7px;
  padding: 3px 9px;
  font-size: .86rem;
  width: fit-content;
}
.assoc-chips .seta { color: var(--ne-accent-dark); font-weight: 700; }

/* ----------------------------------------------------------- botão (acento) */
.ne-btn {
  background: var(--ne-accent);
  color: var(--ne-primary);
  font-weight: 700;
  border: 0;
  border-radius: 9px;
  padding: 12px 1.6rem;
  cursor: pointer;
  font-size: .95rem;
  transition: background .15s, transform .05s;
  white-space: nowrap;
}
.ne-btn:hover { background: var(--ne-accent-dark); }
.ne-btn:active { transform: translateY(1px); }
.ne-btn:disabled { opacity: .55; cursor: progress; }
.ne-btn.ghost {
  background: transparent;
  color: var(--ne-text-muted);
  border: 1px solid var(--ne-borda);
}
.ne-btn.ghost:hover { background: var(--ne-bg); color: var(--ne-text); }

/* ações da tabela (editar/excluir) */
.acoes-col { white-space: nowrap; width: 1%; }
.btn-link {
  background: none;
  border: 0;
  cursor: pointer;
  font-family: var(--ne-font-heading);
  font-weight: 700;
  font-size: .82rem;
  color: var(--ne-verde-mangue);
  padding: 4px 8px;
  border-radius: 7px;
}
.btn-link:hover { background: var(--ne-verde-raso); }
.btn-link.danger { color: #b3261e; }
.btn-link.danger:hover { background: #fdecea; }

/* botões de ação só com ícone (tooltip nativo via title=) */
.icon-btn {
  background: none;
  border: 0;
  cursor: pointer;
  padding: 6px;
  margin: 0 1px;
  border-radius: 7px;
  line-height: 0;
  color: var(--ne-primary);
  vertical-align: middle;
}
.icon-btn:hover { background: var(--ne-verde-raso); }
.icon-btn.danger { color: #b3261e; }
.icon-btn.danger:hover { background: #fdecea; }
.icon-btn svg { width: 18px; height: 18px; pointer-events: none; }
.icon-btn:disabled { opacity: .35; cursor: not-allowed; }
.icon-btn:disabled:hover { background: none; }

/* ------------------------------------------------------------------- resumo */
.resumo {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 16px;
  margin-bottom: 22px;
}
.kpi {
  background: var(--ne-surface);
  border: 1px solid var(--ne-borda);
  border-left: 4px solid var(--ne-accent);
  border-radius: var(--ne-radius);
  box-shadow: var(--ne-shadow);
  padding: 14px 18px;
  display: flex;
  flex-direction: column;
  gap: 4px;
}
.kpi-label {
  font-size: .75rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: .5px;
  color: var(--ne-text-muted);
}
.kpi-value {
  font-family: var(--ne-font-display);
  font-size: 1.5rem;
  font-weight: 800;
  color: var(--ne-primary);
}

/* ------------------------------------------------------------------- tabela */
.card-head {
  display: flex;
  justify-content: flex-end;
  margin-bottom: 8px;
}
.status {
  color: var(--ne-text-muted);
  padding: 8px 2px;
}
.status.error { color: #b3261e; font-weight: 600; }
.table-wrap { overflow-x: auto; }
.table {
  width: 100%;
  border-collapse: collapse;
  font-size: .93rem;
}
.table thead th {
  text-align: left;
  font-size: .76rem;
  text-transform: uppercase;
  letter-spacing: .4px;
  color: var(--ne-text-on-dark);
  background: var(--ne-primary);
  padding: 11px 12px;
  position: sticky;
  top: 0;
}
.table thead th:first-child { border-top-left-radius: 8px; }
.table thead th:last-child { border-top-right-radius: 8px; }
.table tbody td {
  padding: 10px 12px;
  border-bottom: 1px solid var(--ne-borda);
}
.table tbody tr:nth-child(even) { background: #fafcff; }
.table tbody tr:hover { background: var(--ne-verde-raso); }
.table .num { text-align: right; font-variant-numeric: tabular-nums; }
.table tfoot td {
  padding: 12px;
  font-weight: 800;
  color: var(--ne-primary);
  border-top: 2px solid var(--ne-accent);
}
.ean-empty { color: var(--ne-text-muted); font-style: italic; }

/* ------------------------------------------------ mapa de vendas (por mês) */
.periodo-cap { color: var(--ne-text-muted); font-size: .92em; }
.table-mapa .uf { color: var(--ne-text-muted); font-weight: 400; font-size: .9em; }
.table-mapa thead th small { font-weight: 400; opacity: .85; }
/* destaque do mês atual */
.table-mapa thead th.mes-atual { box-shadow: inset 0 -3px 0 var(--ne-accent); }
.table-mapa td.mes-atual { background: rgba(22, 214, 58, .10); }
.table-mapa tbody tr:hover td.mes-atual { background: rgba(22, 214, 58, .18); }
/* colunas de estoque (atual / trânsito / pulmão) */
.table-mapa .estoque-col { background: rgba(186, 229, 246, .14); }
.table-mapa thead th.estoque-col { box-shadow: inset 0 -3px 0 var(--ne-azul-amanhecer); }
.table-mapa tbody tr:hover td.estoque-col { background: rgba(186, 229, 246, .28); }
.table-mapa td.estoque-col:nth-of-type(6) { border-right: 2px solid var(--ne-borda); }
/* coluna de média */
.table-mapa .media-col { border-left: 2px solid var(--ne-borda); }
.table-mapa thead th.media-col { border-left-color: rgba(186, 229, 246, .35); }
.table-mapa td.media-col { font-weight: 700; color: var(--ne-primary); }
.table-mapa tfoot td.media-col { color: var(--ne-primary); }

/* ---------------------------------------------------------------- mensagens */
.flash {
  border-radius: var(--ne-radius);
  padding: 12px 16px;
  margin-bottom: 18px;
  font-weight: 600;
  border: 1px solid transparent;
}
.flash-error { background: #fdecea; color: #b3261e; border-color: #f5c6c0; }
.flash-success { background: var(--ne-verde-raso); color: var(--ne-verde-mangue); }
.flash-warning { background: #fff7e0; color: #8a6d00; border-color: #ffe8a3; }

/* --------------------------------------------------- senha provisória gerada */
.senha-box { border-left: 4px solid var(--ne-accent); margin-bottom: 18px; }
.senha-box-head { display: flex; justify-content: space-between; align-items: center; }
.senha-box-row { display: flex; align-items: center; gap: 10px; flex-wrap: wrap; margin-top: 8px; }
.senha-box-alvo { color: var(--ne-text-muted); font-weight: 600; }
#senha-box-val {
  font-family: ui-monospace, "Cascadia Code", Consolas, monospace;
  font-size: 1.05rem;
  background: var(--ne-bg);
  border: 1px solid var(--ne-borda);
  border-radius: 7px;
  padding: 6px 12px;
  letter-spacing: 1px;
  user-select: all;
}

/* -------------------------------------------------------------------- login */
.auth-wrap {
  min-height: 60vh;
  display: flex;
  align-items: center;
  justify-content: center;
}
.auth-card {
  width: 100%;
  max-width: 380px;
  display: flex;
  flex-direction: column;
  gap: 14px;
}
.auth-card h1 { margin: 0; color: var(--ne-primary); font-size: 1.5rem; }
.auth-logo { width: 170px; max-width: 70%; height: auto; align-self: center; margin: 4px 0 8px; }
.auth-card .subtitle { margin: 0 0 6px; text-align: center; }
.auth-btn { width: 100%; margin-top: 4px; }
.auth-alt { color: var(--ne-text-muted); font-size: .85rem; text-align: center; margin: 4px 0 0; }

/* --------------------------------------------------------------------- logs */
.pagination {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 16px;
  margin-top: 16px;
}
.pag-info { color: var(--ne-text-muted); font-size: .88rem; }
.badge-evt {
  display: inline-block;
  font-size: .76rem;
  font-weight: 700;
  padding: 3px 9px;
  border-radius: 999px;
  background: var(--ne-bg);
  border: 1px solid var(--ne-borda);
  color: var(--ne-text);
}
.badge-evt.evt-login_ok { background: var(--ne-verde-raso); color: var(--ne-verde-mangue); border-color: transparent; }
.badge-evt.evt-login_falha,
.badge-evt.evt-login_bloqueado { background: #fdecea; color: #b3261e; border-color: transparent; }
.badge-evt.evt-logout { background: var(--ne-azul-amanhecer); color: var(--ne-primary); border-color: transparent; }
.table .kv { list-style: none; margin: 6px 0 0; padding: 0; display: flex; flex-direction: column; gap: 2px; }
.table .kv li { font-size: .84rem; }
.table details summary { cursor: pointer; }

/* ------------------------------------------------------------------- footer */
.footer {
  background: var(--ne-primary);
  color: var(--ne-text-on-dark);
  text-align: center;
  font-size: .82rem;
  padding: 16px 24px;
}

/* ---------------------------------------------------------------- responsivo */
@media (max-width: 860px) {
  .filtros { grid-template-columns: 1fr 1fr; }
  .field-action { grid-column: 1 / -1; }
  .field-action .ne-btn { width: 100%; }
  .resumo { grid-template-columns: 1fr; }
}
