/* ==========================================================
   IMPERSOL — Custos (design system)
   Seletores: .custos-*, .csb-*, breadcrumb nav
   ========================================================== */

/* ── Breadcrumb nav ── */
.custos-nav-item {
  color: var(--imp-text-muted);
  font-size: var(--imp-text-sm);
  font-weight: var(--imp-weight-medium);
  cursor: pointer;
  transition: color var(--imp-duration-fast);
  padding: 2px 4px;
  border-radius: var(--imp-radius-xs);
}
.custos-nav-item:hover { color: var(--imp-brand-400); }
.custos-nav-item.active {
  color: var(--imp-text);
  font-weight: var(--imp-weight-semibold);
  pointer-events: none;
}
.custos-nav-sep {
  color: var(--imp-text-faint);
  font-size: var(--imp-text-sm);
  margin: 0 2px;
}

/* ── Section heading ── */
.custos-section-head {
  font-size: var(--imp-text-xs);
  font-weight: var(--imp-weight-semibold);
  letter-spacing: .07em;
  text-transform: uppercase;
  color: var(--imp-text-dim);
  padding: var(--imp-space-4) var(--imp-space-4) var(--imp-space-2);
}

/* ── Obra card ── */
.custos-obra-card {
  background: var(--imp-surface);
  border: 1px solid var(--imp-border);
  border-radius: var(--imp-radius-md);
  padding: var(--imp-space-4);
  margin: 0 var(--imp-space-3) var(--imp-space-3);
  cursor: pointer;
  transition: border-color var(--imp-duration-fast), background var(--imp-duration-fast), transform var(--imp-duration-fast);
}
.custos-obra-card:hover {
  border-color: var(--imp-brand-border);
  background: var(--imp-surface-alt);
  transform: translateY(-1px);
}
.custos-obra-card.emer { border-left: 3px solid var(--imp-danger); }
.custos-obra-card.alerta { border-left: 3px solid var(--imp-warn); }

