/* ================================================================
   PRECIFIKA — MÓDULO FINANCEIRO DE OBRAS
   css/finance.css — v1.0 — Junho 2026

   Centro de Custo & Lucro por orçamento aprovado
   ================================================================ */

/* ── Variáveis ── */
:root {
  --fin-primary:    #1d4ed8;
  --fin-primaryDk:  #1e3a8a;
  --fin-primaryLt:  #dbeafe;
  --fin-primaryXL:  #eff6ff;
  --fin-green:      #16a34a;
  --fin-greenLt:    #dcfce7;
  --fin-red:        #dc2626;
  --fin-redLt:      #fef2f2;
  --fin-amber:      #d97706;
  --fin-amberLt:    #fef3c7;
  --fin-gray50:     #f8fafc;
  --fin-gray100:    #f1f5f9;
  --fin-gray200:    #e2e8f0;
  --fin-gray400:    #94a3b8;
  --fin-gray600:    #475569;
  --fin-gray800:    #1e293b;
  --fin-radius:     14px;
  --fin-shadow:     0 4px 24px rgba(0,0,0,.08);
  --fin-shadow-lg:  0 8px 40px rgba(0,0,0,.13);
}

/* ================================================================
   1. BOTÃO "FINANCEIRO" NA TABELA DE ORÇAMENTOS
   ================================================================ */
.btn-open-finance {
  display: inline-flex;
  align-items: center;
  gap: 5px;
  padding: 5px 10px;
  font-size: 12px;
  font-weight: 600;
  color: var(--fin-primary);
  background: var(--fin-primaryXL);
  border: 1px solid var(--fin-primaryLt);
  border-radius: 7px;
  cursor: pointer;
  transition: background .15s, box-shadow .15s;
  font-family: inherit;
  white-space: nowrap;
}
.btn-open-finance:hover {
  background: var(--fin-primaryLt);
  box-shadow: 0 2px 8px rgba(29,78,216,.15);
}
.btn-open-finance i { font-size: 11px; }

/* ================================================================
   2. PAGE FINANCEIRO — HEADER
   ================================================================ */
.fin-page-header {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 16px;
  flex-wrap: wrap;
  margin-bottom: 24px;
}
.fin-page-header-left { flex: 1; min-width: 0; }
.fin-back-btn {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  font-size: 12.5px;
  font-weight: 600;
  color: var(--fin-gray600);
  background: none;
  border: none;
  cursor: pointer;
  padding: 0 0 8px;
  font-family: inherit;
  transition: color .15s;
}
.fin-back-btn:hover { color: var(--fin-primary); }
.fin-page-title {
  font-size: 22px;
  font-weight: 800;
  color: var(--fin-gray800);
  margin: 0 0 4px;
  display: flex;
  align-items: center;
  gap: 10px;
  flex-wrap: wrap;
}
.fin-page-title .fin-approved-badge {
  font-size: 11px;
  font-weight: 700;
  color: var(--fin-green);
  background: var(--fin-greenLt);
  border: 1px solid #bbf7d0;
  padding: 2px 10px;
  border-radius: 20px;
  letter-spacing: .2px;
}
.fin-page-subtitle {
  font-size: 13px;
  color: var(--fin-gray600);
  margin: 0;
  display: flex;
  align-items: center;
  gap: 12px;
  flex-wrap: wrap;
}
.fin-page-subtitle span {
  display: flex;
  align-items: center;
  gap: 4px;
}
.fin-header-actions {
  display: flex;
  gap: 10px;
  flex-shrink: 0;
  flex-wrap: wrap;
}

/* ================================================================
   3. CARDS DE RESUMO (KPIs)
   ================================================================ */
