/* ============================================================
   KIPUS — Base configuration
   Bootstrap 5 theme overrides & project design tokens.
   Load BEFORE all other Kipus CSS files.
   ============================================================ */

/* ── Design tokens ─────────────────────────────────────── */
:root {
  /* Brand */
  --kp-red:       #991b1b;
  --kp-red-dk:    #7f1d1d;
  --kp-red-alpha: rgba(153, 27, 27, 0.09);
  --kp-red-ring:  rgba(153, 27, 27, 0.18);

  /* Roxo de "Entregue" / "Em Revisão" (fidelidade ao legado) — chrome, não dado */
  --kp-purple:    #b24ef0;

  /* Layout */
  --sb-bg:        #ffffff;
  --sb-border:    #e8eaed;
  --sb-width:     260px;

  /* Text */
  --tx-primary:   #111827;
  --tx-secondary: #6b7280;
  --tx-muted:     #9ca3af;

  /* Interaction */
  --item-hover:   rgba(0, 0, 0, 0.04);
  --item-radius:  7px;

  /* Typography */
  --font-main: 'DM Sans', 'Segoe UI', sans-serif;
  --font-mono: 'DM Mono', 'Courier New', monospace;

  /* Bootstrap 5 primary → project red */
  --bs-primary:          var(--kp-red);
  --bs-primary-rgb:      153, 27, 27;
  --bs-link-color:       var(--kp-red);
  --bs-link-hover-color: var(--kp-red-dk);
}

/* ── Bootstrap button overrides → project red ─────────── */
/* CSS variables alone are ignored by AdminLTE's hardcoded !important rules,
   so we also set the concrete properties with !important on each state. */
.btn-primary {
  --bs-btn-bg:                    var(--kp-red);
  --bs-btn-border-color:          var(--kp-red);
  --bs-btn-hover-bg:              var(--kp-red-dk);
  --bs-btn-hover-border-color:    var(--kp-red-dk);
  --bs-btn-focus-shadow-rgb:      153, 27, 27;
  --bs-btn-active-bg:             var(--kp-red-dk);
  --bs-btn-active-border-color:   var(--kp-red-dk);
  --bs-btn-disabled-bg:           var(--kp-red);
  --bs-btn-disabled-border-color: var(--kp-red);
  background-color: var(--kp-red) !important;
  border-color:     var(--kp-red) !important;
}

.btn-primary:hover {
  background-color: var(--kp-red-dk) !important;
  border-color:     var(--kp-red-dk) !important;
}

.btn-primary:focus {
  background-color: var(--kp-red) !important;
  border-color:     var(--kp-red) !important;
  box-shadow: 0 0 0 0.25rem var(--kp-red-ring) !important;
}

.btn-primary:active,
.btn-primary.active {
  background-color: var(--kp-red-dk) !important;
  border-color:     var(--kp-red-dk) !important;
}

.btn-primary:disabled,
.btn-primary.disabled {
  background-color: var(--kp-red) !important;
  border-color:     var(--kp-red) !important;
}

.btn-outline-primary {
  --bs-btn-color:               var(--kp-red);
  --bs-btn-border-color:        var(--kp-red);
  --bs-btn-hover-bg:            var(--kp-red);
  --bs-btn-hover-border-color:  var(--kp-red);
  --bs-btn-focus-shadow-rgb:    153, 27, 27;
  --bs-btn-active-bg:           var(--kp-red);
  --bs-btn-active-border-color: var(--kp-red);
  color:        var(--kp-red) !important;
  border-color: var(--kp-red) !important;
}

.btn-outline-primary:hover,
.btn-outline-primary:active,
.btn-outline-primary.active {
  background-color: var(--kp-red) !important;
  border-color:     var(--kp-red) !important;
  color: #fff !important;
}

/* ── Bootstrap utility class overrides ────────────────── */
.text-primary   { color:            var(--kp-red) !important; }
.border-primary { border-color:     var(--kp-red) !important; }
.bg-primary     {
  background-color: rgba(var(--bs-primary-rgb), var(--bs-bg-opacity, 1)) !important;
}

/* ── Bootstrap pagination → project red ───────────────── */
.page-link {
  color: var(--kp-red) !important;
}

.page-link:hover,
.page-link:focus {
  color: var(--kp-red-dk) !important;
  box-shadow: none !important;
}

.page-item.active .page-link {
  background-color: var(--kp-red) !important;
  border-color:     var(--kp-red) !important;
  color: #fff !important;
}

/* ── AdminLTE card-outline → project red ──────────────── */
.card.card-outline.card-danger {
  border-top-color: var(--kp-red) !important;
}

/* ============================================================
   DARK MODE — design tokens + global structural fixes
   Uses the BS5-standard [data-bs-theme="dark"] selector so
   ALL BS5 components (card, table, form, modal…) adapt
   automatically with zero per-component CSS.
   Only AdminLTE shell elements (sidebar, header, content-
   wrapper) still need explicit overrides in their own files.
   ============================================================ */
[data-bs-theme="dark"] {
  /* Kipus shell tokens */
  --sb-bg:        #111318;
  --sb-border:    #1e2025;
  --tx-primary:   #e6edf3;
  --tx-secondary: #8b949e;
  --tx-muted:     #6e7681;
  --item-hover:   rgba(255, 255, 255, 0.07);
}

/* AdminLTE's .content-wrapper has a hardcoded light background.
   One rule here covers every page — no per-page dark CSS needed. */
[data-bs-theme="dark"] .content-wrapper {
  background-color: var(--bs-body-bg);
  color: var(--bs-body-color);
}

/* Pagination: let BS5 handle the base colors in dark mode;
   only keep the brand-red active state and disabled muting. */
[data-bs-theme="dark"] .page-link {
  background-color: var(--sb-bg) !important;
  border-color:     var(--sb-border) !important;
  color: #f87171 !important;
}

[data-bs-theme="dark"] .page-item.active .page-link {
  background-color: var(--kp-red) !important;
  border-color:     var(--kp-red) !important;
  color: #fff !important;
}

[data-bs-theme="dark"] .page-item.disabled .page-link {
  background-color: var(--sb-bg) !important;
  border-color:     var(--sb-border) !important;
}

