/* ============================================================
   permissoes.css + indicadores.css — Onda 6
   Namespace .cf-perm-* / .cf-ind-*
   ============================================================ */

/* ──── PERMISSÕES ──── */
.cf-perm {
  /* Sessão 134: full-width sem max-width — ocupa tela toda */
  padding: 22px 28px;
  display: flex; flex-direction: column; gap: 24px;
}
.cf-perm-head {
  display: flex; justify-content: space-between; align-items: flex-start; gap: 16px;
}
.cf-perm-title { font-size: 22px; font-weight: 600; margin: 0; font-family: 'IBM Plex Sans', sans-serif; color: #0f172a; }
.cf-perm-sub { font-size: 12.5px; color: #64748b; margin: 4px 0 0 0; }

.cf-perm-body {
  display: grid; grid-template-columns: 1.5fr 1fr; gap: 14px;
  align-items: start;
}
@media (max-width: 1100px) { .cf-perm-body { grid-template-columns: 1fr; } }

.cf-perm-pane {
  background: #fff; border: 1px solid #ecf0f4; border-radius: 10px;
  padding: 14px;
  display: flex; flex-direction: column; gap: 12px;
}
.cf-perm-pane-head {
  display: flex; justify-content: space-between; align-items: center;
}
.cf-perm-pane-head h3 { font-size: 14px; font-weight: 600; margin: 0; color: #0f172a; }
.cf-perm-count {
  display: inline-flex; align-items: center; justify-content: center;
  min-width: 24px; height: 22px; padding: 0 8px;
  background: #1e5baa; color: #fff; border-radius: 11px;
  font-size: 11.5px; font-weight: 600;
}
.cf-perm-list, .cf-perm-groups { display: flex; flex-direction: column; gap: 6px; max-height: 600px; overflow-y: auto; }

.cf-perm-user-row {
  display: flex; align-items: center; gap: 10px;
  padding: 10px 12px; background: #f8fafc; border: 1px solid transparent; border-radius: 7px;
  cursor: pointer; text-align: left; width: 100%;
  font-family: inherit; transition: background .15s, border-color .15s;
}
.cf-perm-user-row:hover { background: #f0f6ff; border-color: #bfdbfe; }
.cf-perm-user-info { flex: 1; min-width: 0; }
.cf-perm-user-info strong { display: block; font-size: 13px; color: #0f172a; }
.cf-perm-user-info small { display: block; font-size: 11px; color: #64748b; margin-top: 1px; }
.cf-perm-group-select { min-width: 150px; }
.cf-perm-status {
  font-size: 10.5px; padding: 2px 8px; border-radius: 9px; font-weight: 600;
  text-transform: capitalize;
}
.cf-perm-status-active  { background: #d1fae5; color: #065f46; }
.cf-perm-status-pending { background: #fef3c7; color: #92400e; }
.cf-perm-status-paused  { background: #f1f5f9; color: #64748b; }
.cf-perm-status-blocked { background: #fee2e2; color: #991b1b; }

.cf-perm-group-row {
  display: flex; align-items: center; gap: 10px;
  padding: 10px 12px; background: #f8fafc; border: 1px solid transparent; border-radius: 7px;
  cursor: pointer; text-align: left; width: 100%;
  font-family: inherit; transition: background .15s, border-color .15s;
}
.cf-perm-group-row:hover { background: #f0f6ff; border-color: #bfdbfe; }
.cf-perm-group-info { flex: 1; min-width: 0; }
.cf-perm-group-info strong { display: block; font-size: 13px; color: #0f172a; }
.cf-perm-group-info small { display: block; font-size: 11px; color: #64748b; margin-top: 1px; }
.cf-perm-group-count {
  font-size: 11px; color: #64748b;
  background: #fff; padding: 2px 8px; border-radius: 9px;
  border: 1px solid #e2e8f0;
}
.cf-perm-custom-tag {
  font-size: 9px; padding: 1px 5px; border-radius: 4px;
  background: #ede9fe; color: #5b21b6; font-weight: 600;
}

/* Drawer */
.cf-perm-drawer { padding: 0; }
.cf-perm-drawer-head {
  position: relative;
  padding: 20px 22px 16px 22px;
  background: linear-gradient(180deg, #f0f6ff 0%, #fff 100%);
  border-bottom: 1px solid #ecf0f4;
}
.cf-perm-drawer-eyebrow {
  font-size: 10.5px; color: #1e5baa;
  text-transform: uppercase; letter-spacing: 0.4px; font-weight: 600;
}
.cf-perm-drawer-head h2 { margin: 6px 0 4px 0; }
.cf-perm-name-input {
  width: 100%; font-size: 19px; font-weight: 600; color: #0f172a;
  background: transparent; border: none; outline: none;
  padding: 4px 6px; border-radius: 5px; margin-left: -6px;
  font-family: 'IBM Plex Sans', sans-serif;
}
.cf-perm-name-input:hover, .cf-perm-name-input:focus { background: #f1f5f9; }
.cf-perm-name-input:disabled { background: transparent; cursor: not-allowed; opacity: 0.7; }
.cf-perm-desc-input {
  width: 100%; font-size: 12.5px; color: #64748b;
  background: transparent; border: none; outline: none;
  padding: 4px 6px; border-radius: 5px; margin: 0 0 0 -6px;
  font-family: inherit;
}
.cf-perm-desc-input:hover, .cf-perm-desc-input:focus { background: #f1f5f9; color: #0f172a; }

.cf-perm-user-hero {
  display: flex; align-items: center; gap: 12px;
}
.cf-perm-user-hero small { font-size: 11.5px; color: #64748b; display: block; margin-top: 4px; padding-left: 6px; }

.cf-perm-drawer-body {
  flex: 1; overflow-y: auto;
  padding: 24px 26px 32px; background: #fafbfc;
  display: flex; flex-direction: column; gap: 16px;
}

.cf-perm-block {
  background: #fff; border: 1px solid #ecf0f4; border-radius: 12px;
  padding: 20px 22px;
  display: flex; flex-direction: column; gap: 16px;
}
.cf-perm-block-head {
  display: flex; gap: 12px; align-items: center;
  padding-bottom: 14px; border-bottom: 1px solid #f1f5f9;
}
.cf-perm-block-icon {
  width: 36px; height: 36px; border-radius: 10px; flex-shrink: 0;
  display: flex; align-items: center; justify-content: center;
}
.cf-perm-block-head strong { display: block; font-size: 14.5px; font-weight: 600; color: #0f172a; letter-spacing: -0.01em; }
.cf-perm-block-head small { display: block; font-size: 12px; color: #94a3b8; margin-top: 2px; font-weight: 400; }

.cf-perm-toggles {
  display: grid; grid-template-columns: repeat(2, 1fr); gap: 4px 24px;
}
@media (max-width: 600px) { .cf-perm-toggles { grid-template-columns: 1fr; } }

/* Toggle switch moderno — alinhado com .v3-switch do design system.
   Layout: texto à esquerda, switch à direita.
   Usa specificity .cf-perm-block .cf-perm-toggles .cf-perm-toggle pra vencer
   qualquer reset global de checkbox (.ell-check etc). */
.cf-perm-block .cf-perm-toggles .cf-perm-toggle {
  display: flex; align-items: center; justify-content: space-between; gap: 14px;
  padding: 9px 6px; border-radius: 6px; cursor: pointer;
  font-size: 13px; color: #334155;
  text-transform: none !important; letter-spacing: normal !important; font-weight: 400;
  transition: background .15s;
  min-height: 36px;
}
.cf-perm-block .cf-perm-toggles .cf-perm-toggle:hover { background: #f8fafc; }
.cf-perm-block .cf-perm-toggles .cf-perm-toggle > span {
  text-transform: none !important; letter-spacing: normal !important;
  font-weight: 400; color: #334155; flex: 1 1 auto; min-width: 0;
  white-space: normal; line-height: 1.35;
}
.cf-perm-block .cf-perm-toggles .cf-perm-toggle > input[type="checkbox"] {
  appearance: none !important; -webkit-appearance: none !important;
  width: 36px !important; height: 20px !important; min-width: 36px !important;
  border-radius: 10px !important;
  background: #cbd5e1 !important;
  cursor: pointer; position: relative;
  transition: background .2s; flex: 0 0 36px;
  margin: 0 !important; padding: 0 !important;
  border: none !important; outline: none !important;
  accent-color: auto !important;
}
.cf-perm-block .cf-perm-toggles .cf-perm-toggle > input[type="checkbox"]::after {
  content: ''; position: absolute;
  top: 2px; left: 2px; width: 16px; height: 16px;
  border-radius: 50%; background: #fff;
  box-shadow: 0 1px 3px rgba(0,0,0,0.2);
  transition: transform .2s;
}
.cf-perm-block .cf-perm-toggles .cf-perm-toggle > input[type="checkbox"]:checked {
  background: #1e5baa !important;
}
.cf-perm-block .cf-perm-toggles .cf-perm-toggle > input[type="checkbox"]:checked::after {
  transform: translateX(16px);
}
.cf-perm-block .cf-perm-toggles .cf-perm-toggle > input[type="checkbox"]:focus-visible {
  box-shadow: 0 0 0 3px rgba(30,91,170,0.22);
}
/* Aviso em grupos do sistema: cursor padrão (não interativo) */
.cf-perm-drawer[data-system="1"] .cf-perm-toggle,
.cf-perm-drawer[data-system="1"] .cf-perm-toggle input { cursor: not-allowed !important; opacity: 0.85; }

.cf-perm-group-picker {
  display: flex; flex-direction: column; gap: 8px;
}
.cf-perm-foot-meta { font-size: 11px; color: #94a3b8; font-style: italic; }

/* ──── INDICADORES (refinado sessão 134 · M59 turno 38: sem background próprio · herda do tab parent) ──── */
.cf-ind {
  padding: 28px;
  display: flex; flex-direction: column; gap: 24px;
  /* sem background: o tab parent [id^="tab-"] já tem var(--bg-app) cinza */
  /* sem min-height: deixa fluir natural */
}
.cf-ind-head {
  display: flex; justify-content: space-between; align-items: flex-start; gap: 16px; flex-wrap: wrap;
  padding-bottom: 16px; border-bottom: 1px solid #ecf0f4;
}
.cf-ind-title { font-size: 22px; font-weight: 600; margin: 0; font-family: 'IBM Plex Sans', sans-serif; color: #0f172a; letter-spacing: -0.01em; }
.cf-ind-sub { font-size: 12.5px; color: #64748b; margin: 4px 0 0 0; }
.cf-ind-filters { display: flex; gap: 8px; align-items: center; flex-wrap: wrap; }

.cf-ind-body { display: flex; flex-direction: column; gap: 16px; }

/* M19.4: agregação por canal/origem/setor */
.cf-ind-canal-group { margin-top: 14px; }
.cf-ind-canal-group:first-child { margin-top: 0; }
.cf-ind-canal-group h4 {
  font-size: 11.5px; color: #475569; font-weight: 600;
  text-transform: uppercase; letter-spacing: .04em;
  margin: 0 0 8px 0;
}
.cf-ind-canal-list { list-style: none; margin: 0; padding: 0; display: flex; flex-direction: column; gap: 6px; }
.cf-ind-canal-list li {
  display: grid; grid-template-columns: 14px 1fr 50px 120px; gap: 8px;
  align-items: center; padding: 4px 0;
}
.cf-ind-canal-dot { width: 8px; height: 8px; border-radius: 50%; }
.cf-ind-canal-label { font-size: 12.5px; color: #0f172a; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.cf-ind-canal-count { font-size: 12px; color: #64748b; font-weight: 600; text-align: right; }
.cf-ind-canal-bar { background: #f1f5f9; height: 6px; border-radius: 3px; overflow: hidden; }
.cf-ind-canal-bar-fill { display: block; height: 100%; border-radius: 3px; }
.cf-ind-canal-sem .cf-ind-canal-label { color: #94a3b8; font-style: italic; }
.cf-ind-empty { display: block; padding: 12px 0; color: #94a3b8; font-style: italic; }

/* M20.5: tabela de conversão por origem */
.cf-ind-conv-tbl {
  width: 100%; border-collapse: collapse; margin-top: 6px;
}
.cf-ind-conv-tbl th, .cf-ind-conv-tbl td {
  text-align: left; padding: 8px 10px;
  font-size: 12.5px; border-bottom: 1px solid #f1f5f9;
}
.cf-ind-conv-tbl th {
  font-size: 10.5px; color: #94a3b8; font-weight: 600;
  text-transform: uppercase; letter-spacing: .04em;
}
.cf-ind-conv-tbl td { color: #0f172a; }
.cf-ind-conv-tbl td small { color: #64748b; font-size: 11px; }
.cf-ind-conv-tbl tr:last-child td { border-bottom: none; }

.cf-ind-kpis {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
  gap: 24px;                /* M59 turno 38: aumentado pra 24 · separação mais clara */
  margin-bottom: 32px;
  padding: 12px 0;          /* respiro maior pra sombra elevada não cortar */
  background: transparent;
}

/* ===========================================================================
 * KPI Card moderno (M59 · 2026-06-01)
 * Layout: label uppercase pequena em cima · valor BEM grande dominante embaixo
 * Sem linhas internas · sem fieldset · estilo "ticker" Linear/Notion/Stripe
 * --cf-kpi-accent injetado inline pelo JS (cor do tipo de KPI)
 * ========================================================================= */
.cf-ind-kpi-card {
  background: #fff;
  border: 0;
  border-radius: 10px;
  padding: 16px 18px 18px;
  display: flex;
  flex-direction: column;
  gap: 4px;
  position: relative;
  overflow: hidden;
  transition: transform 200ms ease, box-shadow 200ms ease;
  box-shadow: 0 1px 2px rgba(15, 23, 42, 0.04);
  cursor: default;
}

/* Faixa de cor sutil no topo · marca identidade do KPI sem peso visual */
.cf-ind-kpi-card::before {
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  height: 3px;
  background: var(--cf-kpi-accent, #94a3b8);
  opacity: 0.85;
}

.cf-ind-kpi-card:hover {
  transform: translateY(-2px);
  box-shadow: 0 8px 24px -4px rgba(15, 23, 42, 0.1), 0 2px 6px rgba(15, 23, 42, 0.05);
}

/* Header: label à esquerda + ícone subtle no canto direito */
.cf-ind-kpi-card__header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 8px;
  margin-bottom: 8px;
}

.cf-ind-kpi-card__label {
  font-family: 'IBM Plex Sans', sans-serif;
  font-size: 11px;
  font-weight: 600;
  letter-spacing: 0.04em;
  color: #64748b;
  text-transform: uppercase;
  line-height: 1.3;
  flex: 1;
  min-width: 0;
}

.cf-ind-kpi-card__icon {
  width: 14px;
  height: 14px;
  color: var(--cf-kpi-accent, #94a3b8);
  opacity: 0.6;
  flex-shrink: 0;
  transition: opacity 200ms ease;
}

.cf-ind-kpi-card:hover .cf-ind-kpi-card__icon {
  opacity: 1;
}

/* Valor DOMINANTE · IBM Plex Mono pra números · negative letter-spacing pra densidade */
.cf-ind-kpi-card__value {
  font-family: 'IBM Plex Mono', monospace;
  font-size: 30px;
  font-weight: 600;
  line-height: 1;
  letter-spacing: -0.025em;
  color: #0f172a;
}

.cf-ind-kpi-card__sub {
  font-size: 11.5px;
  color: #64748b;
  line-height: 1.4;
  margin-top: 6px;
}

/* M59 · 2026-06-01: cf-ds-target/cf-ds-icon removidos do card-raiz
   (data-cf-source-* foi tirado do kpiCard pra impedir auto-observer de injetar
   span filho que quebrava layout). Sem hack !important. */

.cf-ind-row {
  display: grid; grid-template-columns: 1fr 1fr; gap: 14px;
}
@media (max-width: 900px) { .cf-ind-row { grid-template-columns: 1fr; } }

.cf-ind-card {
  /* Sessão 134: sem borda — só background branco em fundo cinza */
  background: #fff; border-radius: 10px;
  padding: 20px 22px;
  display: flex; flex-direction: column; gap: 14px;
}
.cf-ind-card header { display: flex; justify-content: space-between; align-items: baseline; gap: 8px; }
.cf-ind-card header h3 { font-size: 13px; font-weight: 600; margin: 0; color: #0f172a; text-transform: uppercase; letter-spacing: 0.3px; }
.cf-ind-card header small { font-size: 11px; color: #94a3b8; }

.cf-ind-empty {
  padding: 20px; text-align: center; color: #94a3b8; font-size: 12px;
}

.cf-ind-bars { display: flex; flex-direction: column; gap: 7px; }
.cf-ind-bar-row {
  display: grid; grid-template-columns: 140px 1fr 80px;
  gap: 10px; align-items: center;
}
.cf-ind-bar-label {
  font-size: 12px; color: #475569;
  white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
}
.cf-ind-bar-track {
  height: 18px; background: #f1f5f9; border-radius: 9px;
  position: relative; overflow: hidden;
}
.cf-ind-bar-fill {
  height: 100%; border-radius: 9px;
  transition: width .3s ease-out;
}
.cf-ind-bar-val {
  font-size: 12px; color: #0f172a; font-weight: 600;
  text-align: right;
  font-family: 'IBM Plex Sans', sans-serif;
}

/* Funil */
.cf-ind-funnel { display: flex; flex-direction: column; gap: 6px; }
.cf-ind-funnel-row { display: grid; grid-template-columns: 200px 1fr; gap: 10px; align-items: center; }
.cf-ind-funnel-name {
  font-size: 12px; color: #475569;
  white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
}
.cf-ind-funnel-bar {
  height: 26px; border-radius: 6px; position: relative; overflow: hidden;
  display: flex; align-items: center;
}
.cf-ind-funnel-fill { height: 100%; transition: width .3s ease-out; }
.cf-ind-funnel-val {
  position: absolute; right: 8px;
  font-size: 12px; font-weight: 600; color: #0f172a;
  font-family: 'IBM Plex Sans', sans-serif;
}

/* Tabela compacta */
.cf-ind-table { width: 100%; border-collapse: collapse; }
.cf-ind-table td {
  padding: 8px 10px; border-bottom: 1px solid #f1f5f9;
  font-size: 12.5px; vertical-align: middle;
}
.cf-ind-table td:last-child { text-align: right; color: #10b981; }
.cf-ind-card-half { /* pra colocar 2 lado a lado */ }

/* ──── TIMELINE CHART ──── */
.cf-ind-timeline {
  display: flex; flex-direction: column; gap: 10px;
}
.cf-ind-timeline-bars {
  display: flex; align-items: flex-end; gap: 2px;
  height: 180px; padding: 12px 6px;
  background: #f8fafc; border-radius: 7px;
  position: relative;
}
.cf-ind-tl-col {
  flex: 1; min-width: 4px; height: 100%;
  position: relative;
  display: flex; align-items: flex-end; justify-content: center;
  cursor: pointer;
}
.cf-ind-tl-revenue {
  width: 100%;
  background: linear-gradient(180deg, #1e5baa 0%, #3b82f6 100%);
  border-radius: 3px 3px 0 0;
  transition: opacity .15s, transform .15s;
}
.cf-ind-tl-col:hover .cf-ind-tl-revenue { opacity: 0.85; transform: scaleY(1.02); transform-origin: bottom; }
.cf-ind-tl-count {
  position: absolute; left: 50%; transform: translateX(-50%);
  width: 6px; height: 6px; border-radius: 50%;
  background: #f59e0b; border: 1.5px solid #fff;
  margin-bottom: -3px;
}
.cf-ind-tl-tip {
  position: absolute; bottom: calc(100% + 8px); left: 50%; transform: translateX(-50%);
  background: #0f172a; color: #fff;
  padding: 6px 10px; border-radius: 6px;
  font-size: 11px; white-space: nowrap;
  opacity: 0; pointer-events: none;
  transition: opacity .15s;
  z-index: 10;
}
.cf-ind-tl-col:hover .cf-ind-tl-tip { opacity: 1; }

.cf-ind-timeline-axis {
  display: flex; gap: 2px;
  font-size: 9.5px; color: #94a3b8;
  padding: 0 6px;
}
.cf-ind-timeline-axis span { flex: 1; text-align: center; }

.cf-ind-timeline-legend {
  display: flex; gap: 14px; justify-content: center;
  padding-top: 4px;
}
.cf-ind-tl-legend-item {
  display: inline-flex; align-items: center; gap: 5px;
  font-size: 10.5px; color: #64748b;
}
.cf-ind-tl-legend-bar {
  display: inline-block; width: 10px; height: 10px;
  background: linear-gradient(180deg, #1e5baa 0%, #3b82f6 100%);
  border-radius: 2px;
}
.cf-ind-tl-legend-dot {
  display: inline-block; width: 8px; height: 8px;
  background: #f59e0b; border-radius: 50%;
}

/* ──── PARCELAS ──── */
.cf-mat-pag-empty {
  padding: 14px; background: #f8fafc; border-radius: 6px;
  display: flex; gap: 10px; align-items: center;
}
.cf-mat-pag-empty small { color: #64748b; font-size: 11.5px; line-height: 1.5; }

.cf-mat-pag-summary {
  display: flex; flex-direction: column; gap: 5px;
  padding: 10px 12px; background: #f8fafc; border-radius: 6px;
  margin-bottom: 8px;
}
.cf-mat-pag-summary span { font-size: 12.5px; color: #475569; }
.cf-mat-pag-summary strong { color: #10b981; font-family: 'IBM Plex Sans', sans-serif; font-size: 14px; }
.cf-mat-pag-bar {
  height: 5px; background: #e2e8f0; border-radius: 3px; overflow: hidden;
}
.cf-mat-pag-bar-fill {
  height: 100%; background: #10b981; transition: width .3s;
}

.cf-mat-pag-table { width: 100%; border-collapse: collapse; }
.cf-mat-pag-table th, .cf-mat-pag-table td {
  padding: 7px 8px; border-bottom: 1px solid #f1f5f9;
  font-size: 12px; vertical-align: middle;
}
.cf-mat-pag-table th {
  font-size: 10px; color: #94a3b8; font-weight: 600;
  text-transform: uppercase; letter-spacing: 0.4px; text-align: left;
}
.cf-mat-pag-table tr.pago td { color: #065f46; }
.cf-mat-pag-table tr.atrasado td { color: #991b1b; background: #fef2f2; }

.cf-mat-pag-del {
  width: 22px; height: 22px; border: none; background: transparent;
  border-radius: 4px; cursor: pointer; color: #94a3b8;
  display: flex; align-items: center; justify-content: center;
}
.cf-mat-pag-del:hover { background: #fee2e2; color: #dc2626; }

/* Esconder tab que perdeu permissão */
.cf-perm-hidden { display: none !important; }