.fin-summary-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(175px, 1fr));
  gap: 14px;
  margin-bottom: 28px;
}
.fin-kpi-card {
  background: #fff;
  border: 1px solid var(--fin-gray200);
  border-radius: var(--fin-radius);
  padding: 18px 20px;
  position: relative;
  overflow: hidden;
  transition: box-shadow .15s;
}
.fin-kpi-card:hover { box-shadow: var(--fin-shadow); }
.fin-kpi-card::before {
  content: '';
  position: absolute;
  top: 0; left: 0;
  width: 4px; height: 100%;
  border-radius: 0 0 0 0;
}
.fin-kpi-card--contracted::before { background: var(--fin-primary); }
.fin-kpi-card--received::before   { background: var(--fin-green); }
.fin-kpi-card--expense::before    { background: var(--fin-red); }
.fin-kpi-card--balance::before    { background: var(--fin-amber); }
.fin-kpi-card--profit::before     { background: #7c3aed; }

.fin-kpi-label {
  font-size: 11px;
  font-weight: 700;
  color: var(--fin-gray400);
  text-transform: uppercase;
  letter-spacing: .6px;
  margin-bottom: 8px;
  display: flex;
  align-items: center;
  gap: 5px;
}
.fin-kpi-value {
  font-size: 22px;
  font-weight: 800;
  color: var(--fin-gray800);
  line-height: 1.1;
  margin-bottom: 4px;
}
.fin-kpi-value--contracted { color: var(--fin-primary); }
.fin-kpi-value--received   { color: var(--fin-green); }
.fin-kpi-value--expense    { color: var(--fin-red); }
.fin-kpi-value--balance    { color: var(--fin-amber); }
.fin-kpi-value--profit-pos { color: var(--fin-green); }
.fin-kpi-value--profit-neg { color: var(--fin-red); }
.fin-kpi-value--purple     { color: #7c3aed; }

.fin-kpi-sub {
  font-size: 11.5px;
  color: var(--fin-gray400);
}
.fin-kpi-bar {
  margin-top: 10px;
  height: 5px;
  background: var(--fin-gray100);
  border-radius: 10px;
  overflow: hidden;
}
.fin-kpi-bar-fill {
  height: 100%;
  border-radius: 10px;
  transition: width .5s ease;
}

/* ================================================================
   4. ABAS (receitas / despesas / todos)
   ================================================================ */
.fin-tabs {
  display: flex;
  gap: 4px;
  background: var(--fin-gray100);
  border-radius: 10px;
  padding: 4px;
  margin-bottom: 20px;
  width: fit-content;
}
.fin-tab-btn {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 7px 16px;
  font-size: 13px;
  font-weight: 600;
  color: var(--fin-gray600);
  background: transparent;
  border: none;
  border-radius: 7px;
  cursor: pointer;
  font-family: inherit;
  transition: all .15s;
}
.fin-tab-btn.active {
  background: #fff;
  color: var(--fin-primary);
  box-shadow: 0 1px 4px rgba(0,0,0,.1);
}
.fin-tab-btn:not(.active):hover { background: rgba(255,255,255,.5); }
.fin-tab-count {
  font-size: 10.5px;
  font-weight: 700;
  padding: 1px 6px;
  border-radius: 20px;
  background: var(--fin-gray200);
  color: var(--fin-gray600);
}
.fin-tab-btn.active .fin-tab-count {
  background: var(--fin-primaryLt);
  color: var(--fin-primary);
}
.fin-tab-btn.active[data-fintab="receita"] .fin-tab-count {
  background: var(--fin-greenLt);
  color: var(--fin-green);
}
.fin-tab-btn.active[data-fintab="despesa"] .fin-tab-count {
  background: var(--fin-redLt);
  color: var(--fin-red);
}

/* ================================================================
   5. TOOLBAR (busca + filtros + botão novo)
   ================================================================ */
.fin-toolbar {
  display: flex;
  align-items: center;
  gap: 10px;
  flex-wrap: wrap;
  margin-bottom: 16px;
}
.fin-search-box {
  flex: 1;
  min-width: 200px;
  position: relative;
}
.fin-search-box i {
  position: absolute;
  left: 12px;
  top: 50%;
  transform: translateY(-50%);
  color: var(--fin-gray400);
  font-size: 13px;
}
.fin-search-box input {
  width: 100%;
  padding: 9px 12px 9px 36px;
  border: 1.5px solid var(--fin-gray200);
  border-radius: 9px;
  font-size: 13px;
  font-family: inherit;
  background: #fff;
  color: var(--fin-gray800);
  outline: none;
  transition: border-color .2s;
  box-sizing: border-box;
}
.fin-search-box input:focus { border-color: var(--fin-primary); }
.fin-filter-select {
  padding: 9px 12px;
  border: 1.5px solid var(--fin-gray200);
  border-radius: 9px;
  font-size: 13px;
  font-family: inherit;
  color: var(--fin-gray800);
  background: #fff;
  outline: none;
  cursor: pointer;
  transition: border-color .2s;
}
.fin-filter-select:focus { border-color: var(--fin-primary); }

/* ================================================================
   6. BOTÕES DE AÇÃO PRINCIPAIS
   ================================================================ */
.btn-fin-receita {
  display: inline-flex;
  align-items: center;
  gap: 7px;
  padding: 9px 18px;
  font-size: 13.5px;
  font-weight: 700;
  color: #fff;
  background: var(--fin-green);
  border: none;
  border-radius: 10px;
  cursor: pointer;
  font-family: inherit;
  transition: background .15s, box-shadow .15s;
  box-shadow: 0 2px 8px rgba(22,163,74,.25);
}
.btn-fin-receita:hover { background: #15803d; }
.btn-fin-despesa {
  display: inline-flex;
  align-items: center;
  gap: 7px;
  padding: 9px 18px;
  font-size: 13.5px;
  font-weight: 700;
  color: #fff;
  background: var(--fin-red);
  border: none;
  border-radius: 10px;
  cursor: pointer;
  font-family: inherit;
  transition: background .15s, box-shadow .15s;
  box-shadow: 0 2px 8px rgba(220,38,38,.25);
}
.btn-fin-despesa:hover { background: #b91c1c; }
.btn-fin-ghost {
  display: inline-flex;
  align-items: center;
  gap: 7px;
  padding: 9px 16px;
  font-size: 13px;
  font-weight: 600;
  color: var(--fin-gray600);
  background: #fff;
  border: 1.5px solid var(--fin-gray200);
  border-radius: 10px;
  cursor: pointer;
  font-family: inherit;
  transition: all .15s;
}
.btn-fin-ghost:hover { border-color: var(--fin-primary); color: var(--fin-primary); background: var(--fin-primaryXL); }

/* ================================================================
   7. LISTA DE LANÇAMENTOS
   ================================================================ */
.fin-entries-list {
  display: flex;
  flex-direction: column;
  gap: 8px;
}
.fin-entry-item {
  background: #fff;
  border: 1px solid var(--fin-gray200);
  border-radius: var(--fin-radius);
  padding: 14px 18px;
  display: flex;
  align-items: center;
  gap: 14px;
  transition: box-shadow .15s, border-color .15s;
  cursor: default;
}
.fin-entry-item:hover {
  box-shadow: var(--fin-shadow);
  border-color: #cbd5e1;
}
.fin-entry-item--receita { border-left: 4px solid var(--fin-green); }
.fin-entry-item--despesa { border-left: 4px solid var(--fin-red); }

.fin-entry-icon {
  width: 40px;
  height: 40px;
  border-radius: 10px;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 16px;
  flex-shrink: 0;
}
.fin-entry-icon--receita {
  background: var(--fin-greenLt);
  color: var(--fin-green);
}
.fin-entry-icon--despesa {
  background: var(--fin-redLt);
  color: var(--fin-red);
}

.fin-entry-body { flex: 1; min-width: 0; }
.fin-entry-desc {
  font-size: 14px;
  font-weight: 600;
  color: var(--fin-gray800);
  margin-bottom: 3px;
  /* descrição de negócio: quebra linha em vez de cortar */
  white-space: normal;
  overflow: visible;
  text-overflow: unset;
  word-break: break-word;
}
.fin-entry-meta {
  font-size: 11.5px;
  color: var(--fin-gray400);
  display: flex;
  align-items: center;
  gap: 10px;
  flex-wrap: wrap;
}
.fin-entry-meta span { display: flex; align-items: center; gap: 4px; }
.fin-category-chip {
  display: inline-flex;
  align-items: center;
  gap: 3px;
  font-size: 10.5px;
  font-weight: 700;
  padding: 2px 8px;
  border-radius: 20px;
  background: var(--fin-primaryXL);
  color: var(--fin-primary);
  border: 1px solid var(--fin-primaryLt);
  white-space: nowrap;
}
.fin-entry-right {
  display: flex;
  flex-direction: column;
  align-items: flex-end;
  gap: 6px;
  flex-shrink: 0;
}
.fin-entry-amount {
  font-size: 17px;
  font-weight: 800;
  line-height: 1;
}
.fin-entry-amount--receita { color: var(--fin-green); }
.fin-entry-amount--despesa { color: var(--fin-red); }
.fin-entry-date {
  font-size: 11px;
  color: var(--fin-gray400);
}
.fin-entry-actions {
  display: flex;
  gap: 5px;
  align-items: center;
}
.fin-action-btn {
  width: 30px;
  height: 30px;
  border-radius: 7px;
  border: 1px solid var(--fin-gray200);
  background: var(--fin-gray50);
  color: var(--fin-gray600);
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 12px;
  transition: all .15s;
  font-family: inherit;
}
.fin-action-btn:hover { background: var(--fin-primaryXL); border-color: var(--fin-primaryLt); color: var(--fin-primary); }
.fin-action-btn--del:hover { background: var(--fin-redLt); border-color: #fecaca; color: var(--fin-red); }

/* Anexo no card */
.fin-attachment-chip {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  font-size: 10px;
  font-weight: 600;
  color: var(--fin-primary);
  background: var(--fin-primaryXL);
  border: 1px solid var(--fin-primaryLt);
  padding: 2px 7px;
  border-radius: 20px;
  cursor: pointer;
  transition: background .15s;
  text-decoration: none;
}
.fin-attachment-chip:hover { background: var(--fin-primaryLt); }

/* Badge de origem: recibo automático */
.fin-origin-badge {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  background: #fff7ed;
  color: #c2410c;
  border: 1px solid #fed7aa;
  border-radius: 6px;
  padding: 2px 8px;
  font-size: 11px;
  font-weight: 600;
  cursor: default;
}

/* Entrada virtual (recibo não sincronizado) */
.fin-entry-item--virtual {
  border-left-color: #d97706 !important;
  background: linear-gradient(135deg, #fffbeb, #fff) !important;
  opacity: 0.92;
}
.fin-entry-item--virtual:hover { opacity: 1; }

/* ================================================================
   8. ESTADO VAZIO
   ================================================================ */
.fin-empty {
  text-align: center;
  padding: 56px 24px;
  color: var(--fin-gray400);
}
.fin-empty-icon {
  width: 70px;
  height: 70px;
  background: var(--fin-gray100);
  border-radius: 18px;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 30px;
  margin: 0 auto 18px;
  color: var(--fin-gray400);
}
.fin-empty p { font-size: 14px; margin: 0 0 6px; font-weight: 600; color: var(--fin-gray600); }
.fin-empty small { font-size: 12.5px; color: var(--fin-gray400); }

/* ================================================================
   9. MODAL DE LANÇAMENTO
   ================================================================ */
.fin-modal-overlay {
  display: none;
  position: fixed;
  inset: 0;
  background: rgba(15, 23, 42, .7);
  z-index: 1100; /* padronizado — precifika-fixes.css */
  align-items: center;
  justify-content: center;
  padding: 16px;
  backdrop-filter: blur(2px);
}
.fin-modal-overlay.active {
  display: flex;
}
.fin-modal-box {
  background: #fff;
  border-radius: 20px;
  width: 100%;
  max-width: 580px;
  max-height: 90vh;
  overflow-y: auto;
  box-shadow: var(--fin-shadow-lg);
  animation: finModalIn .22s ease;
}
@keyframes finModalIn {
  from { opacity:0; transform: translateY(20px) scale(.97); }
  to   { opacity:1; transform: translateY(0)    scale(1);   }
}

.fin-modal-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 22px 24px 16px;
  border-bottom: 1px solid var(--fin-gray200);
  position: sticky;
  top: 0;
  background: #fff;
  z-index: 1;
  border-radius: 20px 20px 0 0;
}
.fin-modal-title {
  display: flex;
  align-items: center;
  gap: 12px;
}
.fin-modal-title-icon {
  width: 42px;
  height: 42px;
  border-radius: 11px;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 18px;
  flex-shrink: 0;
}
.fin-modal-title-icon--receita { background: var(--fin-greenLt); color: var(--fin-green); }
.fin-modal-title-icon--despesa { background: var(--fin-redLt);   color: var(--fin-red);   }

.fin-modal-title h2 {
  font-size: 17px;
  font-weight: 800;
  color: var(--fin-gray800);
  margin: 0 0 2px;
}
.fin-modal-title p {
  font-size: 12px;
  color: var(--fin-gray400);
  margin: 0;
}
.fin-modal-close {
  width: 34px;
  height: 34px;
  border-radius: 8px;
  border: 1px solid var(--fin-gray200);
  background: var(--fin-gray50);
  color: var(--fin-gray400);
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 14px;
  transition: all .15s;
  font-family: inherit;
}
.fin-modal-close:hover { background: var(--fin-redLt); color: var(--fin-red); border-color: #fecaca; }

.fin-modal-body {
  padding: 20px 24px;
  display: flex;
  flex-direction: column;
  gap: 18px;
}

/* Seção título dentro do modal */
.fin-section-title {
  font-size: 11.5px;
  font-weight: 700;
  color: var(--fin-primary);
  text-transform: uppercase;
  letter-spacing: .6px;
  display: flex;
  align-items: center;
  gap: 6px;
  margin-bottom: 10px;
  padding-bottom: 8px;
  border-bottom: 1px solid var(--fin-primaryLt);
}

/* Form grid */
.fin-form-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 14px;
}
.fin-form-full { grid-column: 1 / -1; }
.fin-form-group { display: flex; flex-direction: column; gap: 5px; }
.fin-form-label {
  font-size: 12px;
  font-weight: 700;
  color: var(--fin-gray600);
  text-transform: uppercase;
  letter-spacing: .4px;
}
.fin-form-label span { color: #ef4444; margin-left: 2px; }
.fin-form-input,
.fin-form-select,
.fin-form-textarea {
  width: 100%;
  padding: 9px 13px;
  border: 1.5px solid var(--fin-gray200);
  border-radius: 9px;
  font-size: 13.5px;
  font-family: inherit;
  color: var(--fin-gray800);
  background: #fff;
  outline: none;
  transition: border-color .2s, box-shadow .2s;
  box-sizing: border-box;
}
.fin-form-input:focus,
.fin-form-select:focus,
.fin-form-textarea:focus {
  border-color: var(--fin-primary);
  box-shadow: 0 0 0 3px rgba(29,78,216,.08);
}
.fin-form-textarea { resize: vertical; min-height: 72px; }

/* Tipo de lançamento (receita/despesa) */
.fin-type-toggle {
  display: flex;
  gap: 8px;
}
.fin-type-btn {
  flex: 1;
  padding: 10px;
  border: 2px solid var(--fin-gray200);
  border-radius: 10px;
  background: #fff;
  cursor: pointer;
  font-family: inherit;
  font-size: 13.5px;
  font-weight: 700;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  transition: all .15s;
  color: var(--fin-gray600);
}
.fin-type-btn.active--receita {
  border-color: var(--fin-green);
  background: var(--fin-greenLt);
  color: var(--fin-green);
}
.fin-type-btn.active--despesa {
  border-color: var(--fin-red);
  background: var(--fin-redLt);
  color: var(--fin-red);
}
.fin-type-btn:not(.active--receita):not(.active--despesa):hover {
  border-color: var(--fin-gray400);
  background: var(--fin-gray50);
}

/* Área de anexo */
.fin-attachment-area {
  border: 2px dashed var(--fin-gray200);
  border-radius: 10px;
  padding: 20px;
  text-align: center;
  cursor: pointer;
  transition: border-color .2s, background .2s;
  position: relative;
}
.fin-attachment-area:hover {
  border-color: var(--fin-primary);
  background: var(--fin-primaryXL);
}
.fin-attachment-area input[type="file"] {
  position: absolute;
  inset: 0;
  opacity: 0;
  cursor: pointer;
  width: 100%;
  height: 100%;
}
.fin-attachment-area i { font-size: 24px; color: var(--fin-gray400); display: block; margin-bottom: 8px; }
.fin-attachment-area p { margin: 0; font-size: 12.5px; color: var(--fin-gray600); }
.fin-attachment-area small { font-size: 11px; color: var(--fin-gray400); }
.fin-attachment-preview {
  display: none;
  align-items: center;
  gap: 10px;
  padding: 10px 14px;
  background: var(--fin-primaryXL);
  border: 1px solid var(--fin-primaryLt);
  border-radius: 9px;
  font-size: 12.5px;
  font-weight: 600;
  color: var(--fin-primary);
}
.fin-attachment-preview.visible { display: flex; }
.fin-attachment-preview button {
  margin-left: auto;
  background: none;
  border: none;
  color: var(--fin-red);
  cursor: pointer;
  font-size: 13px;
  padding: 0;
}

.fin-modal-footer {
  display: flex;
  justify-content: flex-end;
  gap: 10px;
  padding: 16px 24px 22px;
  border-top: 1px solid var(--fin-gray200);
}

/* ================================================================
   10. MODAL VISUALIZAR ANEXO
   ================================================================ */
.fin-attachment-viewer {
  display: none;
  position: fixed;
  inset: 0;
  background: rgba(0,0,0,.85);
  z-index: 2000; /* padronizado — precifika-fixes.css */
  align-items: center;
  justify-content: center;
  padding: 20px;
}
.fin-attachment-viewer.active { display: flex; }
.fin-attachment-viewer-inner {
  background: #fff;
  border-radius: 16px;
  max-width: 860px;
  width: 100%;
  max-height: 90vh;
  overflow: auto;
}
.fin-attachment-viewer-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 14px 20px;
  border-bottom: 1px solid var(--fin-gray200);
}
.fin-attachment-viewer-header span { font-size: 14px; font-weight: 700; color: var(--fin-gray800); }
.fin-attachment-viewer img {
  max-width: 100%;
  display: block;
  margin: 0 auto;
  padding: 16px;
}

/* ================================================================
   11. RESPONSIVO MOBILE
   ================================================================ */
@media (max-width: 900px) {
  /* Header */
  .fin-page-header { flex-direction: column; align-items: flex-start; gap: 12px; }
  .fin-page-header-left { width: 100%; }
  .fin-page-title { font-size: 18px; flex-wrap: wrap; gap: 6px; }
  .fin-page-subtitle { flex-wrap: wrap; gap: 6px 10px; font-size: 12px; }
  .fin-header-actions { width: 100%; flex-wrap: wrap; }
  .fin-header-actions button { flex: 1; justify-content: center; min-height: 44px; }

  /* KPIs */
  .fin-summary-grid { grid-template-columns: repeat(2, 1fr); gap: 10px; }
  .fin-kpi-card { padding: 14px 12px; }
  .fin-kpi-value { font-size: 17px; }
  .fin-kpi-label { font-size: 11px; }

  /* Profit bar */
  .fin-profit-bar { margin-bottom: 16px; }

  /* Abas */
  .fin-tabs { width: 100%; }
  .fin-tab-btn { flex: 1; justify-content: center; font-size: 12px; padding: 8px 6px; min-height: 40px; }

  /* Toolbar filtros */
  .fin-toolbar { flex-direction: column; gap: 8px; }
  .fin-search-box { min-width: 100%; width: 100%; }
  .fin-filter-select { width: 100%; min-height: 42px; }

  /* Itens */
  .fin-entry-item { gap: 10px; padding: 14px; }
  .fin-entry-desc { white-space: normal; }
  .fin-entry-meta { flex-wrap: wrap; gap: 5px; }
  .fin-entry-right { flex-direction: row; align-items: center; flex-wrap: wrap; justify-content: flex-end; gap: 8px; }
  .fin-entry-amount { font-size: 15px; white-space: nowrap; }
  .fin-action-btn { width: 34px; height: 34px; }

  /* Seletor de obras */
  .fin-sel-card { padding: 14px; gap: 12px; }
  .fin-sel-name { font-size: 14px; }
  .fin-sel-meta { flex-wrap: wrap; font-size: 11px; }
  .fin-sel-value { font-size: 15px; font-weight: 800; }
  .fin-back-btn { font-size: 13px; padding: 7px 12px; min-height: 38px; }
}

@media (max-width: 680px) {
  .fin-form-grid { grid-template-columns: 1fr; }
  .fin-modal-overlay { align-items: flex-end; padding: 0; }
  .fin-modal-box {
    border-radius: 20px 20px 0 0;
    max-height: 96vh;
    width: 100%;
    max-width: 100%;
    margin: 0;
  }
  .fin-modal-header { padding: 16px 16px 12px; }
  .fin-modal-body   { padding: 16px; }
  .fin-modal-footer { padding: 12px 16px 20px; }
  .fin-type-toggle { width: 100%; }
  .fin-type-btn    { flex: 1; justify-content: center; min-height: 44px; }
  #fin-save-btn    { width: 100%; min-height: 48px; font-size: 15px; }
}

@media (max-width: 480px) {
  .fin-summary-grid { grid-template-columns: 1fr 1fr; gap: 8px; }
  .fin-kpi-value    { font-size: 15px; }
}

/* ================================================================
   12. ANIMAÇÕES
   ================================================================ */
.fin-fade-in {
  animation: finFadeIn .3s ease;
}
@keyframes finFadeIn {
  from { opacity: 0; transform: translateY(8px); }
  to   { opacity: 1; transform: translateY(0);   }
}

/* Spinner de loading */
.fin-loading {
  text-align: center;
  padding: 48px 20px;
  color: var(--fin-gray400);
}
.fin-loading i { font-size: 28px; display: block; margin-bottom: 12px; }
.fin-loading p { font-size: 13px; margin: 0; }

/* ================================================================
   13. BARRA DE PROGRESSO LUCRO/PREJUÍZO
   ================================================================ */
.fin-profit-bar {
  margin-top: 20px;
  padding: 16px 20px;
  background: var(--fin-gray50);
  border: 1px solid var(--fin-gray200);
  border-radius: 12px;
}
.fin-profit-bar-label {
  display: flex;
  justify-content: space-between;
  font-size: 12px;
  font-weight: 700;
  color: var(--fin-gray600);
  margin-bottom: 8px;
}
.fin-profit-bar-track {
  height: 12px;
  background: var(--fin-gray200);
  border-radius: 20px;
  overflow: hidden;
  position: relative;
}
.fin-profit-bar-fill {
  height: 100%;
  border-radius: 20px;
  transition: width .5s ease;
}
.fin-profit-bar-fill--pos { background: linear-gradient(90deg, #4ade80, #16a34a); }
.fin-profit-bar-fill--neg { background: linear-gradient(90deg, #f87171, #dc2626); }

/* ================================================================
   14. COMPLEMENTOS — MODAL ACTIONS, BOTÕES, ATTACHMENT PREVIEW
   ================================================================ */

/* Área de ações do modal (Cancelar / Salvar) */
.fin-modal-actions {
  display: flex;
  justify-content: flex-end;
  gap: 10px;
  padding: 16px 24px 22px;
  border-top: 1px solid var(--fin-gray200);
  margin-top: 4px;
}

/* Botão salvar lançamento */
.btn-fin-save {
  display: inline-flex;
  align-items: center;
  gap: 7px;
  padding: 10px 20px;
  background: var(--fin-primary);
  color: #fff;
  border: none;
  border-radius: 10px;
  font-size: 13.5px;
  font-weight: 700;
  font-family: inherit;
  cursor: pointer;
  transition: background .15s, transform .1s;
}
.btn-fin-save:hover  { background: var(--fin-primaryDk); }
.btn-fin-save:active { transform: scale(.97); }
.btn-fin-save:disabled { opacity: .6; cursor: default; }

/* Classe .fin-form-group--full para grid */
.fin-form-group--full { grid-column: 1 / -1; }

/* Campo required asterisco */
.fin-required { color: #ef4444; margin-left: 2px; }

/* Attachment file input (oculto, cobre a área) */
.fin-attachment-file-input {
  position: absolute;
  inset: 0;
  opacity: 0;
  cursor: pointer;
  width: 100%;
  height: 100%;
  z-index: 2;
}

/* Preview de arquivo selecionado */
.fin-attachment-placeholder {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 4px;
  pointer-events: none;
}
.fin-attachment-placeholder i  { font-size: 24px; color: var(--fin-gray400); }
.fin-attachment-placeholder span { font-size: 13px; color: var(--fin-gray600); font-weight: 600; }
.fin-attachment-placeholder small { font-size: 11px; color: var(--fin-gray400); }

.fin-attachment-preview {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 10px 14px;
  background: var(--fin-primaryXL);
  border: 1px solid var(--fin-primaryLt);
  border-radius: 9px;
  font-size: 12.5px;
  font-weight: 600;
  color: var(--fin-primary);
}
.fin-attachment-preview-info {
  display: flex;
  align-items: center;
  gap: 8px;
  flex: 1;
  min-width: 0;
}
.fin-attachment-preview-icon { font-size: 18px; flex-shrink: 0; }
.fin-attachment-preview-name {
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  font-size: 13px;
}
.fin-attachment-remove {
  margin-left: auto;
  background: none;
  border: none;
  color: var(--fin-red);
  cursor: pointer;
  font-size: 14px;
  padding: 4px 6px;
  border-radius: 6px;
  transition: background .15s;
  flex-shrink: 0;
  line-height: 1;
}
.fin-attachment-remove:hover { background: var(--fin-redLt); }

/* ── Attachment Viewer (lightbox) ── */
.fin-attachment-viewer {
  position: fixed;
  inset: 0;
  background: rgba(0,0,0,.85);
  z-index: 2000; /* padronizado — precifika-fixes.css */
  display: none;
  align-items: center;
  justify-content: center;
  padding: 20px;
}
.fin-attachment-viewer[style*="display:flex"],
.fin-attachment-viewer.active { display: flex !important; }

.fin-attachment-viewer-box {
  background: #fff;
  border-radius: 16px;
  max-width: 880px;
  width: 100%;
  max-height: 92vh;
  display: flex;
  flex-direction: column;
  overflow: hidden;
  box-shadow: 0 30px 80px rgba(0,0,0,.4);
}
.fin-attachment-viewer-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 14px 18px;
  border-bottom: 1px solid var(--fin-gray200);
  flex-shrink: 0;
}
.fin-attachment-viewer-title {
  font-size: 14px;
  font-weight: 700;
  color: var(--fin-gray800);
  /* título do attachment viewer: ellipsis aceitável pois tem max-width */
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  max-width: 60%;
  min-width: 0;
}
.fin-attachment-viewer-actions {
  display: flex;
  align-items: center;
  gap: 8px;
  flex-shrink: 0;
}
.fin-viewer-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 34px;
  height: 34px;
  border-radius: 8px;
  border: 1px solid var(--fin-gray200);
  background: var(--fin-gray50);
  color: var(--fin-gray600);
  cursor: pointer;
  font-size: 14px;
  transition: all .15s;
  text-decoration: none;
}
.fin-viewer-btn--download:hover { background: var(--fin-primaryXL); color: var(--fin-primary); border-color: var(--fin-primaryLt); }
.fin-viewer-btn--close:hover    { background: var(--fin-redLt); color: var(--fin-red); border-color: #fecaca; }

.fin-attachment-viewer-body {
  flex: 1;
  overflow: auto;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 16px;
  background: var(--fin-gray50);
  min-height: 300px;
}
.fin-attachment-viewer-body img {
  max-width: 100%;
  max-height: 70vh;
  border-radius: 8px;
  box-shadow: 0 4px 20px rgba(0,0,0,.15);
}
.fin-attachment-viewer-body iframe {
  width: 100%;
  height: 70vh;
  border: none;
  border-radius: 8px;
}

/* Botão "Financeiro" na tabela de orçamentos */
.btn-open-finance {
  background: #fff7ed !important;
  color: #c2410c !important;
  border: 1px solid #fed7aa !important;
}
.btn-open-finance:hover {
  background: #ffedd5 !important;
  color: #9a3412 !important;
  border-color: #fb923c !important;
}

/* ================================================================
   15. TELA DE SELEÇÃO DE OBRA (acesso via menu principal)
   ================================================================ */

/* Wrapper geral da tela seletora */
.fin-selector-wrap {
  padding: 8px 0;
}

/* Cabeçalho da seleção */
.fin-selector-header {
  display: flex;
  align-items: center;
  gap: 14px;
  padding: 18px 20px 14px;
  border-bottom: 1px solid var(--fin-gray200);
  margin-bottom: 8px;
}
.fin-selector-header i {
  font-size: 26px;
  color: var(--fin-primary);
  width: 44px;
  height: 44px;
  background: var(--fin-primaryXL);
  border-radius: 12px;
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
}
.fin-selector-header h3 {
  font-size: 16px;
  font-weight: 800;
  color: var(--fin-gray800);
  margin: 0 0 3px;
}
.fin-selector-header p {
  font-size: 12.5px;
  color: var(--fin-gray400);
  margin: 0;
}

/* Lista de cards */
.fin-selector-list {
  display: flex;
  flex-direction: column;
  gap: 2px;
  padding: 4px 8px 12px;
}

/* Card individual de obra */
.fin-sel-card {
  display: flex;
  align-items: center;
  gap: 14px;
  padding: 14px 16px;
  border-radius: 12px;
  border: 1.5px solid transparent;
  background: #fff;
  cursor: pointer;
  transition: all .15s;
  text-decoration: none;
  outline: none;
}
.fin-sel-card:hover {
  background: var(--fin-primaryXL);
  border-color: var(--fin-primaryLt);
  transform: translateX(3px);
  box-shadow: 0 2px 12px rgba(29,78,216,.1);
}
.fin-sel-card:focus-visible {
  border-color: var(--fin-primary);
  box-shadow: 0 0 0 3px rgba(29,78,216,.15);
}

/* Avatar com iniciais */
.fin-sel-avatar {
  width: 44px;
  height: 44px;
  border-radius: 12px;
  background: linear-gradient(135deg, var(--fin-primary), #4f46e5);
  color: #fff;
  font-size: 15px;
  font-weight: 800;
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
  letter-spacing: -.5px;
}

/* Informações centrais */
.fin-sel-info {
  flex: 1;
  min-width: 0;
}
.fin-sel-name {
  font-size: 14px;
  font-weight: 700;
  color: var(--fin-gray800);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  margin-bottom: 4px;
}
.fin-sel-meta {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  font-size: 11.5px;
  color: var(--fin-gray400);
}
.fin-sel-meta span {
  display: inline-flex;
  align-items: center;
  gap: 4px;
}
.fin-sel-meta i { font-size: 10px; }
.fin-sel-code {
  font-size: 10.5px;
  font-weight: 700;
  background: var(--fin-primaryXL);
  color: var(--fin-primary);
  padding: 1px 7px;
  border-radius: 20px;
  font-family: monospace;
}

/* Direita: valor + seta */
.fin-sel-right {
  display: flex;
  flex-direction: column;
  align-items: flex-end;
  gap: 4px;
  flex-shrink: 0;
}
.fin-sel-value {
  font-size: 14px;
  font-weight: 800;
  color: var(--fin-primary);
  white-space: nowrap;
}
.fin-sel-cta {
  font-size: 12px;
  color: var(--fin-gray400);
  transition: color .15s, transform .15s;
}
.fin-sel-card:hover .fin-sel-cta {
  color: var(--fin-primary);
  transform: translateX(3px);
}

/* Estado vazio da seleção */
.fin-selector-empty {
  display: flex;
  flex-direction: column;
  align-items: center;
  padding: 56px 24px;
  gap: 12px;
  text-align: center;
}
.fin-selector-empty-icon {
  width: 64px;
  height: 64px;
  background: var(--fin-primaryXL);
  border-radius: 18px;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 28px;
  color: var(--fin-primary);
  margin-bottom: 4px;
}
.fin-selector-empty h3 {
  font-size: 17px;
  font-weight: 800;
  color: var(--fin-gray800);
  margin: 0;
}
.fin-selector-empty p {
  font-size: 13px;
  color: var(--fin-gray400);
  margin: 0;
  max-width: 340px;
}

/* Responsivo */
@media (max-width: 520px) {
  .fin-sel-card { padding: 12px; gap: 10px; }
  .fin-sel-avatar { width: 38px; height: 38px; font-size: 13px; }
  .fin-sel-value { font-size: 13px; }
}
