/* ============================================================
   SAPIEN UI — biblioteca consolidada (base + extensão)
   Drop-in: copie para Frontend/css/sapien-ui.css
   Requer as variáveis de marca (colors_and_type.css / variables.css).
   ============================================================ */

/* ============================================================
   SAPIEN UI · Componentes padrão
   ------------------------------------------------------------
   Biblioteca de componentes base para o admin Sapien.
   Inspiração: ReUI (reui.io) — superfícies limpas, bordas
   sutis, foreground "muted", foco em clareza.
   Mantém os tokens da marca (teal #05636c / #49c3ce).

   Uso: <link> este arquivo DEPOIS de colors_and_type.css.
   Os componentes JS (select, modal) vivem em sapien-ui.js.
   ============================================================ */

:root {
  /* Aliases neutros estilo ReUI, mapeados pra paleta Sapien */
  --ui-bg:            #ffffff;
  --ui-bg-subtle:     #f7f8f8;
  --ui-bg-muted:      #f0f2f2;
  --ui-border:        #e4e7e7;
  --ui-border-strong: #d3d8d8;
  --ui-fg:            #0b1f23;   /* texto principal */
  --ui-fg-muted:      #66767b;   /* texto secundário */
  --ui-fg-subtle:     #939fa3;   /* placeholders, hints */
  --ui-primary:       #05636c;
  --ui-primary-hover: #044b54;
  --ui-accent:        #49c3ce;
  --ui-ring:          rgba(5, 99, 108, 0.12);

  --ui-radius-sm: 6px;
  --ui-radius:    8px;
  --ui-radius-lg: 10px;
  --ui-radius-xl: 14px;

  --ui-shadow-xs: 0 1px 2px rgba(11, 31, 35, 0.04);
  --ui-shadow-sm: 0 1px 3px rgba(11, 31, 35, 0.06), 0 1px 2px rgba(11, 31, 35, 0.04);
  --ui-shadow-md: 0 4px 12px -2px rgba(11, 31, 35, 0.10), 0 2px 6px -2px rgba(11, 31, 35, 0.06);
  --ui-shadow-lg: 0 12px 32px -8px rgba(11, 31, 35, 0.16), 0 4px 12px -4px rgba(11, 31, 35, 0.08);

  --ui-height-sm: 32px;
  --ui-height:    36px;
  --ui-height-lg: 40px;
}

/* ============================================================
   BUTTON
   ============================================================ */
.ui-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 7px;
  height: var(--ui-height);
  padding: 0 14px;
  border: 1px solid transparent;
  border-radius: var(--ui-radius);
  font-family: var(--font-primary, 'Inter', sans-serif);
  font-size: 13px;
  font-weight: 600;
  line-height: 1;
  white-space: nowrap;
  cursor: pointer;
  user-select: none;
  transition: background 150ms ease, border-color 150ms ease,
              color 150ms ease, box-shadow 150ms ease, transform 100ms ease;
}
.ui-btn:active { transform: translateY(0.5px); }
.ui-btn i { font-size: 12px; }
.ui-btn:focus-visible { outline: none; box-shadow: 0 0 0 3px var(--ui-ring); }

.ui-btn--sm { height: var(--ui-height-sm); padding: 0 11px; font-size: 12.5px; }
.ui-btn--lg { height: var(--ui-height-lg); padding: 0 18px; font-size: 14px; }
.ui-btn--icon { width: var(--ui-height); padding: 0; }
.ui-btn--icon.ui-btn--sm { width: var(--ui-height-sm); }

/* variants */
.ui-btn--primary {
  background: var(--ui-primary);
  color: #fff;
  box-shadow: var(--ui-shadow-xs);
}
.ui-btn--primary:hover { background: var(--ui-primary-hover); }

.ui-btn--secondary {
  background: var(--ui-bg);
  color: var(--ui-fg);
  border-color: var(--ui-border-strong);
  box-shadow: var(--ui-shadow-xs);
}
.ui-btn--secondary:hover { background: var(--ui-bg-subtle); border-color: var(--ui-fg-subtle); }

.ui-btn--ghost {
  background: transparent;
  color: var(--ui-fg-muted);
}
.ui-btn--ghost:hover { background: var(--ui-bg-muted); color: var(--ui-fg); }