/* ===== Select2: altura/alinhamento BS5 + suporte a dark mode ===== */
.select2-container--bootstrap4 .select2-selection--single {
  height: calc(1.5em + 0.75rem + 2px);
}
.select2-container--bootstrap4 .select2-selection--single .select2-selection__rendered {
  line-height: calc(1.5em + 0.75rem);
}
.select2-container--bootstrap4 .select2-selection--single .select2-selection__arrow {
  top: 0 !important;
  height: 100% !important;
}
.select2-container--bootstrap4 .select2-selection--single .select2-selection__arrow b {
  top: 50% !important;
}
[data-bs-theme="dark"] .select2-container--bootstrap4 .select2-selection,
[data-bs-theme="dark"] .select2-dropdown,
[data-bs-theme="dark"] .select2-search__field {
  background-color: var(--bs-body-bg) !important;
  border-color: var(--bs-border-color) !important;
  color: var(--bs-body-color) !important;
}
[data-bs-theme="dark"] .select2-container--bootstrap4 .select2-selection__rendered,
[data-bs-theme="dark"] .select2-results__option {
  color: var(--bs-body-color) !important;
}
[data-bs-theme="dark"] .select2-container--bootstrap4 .select2-results__option--highlighted {
  background-color: var(--kp-red) !important;
  color: #fff !important;
}

/* Cards de dashboard clicáveis (cards-como-filtro) — leve realce no hover */
.kp-card-filtro { transition: transform .12s ease, box-shadow .12s ease; }
.kp-card-filtro:hover { transform: translateY(-2px); box-shadow: 0 .5rem 1rem rgba(0,0,0,.08) !important; }

/* Chevron dos cards de dashboard retráteis (lista_alertas) — gira ao expandir */
.kp-collapse-chevron { transition: transform .15s ease; }
[data-bs-toggle="collapse"][aria-expanded="true"] .kp-collapse-chevron { transform: rotate(180deg); }

/* Painel: linha de OS em revisão — roxo claro (fidelidade ao legado #edc8f3),
   com especificidade que vence o .table-striped do Bootstrap. */
