/* ================================================================
   nmark-dashboard — componentes (consomem SÓ tokens semânticos da Camada 2).
   Base de tokens em tokens.css (design system interno Resorts.com.br §15).
   Funciona em [data-theme="light"|"dark"] sem ajuste manual.
   ================================================================ */

a { color: var(--text-link); text-decoration: none; }
a:hover { text-decoration: underline; }
::selection { background: var(--selection-bg); }

/* ---------------- shell ---------------- */
.app { min-height: 100vh; display: flex; flex-direction: column; }

.topbar {
  position: sticky; top: 0; z-index: var(--z-sticky);
  display: flex; align-items: center; gap: var(--space-4);
  padding: var(--space-3) var(--space-6);
  background: var(--surface-raised);
  border-bottom: 1px solid var(--border-subtle);
}
.topbar .brand {
  font-size: var(--text-lg); font-weight: var(--weight-semibold);
  color: var(--text-primary); letter-spacing: var(--tracking-tight);
  display: inline-flex; align-items: center; gap: var(--space-2);
}
.topbar .brand .dot {
  width: 8px; height: 8px; border-radius: var(--radius-full);
  background: var(--brand-accent); display: inline-block;
}
.topbar .brand .sub { color: var(--text-tertiary); font-weight: var(--weight-regular); }
.topbar-spacer { flex: 1; }
.topbar-actions { display: flex; align-items: center; gap: var(--space-3); }
.topbar .meta { color: var(--text-tertiary); font-size: var(--text-xs); }
.topbar .user { color: var(--text-secondary); font-size: var(--text-xs); }

.page {
  width: 100%; max-width: 1320px; margin: 0 auto;
  padding: var(--space-6); display: flex; flex-direction: column; gap: var(--space-4);
}

/* responsivo do header — esconde o menos essencial por largura, mantém
   brand + ações (Atualizar/tema/Sair). Evita estouro horizontal no mobile. */
.topbar .brand { min-width: 0; white-space: nowrap; }
@media (max-width: 900px) {
  .topbar .user { display: none; }            /* email — você já sabe quem é */
}
@media (max-width: 640px) {
  .topbar { padding: var(--space-3) var(--space-4); gap: var(--space-3); }
  .topbar .brand .sub { display: none; }       /* "· resultados" */
  .topbar .meta { display: none; }             /* "última atualização: …" (reaparece em tela maior) */
  .topbar-actions { gap: var(--space-2); }
}

/* ---------------- botões (tiers de ação) ---------------- */
.btn {
  display: inline-flex; align-items: center; justify-content: center; gap: var(--space-2);
  font-family: inherit; font-size: var(--text-sm); font-weight: var(--weight-medium);
  line-height: 1; padding: 8px 14px; border-radius: var(--radius-md);
  border: 1px solid transparent; cursor: pointer; white-space: nowrap;
  transition: background var(--duration-fast) var(--easing-ease-out),
              border-color var(--duration-fast) var(--easing-ease-out),
              color var(--duration-fast) var(--easing-ease-out);
}
.btn:disabled { cursor: not-allowed; background: var(--action-disabled-bg); color: var(--action-disabled-text); border-color: transparent; }
.btn-sm { padding: 6px 10px; font-size: var(--text-xs); }
.btn-block { width: 100%; }

.btn-primary { background: var(--action-primary-bg); color: var(--action-primary-text); }
.btn-primary:hover:not(:disabled) { background: var(--action-primary-bg-hover); }
.btn-primary:active:not(:disabled) { background: var(--action-primary-bg-active); }

.btn-secondary { background: var(--action-secondary-bg); color: var(--action-secondary-text); border-color: var(--action-secondary-border); }
.btn-secondary:hover:not(:disabled) { background: var(--action-secondary-bg-hover); }
.btn-secondary:active:not(:disabled) { background: var(--action-secondary-bg-active); }

.btn-ghost { background: transparent; color: var(--action-tertiary-text); }
.btn-ghost:hover:not(:disabled) { background: var(--action-tertiary-bg-hover); }

.btn-icon { padding: 7px; width: 34px; height: 34px; }