.custos-obra-head {
  display: flex;
  align-items: center;
  gap: var(--imp-space-2);
  margin-bottom: var(--imp-space-2);
}
.custos-obra-dot {
  width: 10px;
  height: 10px;
  border-radius: 50%;
  flex-shrink: 0;
}
.custos-obra-nome {
  flex: 1;
  font-size: var(--imp-text-md);
  font-weight: var(--imp-weight-semibold);
  color: var(--imp-text);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.custos-obra-total {
  font-size: var(--imp-text-md);
  font-weight: var(--imp-weight-bold);
  color: var(--imp-brand-400);
}
.custos-obra-meta {
  display: flex;
  flex-wrap: wrap;
  gap: var(--imp-space-2);
}
.custos-obra-meta-item {
  font-size: var(--imp-text-xs);
  color: var(--imp-text-muted);
}
.custos-obra-meta-item strong { color: var(--imp-text); }

/* ── Progress bar ── */
.custos-barra-wrap { margin-top: var(--imp-space-3); }
.custos-barra-top {
  display: flex;
  justify-content: space-between;
  margin-bottom: var(--imp-space-1);
}
.custos-barra-lbl { font-size: var(--imp-text-xs); color: var(--imp-text-muted); }
.custos-barra-pct {
  font-size: var(--imp-text-xs);
  font-weight: var(--imp-weight-semibold);
  color: var(--imp-success);
}
.custos-barra-pct.alerta { color: var(--imp-warn); }
.custos-barra-pct.emer   { color: var(--imp-danger); }
.custos-barra-track {
  height: 4px;
  background: var(--imp-border);
  border-radius: var(--imp-radius-full);
  overflow: hidden;
}
.custos-barra-fill {
  height: 100%;
  background: var(--imp-success);
  border-radius: var(--imp-radius-full);
  transition: width var(--imp-duration-slow) var(--imp-ease-out);
}
.custos-barra-fill.alerta { background: var(--imp-warn); }
.custos-barra-fill.emer   { background: var(--imp-danger); }

/* ── Serviço card ── */
.custos-serv-card {
  background: var(--imp-surface);
  border: 1px solid var(--imp-border);
  border-radius: var(--imp-radius-md);
  padding: var(--imp-space-4);
  margin: 0 var(--imp-space-3) var(--imp-space-3);
  cursor: pointer;
  transition: border-color var(--imp-duration-fast), background var(--imp-duration-fast);
}
.custos-serv-card:hover {
  border-color: var(--imp-brand-border);
  background: var(--imp-surface-alt);
}
.custos-serv-head {
  display: flex;
  align-items: center;
  gap: var(--imp-space-2);
}
.custos-serv-icone { font-size: 18px; }
.custos-serv-nome {
  flex: 1;
  font-size: var(--imp-text-md);
  font-weight: var(--imp-weight-medium);
  color: var(--imp-text);
}
.custos-serv-total {
  font-size: var(--imp-text-md);
  font-weight: var(--imp-weight-semibold);
  color: var(--imp-brand-400);
}
.custos-serv-badges {
  display: flex;
  flex-wrap: wrap;
  gap: var(--imp-space-1);
  margin-top: var(--imp-space-2);
}

/* ── Registro item ── */
.custos-reg-item {
  display: flex;
  align-items: flex-start;
  gap: var(--imp-space-3);
  padding: var(--imp-space-3) var(--imp-space-4);
  border-bottom: 1px solid var(--imp-border-soft);
}
.custos-reg-item.emergencial { border-left: 3px solid var(--imp-danger); }
.custos-reg-cat {
  width: 32px;
  height: 32px;
  border-radius: var(--imp-radius-sm);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 16px;
  flex-shrink: 0;
  background: var(--imp-surface-3);
}
.custos-reg-info { flex: 1; min-width: 0; }
.custos-reg-desc {
  font-size: var(--imp-text-md);
  font-weight: var(--imp-weight-medium);
  color: var(--imp-text);
}
.custos-reg-sub { font-size: var(--imp-text-xs); color: var(--imp-text-muted); margin-top: 2px; }
.custos-reg-valor {
  font-size: var(--imp-text-md);
  font-weight: var(--imp-weight-bold);
  color: var(--imp-text);
}
.custos-reg-del {
  background: transparent;
  border: none;
  color: var(--imp-danger-soft);
  cursor: pointer;
  opacity: 0;
  padding: 4px;
  border-radius: var(--imp-radius-xs);
  transition: opacity var(--imp-duration-fast), background var(--imp-duration-fast);
}
.custos-reg-item:hover .custos-reg-del { opacity: 1; }
.custos-reg-del:hover { background: var(--imp-danger-bg); }

/* ── Margem row ── */
.custos-margem-row {
  display: flex;
  align-items: center;
  gap: var(--imp-space-3);
  padding: var(--imp-space-3) var(--imp-space-4);
  background: var(--imp-surface-3);
  border-radius: var(--imp-radius-md);
  margin: var(--imp-space-3) var(--imp-space-3) 0;
  flex-wrap: wrap;
}
.custos-margem-lbl { font-size: var(--imp-text-sm); color: var(--imp-text-muted); }
.custos-receita-input {
  background: var(--imp-surface);
  border: 1px solid var(--imp-border);
  border-radius: var(--imp-radius-xs);
  color: var(--imp-text);
  font-size: var(--imp-text-sm);
  padding: 3px 8px;
  width: 100px;
}
.custos-margem-val {
  font-size: var(--imp-text-sm);
  font-weight: var(--imp-weight-semibold);
  color: var(--imp-success);
}
.custos-margem-val.negativo { color: var(--imp-danger); }
.custos-margem-val.sem-dado { color: var(--imp-text-faint); }

/* ── Category badges ── */
.csb { display: inline-flex; align-items: center; gap: 3px; padding: 2px 7px; border-radius: var(--imp-radius-full); font-size: var(--imp-text-xs); font-weight: var(--imp-weight-medium); }
.csb-mo          { background: var(--imp-brand-bg);    color: var(--imp-brand-400); }
.csb-material    { background: var(--imp-info-bg);     color: var(--imp-info-soft); }
.csb-logistica   { background: var(--imp-success-bg);  color: var(--imp-success-soft); }
.csb-emergencial { background: var(--imp-danger-bg);   color: var(--imp-danger-soft); }
.csb-outro       { background: var(--imp-surface-3);   color: var(--imp-text-muted); }

/* ── Empty state ── */
.custos-empty {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  padding: var(--imp-space-10) var(--imp-space-6);
  gap: var(--imp-space-3);
  color: var(--imp-text-muted);
}
.custos-empty svg { opacity: .35; }
.custos-empty-title {
  font-size: var(--imp-text-md);
  font-weight: var(--imp-weight-semibold);
  color: var(--imp-text-muted);
}
.custos-empty-sub { font-size: var(--imp-text-sm); color: var(--imp-text-faint); }