.ui-btn--danger {
  background: #dc3545;
  color: #fff;
  box-shadow: var(--ui-shadow-xs);
}
.ui-btn--danger:hover { background: #c52a39; }

.ui-btn--danger-soft {
  background: rgba(220, 53, 69, 0.08);
  color: #b3202f;
}
.ui-btn--danger-soft:hover { background: rgba(220, 53, 69, 0.14); }

.ui-btn:disabled { opacity: 0.55; pointer-events: none; }

/* ============================================================
   INPUT / TEXTAREA
   ============================================================ */
.ui-field { display: flex; flex-direction: column; gap: 6px; }
.ui-label {
  font-size: 12.5px;
  font-weight: 600;
  color: var(--ui-fg);
}
.ui-label .req { color: #dc3545; margin-left: 2px; }
.ui-hint { font-size: 11.5px; color: var(--ui-fg-subtle); line-height: 1.4; }

.ui-input,
.ui-textarea {
  width: 100%;
  height: var(--ui-height);
  padding: 0 12px;
  background: var(--ui-bg);
  border: 1px solid var(--ui-border-strong);
  border-radius: var(--ui-radius);
  font-family: var(--font-primary, 'Inter', sans-serif);
  font-size: 13px;
  color: var(--ui-fg);
  transition: border-color 150ms ease, box-shadow 150ms ease;
}
.ui-textarea { height: auto; min-height: 92px; padding: 9px 12px; resize: vertical; line-height: 1.55; }
.ui-input::placeholder,
.ui-textarea::placeholder { color: var(--ui-fg-subtle); }
.ui-input:focus,
.ui-textarea:focus {
  outline: none;
  border-color: var(--ui-primary);
  box-shadow: 0 0 0 3px var(--ui-ring);
}
.ui-input:disabled,
.ui-textarea:disabled { background: var(--ui-bg-muted); color: var(--ui-fg-muted); cursor: not-allowed; }

/* SELECT nativo com a cara do .ui-input (chevron próprio) */
select.ui-input {
  cursor: pointer;
  appearance: none; -webkit-appearance: none;
  padding-right: 34px;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='14' height='14' viewBox='0 0 24 24' fill='none' stroke='%2366767b' stroke-width='2.5' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='6 9 12 15 18 9'/%3E%3C/svg%3E");
  background-repeat: no-repeat; background-position: right 12px center;
}

/* FORM LAYOUT — grade de campos responsiva + rodapé de ações (migração dos forms p/ .ui-*) */
.ui-form-row { display: grid; grid-template-columns: repeat(auto-fit, minmax(220px, 1fr)); gap: 16px; }
.ui-form-row + .ui-form-row { margin-top: 16px; }
.ui-form-actions { display: flex; gap: 12px; justify-content: flex-end; align-items: center; padding-top: 20px; margin-top: 24px; border-top: 1px solid var(--ui-border); }

/* input with leading icon */
.ui-input-group { position: relative; }
.ui-input-group > i {
  position: absolute; left: 11px; top: 50%; transform: translateY(-50%);
  color: var(--ui-fg-subtle); font-size: 13px; pointer-events: none;
}
.ui-input-group .ui-input { padding-left: 33px; }

/* ============================================================
   SELECT (custom — JS driven via sapien-ui.js)
   Markup:
   <div class="ui-select" data-value="all">
     <button class="ui-select__trigger" type="button">
       <span class="ui-select__prefix">Tipo</span>
       <span class="ui-select__value">Todos</span>
       <i class="fas fa-chevron-down ui-select__chevron"></i>
     </button>
     <div class="ui-select__menu" role="listbox">
       <button class="ui-select__option" data-value="all">Todos os tipos</button>
       ...
     </div>
   </div>
   ============================================================ */
.ui-select { position: relative; display: inline-block; }

.ui-select__trigger {
  display: inline-flex;
  align-items: center;
  gap: 7px;
  height: var(--ui-height-sm);
  padding: 0 9px 0 11px;
  background: var(--ui-bg);
  border: 1px solid var(--ui-border-strong);
  border-radius: var(--ui-radius);
  font-family: var(--font-primary, 'Inter', sans-serif);
  font-size: 12.5px;
  color: var(--ui-fg);
  cursor: pointer;
  white-space: nowrap;
  transition: border-color 150ms ease, box-shadow 150ms ease, background 150ms ease;
}
.ui-select__trigger:hover { border-color: var(--ui-fg-subtle); }
.ui-select__trigger:focus-visible { outline: none; border-color: var(--ui-primary); box-shadow: 0 0 0 3px var(--ui-ring); }
.ui-select.is-open .ui-select__trigger { border-color: var(--ui-primary); box-shadow: 0 0 0 3px var(--ui-ring); }

.ui-select__prefix {
  color: var(--ui-fg-subtle);
  font-weight: 500;
}
.ui-select__prefix::after { content: ":"; }
.ui-select__value { font-weight: 600; }
.ui-select__chevron {
  font-size: 9px;
  color: var(--ui-fg-subtle);
  margin-left: 2px;
  transition: transform 180ms ease;
}
.ui-select.is-open .ui-select__chevron { transform: rotate(180deg); }

/* clear (x) button shown when a non-default value is active */
.ui-select__clear {
  display: none;
  align-items: center; justify-content: center;
  width: 15px; height: 15px;
  margin-left: 1px;
  border: none; border-radius: 50%;
  background: var(--ui-bg-muted);
  color: var(--ui-fg-muted);
  font-size: 8px;
  cursor: pointer;
}
.ui-select.is-filtered .ui-select__clear { display: inline-flex; }
.ui-select.is-filtered .ui-select__trigger {
  border-color: var(--ui-primary);
  background: rgba(5, 99, 108, 0.04);
}
.ui-select.is-filtered .ui-select__prefix { color: var(--ui-primary); }

.ui-select__menu {
  position: absolute;
  top: calc(100% + 5px);
  left: 0;
  min-width: 100%;
  width: max-content;
  max-width: 260px;
  background: var(--ui-bg);
  border: 1px solid var(--ui-border);
  border-radius: var(--ui-radius-lg);
  box-shadow: var(--ui-shadow-lg);
  padding: 4px;
  z-index: 50;
  opacity: 0;
  transform: translateY(-4px) scale(0.98);
  transform-origin: top left;
  pointer-events: none;
  transition: opacity 140ms ease, transform 140ms ease;
}
.ui-select.is-open .ui-select__menu {
  opacity: 1;
  transform: translateY(0) scale(1);
  pointer-events: auto;
}
.ui-select__menu--right { left: auto; right: 0; transform-origin: top right; }

.ui-select__option {
  display: flex;
  align-items: center;
  gap: 9px;
  width: 100%;
  padding: 7px 9px;
  background: transparent;
  border: none;
  border-radius: var(--ui-radius-sm);
  font-family: var(--font-primary, 'Inter', sans-serif);
  font-size: 12.5px;
  color: var(--ui-fg);
  text-align: left;
  cursor: pointer;
  transition: background 120ms ease;
}
.ui-select__option:hover { background: var(--ui-bg-muted); }
.ui-select__option .dot {
  width: 7px; height: 7px; border-radius: 50%;
  flex-shrink: 0;
}
.ui-select__option .label { flex: 1; }
.ui-select__option .check {
  font-size: 11px;
  color: var(--ui-primary);
  opacity: 0;
}
.ui-select__option[aria-selected="true"] { color: var(--ui-primary); font-weight: 600; }
.ui-select__option[aria-selected="true"] .check { opacity: 1; }

/* ============================================================
   FILTER BAR — agrupa selects + busca
   ============================================================ */
.ui-filterbar {
  display: flex;
  align-items: center;
  gap: 8px;
  flex-wrap: wrap;
}
.ui-filterbar__spacer { flex: 1; }
.ui-filterbar__divider {
  width: 1px; height: 22px;
  background: var(--ui-border);
  margin: 0 2px;
}
/* "Limpar filtros" só aparece quando há filtro ativo */
.ui-filterbar__clear {
  display: none;
  align-items: center; gap: 5px;
  height: var(--ui-height-sm);
  padding: 0 9px;
  background: transparent;
  border: none;
  border-radius: var(--ui-radius);
  font-size: 12px; font-weight: 600;
  color: var(--ui-fg-muted);
  cursor: pointer;
}
.ui-filterbar__clear:hover { background: var(--ui-bg-muted); color: var(--ui-fg); }
.ui-filterbar.has-active .ui-filterbar__clear { display: inline-flex; }

/* ============================================================
   PAGE HEADER — padrão do admin
   ============================================================ */
.ui-pageheader {
  display: flex;
  align-items: center;
  gap: 16px;
  padding: 14px 28px;
  background: var(--ui-bg);
  border-bottom: 1px solid var(--ui-border);
}
.ui-pageheader__chip {
  width: 40px; height: 40px;
  flex-shrink: 0;
  border-radius: var(--ui-radius-lg);
  background: linear-gradient(135deg, var(--ui-primary), #077885);
  color: #fff;
  display: flex; align-items: center; justify-content: center;
  font-size: 17px;
  box-shadow: 0 3px 9px rgba(5, 99, 108, 0.22);
}
.ui-pageheader__titles { display: flex; flex-direction: column; gap: 1px; min-width: 0; }
.ui-pageheader__title {
  font-family: var(--font-primary, 'Inter', sans-serif);
  font-size: 19px;
  font-weight: 700;
  color: var(--ui-fg);
  letter-spacing: -0.01em;
  line-height: 1.2;
  display: flex; align-items: center; gap: 9px;
}
.ui-pageheader__count {
  font-size: 12px;
  font-weight: 600;
  color: var(--ui-fg-muted);
  background: var(--ui-bg-muted);
  padding: 1px 8px;
  border-radius: 9999px;
  font-variant-numeric: tabular-nums;
}
.ui-pageheader__subtitle {
  font-size: 12.5px;
  color: var(--ui-fg-muted);
  line-height: 1.3;
}
.ui-pageheader__actions {
  margin-left: auto;
  display: flex; align-items: center; gap: 8px;
  flex-wrap: wrap;
  justify-content: flex-end;
}

/* ============================================================
   EMPTY STATE — padrão
   ============================================================ */
.ui-empty {
  display: flex;
  flex-direction: column;
  align-items: center;
  text-align: center;
  padding: 56px 24px;
  max-width: 420px;
  margin: 0 auto;
}
.ui-empty__art {
  position: relative;
  width: 96px; height: 96px;
  display: flex; align-items: center; justify-content: center;
  margin-bottom: 20px;
}
.ui-empty__art::before {
  content: "";
  position: absolute; inset: 0;
  border-radius: 24px;
  background: linear-gradient(135deg, rgba(5,99,108,0.07), rgba(73,195,206,0.10));
}
.ui-empty__art::after {
  content: "";
  position: absolute; inset: 10px;
  border-radius: 18px;
  border: 1px dashed rgba(5, 99, 108, 0.22);
}
.ui-empty__icon {
  position: relative;
  font-size: 34px;
  color: var(--ui-primary);
  opacity: 0.85;
}
.ui-empty__title {
  font-family: var(--font-primary, 'Inter', sans-serif);
  font-size: 16px;
  font-weight: 700;
  color: var(--ui-fg);
  margin-bottom: 6px;
}
.ui-empty__text {
  font-size: 13px;
  color: var(--ui-fg-muted);
  line-height: 1.55;
  margin-bottom: 20px;
}
.ui-empty__actions { display: flex; align-items: center; gap: 8px; }

/* Empty-state que PREENCHE o espaço disponível e centraliza nos dois
   eixos. Use como wrapper da área de conteúdo: o container cresce
   (flex:1) e o .ui-empty fica no centro vertical + horizontal.
   A página/área precisa ser flex-column com altura definida
   (ex: a .content com flex:1 dentro de um shell 100vh). */
.ui-empty-fill {
  flex: 1 1 auto;
  align-self: stretch;
  width: 100%;
  min-height: 320px;
  display: flex;
  align-items: center;
  justify-content: center;
}

/* ============================================================
   MODAL / DIALOG — estilo ReUI
   ============================================================ */
.ui-overlay[hidden] { display: none; }
.ui-overlay {
  position: fixed; inset: 0;
  background: rgba(11, 31, 35, 0.45);
  backdrop-filter: blur(2px);
  display: flex; align-items: center; justify-content: center;
  padding: 24px;
  z-index: 1000;
  opacity: 0;
  transition: opacity 180ms ease;
}
.ui-overlay.is-open { opacity: 1; }

.ui-dialog {
  width: 100%;
  max-width: 460px;
  background: var(--ui-bg);
  border: 1px solid var(--ui-border);
  border-radius: var(--ui-radius-xl);
  box-shadow: var(--ui-shadow-lg);
  overflow: hidden;
  transform: translateY(8px) scale(0.97);
  opacity: 0;
  transition: transform 200ms cubic-bezier(.16,1,.3,1), opacity 200ms ease;
}
.ui-overlay.is-open .ui-dialog { transform: translateY(0) scale(1); opacity: 1; }
.ui-dialog--lg { max-width: 600px; }

.ui-dialog__header {
  display: flex;
  align-items: flex-start;
  gap: 13px;
  padding: 20px 20px 0;
}
.ui-dialog__icon {
  width: 38px; height: 38px;
  flex-shrink: 0;
  border-radius: var(--ui-radius-lg);
  display: flex; align-items: center; justify-content: center;
  font-size: 16px;
}
.ui-dialog__icon--primary { background: rgba(5,99,108,0.10); color: var(--ui-primary); }
.ui-dialog__icon--danger  { background: rgba(220,53,69,0.10); color: #dc3545; }
.ui-dialog__icon--warning { background: rgba(245,166,35,0.12); color: #c97e0a; }
.ui-dialog__heading { flex: 1; min-width: 0; padding-top: 1px; }
.ui-dialog__title {
  font-family: var(--font-primary, 'Inter', sans-serif);
  font-size: 16px;
  font-weight: 700;
  color: var(--ui-fg);
  line-height: 1.3;
}
.ui-dialog__desc {
  font-size: 12.5px;
  color: var(--ui-fg-muted);
  line-height: 1.5;
  margin-top: 3px;
}
.ui-dialog__close {
  width: 28px; height: 28px;
  flex-shrink: 0;
  display: flex; align-items: center; justify-content: center;
  background: transparent;
  border: none; border-radius: var(--ui-radius-sm);
  color: var(--ui-fg-subtle);
  font-size: 14px;
  cursor: pointer;
  transition: background 120ms ease, color 120ms ease;
}
.ui-dialog__close:hover { background: var(--ui-bg-muted); color: var(--ui-fg); }

.ui-dialog__body {
  padding: 16px 20px 4px;
  font-size: 13px;
  color: var(--ui-fg);
  line-height: 1.6;
}
.ui-dialog__body strong { color: var(--ui-primary); font-weight: 600; }

.ui-dialog__footer {
  display: flex;
  align-items: center;
  justify-content: flex-end;
  gap: 8px;
  padding: 16px 20px 20px;
}
.ui-dialog__footer--between { justify-content: space-between; }

/* tom de sucesso no ícone do modal */
.ui-dialog__icon--success { background: rgba(40,167,69,0.12); color: #1d7330; }

/* caixa de aviso (modal destrutivo) */
.sp-dlg-warn { display:flex; gap:9px; background:rgba(220,53,69,0.05); border:1px solid rgba(220,53,69,0.18); border-radius:9px; padding:10px 12px; font-size:12.5px; color:#8a2531; line-height:1.5; }
.sp-dlg-warn i { margin-top:1px; flex-shrink:0; }
.sp-dlg-warn b { color:#8a2531; }

/* layout centralizado (modal de resultado) */
.ui-dialog.sp-dlg--center { position:relative; text-align:center; }
.ui-dialog.sp-dlg--center .ui-dialog__header { flex-direction:column; align-items:center; padding:24px 20px 0; gap:10px; }
.ui-dialog.sp-dlg--center .ui-dialog__icon { width:48px; height:48px; font-size:20px; border-radius:14px; }
.ui-dialog.sp-dlg--center .ui-dialog__close { position:absolute; top:12px; right:12px; }
.ui-dialog.sp-dlg--center .ui-dialog__footer { justify-content:center; }
.ui-dialog.sp-dlg--center .ui-dialog__footer .ui-btn { flex:1; }


/* ===== EXTENSÃO: toggle, date-range, popover, chips, tabs, header ===== */

/* ============================================================
   SAPIEN UI · Extensão de componentes
   Componentes adicionais focados em HEADER e EMPTY-STATE,
   pensados para escalar sob carga (muitos filtros) e continuar
   compactos. Use junto de sapien-ui.css.
   ============================================================ */

/* ============================================================
   TOGGLE (switch)
   <label class="ui-toggle"><input type="checkbox"><span class="track"></span><span class="ui-toggle__label">Consolidar</span></label>
   ============================================================ */
.ui-toggle { display: inline-flex; align-items: center; gap: 8px; cursor: pointer; user-select: none; }
.ui-toggle input { position: absolute; opacity: 0; width: 0; height: 0; }
.ui-toggle .track {
  position: relative; width: 34px; height: 20px; border-radius: 9999px;
  background: var(--ui-border-strong);
  transition: background 160ms ease;
  flex-shrink: 0;
}
.ui-toggle .track::after {
  content: ""; position: absolute; top: 2px; left: 2px;
  width: 16px; height: 16px; border-radius: 50%;
  background: #fff; box-shadow: 0 1px 2px rgba(0,0,0,0.2);
  transition: transform 160ms cubic-bezier(.4,0,.2,1);
}
.ui-toggle input:checked + .track { background: var(--ui-primary); }
.ui-toggle input:checked + .track::after { transform: translateX(14px); }
.ui-toggle input:focus-visible + .track { box-shadow: 0 0 0 3px var(--ui-ring); }
.ui-toggle__label { font-size: 12.5px; font-weight: 600; color: var(--ui-fg); }
.ui-toggle__label .muted { color: var(--ui-fg-subtle); font-weight: 500; }

/* ============================================================
   DATE RANGE PILL
   Um único controle no lugar de 2 inputs + 1 select soltos.
   <button class="ui-daterange"><i class="far fa-calendar"></i>
     <span class="ui-daterange__value">Últimos 15 dias</span>
     <i class="fas fa-chevron-down"></i></button>
   ============================================================ */
.ui-daterange {
  display: inline-flex; align-items: center; gap: 8px;
  height: var(--ui-height-sm); padding: 0 10px;
  background: var(--ui-bg);
  border: 1px solid var(--ui-border-strong);
  border-radius: var(--ui-radius);
  font-family: var(--font-primary, 'Inter', sans-serif);
  font-size: 12.5px; font-weight: 600; color: var(--ui-fg);
  cursor: pointer; white-space: nowrap;
  transition: border-color 150ms ease, box-shadow 150ms ease;
}
.ui-daterange:hover { border-color: var(--ui-fg-subtle); }
.ui-daterange > i:first-child { color: var(--ui-fg-subtle); font-size: 12px; }
.ui-daterange > i:last-child { color: var(--ui-fg-subtle); font-size: 9px; margin-left: 1px; }
.ui-daterange__value { font-weight: 600; }
.ui-daterange__sep { color: var(--ui-fg-subtle); font-weight: 400; }

/* ============================================================
   FILTER BUTTON + POPOVER
   Esconde os filtros secundários atrás de 1 botão "Filtros (n)".
   Mantém a barra limpa mesmo com 6+ filtros.
   ============================================================ */
.ui-filterbtn-wrap { position: relative; display: inline-block; }
.ui-filterbtn {
  display: inline-flex; align-items: center; gap: 7px;
  height: var(--ui-height-sm); padding: 0 12px;
  background: var(--ui-bg);
  border: 1px solid var(--ui-border-strong);
  border-radius: var(--ui-radius);
  font-family: var(--font-primary, 'Inter', sans-serif);
  font-size: 12.5px; font-weight: 600; color: var(--ui-fg);
  cursor: pointer; white-space: nowrap;
  transition: border-color 150ms ease, background 150ms ease;
}
.ui-filterbtn:hover { border-color: var(--ui-fg-subtle); }
.ui-filterbtn i.lead { font-size: 12px; color: var(--ui-fg-muted); }
.ui-filterbtn .badge {
  display: inline-flex; align-items: center; justify-content: center;
  min-width: 17px; height: 17px; padding: 0 5px;
  background: var(--ui-primary); color: #fff;
  border-radius: 9999px; font-size: 10.5px; font-weight: 700;
  font-variant-numeric: tabular-nums;
}
.ui-filterbtn-wrap.is-open .ui-filterbtn { border-color: var(--ui-primary); box-shadow: 0 0 0 3px var(--ui-ring); }

.ui-popover {
  position: absolute; top: calc(100% + 6px); right: 0;
  width: 280px; /* padrão de fato do popover de filtros (era inline em 16 páginas) */
  background: var(--ui-bg);
  border: 1px solid var(--ui-border);
  border-radius: var(--ui-radius-lg);
  box-shadow: var(--ui-shadow-lg);
  z-index: 60;
  opacity: 0; transform: translateY(-4px) scale(0.98); transform-origin: top right;
  pointer-events: none;
  transition: opacity 140ms ease, transform 140ms ease;
}
.ui-filterbtn-wrap.is-open .ui-popover { opacity: 1; transform: none; pointer-events: auto; }
.ui-popover__head {
  display: flex; align-items: center; justify-content: space-between;
  padding: 12px 14px; border-bottom: 1px solid var(--ui-border);
}
.ui-popover__head strong { font-size: 13px; font-weight: 700; }
.ui-popover__head button { background: none; border: none; font-size: 12px; font-weight: 600; color: var(--ui-fg-muted); cursor: pointer; }
.ui-popover__head button:hover { color: var(--ui-primary); }
.ui-popover__body { padding: 12px 14px 14px; display: flex; flex-direction: column; gap: 8px; } /* gap/pb antes inline em 18 páginas */
.ui-popover__field { display: flex; flex-direction: column; gap: 5px; }
.ui-popover__field > label { font-size: 11.5px; font-weight: 600; color: var(--ui-fg-muted); }
.ui-popover__foot { padding: 10px 14px; border-top: 1px solid var(--ui-border); display: flex; gap: 8px; justify-content: flex-end; }
/* select inside popover stretches full width */
.ui-popover .ui-select { display: block; }
.ui-popover .ui-select__trigger { width: 100%; height: var(--ui-height); justify-content: space-between; }
.ui-popover .ui-select__menu { width: 100%; }

/* popover modifiers: width + left-anchored */
.ui-popover--sm { width: 220px; }
.ui-popover--left { left: 0; right: auto; transform-origin: top left; }
.ui-popover--center { left: 50%; right: auto; transform: translateX(-50%) translateY(-4px) scale(0.98); transform-origin: top center; }
.ui-filterbtn-wrap.is-open .ui-popover--center { transform: translateX(-50%); }

/* search field inside a popover */
.ui-popover__search { padding: 10px 12px 4px; }
.ui-popover__search .ui-input-group .ui-input { height: 32px; }

/* MENU — lista de ações/opções dentro do popover (estilo ReUI dropdown) */
.ui-menu { padding: 5px; max-height: 280px; overflow-y: auto; }
.ui-menu__group { padding: 7px 9px 3px; font-size: 10.5px; font-weight: 700; text-transform: uppercase; letter-spacing: 0.5px; color: var(--ui-fg-subtle); }
.ui-menu__item {
  display: flex; align-items: center; gap: 10px; width: 100%;
  padding: 7px 9px; background: none; border: none; border-radius: var(--ui-radius-sm);
  font-family: var(--font-primary, 'Inter', sans-serif);
  font-size: 12.5px; font-weight: 500; color: var(--ui-fg);
  text-align: left; cursor: pointer; transition: background 120ms ease;
}
.ui-menu__item i.lead { width: 15px; text-align: center; font-size: 12px; color: var(--ui-fg-muted); }
.ui-menu__item .label { flex: 1; }
.ui-menu__item .kbd { font-family: 'Fira Code', monospace; font-size: 10px; color: var(--ui-fg-subtle); }
.ui-menu__item:hover { background: var(--ui-bg-muted); }
.ui-menu__item:hover i.lead { color: var(--ui-fg); }
.ui-menu__item.is-danger { color: #c52a39; }
.ui-menu__item.is-danger i.lead { color: #dc3545; }
.ui-menu__item.is-danger:hover { background: rgba(220,53,69,0.08); }
.ui-menu__item[aria-checked] { }
.ui-menu__item[aria-checked] .check { font-size: 11px; color: var(--ui-primary); opacity: 0; margin-left: auto; }
.ui-menu__item[aria-checked="true"] { color: var(--ui-primary); font-weight: 600; }
.ui-menu__item[aria-checked="true"] .check { opacity: 1; }
.ui-menu__sep { height: 1px; background: var(--ui-border); margin: 5px 0; }

/* CHECK ITEM — multi-seleção (checkbox row) */
.ui-checkitem {
  display: flex; align-items: center; gap: 9px; width: 100%;
  padding: 6px 9px; background: none; border: none; border-radius: var(--ui-radius-sm);
  font-family: var(--font-primary, 'Inter', sans-serif);
  font-size: 12.5px; color: var(--ui-fg); text-align: left; cursor: pointer;
  transition: background 120ms ease;
}
.ui-checkitem:hover { background: var(--ui-bg-muted); }
.ui-checkitem .box {
  width: 16px; height: 16px; border-radius: 5px; flex-shrink: 0;
  border: 1.5px solid var(--ui-border-strong);
  display: flex; align-items: center; justify-content: center;
  color: #fff; font-size: 9px; transition: all 120ms ease;
}
.ui-checkitem .box i { opacity: 0; }
.ui-checkitem[aria-checked="true"] .box { background: var(--ui-primary); border-color: var(--ui-primary); }
.ui-checkitem[aria-checked="true"] .box i { opacity: 1; }
.ui-checkitem .dot { width: 7px; height: 7px; border-radius: 50%; flex-shrink: 0; }
.ui-checkitem .label { flex: 1; }
.ui-checkitem .meta { font-size: 11px; color: var(--ui-fg-subtle); font-variant-numeric: tabular-nums; }

/* generic trigger so the popover pattern works on any button */
.ui-pop-wrap { position: relative; display: inline-block; }
.ui-pop-wrap.is-open .ui-popover { opacity: 1; transform: none; pointer-events: auto; }
.ui-pop-wrap.is-open .ui-popover--center { transform: translateX(-50%); }

/* ============================================================
   ACTIVE FILTER CHIPS (removíveis)
   Segunda linha fina do header, aparece só quando há filtro.
   ============================================================ */
.ui-activechips {
  display: flex; align-items: center; gap: 7px; flex-wrap: wrap;
  padding: 9px 28px;
  background: var(--ui-bg-subtle);
  border-bottom: 1px solid var(--ui-border);
}
.ui-activechips__label { font-size: 11px; font-weight: 700; text-transform: uppercase; letter-spacing: 0.5px; color: var(--ui-fg-subtle); margin-right: 2px; }
.ui-chip {
  display: inline-flex; align-items: center; gap: 6px;
  height: 24px; padding: 0 6px 0 9px;
  background: var(--ui-bg);
  border: 1px solid var(--ui-border-strong);
  border-radius: 9999px;
  font-size: 11.5px; font-weight: 600; color: var(--ui-fg);
}
.ui-chip .k { color: var(--ui-fg-subtle); font-weight: 500; }
.ui-chip .dot { width: 6px; height: 6px; border-radius: 50%; }
.ui-chip__x {
  display: inline-flex; align-items: center; justify-content: center;
  width: 15px; height: 15px; border-radius: 50%;
  background: var(--ui-bg-muted); border: none; color: var(--ui-fg-muted);
  font-size: 8px; cursor: pointer;
}
.ui-chip__x:hover { background: #dc3545; color: #fff; }
.ui-activechips__clear { background: none; border: none; font-size: 11.5px; font-weight: 600; color: var(--ui-fg-muted); cursor: pointer; margin-left: 2px; }
.ui-activechips__clear:hover { color: var(--ui-primary); }

/* ============================================================
   TABS
   ============================================================ */
.ui-tabs { display: flex; gap: 2px; border-bottom: 1px solid var(--ui-border); padding: 0 28px; background: var(--ui-bg); }
.ui-tab {
  display: inline-flex; align-items: center; gap: 7px;
  padding: 11px 14px; background: none; border: none;
  font-family: var(--font-primary, 'Inter', sans-serif);
  font-size: 13px; font-weight: 600; color: var(--ui-fg-muted);
  cursor: pointer; position: relative;
  /* !important: vence a regra genérica de botão do sapien-premium
     (`.btn, button:not(.close)` = border-radius + border:none) que arredondava
     as pontas do sublinhado e apagava a borda da aba ativa. */
  border-bottom: 2px solid transparent !important; margin-bottom: -1px;
  border-radius: 0 !important;
  transition: color 150ms ease;
}
.ui-tab i { font-size: 12px; }
.ui-tab:hover { color: var(--ui-fg); }
.ui-tab.active { color: var(--ui-primary); border-bottom-color: var(--ui-primary) !important; }
.ui-tab .ui-tab__count { font-size: 11px; padding: 0 6px; height: 16px; display: inline-flex; align-items: center; border-radius: 9999px; background: var(--ui-bg-muted); color: var(--ui-fg-muted); font-variant-numeric: tabular-nums; }
.ui-tab.active .ui-tab__count { background: rgba(5,99,108,0.10); color: var(--ui-primary); }

/* ============================================================
   HEADER — versão "tools" que comporta muitos controles
   .ui-header (linha principal) + .ui-header__tools (direita, com
   wrap controlado) + divisória antes da ação primária.
   ============================================================ */
.ui-header {
  display: flex; align-items: center; gap: 14px;
  padding: 12px 28px;
  background: var(--ui-bg);
  border-bottom: 1px solid var(--ui-border);
}
.ui-header__chip {
  width: 40px; height: 40px; flex-shrink: 0;
  border-radius: var(--ui-radius-lg);
  background: linear-gradient(135deg, var(--ui-primary), #077885);
  color: #fff; display: flex; align-items: center; justify-content: center;
  font-size: 17px; box-shadow: 0 3px 9px rgba(5,99,108,0.22);
}
.ui-header__titles { min-width: 0; }
.ui-header__title { font-size: 19px; font-weight: 700; letter-spacing: -0.01em; line-height: 1.2; display: flex; align-items: center; gap: 9px; }
.ui-header__count { font-size: 12px; font-weight: 600; color: var(--ui-fg-muted); background: var(--ui-bg-muted); padding: 1px 8px; border-radius: 9999px; font-variant-numeric: tabular-nums; }
.ui-header__subtitle { font-size: 12.5px; color: var(--ui-fg-muted); line-height: 1.3; margin-top: 1px; }
.ui-header__tools {
  margin-left: auto;
  display: flex; align-items: center; gap: 8px;
  flex-wrap: wrap; justify-content: flex-end;
}
.ui-header__divider { width: 1px; height: 24px; background: var(--ui-border); margin: 0 2px; }

/* ============================================================
   HEADER — peças do header-final (antes inline no template):
   chip-soft, busca compacta, linha de filtro clicável (ff-row),
   seções/divisor/toggle do popover. Necessárias nas páginas reais.
   ============================================================ */
.chip-soft {
  width: 40px; height: 40px; border-radius: 11px;
  background: rgba(5,99,108,0.08); color: var(--ui-primary);
  display: flex; align-items: center; justify-content: center;
  font-size: 17px; flex-shrink: 0;
  box-shadow: inset 0 0 0 1px rgba(5,99,108,0.14);
}

/* busca compacta do header */
.hsearch { position: relative; width: 190px; }
.hsearch i { position: absolute; left: 10px; top: 50%; transform: translateY(-50%); color: var(--ui-fg-subtle); font-size: 12px; }
.hsearch input {
  width: 100%; height: var(--ui-height-sm); padding: 0 10px 0 30px;
  border: 1px solid var(--ui-border-strong); border-radius: var(--ui-radius);
  font-family: var(--font-primary, 'Inter', sans-serif); font-size: 12.5px; color: var(--ui-fg);
  background: var(--ui-bg);
}
.hsearch input::placeholder { color: var(--ui-fg-subtle); }
.hsearch input:focus { outline: none; border-color: var(--ui-primary); box-shadow: 0 0 0 3px var(--ui-ring); }

/* linha de filtro clicável (single-select V2) dentro do popover */
.ff__icon {
  width: 30px; height: 30px; flex-shrink: 0; border-radius: 9px;
  background: rgba(5,99,108,0.09); color: var(--ui-primary);
  display: flex; align-items: center; justify-content: center; font-size: 13px;
}
.ff__label { font-size: 12.5px; font-weight: 700; color: var(--ui-fg); line-height: 1.25; }
.ff__sub { font-size: 11px; color: var(--ui-fg-muted); font-weight: 600; line-height: 1.3; }
.ff-row { display: block; }
.ff-row .ui-select__trigger { width: 100%; height: auto; padding: 9px 11px; gap: 11px; align-items: center; }
.ff-row .ff-row__txt { flex: 1; min-width: 0; text-align: left; display: flex; flex-direction: column; gap: 1px; }
.ff-row.is-filtered .ff__sub { color: var(--ui-primary); }
.ff-row .ui-select__chevron { margin-left: auto; flex-shrink: 0; }
/* Rótulo e valor longos (ex.: nome grande de operadora) truncam com "…" em vez
   de estourar o popover (280px). */
.ff__label, .ff__sub { overflow: hidden; text-overflow: ellipsis; white-space: nowrap; max-width: 100%; }

/* seções / divisor / toggle-row do popover */
.pop-section { font-size: 10.5px; font-weight: 700; text-transform: uppercase; letter-spacing: 0.5px; color: var(--ui-fg-subtle); padding: 2px 2px 0; }
.pop-div { height: 1px; background: var(--ui-border); margin: 4px 0; }
.toggle-row { display: flex; align-items: center; justify-content: space-between; padding: 4px 2px; }
.toggle-row .tr-txt .t { font-size: 12.5px; font-weight: 600; color: var(--ui-fg); }
.toggle-row .tr-txt .s { font-size: 11px; color: var(--ui-fg-subtle); }

/* ============================================================
   SHELL de página real — faz o empty-state preencher a tela.
   Aplicar .ui-screen no .main-content e envolver o conteúdo em .ui-content.
   ============================================================ */
.ui-screen { display: flex; flex-direction: column; min-height: calc(100vh - 30px); }
.ui-screen .ui-content { flex: 1 1 auto; display: flex; flex-direction: column; min-height: 0; }

/* painéis de aba (troca via sapien-ui-bridge.js) */
.ui-tabpanel { display: none; }
.ui-tabpanel.active { display: block; }

/* wrapper do date-range (popover próprio da ponte) */
.dr-wrap { position: relative; display: inline-block; }
.dr-wrap.is-open .ui-popover { opacity: 1; transform: none; pointer-events: auto; }

/* período PERSONALIZADO: Início/Fim empilhados, label à esquerda (não estoura a largura) */
.dr-custom { padding: 9px 11px; border-top: 1px solid var(--ui-border); display: flex; flex-direction: column; gap: 7px; }
.dr-custom__hint { font-size: 10.5px; font-weight: 700; text-transform: uppercase; letter-spacing: 0.5px; color: var(--ui-fg-subtle); }
.dr-custom__row { display: flex; align-items: center; gap: 8px; }
.dr-custom__lbl { width: 42px; flex-shrink: 0; font-size: 11.5px; font-weight: 600; color: var(--ui-fg-muted); }
.dr-custom input[type="date"] {
  flex: 1; min-width: 0; height: 32px; padding: 0 8px; font-size: 12px;
  color: var(--ui-fg); background: var(--ui-bg);
  border: 1px solid var(--ui-border-strong); border-radius: var(--ui-radius);
  font-family: var(--font-primary, 'Inter', sans-serif);
}
.dr-custom input[type="date"]:focus { outline: none; border-color: var(--ui-primary); box-shadow: 0 0 0 3px var(--ui-ring); }

/* ============================================================
   FULL-BLEED em página real: o header/chips/tabs vão de borda a borda
   do conteúdo (cancelam o padding horizontal do body — como o antigo
   .page-header fazia com margem negativa). Aplica SÓ dentro de .main-content,
   então não afeta os demos (que ficam fora de .main-content).
   ============================================================ */
.main-content > .ui-header,
.main-content > .ui-activechips,
.main-content > .ui-tabs {
  margin-left: calc(var(--space-xl, 30px) * -1);
  margin-right: calc(var(--space-xl, 30px) * -1);
}

/* Header FIXO no topo ao rolar (como o antigo .page-header sticky).
   Fundo opaco (--ui-bg) garante que o conteúdo role por baixo limpo. */
.main-content > .ui-header {
  position: sticky;
  top: 0;
  z-index: 50;
}

/* ============================================================
   EMPTY-STATE LEGADO → visual do design.
   As listas já renderizam .empty-state (+ -icon/-title/-message). Aqui
   reescrevemos o visual pro padrão .ui-empty (arte tracejada, centralizado,
   preenchendo a área) — assim TODAS as listas ganham o novo empty-state sem
   editar o JS de cada página. Carrega DEPOIS de sapien-premium → vence.
   ============================================================ */
.empty-state {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  text-align: center;
  min-height: 46vh;
  max-width: 440px;
  margin: 0 auto;
  padding: 40px 24px;
}
.empty-state-icon {
  position: relative;
  width: 96px; height: 96px;
  display: flex; align-items: center; justify-content: center;
  margin: 0 auto 20px;
  background: none;
  border-radius: 0;
}
.empty-state-icon::before {
  content: ""; position: absolute; inset: 0; border-radius: 24px;
  background: linear-gradient(135deg, rgba(5,99,108,0.07), rgba(73,195,206,0.10));
}
.empty-state-icon::after {
  content: ""; position: absolute; inset: 10px; border-radius: 18px;
  border: 1px dashed rgba(5,99,108,0.22);
}
.empty-state-icon i,
.empty-state-icon svg {
  position: relative;
  font-size: 34px;
  color: var(--ui-primary, #05636c);
  opacity: 0.85;
}
.empty-state-title {
  font-size: 16px; font-weight: 700;
  color: var(--ui-fg, #0b1f23);
  margin-bottom: 6px;
}
.empty-state-message {
  font-size: 13px;
  color: var(--ui-fg-muted, #66767b);
  line-height: 1.55;
  margin-bottom: 0;
}
/* dentro de uma célula de tabela (empty como linha), centraliza ocupando a largura */
td > .empty-state { width: 100%; }
/* Respiro abaixo do "band" — o conteúdo não pode grudar no header.
   Quando há CHIPS ATIVOS logo abaixo, eles ficam grudados ao header (banda
   contínua) e o respiro vai depois dos chips. */
.main-content > .ui-header { margin-bottom: var(--space-lg, 20px); }
.main-content > .ui-header:has(+ .ui-activechips.has-chips) { margin-bottom: 0; }
.main-content > .ui-activechips.has-chips { margin-bottom: var(--space-lg, 20px); }
.main-content > .ui-tabs { margin-bottom: var(--space-lg, 20px); }

/* Relatórios (guias/juntas): a faixa de abas fica dentro de #conteudo. Tiramos
   só o recuo de 28px da FAIXA → a borda do 1º botão encosta na esquerda (no eixo
   do conteúdo), mas o botão MANTÉM o padding próprio (texto com respiro). */
#conteudo .jm-tabs-container > .ui-tabs { padding-left: 0; }

/* ============================================================
   STAT CARD (.ui-stat) — canônico do design (stat-card-final.html).
   Ícone soft + label/valor + delta opcional. Grade .ui-stat-grid.
   ============================================================ */
.ui-stat { display:flex; align-items:center; gap:12px; background:var(--ui-bg); border:1px solid var(--ui-border-strong); border-radius:12px; padding:12px 14px; box-shadow: var(--ui-shadow-sm); transition: box-shadow .2s ease, transform .15s ease, border-color .2s ease; }
.ui-stat:hover { box-shadow: var(--ui-shadow-md); transform: translateY(-1px); border-color: var(--ui-fg-subtle); }
.ui-stat__icon { width:38px; height:38px; flex-shrink:0; border-radius:10px; display:flex; align-items:center; justify-content:center; font-size:16px; background: var(--stat-bg, rgba(5,99,108,0.10)); color: var(--stat-fg, #05636c); box-shadow: inset 0 0 0 1px var(--stat-ring, rgba(5,99,108,0.18)); }
.ui-stat__mid { flex:1; min-width:0; }
.ui-stat__label { font-size:12px; font-weight:600; color: var(--ui-fg-muted); line-height:1.2; white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }
.ui-stat__value { font-family:'Poppins','Inter',sans-serif; font-size:22px; font-weight:700; color: var(--ui-fg); line-height:1.15; font-variant-numeric: tabular-nums; letter-spacing:-0.02em; }
.ui-stat__value .cur { font-size:13px; font-weight:600; color: var(--ui-fg-muted); margin-right:2px; }
.ui-stat__sub { font-size:11px; color: var(--ui-fg-subtle); margin-top:1px; white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }
.ui-stat__delta { flex-shrink:0; font-size:10.5px; font-weight:700; padding:2px 7px; border-radius:9999px; display:inline-flex; align-items:center; gap:3px; white-space:nowrap; font-variant-numeric:tabular-nums; }
.ui-stat__delta.up { background: rgba(40,167,69,0.12); color:#1d7330; }
.ui-stat__delta.down { background: rgba(220,53,69,0.11); color:#c52a39; }
.ui-stat__delta.flat { background: var(--ui-bg-muted); color: var(--ui-fg-muted); }
.ui-stat--primary { --stat-bg:rgba(5,99,108,0.10); --stat-fg:#05636c; --stat-ring:rgba(5,99,108,0.18); }
.ui-stat--success { --stat-bg:rgba(40,167,69,0.12); --stat-fg:#1d7330; --stat-ring:rgba(40,167,69,0.22); }
.ui-stat--warning { --stat-bg:rgba(245,166,35,0.14); --stat-fg:#b9740a; --stat-ring:rgba(245,166,35,0.28); }
.ui-stat--danger  { --stat-bg:rgba(220,53,69,0.11); --stat-fg:#c52a39; --stat-ring:rgba(220,53,69,0.22); }
.ui-stat--info    { --stat-bg:rgba(23,162,184,0.12); --stat-fg:#0c7689; --stat-ring:rgba(23,162,184,0.22); }
.ui-stat-grid { display:grid; grid-template-columns:repeat(auto-fit, minmax(220px,1fr)); gap:14px; }

/* ============================================================
   TABLE (.ui-tbl) — canônico do design (tables-final.html).
   ============================================================ */
.ui-tablecard { background:#fff; border:1px solid var(--ui-border-strong); border-radius:12px; box-shadow:var(--ui-shadow-sm); overflow:hidden; }
.ui-tablecard__head { display:flex; align-items:center; gap:12px; padding:12px 16px; border-bottom:1px solid var(--ui-border); }
.ui-tablecard__title { font-size:14px; font-weight:700; display:flex; align-items:center; gap:8px; }
.ui-tablecard__title i { color:var(--ui-primary); font-size:13px; }
.ui-tablecard__count { font-size:11.5px; font-weight:600; color:var(--ui-fg-muted); background:var(--ui-bg-muted); padding:1px 8px; border-radius:9999px; font-variant-numeric:tabular-nums; }
.ui-tablecard__tools { margin-left:auto; display:flex; gap:7px; }
.ttool { display:inline-flex; align-items:center; gap:6px; height:30px; padding:0 11px; background:#fff; border:1px solid var(--ui-border-strong); border-radius:8px; font-family:inherit; font-size:12px; font-weight:600; color:var(--ui-fg-muted); cursor:pointer; }
.ttool:hover { border-color:var(--ui-fg-subtle); color:var(--ui-fg); }
.ui-tbl { width:100%; border-collapse:collapse; font-size:13px; }
.ui-tbl thead th { text-align:left; padding:9px 16px; font-size:11px; font-weight:700; text-transform:uppercase; letter-spacing:0.4px; color:var(--ui-fg-muted); background:var(--ui-bg-subtle); border-bottom:1px solid var(--ui-border); white-space:nowrap; }
.ui-tbl tbody td { padding:10px 16px; border-bottom:1px solid var(--ui-border); color:var(--ui-fg); vertical-align:middle; }
.ui-tbl tbody tr:last-child td { border-bottom:none; }
.ui-tbl tbody tr { transition:background .12s ease; }
.ui-tbl tbody tr:hover { background:rgba(5,99,108,0.035); cursor:pointer; }
.ui-tbl .num, .ui-tbl th.num { text-align:right; font-variant-numeric:tabular-nums; }
.ui-tbl .center, .ui-tbl th.center { text-align:center; }
.ui-tbl .col-actions, .ui-tbl th.col-actions { text-align:right; width:1%; white-space:nowrap; }
.cell-id { font-family:'Fira Code',monospace; font-size:12px; color:var(--ui-primary); font-weight:600; text-decoration:none; white-space:nowrap; }
.cell-id:hover { text-decoration:underline; }
.cell-primary { font-weight:600; color:var(--ui-fg); }
.cell-sub { font-size:11px; color:var(--ui-fg-subtle); margin-top:1px; }
.money { font-weight:600; }
.money .cur { font-size:11px; color:var(--ui-fg-muted); font-weight:600; margin-right:1px; }
.ui-badge { display:inline-flex; align-items:center; gap:5px; padding:2px 9px; border-radius:9999px; font-size:10.5px; font-weight:700; text-transform:uppercase; letter-spacing:0.3px; white-space:nowrap; }
.ui-badge .d { width:6px; height:6px; border-radius:50%; }
.ui-badge--warning { background:rgba(245,166,35,0.14); color:#b9740a; }
.ui-badge--success { background:rgba(40,167,69,0.13); color:#1d7330; }
.ui-badge--danger  { background:rgba(220,53,69,0.11); color:#c52a39; }
.ui-badge--info    { background:rgba(23,162,184,0.12); color:#0c7689; }
.ui-badge--neutral { background:var(--ui-bg-muted); color:var(--ui-fg-muted); }
.tbl-actions { display:inline-grid; grid-template-columns:repeat(3,28px); gap:6px; justify-content:end; }
.tbl-actions .ta { width:28px; height:28px; display:inline-flex; align-items:center; justify-content:center; border:1px solid transparent; border-radius:7px; background:transparent; font-size:12px; cursor:pointer; transition:all .15s ease; }
.tbl-actions .ta.view { color:#0c7689; background:rgba(23,162,184,0.06); border-color:rgba(23,162,184,0.18); }
.tbl-actions .ta.edit { color:#05636c; background:rgba(5,99,108,0.06); border-color:rgba(5,99,108,0.18); }
.tbl-actions .ta.delete { color:#c52a39; background:rgba(220,53,69,0.06); border-color:rgba(220,53,69,0.18); }
.tbl-actions .ta.view:hover { background:#0c7689; color:#fff; border-color:#0c7689; }
.tbl-actions .ta.edit:hover { background:#05636c; color:#fff; border-color:#05636c; }
.tbl-actions .ta.delete:hover { background:#dc3545; color:#fff; border-color:#dc3545; }

/* ============================================================
   PADRONIZAÇÃO GLOBAL — adapta as classes LEGADAS à linguagem do
   design, sem tocar no HTML/JS de cada página. Carrega depois de
   sapien-premium; usa !important onde o CSS legado (juntas/dashboard)
   carrega DEPOIS desta lib.
   ============================================================ */

/* (1) [removido] As abas legadas .jm-tab-btn/.tab-button foram convertidas
   para o padrão único .ui-tabs/.ui-tab — não há mais ponte de abas aqui. */

/* (2) STAT CARDS legados (.stat-card) → linguagem visual .ui-stat:
   horizontal, ícone soft tintado, valor compacto. NÃO afeta os
   composites .metric-section/.dashboard-card (não levam .stat-card)
   e cards de gráfico/cabeçalho são excluídos via :has(). */
.stat-card {
  display: flex; align-items: center; gap: 12px;
  padding: 12px 14px;
  border-radius: 12px;
  box-shadow: var(--ui-shadow-sm);
}
.stat-card:has(.stat-header),
.stat-card:has(canvas),
.stat-card:has(.progress),
.stat-card:has(.chart-box),
.stat-card:has(table) { display: block; }
.stat-card > .stat-content,
.stat-card > .stat-info,
.stat-card > .stat-body { flex: 1; min-width: 0; }
.stat-card .stat-value { font-size: 24px; line-height: 1.15; letter-spacing: -0.01em; }
.stat-card .stat-label { font-size: 12px; margin-bottom: 2px; }
/* tamanho do ícone (sem cor — preserva as variantes exóticas/inline dos
   dashboards de e-mail/whatsapp/correspondências: info-alt, purple, orange). */
.stat-card .stat-icon { width: 40px; height: 40px; font-size: 16px; border-radius: 10px; }
/* variantes conhecidas: sólido + ícone branco → soft tintado.
   Especificidade 0,3,0 vence o sapien-premium (0,2,0) sem precisar de !important. */
.stat-card .stat-icon.primary { color: var(--ui-primary); background: rgba(5,99,108,0.10); box-shadow: inset 0 0 0 1px rgba(5,99,108,0.18); }
.stat-card .stat-icon.success { color: #1d7330; background: rgba(40,167,69,0.12); box-shadow: inset 0 0 0 1px rgba(40,167,69,0.22); }
.stat-card .stat-icon.warning { color: #b9740a; background: rgba(245,166,35,0.14); box-shadow: inset 0 0 0 1px rgba(245,166,35,0.28); }
.stat-card .stat-icon.danger  { color: #c52a39; background: rgba(220,53,69,0.11); box-shadow: inset 0 0 0 1px rgba(220,53,69,0.22); }
/* Empilhar label/valor (igual ao .ui-stat e aos kpi-cards). Vence o
   justify-content:space-between do juntas-premium (.stats-grid .stat-content
   !important) por especificidade maior (0,3,0 > 0,2,0). */
.stats-grid .stat-card > .stat-content,
.stats-grid .stat-card > .stat-info,
.stats-grid .stat-card > .stat-body {
  flex-direction: column !important;
  align-items: flex-start !important;
  justify-content: center !important;
  gap: 0 !important;
}
.stats-grid .stat-card .stat-label { font-size: 12px !important; white-space: normal !important; margin-bottom: 2px !important; }
.stats-grid .stat-card .stat-value { font-size: 24px !important; line-height: 1.15 !important; }

/* (2b) KPI cards (.kpi-card) — já horizontais; só suaviza o ícone (sólido → soft). */
.kpi-icon { box-shadow: inset 0 0 0 1px rgba(5,99,108,0.10); }
.kpi-icon.teal   { background: rgba(5,99,108,0.10) !important; color: #05636c !important; }
.kpi-icon.green  { background: rgba(22,163,74,0.12) !important; color: #16a34a !important; }
.kpi-icon.blue   { background: rgba(37,99,235,0.12) !important; color: #2563eb !important; }
.kpi-icon.purple { background: rgba(124,58,237,0.12) !important; color: #7c3aed !important; }

/* (2c) Dashboards: a barra "compacta" (.stats-grid.compact) deixava os cards
   GRUDADOS (gap:0 + 1 box só com divisórias). NÃO usamos cards grudados —
   separa em cards individuais (gap + borda/raio/sombra próprios), como o padrão.
   !important vence o <style> inline das páginas de dashboard. */
.stats-grid.compact {
  gap: 14px !important;
  border: none !important;
  border-radius: 0 !important;
  overflow: visible !important;
}
.stats-grid.compact .stat-card {
  border: 1px solid var(--ui-border-strong) !important;
  border-radius: 12px !important;
  box-shadow: var(--ui-shadow-sm) !important;
}

/* (3) TABELAS legadas (.data-table) → cabeçalho plano do design
   (sem gradiente nem borda primária 2px). O resto já bate com o .ui-tbl. */
.data-table { border-radius: var(--ui-radius-lg, 10px); }
.data-table thead {
  background: var(--ui-bg-subtle, #f7f8f8) !important;
  border-bottom: 1px solid var(--ui-border) !important;
}
.data-table th { color: var(--ui-fg-muted); }
/* badges de status → pílula do design (mantém as cores, tira borda pesada) */
.badge { border: none !important; text-transform: uppercase; letter-spacing: .3px; font-size: 10.5px; font-weight: 700; padding: 3px 10px; }
/* Badges DENTRO de tabelas no tamanho padrão compacto (não dominam a linha). */
.data-table .sp-badge { font-size: 10.5px; padding: 1px 8px; line-height: 1.4; }

/* ============================================================
   PÁGINAS DE CADASTRO COM TABELA FIXA (body.pg-tabela-fixa)
   Header/filtros/abas ficam FIXOS; rola só o corpo da tabela, que termina
   dentro da tela. Mesmo padrão da gestão de juntas/usuários. Só desktop —
   mobile mantém o scroll normal da página.
   Aplicar SÓ em páginas cujo container da tabela (.table-container/.data-table/
   .tab-content) seja FILHO DIRETO de .main-content. ============= */
@media (min-width: 769px) {
  body.pg-tabela-fixa { height: 100vh; overflow: hidden; }
  body.pg-tabela-fixa .main-content {
    display: flex; flex-direction: column;
    height: 100vh; min-height: 0; overflow: hidden;
  }
  /* zonas FIXAS (tudo que não é a área rolável da tabela) */
  body.pg-tabela-fixa .main-content > .ui-header,
  body.pg-tabela-fixa .main-content > .ui-activechips,
  body.pg-tabela-fixa .main-content > .ui-tabs,
  body.pg-tabela-fixa .main-content > .info-banner,
  body.pg-tabela-fixa .main-content > .header-filters { flex: 0 0 auto; }
  /* ÚNICA área que rola */
  body.pg-tabela-fixa .main-content > .table-container,
  body.pg-tabela-fixa .main-content > .data-table,
  body.pg-tabela-fixa .main-content > .tab-content.active {
    flex: 1 1 auto; min-height: 0; overflow-y: auto; margin-bottom: 10px;
  }
  /* cabeçalho da tabela grudado no topo ao rolar (fundo opaco) */
  body.pg-tabela-fixa .data-table thead th,
  body.pg-tabela-fixa .table-container table thead th {
    position: sticky; top: 0; z-index: 3;
    background: var(--ui-bg-subtle, #f7f8f8) !important;
    box-shadow: 0 1px 0 var(--ui-border, #e5e7eb);
  }
}

/* (4) EMPTY-STATE ocupa o MÁXIMO de espaço disponível, centralizado nos
   dois eixos (inclusive dentro de <td colspan> de tabela). */
/* min-height aqui é só um PISO; o sapien-empty.js mede o topo real de cada
   empty-state e preenche o espaço exato até o fim da tela (sem estourar nem
   ficar curto), adaptando ao header/abas/filtros que houver acima. */
.empty-state { min-height: 360px; grid-column: 1 / -1; }
td > .empty-state { min-height: 360px; }

/* O empty-state ganha um CARD branco que preenche o vão (largura toda) com o
   conteúdo centralizado — exceto quando já está dentro de um card de tabela
   (.data-table/.table-container = o container), onde fica estreito e centrado. */
.empty-state {
  background: var(--ui-bg, #fff);
  border: 1px solid var(--ui-border);
  border-radius: 16px;
  max-width: none;
  width: 100%;
}
.empty-state-title, .empty-state-message { max-width: 460px; }
.data-table .empty-state,
.table-container .empty-state,
td .empty-state {
  background: transparent;
  border: none;
  max-width: 440px;
}