/* ---------------- card ---------------- */
.card {
  background: var(--surface-raised); border: 1px solid var(--border-subtle);
  border-radius: var(--radius-lg); box-shadow: var(--shadow-card);
}
.card-header {
  display: flex; align-items: baseline; gap: var(--space-2);
  padding: var(--space-3) var(--d-card-padding);
  border-bottom: 1px solid var(--border-subtle);
}
.card-title { font-size: var(--text-lg); font-weight: var(--weight-semibold); color: var(--text-primary); }
.card-title .muted { color: var(--text-tertiary); font-weight: var(--weight-regular); }
.card-subtitle { font-size: var(--text-xs); color: var(--text-tertiary); }
.card-body { padding: var(--d-card-padding); }

/* ---------------- grid utils ---------------- */
.grid { display: grid; gap: var(--space-4); }
.cols-2 { grid-template-columns: 2fr 1fr; }
.cols-half { grid-template-columns: 1fr 1fr; }
@media (max-width: 900px) { .cols-2, .cols-half { grid-template-columns: 1fr; } }
/* grid item NÃO encolhe abaixo do conteúdo por padrão (min-width:auto) → tabela
   larga empurrava a página no mobile. min-width:0 deixa o card encolher e o
   .table-wrap rolar internamente. Idem nos KPIs. */
.grid > *, .kpi-grid > * { min-width: 0; }

/* ---------------- KPIs ---------------- */
.kpi-grid {
  display: grid; gap: var(--space-3);
  grid-template-columns: repeat(4, 1fr);
}
@media (max-width: 1100px) { .kpi-grid { grid-template-columns: repeat(2, 1fr); } }
.kpi { background: var(--surface-raised); border: 1px solid var(--border-subtle); border-radius: var(--radius-lg); padding: var(--d-card-padding); box-shadow: var(--shadow-card); }
.kpi-label { font-size: var(--text-2xs); font-weight: var(--weight-medium); letter-spacing: var(--tracking-wide); text-transform: uppercase; color: var(--text-tertiary); }
.kpi-value { margin-top: var(--space-1); font-size: var(--text-2xl); font-weight: var(--weight-semibold); letter-spacing: var(--tracking-tight); color: var(--text-primary); font-variant-numeric: tabular-nums; }
.kpi-delta { margin-top: 2px; font-size: var(--text-xs); color: var(--text-tertiary); font-variant-numeric: tabular-nums; }
.kpi-delta.up { color: var(--chart-positive); }
.kpi-delta.down { color: var(--chart-negative); }

/* ---------------- funil unificado ---------------- */
.funil { display: flex; align-items: stretch; flex-wrap: wrap; gap: var(--space-1); }
.funil-stage { flex: 1; min-width: 88px; padding: var(--space-2) var(--space-1); text-align: center; }
.funil-num { font-size: var(--text-xl); font-weight: var(--weight-semibold); color: var(--text-primary); letter-spacing: var(--tracking-tight); font-variant-numeric: tabular-nums; line-height: var(--leading-tight); }
.funil-label { margin-top: 2px; font-size: var(--text-2xs); letter-spacing: var(--tracking-wide); text-transform: uppercase; color: var(--text-tertiary); }
.funil-arrow { display: flex; align-items: center; color: var(--border-default); font-size: var(--text-lg); padding: 0 2px; }

/* ---------------- banner (estados de sistema) ---------------- */
.banner { display: none; padding: var(--space-3) var(--space-4); border-radius: var(--radius-md); font-size: var(--text-sm); border: 1px solid transparent; }
.banner.show { display: block; }
.banner-info { background: var(--status-info-bg); color: var(--status-info-fg); border-color: var(--status-info-border); }
.banner-success { background: var(--status-success-bg); color: var(--status-success-fg); border-color: var(--status-success-border); }
.banner-warning { background: var(--status-warning-bg); color: var(--status-warning-fg); border-color: var(--status-warning-border); }
.banner-danger { background: var(--status-danger-bg); color: var(--status-danger-fg); border-color: var(--status-danger-border); }