table.table-striped > tbody > tr.linha-revisao,
table > tbody > tr.linha-revisao { background-color: #f3e6f9 !important; }
table.table-hover > tbody > tr.linha-revisao:hover { background-color: #ecd6f3 !important; }

/* Badge roxo "Entregue" / "Em Revisão" — substitui o hex hardcoded no template */
.kp-badge-revisao {
  background-color: var(--kp-purple) !important;
  color: #fff !important;
}

/* Alpine: esconde elementos x-cloak até o Alpine inicializar (evita flash das fases) */
[x-cloak] { display: none !important; }

/* ── Abas segmentadas (underline) na paleta da marca ──────────────────── */
/* Substitui o nav-tabs básico por um controle underline moderno: ativo em
   vermelho da marca, hover suave, alinhamento limpo. Navegação segue por link. */
.kp-tabs {
  gap: .25rem;
  border-bottom: 1px solid var(--bs-border-color);
}
.kp-tabs .kp-tab {
  position: relative;
  padding: .55rem .9rem;
  font-weight: 600;
  font-size: .9rem;
  color: var(--tx-secondary);
  text-decoration: none;
  border: 0;
  border-bottom: 2px solid transparent;
  margin-bottom: -1px;
  border-radius: var(--item-radius) var(--item-radius) 0 0;
  transition: color .15s ease, background-color .15s ease, border-color .15s ease;
}
.kp-tabs .kp-tab:hover {
  color: var(--kp-red);
  background-color: var(--kp-red-alpha);
}
.kp-tabs .kp-tab.active {
  color: var(--kp-red);
  border-bottom-color: var(--kp-red);
}
.kp-tabs .kp-tab:focus-visible {
  outline: none;
  box-shadow: 0 0 0 .2rem var(--kp-red-ring);
  border-radius: var(--item-radius);
}

/* Botão de ação em massa minimalista: micro-tipografia (menor, uppercase, tracked) + ícone.
   Rótulo curto; o significado completo fica no title (tooltip). Usado na toolbar do /horas-extras. */
.kp-btn-min {
  font-size: .68rem;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: .05em;
  padding: .3rem .75rem;
  display: inline-flex;
  align-items: center;
  gap: .38rem;
  line-height: 1.1;
}
.kp-btn-min > i {
  font-size: .82rem;
  letter-spacing: 0;
}

/* Console de ações em massa do /horas-extras (faixa entre filtros e listagem). */
.kp-massa {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: .4rem;
  padding: .5rem .8rem;
  background: var(--bs-tertiary-bg, #f6f7f9);
  border: 1px solid var(--bs-border-color);
  border-radius: .65rem;
}
.kp-massa-label {
  display: inline-flex;
  align-items: center;
  gap: .4rem;
  font-size: .64rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: .07em;
  color: var(--tx-secondary, #6c757d);
  padding-right: .1rem;
}
.kp-massa-sep {
  align-self: stretch;
  width: 1px;
  background: var(--bs-border-color);
  margin: .15rem .2rem;
}
.kp-massa-btn {
  display: inline-flex;
  align-items: center;
  gap: .4rem;
  border: 1px solid transparent;
  background: transparent;
  padding: .32rem .72rem;
  border-radius: 2rem;
  font-size: .66rem;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: .045em;
  color: var(--tx-secondary, #495057);
  line-height: 1.1;
  transition: background-color .15s ease, color .15s ease, border-color .15s ease;
}
.kp-massa-btn > i {
  font-size: .84rem;
  letter-spacing: 0;
}
.kp-massa-btn:hover { background: rgba(0, 0, 0, .04); }
.kp-massa-btn.is-banco:hover { background: rgba(25, 135, 84, .12); color: #198754; border-color: rgba(25, 135, 84, .32); }
.kp-massa-btn.is-pagar:hover { background: rgba(13, 110, 253, .12); color: #0d6efd; border-color: rgba(13, 110, 253, .32); }
.kp-massa-btn.is-vincular:hover { background: var(--kp-red-alpha); color: var(--kp-red); border-color: var(--kp-red); }
.kp-massa-btn.is-recalcular:hover { background: rgba(108, 117, 125, .14); color: #495057; border-color: rgba(108, 117, 125, .32); }
.kp-massa-btn.is-excluir:hover { background: rgba(220, 53, 69, .12); color: #dc3545; border-color: rgba(220, 53, 69, .32); }

/* ── Polimento da barra de filtros compartilhada (foco na marca) ──────── */
/* Escopo restrito à régua de filtros (.card-body.border-bottom do element
   kipus/tables/filters.php), p/ não afetar formulários de add/edit. */
.card-body.border-bottom .form-control:focus,
.card-body.border-bottom .form-select:focus {
  border-color: var(--kp-red);
  box-shadow: 0 0 0 .2rem var(--kp-red-ring);
}
.card-body.border-bottom .input-group-text {
  color: var(--tx-muted);
}

/* Controles da régua: cantos suaves, respiro e altura coerente. */
.card-body.border-bottom .form-control,
.card-body.border-bottom .form-select {
  border-radius: var(--item-radius, .5rem);
  border-color: var(--bs-border-color);
  transition: border-color .15s ease, box-shadow .15s ease, background-color .15s ease;
}
/* Selects respiram melhor e revelam afinidade com a marca no hover. */
.card-body.border-bottom .form-select {
  padding-block: .3rem;
  cursor: pointer;
}
.card-body.border-bottom .form-select:hover {
  border-color: var(--kp-red-ring);
}
/* Search: agrupa lupa + campo como um único “pill” coeso. */
.card-body.border-bottom .input-group .input-group-text {
  border-radius: var(--item-radius, .5rem) 0 0 var(--item-radius, .5rem);
}
.card-body.border-bottom .input-group .form-control {
  border-radius: 0 var(--item-radius, .5rem) var(--item-radius, .5rem) 0;
}
.card-body.border-bottom .input-group:focus-within {
  border-radius: var(--item-radius, .5rem);
  box-shadow: 0 0 0 .2rem var(--kp-red-ring);
}
.card-body.border-bottom .input-group:focus-within .input-group-text,
.card-body.border-bottom .input-group:focus-within .form-control {
  border-color: var(--kp-red);
  box-shadow: none;
}
.card-body.border-bottom .input-group:focus-within .input-group-text {
  color: var(--kp-red);
}

/* ── Régua de filtros: botões coesos (Filtrar / Limpar / Add) ─────────── */
/* Altura/raio dos controles e botões batem com os inputs-sm da régua,
   para que tudo descanse na mesma baseline. */
.card-body.border-bottom .btn-sm,
.card-body.border-bottom .btn-group-sm > .btn {
  border-radius: var(--item-radius, .5rem);
  padding-block: .3rem;
  line-height: 1.35;
}
/* Grupo Filtrar+Limpar lê como uma única peça: cantos externos suaves,
   junção interna reta para reforçar que agem juntos. */
.card-body.border-bottom .kp-filtros-acoes .btn:not(:last-child) {
  border-top-right-radius: 0;
  border-bottom-right-radius: 0;
}
.card-body.border-bottom .kp-filtros-acoes .btn:not(:first-child) {
  border-top-left-radius: 0;
  border-bottom-left-radius: 0;
  margin-left: -1px;
}
/* Filtrar: ação primária sutil (afinidade com a marca, sem competir com o
   vermelho cheio do Add). Limpar: discreto/ghost. */
.card-body.border-bottom .kp-filtros-acoes .btn-outline-primary {
  --bs-btn-color: var(--kp-red);
  --bs-btn-border-color: var(--kp-red-ring);
  --bs-btn-hover-bg: var(--kp-red);
  --bs-btn-hover-border-color: var(--kp-red);
  --bs-btn-active-bg: var(--kp-red-dk);
  --bs-btn-active-border-color: var(--kp-red-dk);
}
.card-body.border-bottom .kp-filtros-acoes .btn-outline-secondary {
  --bs-btn-color: var(--tx-muted);
  --bs-btn-border-color: var(--bs-border-color);
  --bs-btn-hover-bg: var(--bs-secondary-bg);
  --bs-btn-hover-color: var(--bs-body-color);
  --bs-btn-hover-border-color: var(--bs-border-color);
}
.card-body.border-bottom .kp-filtros-acoes .btn:focus-visible {
  box-shadow: 0 0 0 .2rem var(--kp-red-ring);
  z-index: 2;
}

/* ── Painel Técnico: faixa de alertas (paleta da marca) ───────────────── */
.kp-alertas-header {
  background-color: var(--kp-red-alpha);
  color: var(--kp-red-dk);
  border-bottom: 1px solid var(--kp-red-ring);
}
.kp-alertas-icon {
  width: 1.6rem;
  height: 1.6rem;
  border-radius: 50%;
  background-color: var(--kp-red);
  color: #fff;
  font-size: 0.8rem;
}
.kp-badge-setor {
  background-color: var(--kp-red);
  color: #fff;
  font-size: 0.68rem;
  letter-spacing: 0.04em;
}
.kp-alerta-item { transition: background-color .12s ease; }
.kp-alerta-item:hover { background-color: var(--kp-red-alpha) !important; }

/* ── Painel Técnico: linha de filtros alinhada ────────────────────────── */
/* Busca cresce à esquerda; filtros agrupados à direita (ms-auto). */
.kp-filtros-busca { flex: 0 1 360px; min-width: 240px; }
.kp-filtros-busca .input-group-text { background-color: var(--bs-body-bg); }
.kp-filtros-sel .form-select { width: auto; min-width: 8.25rem; max-width: 11rem; }

/* Telas médias: filtros descem para uma 2ª régua, ainda lado a lado. */
@media (max-width: 991.98px) {
  .kp-filtros-sel { width: 100%; margin-left: 0 !important; }
  .kp-filtros-busca { flex: 1 1 auto; }
}

@media (max-width: 575.98px) {
  .kp-filtros-sel .form-select { flex: 1 1 calc(50% - .25rem); min-width: 0; max-width: none; }
}

/* ── Painel Técnico: barra de progresso (paleta da marca) ─────────────── */
.kp-progress {
  height: 18px;
  border-radius: 999px;
  background-color: var(--kp-red-alpha);
  overflow: hidden;
  position: relative; /* base p/ o rótulo % centralizado (.kp-progress-pct) */
}
.kp-progress-bar {
  border-radius: 999px;
  background-image: linear-gradient(90deg, var(--kp-red) 0%, var(--kp-red-dk) 100%);
  transition: width .3s ease;
}
/* % centralizado SOBRE a barra inteira (não preso ao preenchimento); branco com sombra
   p/ ficar legível tanto sobre a parte preenchida quanto sobre o trilho claro. */
.kp-progress-pct {
  position: absolute;
  inset: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 0.72rem;
  font-weight: 700;
  color: #fff;
  text-shadow: 0 0 2px rgba(0, 0, 0, .6);
  pointer-events: none;
  white-space: nowrap;
}

/* ── Dashboard card: realce no hover (cell/DashboardCards + element/kipus/dashboard/card) ─── */
.kp-dashboard-card:hover {
  transform: translateY(-3px);
  box-shadow: 0 .5rem 1rem rgba(0, 0, 0, .08) !important;
}

/* ── Stepper de progresso (element/kipus/stepper) — paleta da marca ─────── */
.kp-stepper-card {
  border-radius: 16px;
  border: 1px solid var(--bs-border-color);
  background: var(--bs-body-bg);
  box-shadow: 0 4px 20px rgba(0, 0, 0, .05);
}
.kp-stepper-wrapper {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  padding: 2.5rem 1.5rem;
  position: relative;
  overflow-x: auto;
}
.kp-stepper-item {
  flex: 1;
  display: flex;
  flex-direction: column;
  align-items: center;
  text-align: center;
  position: relative;
  min-width: 130px;
}
.kp-stepper-item::after {
  content: '';
  position: absolute;
  top: 25px;
  left: 50%;
  width: 100%;
  height: 3px;
  background: var(--bs-gray-300);
  z-index: 1;
}
.kp-stepper-item:last-child::after { display: none; }
.kp-stepper-item.line-active::after { background: var(--kp-red); }
.kp-stepper-circle {
  width: 50px;
  height: 50px;
  border-radius: 50%;
  background: var(--bs-gray-100);
  border: 3px solid var(--bs-gray-300);
  display: flex;
  align-items: center;
  justify-content: center;
  z-index: 2;
  margin-bottom: 1rem;
  transition: all .3s ease;
  color: var(--bs-gray-500);
  font-weight: 700;
  font-size: 1.2rem;
}
.kp-stepper-item.active .kp-stepper-circle {
  background: var(--kp-red);
  border-color: var(--kp-red);
  color: #fff;
  box-shadow: 0 0 15px var(--kp-red-ring);
}
.kp-stepper-circle i { font-size: 1.1rem; }
.kp-stepper-content h5 {
  font-size: .9rem;
  font-weight: 700;
  text-transform: uppercase;
  margin: 0 0 .3rem 0;
  color: var(--bs-secondary-color);
  letter-spacing: .5px;
}
.kp-stepper-item.active .kp-stepper-content h5 { color: var(--kp-red); }
.kp-stepper-user {
  font-size: .85rem;
  font-weight: 600;
  color: var(--bs-emphasis-color);
  margin: 0;
}
.kp-stepper-item.active .kp-stepper-user { color: var(--kp-red-dk); }
.kp-stepper-date {
  font-size: .78rem;
  color: var(--bs-secondary-color);
  margin: .15rem 0 0 0;
  line-height: 1.3;
}
@media (max-width: 768px) {
  .kp-stepper-wrapper {
    flex-direction: column;
    gap: 2rem;
    align-items: flex-start;
    padding: 1.5rem;
  }
  .kp-stepper-item {
    flex-direction: row;
    align-items: flex-start;
    text-align: left;
    width: 100%;
    gap: 1rem;
    min-width: unset;
  }
  .kp-stepper-item::after {
    left: 25px;
    top: 25px;
    width: 3px;
    height: calc(100% + 2rem);
  }
  .kp-stepper-circle { margin-bottom: 0; }
}

/* ── Relatório "Vendas por Obra" (Obras/vendas_por_obra) ───────────────── */
/* Matriz obra × competência com cabeçalho/colunas fixas e arraste opcional. */
.kp-tabela-scroll {
  overflow: auto;
  white-space: nowrap;
  position: relative;
  max-height: 80vh;
}
.kp-tabela-scroll.kp-drag-active { cursor: grab; user-select: none; }
.kp-tabela-scroll.kp-drag-active:active { cursor: grabbing; }
.kp-tabela-scroll .table th.kp-sticky-col,
.kp-tabela-scroll .table td.kp-sticky-col {
  position: sticky;
  background-color: var(--bs-body-bg);
  z-index: 10;
  border-right: 2px solid var(--bs-border-color);
}
.kp-tabela-scroll .table thead th.kp-sticky-col {
  z-index: 20;
  background-color: var(--bs-tertiary-bg);
}
.kp-col-id    { left: 0;     width: 60px;  min-width: 60px; }
.kp-col-obra  { left: 60px;  width: 300px; min-width: 300px; }
.kp-col-ocorr { left: 360px; width: 100px; min-width: 100px; }
.kp-col-total { left: 460px; width: 150px; min-width: 150px; }
.kp-valor-positivo { background-color: var(--bs-info-bg-subtle); }
.kp-tabela-scroll .table tr.kp-tr-totais th {
  background-color: var(--bs-secondary-bg);
  font-weight: bold;
}

/* ── Card view (toggle Lista/Cards em Metas/Objetivos) ─────────────────── */
.kp-meta-card { border-radius: 12px; overflow: hidden; }
.kp-card-gradient {
  background: linear-gradient(135deg, var(--kp-red) 0%, var(--kp-red-dk) 100%);
  padding: 16px 18px;
}
.kp-card-gradient .badge {
  background: rgba(255, 255, 255, .2);
  color: #fff;
  font-size: 10px;
  font-weight: 500;
}
.kp-card-ring {
  width: 44px; height: 44px;
  border-radius: 50%;
  border: 3px solid rgba(255, 255, 255, .5);
  display: flex; align-items: center; justify-content: center;
  font-size: 11px; font-weight: 700; color: #fff;
}
.kp-card-bar-track {
  height: 4px; border-radius: 2px;
  background: rgba(255, 255, 255, .2);
  overflow: hidden;
}
.kp-card-bar-fill {
  height: 4px; border-radius: 2px;
  background: rgba(255, 255, 255, .85);
  transition: width .5s;
}
.kp-card-kpi { font-size: 18px; font-weight: 700; }
.kp-card-kpi-label {
  font-size: 10px; text-transform: uppercase; letter-spacing: .05em;
  color: var(--bs-secondary-color);
}

/* Utilitário: permite text-truncate dentro de flex item (Bootstrap não traz por padrão). */
.min-w-0 { min-width: 0; }

/* ── Calendário de Alocações: matriz recurso × dia ───────────────────────── */
/* Célula do dia: bloco colorido preenchendo a célula (não um risco fino). */
.cal-res-cell { font-size: .78rem; white-space: nowrap; }
.cal-type-badge {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 20px;
  height: 20px;
  border-radius: 5px;
  color: #fff;
  font-size: .63rem;
  font-weight: 800;
  margin-right: 6px;
  flex-shrink: 0;
  vertical-align: middle;
}
.cal-cell {
  width: 34px;
  min-width: 34px;
  max-width: 34px;
  padding: 0 !important;
  vertical-align: bottom;
  position: relative;
}
.cal-cell.is-wknd  { background: var(--bs-secondary-bg); }
.cal-cell.is-today { background: var(--bs-warning-bg-subtle); }
.cal-cell.has-events:hover { background: var(--kp-red-alpha); }
.cal-bars {
  display: flex;
  flex-direction: column;
  gap: 1px;
  padding: 3px 2px 2px;
  min-height: 30px;
  justify-content: flex-end;
}
.cal-bar {
  display: block;
  width: 100%;
  height: 6px;
  border-radius: 2px;
  opacity: .92;
}
.cal-count {
  position: absolute;
  top: 1px;
  right: 1px;
  width: 14px;
  height: 14px;
  border-radius: 50%;
  background: #1e293b;
  color: #fff;
  font-size: .55rem;
  font-weight: 700;
  display: flex;
  align-items: center;
  justify-content: center;
  line-height: 1;
  pointer-events: none;
}

/* ── Tabelas padrão (cell/TableStandard, wrapper .kipus-table) ──────────────
   Texto das células QUEBRA p/ caber na largura, eliminando scroll lateral.
   Escopo restrito a .kipus-table p/ não afetar tabelas de modal/ficha. */
.kipus-table > .table-responsive {
  /* Com wrap o conteúdo cabe; mantém overflow só como salvaguarda extrema. */
  overflow-x: visible;
}
.kipus-table .table {
  width: 100%;
}
.kipus-table .table th,
.kipus-table .table td {
  white-space: normal;
  word-break: break-word;
  overflow-wrap: anywhere;
}
/* Exceção: coluna de Ações (botões view/edit/delete) nunca quebra. */
.kipus-table .table th.kp-col-acoes,
.kipus-table .table td.kp-col-acoes {
  white-space: nowrap;
  word-break: normal;
  overflow-wrap: normal;
}
/* Modificador p/ TABELA LARGA (muitas colunas): não quebra a célula — transborda e
   rola na horizontal via .table-responsive, em vez de esmagar/quebrar letra a letra. */
.kp-table-wide .kipus-table .table th,
.kp-table-wide .kipus-table .table td {
  white-space: nowrap;
  word-break: normal;
  overflow-wrap: normal;
}
/* Utilitário opcional p/ colunas curtas (datas, status) que não devem quebrar. */
.kipus-table .table th.kp-col-nowrap,
.kipus-table .table td.kp-col-nowrap {
  white-space: nowrap;
}

/* =====================================================================
   Dashboard Custo de Equipes — modo "Cards" (KPIs por seção)
   Porte do legado element cards_os_dashboard.php; <style> inline movido
   p/ cá (regra v2: sem <style> em template). Cores semânticas mantidas
   (sucesso/erro/alerta) — chrome de marca via --kp-red onde aplicável.
   ===================================================================== */
.kp-card-stat {
  border-radius: 10px;
  box-shadow: 0 4px 6px rgba(0, 0, 0, 0.05);
  padding: 1.5rem;
  background: #fff;
  height: 100%;
  border: none;
  border-bottom: 4px solid #eee;
}
.kp-card-stat.primary   { border-bottom-color: var(--kp-red); }
.kp-card-stat.success   { border-bottom-color: #198754; }
.kp-card-stat.info      { border-bottom-color: #0dcaf0; }
.kp-card-stat.warning   { border-bottom-color: #ffc107; }
.kp-card-stat.danger    { border-bottom-color: #dc3545; }
.kp-card-stat.secondary { border-bottom-color: #6c757d; }
.kp-card-stat.dark      { border-bottom-color: #343a40; }
.kp-stat-title {
  font-size: 0.9rem;
  color: #6c757d;
  text-transform: uppercase;
  font-weight: 600;
  margin-bottom: 0.5rem;
}
.kp-stat-value {
  font-size: 1.8rem;
  font-weight: 700;
  color: #343a40;
}
.kp-section-title {
  font-weight: 600;
  color: #2c3e50;
  border-bottom: 2px solid #eaeaea;
  padding-bottom: 0.5rem;
  margin-bottom: 1rem;
}

/* =====================================================================
   Dashboard Custo de Equipes / Ficha Técnica — aba "Tabela" e sub-abas.
   Porte do legado webroot/css/DashboardCustoEquipes/dashboard.css (planilha
   densa, colunas-grupo, sticky, semáforos). <style>/<script> inline do legado
   movidos p/ cá. Cabeçalho usa o vermelho da marca (var(--kp-red)).
   ===================================================================== */
:root {
  --kp-surf2:  #f8fafc;
  --kp-border2: #e2e8f0;
  --kp-text-1: #1e293b;
  --kp-text-2: #475569;
  --kp-text-3: #94a3b8;
  --kp-green:  #15803d;
  --kp-green-lt: #f0fdf4;
  --kp-danger2: #dc2626;
  --kp-r2:     6px;
  --kp-r-sm2:  4px;
}

/* ---- Column-group pill tabs ---- */
.kp-coltabs {
  padding: 9px 14px;
  background: var(--kp-surf2);
  border-bottom: 1px solid var(--kp-border2);
  gap: 6px;
}
.kp-coltabs-lbl {
  font-size: .65rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: .08em;
  color: var(--kp-text-3);
  white-space: nowrap;
  margin-right: 2px;
}
.kp-coltab {
  padding: 4px 13px;
  font-size: .71rem;
  font-weight: 700;
  border: 1.5px solid var(--kp-border2);
  border-radius: 20px;
  background: #fff;
  color: var(--kp-text-2);
  cursor: pointer;
  transition: all .15s;
  display: inline-flex;
  align-items: center;
  gap: 5px;
  letter-spacing: .04em;
  text-transform: uppercase;
  line-height: 1;
}
.kp-coltab:hover { border-color: var(--kp-red); color: var(--kp-red); background: var(--kp-red-alpha); }
.kp-coltab.active {
  background: var(--kp-red);
  border-color: var(--kp-red);
  color: #fff;
  box-shadow: 0 2px 6px rgba(153, 27, 27, .25);
}
.kp-coltab i { font-size: .62rem; }

/* Column-group visibility: wrapper recebe .kp-colgrp-<grupo> (Alpine :class).
   Por padrão, toda coluna agrupável fica oculta (visão "identificação");
   cada grupo ativo reexibe só as suas. */
.kp-os-planilha [data-colgroup] { display: none; }
.kp-colgrp-receita          [data-colgroup="receita"],
.kp-colgrp-custos_executados [data-colgroup="custos_executados"],
.kp-colgrp-mao_obra          [data-colgroup="mao_obra"],
.kp-colgrp-equipamentos      [data-colgroup="equipamentos"],
.kp-colgrp-custos_adicionais [data-colgroup="custos_adicionais"],
.kp-colgrp-planejados        [data-colgroup="planejados"],
.kp-colgrp-recursos          [data-colgroup="recursos"] { display: table-cell; }

/* ---- Scroll wrapper ---- */
.kp-tbl-wrap {
  max-height: calc(100vh - 320px);
  overflow-y: auto;
  overflow-x: auto;
  min-height: 360px;
}
.kp-tbl-wrap::-webkit-scrollbar { width: 6px; height: 6px; }
.kp-tbl-wrap::-webkit-scrollbar-track { background: var(--kp-border2); }
.kp-tbl-wrap::-webkit-scrollbar-thumb { background: var(--kp-text-3); border-radius: 3px; }
.kp-tbl-wrap::-webkit-scrollbar-thumb:hover { background: var(--kp-red); }

/* ---- Planilha (dense table) ---- */
.table-planilha {
  font-size: .78rem;
  margin-bottom: 0;
  border-collapse: separate;
  border-spacing: 0;
  width: 100%;
}
.table-planilha thead th {
  background: var(--kp-red);
  color: #fff;
  vertical-align: middle;
  text-align: center;
  white-space: nowrap;
  border: none;
  border-right: 1px solid rgba(255, 255, 255, .1);
  position: sticky;
  top: 0;
  z-index: 10;
  padding: 7px 8px;
  font-size: .69rem;
  font-weight: 700;
  letter-spacing: .04em;
}
.table-planilha thead tr.grupo th {
  background: var(--kp-red-dk);
  font-size: .63rem;
  letter-spacing: .08em;
  text-transform: uppercase;
  padding: 4px 8px;
}
.table-planilha tbody tr { transition: background .1s; }
.table-planilha tbody tr:hover td,
.table-planilha tbody tr:hover .sticky-col { background: #fff7f7 !important; }
.table-planilha tbody td {
  vertical-align: middle;
  border-top: 1px solid var(--kp-border2);
  border-bottom: none;
  border-left: none;
  border-right: none;
  padding: 6px 8px;
  color: var(--kp-text-1);
}
.table-planilha tfoot { position: sticky; bottom: 0; z-index: 10; }
.table-planilha tfoot tr { position: sticky; bottom: 0; }
.table-planilha tfoot td {
  font-weight: 700;
  background: #f1f5f9;
  border-top: 2px solid #cbd5e1;
  padding: 7px 8px;
  color: var(--kp-text-1);
  position: sticky;
  bottom: 0;
  z-index: 10;
}

/* ---- Sticky columns ---- */
.sticky-col { position: sticky; background: #fff; z-index: 5; }
thead .sticky-col { background: var(--kp-red) !important; z-index: 15; }
thead tr.grupo .sticky-col { background: var(--kp-red-dk) !important; }
tfoot .sticky-col { background: #f1f5f9 !important; z-index: 15 !important; bottom: 0 !important; }
/* Offsets das colunas fixas da planilha de O.S. (9 colunas de identificação/medição). */
.kp-os-planilha .sticky-col-0 { left: 0; }
.kp-os-planilha .sticky-col-1 { left: 55px; min-width: 130px; }
.kp-os-planilha .sticky-col-2 { left: 185px; min-width: 80px; }
.kp-os-planilha .sticky-col-3 { left: 265px; min-width: 78px; }
.kp-os-planilha .sticky-col-4 { left: 343px; min-width: 78px; }
.kp-os-planilha .sticky-col-5 { left: 421px; min-width: 125px; }
.kp-os-planilha .sticky-col-6 { left: 546px; min-width: 125px; }
.kp-os-planilha .sticky-col-7 { left: 671px; min-width: 125px; }
.kp-os-planilha .sticky-col-8 { left: 796px; min-width: 80px; }

/* ---- Detail (expand) rows ---- */
.kp-detail-row td {
  padding: 12px 16px !important;
  background: #f8f8f8 !important;
  border-top: none !important;
  border-bottom: 1px solid var(--kp-border2) !important;
}
.os-num {
  display: inline-block;
  background: var(--kp-red-dk);
  color: #fff;
  padding: 2px 7px;
  border-radius: var(--kp-r-sm2);
  font-size: .69rem;
  font-weight: 700;
  letter-spacing: .04em;
}
.kp-expand-btn {
  width: 26px;
  height: 26px;
  border: 1px solid var(--kp-border2);
  border-radius: var(--kp-r-sm2);
  background: #fff;
  color: var(--kp-text-2);
  cursor: pointer;
  transition: all .15s;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 0;
}
.kp-expand-btn:hover { background: var(--kp-red-alpha); border-color: var(--kp-red); color: var(--kp-red); }
.kp-expand-btn i { font-size: .7rem; }

/* ---- Legend ---- */
.kp-legend {
  padding: 8px 14px;
  background: var(--kp-surf2);
  border-top: 1px solid var(--kp-border2);
  font-size: .68rem;
  color: var(--kp-text-2);
  line-height: 1.8;
}

/* ---- Ociosidade / diárias badges (semáforo) ---- */
.kp-oci-days {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 30px;
  height: 30px;
  border-radius: 50%;
  font-size: .76rem;
  font-weight: 700;
}
.kp-oci-days.has-idle { background: #fef2f2; color: var(--kp-danger2); }
.kp-oci-days.no-idle  { background: var(--kp-green-lt); color: var(--kp-green); }

/* ---- Produtividade ---- */
.kp-prod-val { display: inline-block; font-weight: 700; font-size: .8rem; }
.kp-prod-ok  { color: var(--kp-green); }
.kp-prod-bad { color: var(--kp-danger2); }
.kp-prod-pct {
  display: block;
  font-size: .63rem;
  font-weight: 600;
  letter-spacing: .02em;
  line-height: 1.2;
}

/* ---- Ociosidade: detalhe de ausências (motivo pill) ---- */
.kp-aus-pill {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  border-radius: 10px;
  padding: 1px 8px;
  font-size: .7rem;
  font-weight: 600;
}
.kp-aus-dot { width: 6px; height: 6px; border-radius: 50%; flex-shrink: 0; }

/* =====================================================================
   Ficha Técnica — seletor de modos (Cards/Tabela/Gráficos/Histórico) e
   sub-abas internas (porte do legado: index.php <style> + .kp-navtabs).
   Estado ativo no vermelho da marca (var(--kp-red)).
   ===================================================================== */
.kp-view-selector {
  display: flex;
  align-items: center;
  gap: 16px;
  background: #fff;
  border: 1px solid var(--kp-border2);
  border-radius: 8px;
  padding: 10px 16px;
  box-shadow: 0 1px 4px rgba(0, 0, 0, .07);
  margin-bottom: 16px;
  flex-wrap: nowrap;
}
.kp-view-selector-label {
  font-size: .68rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: .1em;
  color: var(--kp-text-3);
  white-space: nowrap;
  flex-shrink: 0;
}
ul.kp-view-tabs {
  display: flex;
  flex-direction: row;
  flex-wrap: nowrap;
  list-style: none;
  margin: 0;
  padding: 3px;
  background: #f1f5f9;
  border: 1px solid var(--kp-border2);
  border-radius: 8px;
  gap: 2px;
}
ul.kp-view-tabs > li { display: block; margin: 0; padding: 0; }
ul.kp-view-tabs > li > .kp-vt-link {
  display: flex;
  align-items: center;
  gap: 7px;
  padding: 7px 22px;
  border: none;
  border-radius: 6px;
  font-size: .8rem;
  font-weight: 600;
  color: var(--kp-text-2);
  text-decoration: none;
  background: transparent;
  white-space: nowrap;
  line-height: 1.4;
  cursor: pointer;
  transition: color .15s ease, background .15s ease, box-shadow .15s ease;
}
ul.kp-view-tabs > li > .kp-vt-link:hover { color: var(--kp-text-1); background: rgba(255, 255, 255, .75); }
ul.kp-view-tabs > li > .kp-vt-link.active {
  background: #fff;
  color: var(--kp-red);
  font-weight: 700;
  box-shadow: 0 1px 4px rgba(0, 0, 0, .13), 0 0 0 1px rgba(0, 0, 0, .05);
}
ul.kp-view-tabs > li > .kp-vt-link i { font-size: .72rem; }

/* Sub-abas internas da aba "Tabela" (underline) */
ul.kp-navtabs {
  display: flex;
  gap: 0;
  padding: 0;
  margin: 0 0 0 0;
  list-style: none;
  border-bottom: 2px solid var(--kp-border2);
  flex-wrap: wrap;
}
ul.kp-navtabs > li { margin: 0; padding: 0; }
ul.kp-navtabs .kp-nt-link {
  padding: 9px 18px;
  font-size: .8rem;
  font-weight: 600;
  color: var(--kp-text-2);
  border: none;
  border-bottom: 2px solid transparent;
  margin-bottom: -2px;
  cursor: pointer;
  background: none;
  display: flex;
  align-items: center;
  gap: 6px;
  text-decoration: none;
  transition: color .15s, border-color .15s;
}
ul.kp-navtabs .kp-nt-link:hover { color: var(--kp-red); }
ul.kp-navtabs .kp-nt-link.active { color: var(--kp-red); border-bottom-color: var(--kp-red); }
.kp-tab-badge {
  font-size: .64rem;
  font-weight: 700;
  padding: 2px 6px;
  border-radius: 10px;
  background: var(--kp-border2);
  color: var(--kp-text-2);
  transition: background .15s, color .15s;
}
ul.kp-navtabs .kp-nt-link.active .kp-tab-badge { background: var(--kp-red); color: #fff; }

/* Cabeçalho do card de Filtros no tom da marca (porte do .kp-filter-hdr) */
.kp-filter-hdr {
  font-size: .72rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: .08em;
  color: var(--kp-red);
}

/* ── KPIs de Horas Extras (Total / 60% / 100% / 110%) com split Topógrafo × Auxiliar ──
   Porte fiel ao legado (4 caixas com total geral + quebra por função), na paleta da marca. */
.kp-he-kpi {
  border-radius: var(--card-radius, .75rem);
  background: var(--bs-card-bg, #fff);
}
.kp-he-kpi__title {
  font-size: .72rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: .06em;
  color: var(--tx-secondary, #6c757d);
  padding-bottom: .4rem;
  margin-bottom: .35rem;
  border-bottom: 1px solid var(--bs-border-color);
}
.kp-he-kpi__value {
  font-size: 1.5rem;
  font-weight: 800;
  line-height: 1.1;
  color: var(--kp-red);
  margin: .15rem 0 .5rem;
}
.kp-he-kpi__split {
  display: flex;
  justify-content: space-around;
  gap: .5rem;
  background: var(--kp-red-alpha);
  border-radius: .4rem;
  padding: .4rem .25rem;
}
.kp-he-kpi__sub {
  display: flex;
  flex-direction: column;
  align-items: center;
  flex: 1;
}
.kp-he-kpi__sub-label {
  font-size: .66rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: .03em;
  color: var(--tx-secondary, #6c757d);
}
.kp-he-kpi__sub-value {
  font-size: .95rem;
  font-weight: 800;
  color: var(--tx-primary, #212529);
}

/* Multi-select nativo na barra de filtros (Colaborador / OS em Horas Extras): largura mínima
   utilizável e altura compacta (rolável). Substitui o select2 do legado mantendo a multi-seleção. */
.kp-filtro-multi[multiple] {
  min-width: 150px;
  max-width: 220px;
  height: auto;
  min-height: calc(1.5em + .5rem + 2px);
  max-height: 4.5rem;
  padding-top: .15rem;
  padding-bottom: .15rem;
  background-image: none;
}
.kp-filtro-multi[multiple] option { padding: .1rem .35rem; }
/* Rótulo curto acima dos filtros, no tom da toolbar. O seletor [for$="-id"] cobria só
   campos *_id (multiselects); a barra de filtros (.kp-filtros-barra) padroniza TODOS os
   labels da régua — inclusive os que não terminam em -id (qualif. fornecedor, tipo de data,
   datas) — pro cabeçalho ficar igual entre todos os filtros. */
.card-body label[for$="-id"],
.kp-filtros-barra label {
  font-size: .66rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: .03em;
  color: var(--tx-secondary, #6c757d);
  margin-bottom: .1rem;
}

/* Uniformidade da régua de filtros: o Select2 (single) que o kipus-forms aplica nos selects
   é mais alto que os inputs sm nativos (datas/busca), deixando a linha desalinhada em altura.
   Aqui o widget Select2 dentro de .kp-filtros-barra é forçado à mesma altura do form-*-sm. */
.kp-filtros-barra .select2-container--bootstrap4 .select2-selection--single {
  height: calc(1.5em + .5rem + 2px);
  font-size: .875rem;
}
.kp-filtros-barra .select2-container--bootstrap4 .select2-selection--single .select2-selection__rendered {
  line-height: calc(1.5em + .5rem);
  padding-left: .5rem;
}
.kp-filtros-barra .select2-container--bootstrap4 .select2-selection--single .select2-selection__arrow {
  height: calc(1.5em + .5rem);
}

/* ============================================================
   Dashboard Geral (Controladoria) — classes do porte do legado
   ============================================================ */
.dashboard-geral .cards-gap { margin-bottom: 15px; display: flex; flex-wrap: wrap; }
.dashboard-geral .col-20 { flex: 0 0 20%; max-width: 20%; padding: 0 7.5px; }
.dashboard-geral .col-custom { flex: 0 0 16.66%; max-width: 16.66%; padding: .5rem; }
@media (max-width: 992px) {
  .dashboard-geral .col-20 { flex: 0 0 50%; max-width: 50%; }
  .dashboard-geral .col-custom { flex: 0 0 33.33%; max-width: 33.33%; }
}
.dashboard-geral .section-title {
  font-weight: 700;
  color: #991b1b;
  border-bottom: 2px solid #991b1b;
  padding-bottom: .5rem;
}
.kpi-container { display: flex; gap: 15px; margin-bottom: 20px; flex-wrap: wrap; }
.kpi-box { flex: 1; min-width: 200px; border-radius: 8px; padding: 15px; color: #fff; text-align: center; box-shadow: 0 4px 6px rgba(0,0,0,.1); }
.kpi-total { background-color: #17a2b8; }
.kpi-60 { background-color: #28a745; }
.kpi-100 { background-color: #ffc107; color: #333; }
.kpi-110 { background-color: #dc3545; }
.kpi-title { font-size: 1.1rem; font-weight: bold; text-transform: uppercase; margin-bottom: 10px; }
.kpi-value-main { font-size: 2rem; font-weight: bold; margin-bottom: 15px; }
.kpi-split { display: flex; justify-content: space-between; border-top: 1px solid rgba(255,255,255,.3); padding-top: 10px; }
.kpi-100 .kpi-split { border-top-color: rgba(0,0,0,.1); }
.kpi-sub-item { display: flex; flex-direction: column; align-items: center; width: 50%; }
.kpi-sub-label { font-size: .8rem; opacity: .9; }
.kpi-sub-value { font-size: 1.2rem; font-weight: bold; }
.text-orange { color: #fd7e14 !important; }
.text-purple { color: #6f42c1 !important; }
.badge-purple, .bg-purple-soft { background-color: #6f42c1 !important; color: #fff !important; }
.bg-indigo { background-color: #6610f2 !important; color: #fff !important; }

/* Font Awesome x AdminLTE: a classe utilitária .small (e afins) do AdminLTE força font-weight:400,
   o que sobrescreve o peso dos ícones FA SOLID (precisam de 900) — o navegador cai na face
   fa-regular, que no FA6 Free não tem o glifo, e o ícone vira "tofu" (quadrado). Estes seletores
   i.fa-* vencem .small por especificidade (sem !important) e restauram o peso correto do glifo. */
i.fa-solid, i.fas, i.fa-sharp { font-weight: 900; }
i.fa-regular, i.far { font-weight: 400; }
i.fa-brands, i.fab { font-weight: 400; }

/* Colunas utilitárias de tabela (sem style inline nos templates):
   kp-col-min encolhe a coluna ao conteúdo (checkbox/ícone);
   kp-col-data-acoes dá largura estável à coluna Data/Ações. */
th.kp-col-min, td.kp-col-min { width: 1%; white-space: nowrap; }
th.kp-col-data-acoes { width: 170px; min-width: 170px; }