/* gap do funil — destaque informativo */
.funil-gap { margin-top: var(--space-3); padding: var(--space-2) var(--space-3); border-radius: var(--radius-md); font-size: var(--text-sm); background: var(--status-warning-bg); color: var(--status-warning-fg); border: 1px solid var(--status-warning-border); }
.funil-gap.hidden { display: none; }

/* ---------------- reserva (gauge) ---------------- */
.reserva { display: flex; justify-content: space-between; align-items: center; flex-wrap: wrap; gap: var(--space-3); }
.reserva .big { font-size: var(--text-2xl); font-weight: var(--weight-semibold); color: var(--text-primary); font-variant-numeric: tabular-nums; }
.reserva .unit { color: var(--text-tertiary); font-size: var(--text-sm); }

/* ---------------- tabelas ---------------- */
.table-wrap { overflow-x: auto; }
table.tbl { width: 100%; border-collapse: collapse; font-size: var(--text-sm); }
table.tbl th {
  text-align: left; font-size: var(--text-2xs); font-weight: var(--weight-semibold);
  letter-spacing: var(--tracking-wide); text-transform: uppercase; color: var(--text-tertiary);
  padding: var(--space-2) var(--d-row-padding-x); border-bottom: 1px solid var(--border-default);
  white-space: nowrap;
}
table.tbl td { padding: var(--d-row-padding-y) var(--d-row-padding-x); border-bottom: 1px solid var(--border-subtle); color: var(--text-primary); }
table.tbl tbody tr:nth-child(even) { background: var(--surface-accent); }
table.tbl tbody tr:hover { background: var(--surface-hover); }
table.tbl .num { text-align: right; font-variant-numeric: tabular-nums; }
table.tbl .empty { text-align: center; color: var(--text-tertiary); }

/* ---------------- filtros (form) ---------------- */
.filtros { display: grid; grid-template-columns: repeat(6, 1fr); gap: var(--space-3); align-items: end; }
@media (max-width: 1100px) { .filtros { grid-template-columns: repeat(2, 1fr); } }
.field { display: flex; flex-direction: column; gap: var(--space-1); }
.field .label { font-size: var(--text-xs); font-weight: var(--weight-medium); color: var(--text-secondary); }
.field-actions { flex-direction: row; gap: var(--space-2); }
.field-compare { grid-column: 1 / -1; flex-direction: row; align-items: center; gap: var(--space-3); }

/* mobile: campos full-width (tap fácil), comparação empilhada, página mais justa */
@media (max-width: 640px) {
  .page { padding: var(--space-4); }
  .filtros { gap: var(--space-2); }
  .filtros .field-wide { grid-column: 1 / -1; }   /* hotel/origem/vendedor/botões ocupam a linha */
  .field-compare { flex-direction: column; align-items: stretch; gap: var(--space-1); }
  .field-compare .seg { width: 100%; display: flex; }
  .field-compare .seg label { flex: 1; text-align: center; }
}
.input, .select {
  font-family: inherit; font-size: var(--text-sm); color: var(--text-primary);
  background: var(--surface-raised); border: 1px solid var(--border-default);
  border-radius: var(--radius-md); padding: 7px 9px; min-height: 34px; width: 100%;
}
.input:focus, .select:focus { outline: none; border-color: var(--border-focus); box-shadow: 0 0 0 3px var(--surface-selected); }
select.select[multiple] { min-height: 34px; }

/* multiselect custom (substitui o <select multiple> nativo, que é horrível) */
.ms { position: relative; }
.ms-trigger {
  display: flex; align-items: center; justify-content: space-between; gap: var(--space-2);
  font-family: inherit; font-size: var(--text-sm); color: var(--text-primary);
  background: var(--surface-raised); border: 1px solid var(--border-default);
  border-radius: var(--radius-md); padding: 7px 9px; min-height: 36px; width: 100%;
  cursor: pointer; text-align: left;
}
.ms-trigger:hover { border-color: var(--border-strong); }
.ms.open .ms-trigger { border-color: var(--border-focus); box-shadow: 0 0 0 3px var(--surface-selected); }
.ms-value { overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.ms-value.placeholder { color: var(--text-tertiary); }
.ms-caret { color: var(--text-tertiary); flex: none; transition: transform var(--duration-fast); }
.ms.open .ms-caret { transform: rotate(180deg); }
.ms-panel {
  position: absolute; top: calc(100% + 4px); left: 0; right: 0; z-index: var(--z-dropdown);
  background: var(--surface-overlay); border: 1px solid var(--border-default);
  border-radius: var(--radius-md); box-shadow: var(--shadow-modal); padding: var(--space-2);
  max-height: 300px; overflow: auto; display: none;
}
.ms.open .ms-panel { display: block; }
.ms-search {
  width: 100%; margin-bottom: var(--space-2); font-family: inherit; font-size: var(--text-sm);
  color: var(--text-primary); background: var(--surface-raised);
  border: 1px solid var(--border-default); border-radius: var(--radius-sm); padding: 6px 8px;
}
.ms-search:focus { outline: none; border-color: var(--border-focus); }
.ms-opt {
  display: flex; align-items: center; gap: var(--space-2); padding: 6px; cursor: pointer;
  border-radius: var(--radius-sm); font-size: var(--text-sm); color: var(--text-primary);
}
.ms-opt:hover { background: var(--surface-hover); }
.ms-opt input { accent-color: var(--action-primary-bg); width: 15px; height: 15px; flex: none; }
.ms-opt.hide { display: none; }
.ms-foot { display: flex; justify-content: flex-end; padding-top: var(--space-1); margin-top: var(--space-1); border-top: 1px solid var(--border-subtle); }
.ms-foot button { background: none; border: none; color: var(--text-link); font-size: var(--text-xs); cursor: pointer; padding: 3px 5px; }
.ms-empty { color: var(--text-tertiary); font-size: var(--text-xs); padding: 6px; }

/* segmented control (comparação) */
.seg { display: inline-flex; border: 1px solid var(--border-default); border-radius: var(--radius-md); overflow: hidden; }
.seg label { font-size: var(--text-xs); color: var(--text-secondary); padding: 6px 10px; cursor: pointer; background: var(--surface-raised); }
.seg label:not(:last-child) { border-right: 1px solid var(--border-subtle); }
.seg input { position: absolute; opacity: 0; pointer-events: none; }
.seg input:checked + label { background: var(--surface-selected); color: var(--text-link); font-weight: var(--weight-medium); }

/* ---------------- chart ---------------- */
.chart { min-height: 280px; }

/* ---------------- spinner ---------------- */
.spinner { display: inline-block; width: 14px; height: 14px; border: 2px solid currentColor; border-right-color: transparent; border-radius: 50%; animation: spin 0.6s linear infinite; vertical-align: -2px; }
.hidden { display: none !important; }

/* ---------------- placeholder-card (camada em construção) ----------------
   NÃO usar a classe genérica `.placeholder`: o multiselect usa `.placeholder`
   no span de estado-vazio e colidiria (padding/border desta regra vazavam pro
   trigger, deixando-o alto demais). */
.placeholder-card { border: 1px dashed var(--border-default); border-radius: var(--radius-lg); padding: var(--space-6); text-align: center; color: var(--text-tertiary); font-size: var(--text-sm); }

/* ---------------- login ---------------- */
.login-center { min-height: 100vh; display: flex; align-items: center; justify-content: center; padding: var(--space-4); }
.login-card { width: 100%; max-width: 380px; text-align: center; }
.login-brand { font-size: var(--text-2xl); font-weight: var(--weight-semibold); letter-spacing: var(--tracking-tight); color: var(--text-primary); display: inline-flex; align-items: center; gap: var(--space-2); }
.login-brand .dot { width: 10px; height: 10px; border-radius: var(--radius-full); background: var(--brand-accent); }
.login-sub { color: var(--text-tertiary); font-size: var(--text-sm); margin-top: var(--space-1); }
.login-foot { color: var(--text-tertiary); font-size: var(--text-xs); margin-top: var(--space-4); }
.login-foot sup { font-size: 0.6em; }

/* ---------------- footer ---------------- */
.foot { color: var(--text-tertiary); font-size: var(--text-xs); text-align: center; padding: var(--space-4); }
