/*
 * style.css — Clínica Amonie · Identidade visual aplicada
 *
 * FONTES:
 *   Cormorant Garamond (serif elegante) → títulos, valores monetários, marca
 *   Jost (sans-serif moderno e limpo)   → corpo de texto, labels, botões
 *   Importadas do Google Fonts; requerem internet no primeiro carregamento.
 *
 * PALETA AMONIE:
 *   Base quente: taupe, linho e marrom — tons de terra e nude.
 *   Status: sage (verde), âmbar, terracota — análogos quentes sem o azul frio.
 *   Toda a paleta usa variáveis CSS (--primary, --bg etc.) definidas em :root.
 *   Para mudar uma cor em todo o sistema, basta alterar o valor aqui.
 *
 * ORGANIZAÇÃO DO ARQUIVO (seções em ordem):
 *   1.  Variáveis CSS (paleta + sombras)
 *   2.  Reset básico e body
 *   3.  Header (barra do topo)
 *   4.  Tabs (navegação entre abas)
 *   5.  Cards (caixas de conteúdo)
 *   6.  Layout (grid two-col)
 *   7.  Botões
 *   8.  Campos (user-input, calc-field)
 *   9.  Custos fixos (lista de aluguel etc.)
 *   10. Resultados (box com horas/custo calculados)
 *   11. Alertas (warning, error, info)
 *   12. Tabelas (data-table, badges)
 *   13. Modal genérico
 *   14. Aba Configurações (parâmetros operacionais)
 *   15. Protocolo (cards de cenários)
 *   16. Tabela de serviços (expansível, linha inline)
 *   17. Utilitários (mono, val-pos, val-neg, text-center etc.)
 */

@import url('https://fonts.googleapis.com/css2?family=Cormorant+Garamond:ital,wght@0,300;0,400;0,500;0,600;1,300;1,400&family=Jost:wght@300;400;500;600&display=swap');

/* ──────────────────────────────────────────────────────────────────────────────
   1. VARIÁVEIS CSS (paleta de cores e sombras)
   Todas as cores do sistema passam por aqui. Alterar aqui reflete em todo o CSS.
   ────────────────────────────────────────────────────────────────────────────── */
:root {
  --primary:        #B8977A;   /* taupe quente — cor principal da marca */
  --primary-light:  #F5EFE8;   /* taupe muito claro — hover backgrounds */
  --primary-dark:   #8E6E52;   /* taupe escuro — hover botões */
  --primary-deep:   #2C2018;   /* marrom profundo — header, contraste */
  --bg:             #F2ECE6;   /* linho quente — fundo geral */
  --card:           #FFFFFF;   /* branco puro — fundo de cards */
  --border:         #E2D9CF;   /* bege quente — bordas sutis */
  --text:           #2C2018;   /* marrom escuro quente — texto principal */
  --text-muted:     #8A7060;   /* marrom médio — labels e valores secundários */
  --input-user:     #FAF7F3;   /* creme — fundo de campos preenchidos pelo usuário */
  --input-border-user: #D4C5B5;
  --input-calc:     #F5F2EE;   /* creme acinzentado — fundo de campos calculados */
  --input-border-calc: #E2D9CF;
  --green:          #6B9E7A;   /* sage — margem saudável */
  --green-light:    #EBF3EE;   /* verde muito claro — fundo de badge verde */
  --yellow:         #C9963A;   /* âmbar quente — atenção */
  --yellow-light:   #FBF3E2;   /* âmbar muito claro */
  --red:            #C0594A;   /* terracota — prejuízo/crítico */
  --red-light:      #FAE8E5;   /* terracota muito claro */
  --shadow:    0 1px 3px rgba(44,32,24,0.08), 0 1px 2px rgba(44,32,24,0.05);
  --shadow-md: 0 4px 12px rgba(44,32,24,0.10), 0 2px 4px rgba(44,32,24,0.06);
}

/* ──────────────────────────────────────────────────────────────────────────────
   2. RESET E BODY
   box-sizing: border-box faz com que padding e border sejam incluídos na
   largura/altura declarada — sem isso, um elemento de 100px com padding 10px
   teria 120px de tamanho real, causando quebras de layout.
   ────────────────────────────────────────────────────────────────────────────── */
* { box-sizing: border-box; margin: 0; padding: 0; }

body {
  /* Jost como padrão; fallbacks para sistemas sem a fonte carregada */
  font-family: 'Jost', -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;
  background: var(--bg);   /* linho quente — fundo suave de toda a página */
  color: var(--text);
  font-size: 14px;
  min-height: 100vh;        /* garante que a cor de fundo cobre a tela inteira */
}

/* ──────────────────────────────────────────────────────────────────────────────
   3. HEADER
   ────────────────────────────────────────────────────────────────────────────── */
/* ── Overlay de seleção de arquivo ────────────────────────────────────────
   Cobre o app inteiro antes do arquivo ser selecionado. Visível por padrão;
   app.js muda para display:none após initArquivo() completar com sucesso.
   Fundo semitransparente escuro sobre o app (que está atrás mas inerte). */
.overlay-arquivo {
  position: fixed;
  inset: 0;
  z-index: 1000;
  background: rgba(44, 32, 24, 0.82);
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 24px;
  backdrop-filter: blur(3px);
}
.overlay-card {
  background: #fff;
  border-radius: 12px;
  padding: 40px 48px 44px;
  max-width: 420px;
  width: 100%;
  text-align: center;
  box-shadow: 0 24px 64px rgba(44,32,24,0.28);
}
/* Marca "a." no estilo do header */
.overlay-logo {
  font-family: 'Cormorant Garamond', Georgia, serif;
  font-size: 48px;
  font-weight: 400;
  font-style: italic;
  color: var(--primary);
  line-height: 1;
  margin-bottom: 4px;
}
.overlay-titulo {
  font-family: 'Cormorant Garamond', Georgia, serif;
  font-size: 22px;
  font-weight: 500;
  letter-spacing: 0.5px;
  color: var(--primary-deep);
  margin: 0 0 8px;
}
.overlay-sub {
  font-size: 13px;
  color: var(--text-muted);
  line-height: 1.6;
  margin: 0 0 24px;
}
.overlay-sub code {
  font-family: 'Courier New', monospace;
  background: var(--bg);
  padding: 1px 6px;
  border-radius: 4px;
  font-size: 12px;
  color: var(--primary-dark);
}
.overlay-campo {
  text-align: left;
  margin-bottom: 20px;
}
.overlay-label {
  display: block;
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 0.8px;
  text-transform: uppercase;
  color: var(--text-muted);
  margin-bottom: 6px;
}
.overlay-input {
  width: 100%;
  padding: 10px 14px;
  border: 1.5px solid var(--border);
  border-radius: 8px;
  font-family: 'Jost', sans-serif;
  font-size: 14px;
  color: var(--text);
  box-sizing: border-box;
  outline: none;
  transition: border-color 0.15s;
}
.overlay-input:focus { border-color: var(--primary); }
.overlay-btn {
  width: 100%;
  padding: 12px;
  font-size: 14px;
  border-radius: 8px;
  margin-bottom: 10px;
}
.overlay-separator {
  font-size: 11px;
  color: var(--text-muted);
  letter-spacing: 0.5px;
  text-transform: uppercase;
  margin: 4px 0 10px;
}
.overlay-erro {
  margin-top: 16px;
  padding: 10px 14px;
  background: #FAE8E5;
  border: 1px solid #F0C4BC;
  border-radius: 8px;
  font-size: 12px;
  color: #8A3028;
  line-height: 1.5;
  text-align: left;
}

/* ── Badge de sincronização (header) ──────────────────────────────────────
   Aparece brevemente após cada gravação em dados.json.
   Gerenciado por _mostrarSyncStatus() em dados.js. */
.sync-badge {
  margin-left: auto;
  font-size: 11px;
  font-weight: 600;
  letter-spacing: 0.4px;
  padding: 4px 12px;
  border-radius: 20px;
  white-space: nowrap;
  transition: opacity 0.3s;
}
.sync-salvando { background: rgba(201,150,58,0.25); color: #C9963A; }
.sync-salvo    { background: rgba(107,158,122,0.25); color: #4A8A5A; }
.sync-erro     { background: rgba(192,89,74,0.25);  color: #C0594A; }

.app-header {
  background: var(--primary-deep);
  color: #F5EFE8;
  padding: 18px 32px;
  box-shadow: var(--shadow-md);
  display: flex;
  align-items: center;
  gap: 14px;
}
.header-logo-mark {
  font-family: 'Cormorant Garamond', Georgia, serif;
  font-size: 38px;
  font-weight: 400;
  font-style: italic;
  color: var(--primary);
  line-height: 1;
  letter-spacing: -1px;
}
.header-text { display: flex; flex-direction: column; }
.app-title {
  font-family: 'Cormorant Garamond', Georgia, serif;
  font-size: 22px;
  font-weight: 500;
  letter-spacing: 1px;
  color: #F5EFE8;
  line-height: 1.1;
}
.app-subtitle {
  font-family: 'Jost', sans-serif;
  font-size: 10px;
  font-weight: 400;
  letter-spacing: 3.5px;
  text-transform: uppercase;
  color: var(--primary);
  margin-top: 3px;
}

/* ──────────────────────────────────────────────────────────────────────────────
   4. TABS (navegação entre abas)
   A aba ativa recebe .active via JavaScript (initTabs em app.js).
   A borda inferior colorida no botão ativo é obtida com border-bottom
   e margin-bottom:-1px para "cobrir" a borda do container.
   ────────────────────────────────────────────────────────────────────────────── */
.tabs-nav {
  display: flex;
  background: var(--card);
  border-bottom: 1px solid var(--border);
  padding: 0 24px;
  overflow-x: auto;
}
.tab-btn {
  display: flex;
  align-items: center;
  gap: 6px;
  padding: 13px 20px;
  border: none;
  background: none;
  cursor: pointer;
  color: var(--text-muted);
  font-family: 'Jost', sans-serif;
  font-size: 13px;
  font-weight: 500;
  letter-spacing: 0.3px;
  border-bottom: 2px solid transparent;
  margin-bottom: -1px;
  white-space: nowrap;
  transition: all 0.15s;
}
.tab-btn:hover { color: var(--primary); background: var(--primary-light); }
.tab-btn.active { color: var(--primary-dark); border-bottom-color: var(--primary); font-weight: 600; }

/* ──────────────────────────────────────────────────────────────────────────────
   4b. CONTEÚDO DAS ABAS
   .tab-pane { display: none } — oculta todas as abas por padrão.
   .tab-pane.active { display: block } — exibe apenas a ativa.
   ────────────────────────────────────────────────────────────────────────────── */
/* Loading global — exibido enquanto os dados chegam do servidor */
#app-loading {
  display: none;
  align-items: center;
  justify-content: center;
  gap: 14px;
  padding: 60px 24px;
  font-size: 15px;
  color: var(--text-muted);
  font-family: 'Jost', sans-serif;
}
.app-loading-spinner {
  width: 22px;
  height: 22px;
  border: 2.5px solid var(--border);
  border-top-color: var(--primary);
  border-radius: 50%;
  animation: spin .7s linear infinite;
  flex-shrink: 0;
}
@keyframes spin { to { transform: rotate(360deg); } }

.tabs-content { padding: 24px; max-width: 1200px; margin: 0 auto; }
.tab-pane { display: none; }
.tab-pane.active { display: block; }

.tab-description {
  background: var(--card);
  border: 1px solid var(--border);
  border-left: 3px solid var(--primary);
  border-radius: 8px;
  padding: 12px 16px;
  margin-bottom: 20px;
  color: var(--text-muted);
  font-size: 13px;
  line-height: 1.6;
}

/* ──────────────────────────────────────────────────────────────────────────────
   5. CARDS
   Unidade visual principal: caixa branca com sombra sutil e borda bege.
   .card-header contém título + botão de ação principal (ex.: "+ Novo").
   overflow:hidden no .card garante que o conteúdo interno (tabelas etc.)
   respeite o border-radius.
   ────────────────────────────────────────────────────────────────────────────── */
.card {
  background: var(--card);
  border: 1px solid var(--border);
  border-radius: 12px;
  box-shadow: var(--shadow);
  overflow: hidden;
  margin-bottom: 20px;
}
.card-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 15px 20px;
  border-bottom: 1px solid var(--border);
  background: #FDFAF7;
}
.card-header h2 {
  font-family: 'Cormorant Garamond', Georgia, serif;
  font-size: 17px;
  font-weight: 500;
  letter-spacing: 0.3px;
  color: var(--text);
}
.card-body { padding: 20px; }

/* ──────────────────────────────────────────────────────────────────────────────
   6. LAYOUT
   .two-col: usado na aba Configurações para colocar "Custos Fixos" e
   "Parâmetros Operacionais" lado a lado. Colapsa para coluna única em
   telas menores que 900px (ex.: tablet na vertical).
   ────────────────────────────────────────────────────────────────────────────── */
.two-col {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 20px;
  align-items: start;
}
@media (max-width: 900px) { .two-col { grid-template-columns: 1fr; } }

/* ──────────────────────────────────────────────────────────────────────────────
   7. BOTÕES
   Hierarquia visual:
     .btn-primary  — ação principal (ex.: salvar, adicionar) — taupe sólido
     .btn-secondary— ação secundária — borda, fundo branco
     .btn-danger   — ação destrutiva (excluir) — terracota claro
     .btn-edit     — ação de edição — taupe muito claro
     .btn-icon     — ícone sem borda (X de fechar, X de remover linha)
     .btn-sm       — modificador de tamanho menor (pode combinar com qualquer botão)
   ────────────────────────────────────────────────────────────────────────────── */
.btn-primary {
  background: var(--primary);
  color: #FAF7F3;
  border: none;
  padding: 8px 16px;
  border-radius: 7px;
  cursor: pointer;
  font-family: 'Jost', sans-serif;
  font-size: 13px;
  font-weight: 500;
  letter-spacing: 0.3px;
  transition: background 0.15s;
}
.btn-primary:hover { background: var(--primary-dark); }
.btn-secondary {
  background: var(--card);
  color: var(--text);
  border: 1px solid var(--border);
  padding: 8px 16px;
  border-radius: 7px;
  cursor: pointer;
  font-family: 'Jost', sans-serif;
  font-size: 13px;
  font-weight: 500;
  transition: all 0.15s;
}
.btn-secondary:hover { background: var(--primary-light); border-color: var(--primary); }
.btn-danger {
  background: var(--red-light);
  color: var(--red);
  border: 1px solid #E8B5AE;
  padding: 4px 10px;
  border-radius: 6px;
  cursor: pointer;
  font-size: 12px;
  font-family: 'Jost', sans-serif;
  transition: all 0.15s;
}
.btn-danger:hover { background: #F5D5D0; }
.btn-edit {
  background: var(--primary-light);
  color: var(--primary-dark);
  border: 1px solid #D4C5B5;
  padding: 4px 10px;
  border-radius: 6px;
  cursor: pointer;
  font-size: 12px;
  font-family: 'Jost', sans-serif;
  transition: all 0.15s;
}
.btn-edit:hover { background: #EBE0D4; }
.btn-sm { padding: 6px 12px; font-size: 12px; }
.btn-icon {
  background: none;
  border: none;
  cursor: pointer;
  padding: 4px 6px;
  border-radius: 4px;
  font-size: 14px;
  color: var(--text-muted);
  transition: all 0.15s;
}
.btn-icon:hover { background: var(--primary-light); color: var(--primary-dark); }

/* ──────────────────────────────────────────────────────────────────────────────
   8. CAMPOS (inputs e selects)
   Dois estilos de campo:
     .user-input  — campo preenchido pelo usuário: fundo creme, borda taupe ao focar
     .calc-field  — campo calculado automaticamente: fundo cinza, cursor not-allowed
   A distinção visual é importante para o usuário saber o que pode editar.
   .fields-row  divide 2 campos lado a lado; .fields-row-3 divide em 3.
   ────────────────────────────────────────────────────────────────────────────── */
.field-group { margin-bottom: 14px; }
.field-group label {
  display: block;
  font-size: 11px;
  font-weight: 600;
  letter-spacing: 1px;
  text-transform: uppercase;
  color: var(--text-muted);
  margin-bottom: 5px;
}
.field-help {
  font-size: 11px;
  color: var(--text-muted);
  margin-top: 4px;
  font-style: italic;
}
input.user-input, select.user-input, textarea.user-input {
  width: 100%;
  padding: 8px 11px;
  border: 1.5px solid var(--input-border-user);
  border-radius: 7px;
  background: var(--input-user);
  font-family: 'Jost', sans-serif;
  font-size: 13px;
  color: var(--text);
  outline: none;
  transition: border-color 0.15s, box-shadow 0.15s;
}
input.user-input:focus, select.user-input:focus {
  border-color: var(--primary);
  box-shadow: 0 0 0 3px rgba(184,151,122,0.15);
}
input.calc-field {
  width: 100%;
  padding: 8px 11px;
  border: 1.5px solid var(--input-border-calc);
  border-radius: 7px;
  background: var(--input-calc);
  font-family: 'Jost', sans-serif;
  font-size: 13px;
  color: var(--text-muted);
  font-weight: 500;
  cursor: not-allowed;
}
.fields-row   { display: grid; gap: 12px; grid-template-columns: 1fr 1fr; }
.fields-row-3 { display: grid; gap: 12px; grid-template-columns: 1fr 1fr 1fr; }
@media (max-width: 600px) { .fields-row, .fields-row-3 { grid-template-columns: 1fr; } }

/* ──────────────────────────────────────────────────────────────────────────────
   9. CUSTOS FIXOS
   Lista de itens (aluguel, energia etc.) em grid de 4 colunas.
   Não usa <table> para ter mais controle sobre o alinhamento com CSS grid.
   ────────────────────────────────────────────────────────────────────────────── */
.custo-item {
  display: grid;
  grid-template-columns: 1fr 130px 1fr auto;
  gap: 8px;
  align-items: center;
  padding: 10px 20px;
  border-bottom: 1px solid #F5F0EA;
}
.custo-item:last-child { border-bottom: none; }
.custo-item input {
  padding: 7px 10px;
  border: 1.5px solid var(--input-border-user);
  border-radius: 6px;
  background: var(--input-user);
  font-family: 'Jost', sans-serif;
  font-size: 13px;
  width: 100%;
  outline: none;
  color: var(--text);
}
.custo-item input:focus { border-color: var(--primary); }
.custo-item-header {
  display: grid;
  grid-template-columns: 1fr 130px 1fr auto;
  gap: 8px;
  padding: 8px 20px;
  background: #FDFAF7;
  border-bottom: 1px solid var(--border);
  font-size: 10px;
  font-weight: 600;
  letter-spacing: 1px;
  color: var(--text-muted);
  text-transform: uppercase;
}
.total-row {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 14px 20px;
  background: var(--primary-light);
  border-top: 1px solid var(--border);
  font-weight: 600;
  color: var(--primary-dark);
  font-size: 14px;
}

/* ──────────────────────────────────────────────────────────────────────────────
   10. RESULTADOS CALCULADOS (box na aba Configurações)
   Exibe horas produtivas e custo por minuto calculados das configurações.
   Atualizado em tempo real por atualizarResultadosConfig() em app.js.
   ────────────────────────────────────────────────────────────────────────────── */
.resultados-box {
  margin: 0 20px 20px;
  background: #FDFAF7;
  border: 1px solid var(--border);
  border-radius: 10px;
  overflow: hidden;
}
.resultado-item {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 10px 16px;
  border-bottom: 1px solid #F5F0EA;
  font-size: 13px;
}
.resultado-item:last-child { border-bottom: none; }
.resultado-label { color: var(--text-muted); }
.resultado-valor { font-weight: 700; color: var(--primary-dark); font-size: 14px; }
.resultado-titulo {
  padding: 10px 16px;
  font-size: 10px;
  font-weight: 600;
  letter-spacing: 1.2px;
  text-transform: uppercase;
  color: var(--text-muted);
  background: #F5F0EA;
  border-bottom: 1px solid var(--border);
}

/* ──────────────────────────────────────────────────────────────────────────────
   11. ALERTAS
   Três variantes: warning (âmbar), error (terracota), info (taupe claro).
   Usados para avisar sobre: ocupação baixa, fator inviável, tempo não preenchido.
   Aparecem/somem via display:none/flex controlado por app.js.
   ────────────────────────────────────────────────────────────────────────────── */
.alert {
  margin: 0 20px 16px;
  padding: 10px 14px;
  border-radius: 8px;
  font-size: 12px;
  line-height: 1.5;
  display: flex;
  align-items: flex-start;
  gap: 8px;
}
.alert-icon { font-size: 14px; flex-shrink: 0; }
.alert-warning { background: var(--yellow-light); border: 1px solid #E8C882; color: #7A5A20; }
.alert-error   { background: var(--red-light);    border: 1px solid #DDA090; color: #8A3028; }
.alert-info    { background: var(--primary-light); border: 1px solid var(--border); color: var(--primary-dark); }

/* ──────────────────────────────────────────────────────────────────────────────
   12. TABELAS E BADGES
   .data-table: estilo base de todas as tabelas do sistema.
     .calc-cell: células calculadas dentro de tabelas (fundo cinza).
     .actions-cell: coluna de botões (Editar/Excluir) alinhada à direita.
   .badge: chip colorido para exibir status de margem.
     .badge-green / -yellow / -red / -gray: variantes de status.
   .legend: legenda explicativa (azul = usuário, cinza = calculado).
   ────────────────────────────────────────────────────────────────────────────── */
.data-table { width: 100%; border-collapse: collapse; }
.data-table th {
  background: #FDFAF7;
  padding: 10px 14px;
  text-align: left;
  font-size: 10px;
  font-weight: 600;
  letter-spacing: 1px;
  color: var(--text-muted);
  text-transform: uppercase;
  border-bottom: 1px solid var(--border);
}
.data-table td {
  padding: 10px 14px;
  border-bottom: 1px solid #F5F0EA;
  font-size: 13px;
  color: var(--text);
}
.data-table tr:last-child td { border-bottom: none; }
.data-table tr:hover td { background: var(--primary-light); }
/* Cancela o hover herdado pelo nested calc-memo-table e preserva os cabeçalhos escuros */
.calc-memo-table tr:hover td { background: transparent; }
.calc-step-header td   { background: var(--primary-deep)  !important; color: #F5EFE8 !important; }
.calc-header-atual td  { background: #5A7A65 !important; color: #F5EFE8 !important; }
.data-table .calc-cell { background: var(--input-calc); color: var(--text-muted); font-weight: 600; }
.data-table .actions-cell { text-align: right; white-space: nowrap; }
.insumo-em-uso-msg {
  font-size: 12px;
  color: var(--red);
  white-space: normal;
  text-align: left;
  line-height: 1.4;
}
.empty-state {
  padding: 44px 20px;
  text-align: center;
  color: var(--text-muted);
}
.empty-state p { margin-bottom: 4px; line-height: 1.6; }
.empty-icon { font-size: 32px; margin-bottom: 12px; }

/* ── Badges ── */
.badge {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  padding: 3px 9px;
  border-radius: 20px;
  font-size: 11px;
  font-weight: 600;
  letter-spacing: 0.3px;
}
.badge-green  { background: var(--green-light);  color: #2E6B40; }
.badge-yellow { background: var(--yellow-light); color: #7A5A20; }
.badge-red    { background: var(--red-light);    color: #8A3028; }
.badge-gray   { background: var(--input-calc);   color: var(--text-muted); }

/* ── Serviços ── */
.servicos-layout {
  display: grid;
  grid-template-columns: 300px 1fr;
  gap: 20px;
  align-items: start;
}
@media (max-width: 900px) { .servicos-layout { grid-template-columns: 1fr; } }

.servico-item {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 13px 16px;
  cursor: pointer;
  border-bottom: 1px solid #F5F0EA;
  transition: background 0.1s;
  gap: 8px;
}
.servico-item:last-child { border-bottom: none; }
.servico-item:hover  { background: var(--primary-light); }
.servico-item.active { background: var(--primary-light); border-left: 3px solid var(--primary); }
.servico-item-nome   { font-weight: 500; font-size: 13px; flex: 1; }
.servico-item-tempo  { font-size: 11px; color: var(--text-muted); }

.servico-detalhe { position: sticky; top: 20px; }

/* ── Detalhe serviço ── */
.detalhe-section { border-bottom: 1px solid var(--border); padding: 16px 20px; }
.detalhe-section:last-child { border-bottom: none; }
.detalhe-section-title {
  font-size: 10px;
  font-weight: 600;
  letter-spacing: 1.2px;
  text-transform: uppercase;
  color: var(--text-muted);
  margin-bottom: 12px;
}

/* ── Composição ── */
.composicao-row {
  display: grid;
  grid-template-columns: 2fr 100px 80px auto;
  gap: 8px;
  align-items: center;
  padding: 6px 0;
}
.composicao-row select,
.composicao-row input {
  padding: 6px 8px;
  border: 1.5px solid var(--input-border-user);
  border-radius: 6px;
  background: var(--input-user);
  font-family: 'Jost', sans-serif;
  font-size: 12px;
  width: 100%;
  color: var(--text);
}
.composicao-calc { font-size: 12px; color: var(--text-muted); font-weight: 600; text-align: right; }

/* ── Grid financeiro ── */
.financeiro-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 12px;
  padding: 16px 20px;
}
.financeiro-card {
  background: #FDFAF7;
  border: 1px solid var(--border);
  border-radius: 9px;
  padding: 13px;
}
.financeiro-card.destaque {
  background: var(--primary-light);
  border-color: var(--primary);
}
.financeiro-card-label { font-size: 11px; color: var(--text-muted); margin-bottom: 5px; font-weight: 600; letter-spacing: 0.5px; }
.financeiro-card-valor { font-family: 'Cormorant Garamond', serif; font-size: 22px; font-weight: 500; color: var(--text); }
.financeiro-card.destaque .financeiro-card-valor { color: var(--primary-dark); }
.financeiro-card-sub { font-size: 11px; color: var(--text-muted); margin-top: 3px; }

/* ──────────────────────────────────────────────────────────────────────────────
   15. PROTOCOLO
   .protocolo-info: linha de campos de dados do protocolo (cliente, data, pagamento).
   .protocolo-add-row: linha de adicionar procedimento ao protocolo.
   .cenarios-grid: grade de cards de cenários de negociação.
   .cenario-card: card de cada cenário — variante de cor via classe .green/.yellow/.red.
   ────────────────────────────────────────────────────────────────────────────── */
.protocolo-info {
  display: grid;
  grid-template-columns: 1fr 1fr 200px;
  gap: 16px;
  align-items: end;
}
@media (max-width: 700px) { .protocolo-info { grid-template-columns: 1fr; } }

.protocolo-add-row {
  display: grid;
  grid-template-columns: 1fr 100px auto;
  gap: 10px;
  align-items: end;
  padding: 12px 20px;
  background: #FDFAF7;
  border-top: 1px solid var(--border);
}
.protocolo-table .data-table th,
.protocolo-table .data-table td { font-size: 12px; padding: 8px 12px; }

/* ── Totais ── */
.totais-box {
  background: linear-gradient(135deg, var(--primary-light) 0%, #EFE7DC 100%);
  border: 1px solid #D4C5B5;
  border-radius: 12px;
  padding: 20px;
  margin-top: 4px;
}
/* ── Resumo do Protocolo: valores principais ── */
.resumo-destaques {
  display: flex;
  flex-wrap: wrap;
  align-items: flex-start;
  gap: 8px 32px;
  margin-bottom: 20px;
}
.resumo-dest-item { display: flex; flex-direction: column; }
.resumo-dest-sep      { padding-left: 32px; border-left: 1px solid #D4C5B5; }
.resumo-grupo-vista   { display: flex; gap: 24px; align-items: flex-start; }
.resumo-dest-label {
  font-size: 10px;
  font-weight: 700;
  letter-spacing: 1px;
  text-transform: uppercase;
  color: var(--text-muted);
}
.resumo-dest-valor {
  font-family: 'Jost', sans-serif;
  font-size: 22px;
  font-weight: 600;
  color: var(--primary-dark);
  margin-top: 4px;
  font-variant-numeric: tabular-nums;
}
.resumo-dest-lg { font-size: 32px; }
.resumo-dest-sub {
  font-family: 'Jost', sans-serif;
  font-size: 12px;
  color: var(--text-muted);
  margin-top: 3px;
}

/* ── Resumo do Protocolo: lista secundária ── */
.resumo-secundario {
  display: flex;
  flex-wrap: wrap;
  gap: 4px 28px;
  border-top: 1px solid #D4C5B5;
  padding-top: 12px;
  font-family: 'Jost', sans-serif;
  font-size: 14px;
  color: var(--text-muted);
}
.resumo-sec-label {
  display: block;
  font-size: 10px;
  font-weight: 700;
  letter-spacing: 0.5px;
  text-transform: uppercase;
  margin-bottom: 2px;
}

/* ── Cenários de Negociação ── */
.cn-tipo-grupo {
  display: flex;
  align-items: center;
  gap: 20px;
  padding: 12px 20px;
  border-bottom: 1px solid var(--border);
  background: var(--bg);
}
.cn-tipo-label {
  font-size: 11px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: .5px;
  color: var(--text-muted);
}
.cn-tipo-option {
  display: flex;
  align-items: center;
  gap: 7px;
  font-size: 13px;
  font-weight: 500;
  color: var(--text-main);
  cursor: pointer;
}
.cn-tipo-option input[type="radio"] { accent-color: var(--primary); cursor: pointer; }
.cn-tipo-option:has(input:checked) { color: var(--primary-dark); font-weight: 600; }

.cn-campos-top {
  display: flex;
  gap: 16px;
  padding: 14px 20px;
  border-bottom: 1px solid var(--border);
  background: var(--bg);
  flex-wrap: wrap;
}
.cn-campos-top .field-group label {
  font-size: 11px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.5px;
  color: var(--text-muted);
  display: block;
  margin-bottom: 5px;
}
.cn-campos-top .user-input { width: 160px; }
.no-spinner::-webkit-inner-spin-button,
.no-spinner::-webkit-outer-spin-button { -webkit-appearance: none; margin: 0; }
.no-spinner { -moz-appearance: textfield; }


.cn-ancora-info {
  font-size: 12px;
  color: var(--text-muted);
  font-weight: 400;
}

/* ── Radio de seleção por linha ────────────────────────────────────────────
   Coluna estreita antes de "Cenário". Input estilizado com accent-color taupe.
   A linha selecionada não precisa de estilo extra — o bloco de destaque abaixo
   da tabela é o feedback visual. */
.cn-radio-cell {
  width: 36px;
  text-align: center;
  padding: 0 8px !important;
}
.cn-radio-cell input[type="radio"] {
  width: 16px;
  height: 16px;
  cursor: pointer;
  accent-color: var(--primary);
}

/* ── Bloco de destaque do cenário selecionado ──────────────────────────────
   Aparece ao selecionar um radio na tabela. Layout em 3 grupos separados por
   linhas verticais: [Preço] | [Parcelas] | [Resultado]. Fontes grandes e
   todas em Jost para máxima legibilidade durante reunião com cliente. */
#cn-destaque:empty { display: none; }

.cn-destaque-card {
  margin: 0;
  border-top: 5px solid transparent;
  padding: 28px 32px 32px;
}
.cn-destaque-card.cn-green  { border-top-color: #6B9E7A; background: linear-gradient(180deg, rgba(107,158,122,0.07) 0%, #fff 80px); }
.cn-destaque-card.cn-yellow { border-top-color: #C9963A; background: linear-gradient(180deg, rgba(201,150,58,0.07) 0%, #fff 80px); }
.cn-destaque-card.cn-red    { border-top-color: #C0594A; background: linear-gradient(180deg, rgba(192,89,74,0.07) 0%, #fff 80px); }

/* Cabeçalho: nome do cenário + badge de nível */
.cn-destaque-header {
  display: flex;
  align-items: center;
  gap: 14px;
  flex-wrap: wrap;
  margin-bottom: 0;
}
/* Nome em Cormorant sem itálico — elegante e legível */
.cn-destaque-nome {
  font-family: 'Cormorant Garamond', Georgia, serif;
  font-size: 28px;
  font-weight: 500;
  color: var(--text);
  letter-spacing: 0.3px;
  line-height: 1.1;
}
/* Badge de nível de margem */
.cn-destaque-nivel {
  font-size: 10px;
  font-weight: 700;
  letter-spacing: 1px;
  text-transform: uppercase;
  padding: 4px 11px;
  border-radius: 20px;
  white-space: nowrap;
}
.cn-destaque-card.cn-green  .cn-destaque-nivel { background: #EBF3EE; color: #2E6B40; }
.cn-destaque-card.cn-yellow .cn-destaque-nivel { background: #FBF3E2; color: #7A5A20; }
.cn-destaque-card.cn-red    .cn-destaque-nivel { background: #FAE8E5; color: #8A3028; }

/* Divisor horizontal entre cabeçalho e grupos de valores */
.cn-destaque-divider {
  height: 1px;
  background: var(--border);
  margin: 20px 0;
}

/* Grid: grupos de valores lado a lado, separados por linhas verticais */
.cn-destaque-grid {
  display: flex;
  flex-wrap: wrap;
  align-items: flex-start;
  gap: 0;
}

/* Separador vertical entre grupos — align-self:stretch ocupa a altura do maior grupo */
.cn-destaque-vsep {
  width: 1px;
  background: var(--border);
  align-self: stretch;
  min-height: 56px;
  margin: 0 32px;
}

/* Grupo padrão: itens empilhados em coluna */
.cn-destaque-grupo {
  display: flex;
  flex-direction: column;
  gap: 18px;
}

/* Grupo de resultado (lucro + margem): itens lado a lado em linha */
.cn-destaque-grupo-resultado {
  flex-direction: row;
  gap: 36px;
  align-items: flex-start;
}

.cn-destaque-item { display: flex; flex-direction: column; }

/* Label uppercase pequeno — mesmo padrão do Resumo do Protocolo */
.cn-destaque-label {
  font-size: 10px;
  font-weight: 700;
  letter-spacing: 1.2px;
  text-transform: uppercase;
  color: var(--text-muted);
  margin-bottom: 7px;
}

/* Valores secundários: saldo, lucro, margem */
.cn-destaque-valor {
  font-family: 'Jost', sans-serif;
  font-size: 20px;
  font-weight: 600;
  color: var(--primary-dark);
  font-variant-numeric: tabular-nums;
  line-height: 1;
}

/* Valores principais (preço total, parcelas): Jost bold grande — máxima legibilidade */
.cn-destaque-lg .cn-destaque-valor {
  font-size: 46px;
  font-weight: 700;
  letter-spacing: -1px;
}

/* ── Nota fiscal do cenário selecionado ────────────────────────────────────
   Aparece logo abaixo do bloco de destaque (#cn-destaque) quando um radio está
   selecionado. Estrutura em 4 seções: procedimentos | encargos | resultado | pagamento.
   Estilo limpo de documento — sem cards dentro de card, apenas tipografia e linhas. */
#cn-nota:empty { display: none; }

.cn-nota-fiscal {
  border-top: 2px solid var(--border);
  padding: 28px 32px 32px;
  background: #FDFBF8; /* leve aquecimento para distinguir do branco puro do destaque */
}

/* Linha de informações do protocolo: itens em linha com separadores */
.cn-nota-info {
  display: flex;
  flex-wrap: wrap;
  gap: 0 40px;
  margin-bottom: 28px;
  padding-bottom: 20px;
  border-bottom: 1px solid var(--border);
}
.cn-nota-info-item {
  display: flex;
  flex-direction: column;
  gap: 3px;
}
.cn-nota-info-label {
  font-size: 9px;
  font-weight: 700;
  letter-spacing: 1.2px;
  text-transform: uppercase;
  color: var(--text-muted);
}
.cn-nota-info-val {
  font-family: 'Jost', sans-serif;
  font-size: 14px;
  font-weight: 500;
  color: var(--text);
}

/* Seção (bloco): título + tabela */
.cn-nota-section {
  margin-bottom: 24px;
}
.cn-nota-section:last-child { margin-bottom: 0; }
.cn-nota-export {
  display: flex;
  justify-content: flex-end;
  padding: 16px 24px 20px;
  border-top: 1px solid var(--border);
}

/* Título de seção: linha fina acima, texto uppercase pequeno */
.cn-nota-section-title {
  font-size: 9px;
  font-weight: 700;
  letter-spacing: 1.4px;
  text-transform: uppercase;
  color: var(--primary);
  padding-bottom: 8px;
  margin-bottom: 0;
  border-bottom: 1px solid var(--border);
}

/* Tabela de cada seção: sem bordas externas, apenas linhas entre linhas */
.cn-nota-table {
  width: 100%;
  border-collapse: collapse;
  font-family: 'Jost', sans-serif;
  font-size: 13px;
}
.cn-nota-table thead th {
  font-size: 10px;
  font-weight: 700;
  letter-spacing: 0.6px;
  text-transform: uppercase;
  color: var(--text-muted);
  padding: 8px 0 6px;
  text-align: left;
  border-bottom: 1px solid var(--border);
}
.cn-nota-table thead th.cn-nota-num { text-align: right; }
.cn-nota-table tbody td {
  padding: 7px 0;
  color: var(--text);
  border-bottom: 1px solid rgba(226,217,207,0.5);
}
.cn-nota-table tbody tr:last-child td { border-bottom: none; }

/* Células numéricas alinhadas à direita com fonte mono */
.cn-nota-num {
  text-align: right;
  font-variant-numeric: tabular-nums;
  font-feature-settings: "tnum";
  white-space: nowrap;
}

/* Linha de total (tfoot): bold, linha acima, sem linha abaixo */
.cn-nota-table tfoot td {
  padding: 8px 0 4px;
  font-weight: 600;
  color: var(--text);
  border-top: 1px solid var(--border);
}
.cn-nota-table tfoot tr + tr td { border-top: none; }

/* Lucro em verde */
.cn-nota-lucro { color: var(--green) !important; }

/* Tabela de encargos com coluna de fórmula */
.cn-nota-table-enc { table-layout: fixed; }
.cn-enc-header th { font-size: 10px; font-weight: 700; letter-spacing: .5px; text-transform: uppercase; color: var(--text-muted); background: var(--bg-main); }
.cn-enc-formula { width: 46%; }
.cn-enc-formula-txt { font-size: 11px; color: var(--text-muted); font-style: italic; }
.cn-enc-ref td { background: rgba(184,151,122,0.07); font-weight: 500; }
.cn-enc-ref-val { font-weight: 700; color: var(--primary-dark); }
.cn-enc-sep td { height: 6px; border: none; padding: 0; }
.cn-enc-subtotal td {
  border-top: 1.5px solid var(--border);
  font-weight: 600;
  padding-top: 8px;
}
.cn-enc-formula-lucro td {
  padding-top: 2px;
  padding-bottom: 6px;
  border-bottom: 2px solid var(--primary-dark);
}
.cn-enc-margem {
  font-size: 11px;
  font-weight: 400;
  color: var(--green);
  margin-left: 4px;
}

/* Linha do preço final: destaque maior */
.cn-nota-preco-final td {
  font-size: 15px;
  font-weight: 700;
  color: var(--primary-dark) !important;
  padding-top: 10px;
}
.cn-table {
  width: 100%;
  border-collapse: collapse;
  font-size: 13px;
  font-family: 'Jost', sans-serif;
}
.cn-table thead th {
  font-size: 10px;
  font-weight: 700;
  letter-spacing: 0.8px;
  text-transform: uppercase;
  color: var(--text-muted);
  padding: 10px 14px;
  border-bottom: 2px solid var(--border);
  white-space: nowrap;
  background: #FDFBF8;
}
.cn-table thead th:not(:first-child):not(:nth-child(2)) { text-align: right; }
.cn-row { cursor: help; }
.cn-row td { padding: 11px 14px; border-bottom: 1px solid #F5F0EA; vertical-align: middle; }
.cn-row:last-child td { border-bottom: none; }

/* Faixa de cor por nível: borda esquerda colorida + fundo suave */
.cn-row.cn-green  { border-left: 3px solid #6B9E7A; }
.cn-row.cn-yellow { border-left: 3px solid #C9963A; }
.cn-row.cn-red    { border-left: 3px solid #C0594A; }
.cn-row.cn-green  td:first-child { padding-left: 11px; }
.cn-row.cn-yellow td:first-child { padding-left: 11px; }
.cn-row.cn-red    td:first-child { padding-left: 11px; }
.cn-row.cn-green:hover  td { background: #F2FAF5; }
.cn-row.cn-yellow:hover td { background: #FBF7ED; }
.cn-row.cn-red:hover    td { background: #FBF0EE; }

.cn-nome { font-weight: 600; color: var(--text); white-space: nowrap; }
.cn-pag  { font-size: 11px; color: var(--text-muted); white-space: nowrap; }
.cn-val  { text-align: right; font-variant-numeric: tabular-nums; }
.cn-inviavel { color: #C0594A; font-style: italic; font-size: 12px; }

/* Tag "âncora" na primeira linha */
.cn-ancora-tag {
  display: inline-block;
  font-size: 9px;
  font-weight: 700;
  letter-spacing: 0.6px;
  text-transform: uppercase;
  background: var(--primary-deep);
  color: #F2ECE6;
  padding: 2px 6px;
  border-radius: 4px;
  margin-left: 6px;
  vertical-align: middle;
}

/* ──────────────────────────────────────────────────────────────────────────────
   13. MODAL GENÉRICO
   Overlay escuro semi-transparente cobre toda a tela (position:fixed, inset:0).
   A caixa do modal fica centralizada com display:flex + align/justify center.
   Começa com display:none; app.js muda para display:flex ao abrir.
   max-height + overflow-y:auto permite que formulários longos rolem dentro do modal.
   ────────────────────────────────────────────────────────────────────────────── */
.modal-overlay {
  position: fixed;
  inset: 0;
  background: rgba(44,32,24,0.45);
  display: flex;
  align-items: center;
  justify-content: center;
  z-index: 1000;
  padding: 20px;
}
.modal {
  background: white;
  border-radius: 14px;
  box-shadow: 0 20px 60px rgba(44,32,24,0.2);
  width: 100%;
  max-width: 540px;
  max-height: 90vh;
  display: flex;
  flex-direction: column;
  overflow: hidden;
}
.modal-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 16px 20px;
  border-bottom: 1px solid var(--border);
  background: #FDFAF7;
}
.modal-header h3 {
  font-family: 'Cormorant Garamond', serif;
  font-size: 18px;
  font-weight: 500;
  color: var(--text);
}
.modal-close {
  background: none;
  border: none;
  font-size: 22px;
  cursor: pointer;
  color: var(--text-muted);
  line-height: 1;
  padding: 2px 6px;
  border-radius: 4px;
}
.modal-close:hover { background: var(--primary-light); color: var(--primary-dark); }
.modal-body   { padding: 20px; overflow-y: auto; flex: 1; }
.modal-footer {
  padding: 14px 20px;
  border-top: 1px solid var(--border);
  display: flex;
  justify-content: flex-end;
  gap: 10px;
  background: #FDFAF7;
}

/* ── Legend ── */
.legend {
  display: flex;
  gap: 16px;
  flex-wrap: wrap;
  padding: 10px 20px;
  background: #FDFAF7;
  border-top: 1px solid var(--border);
  font-size: 11px;
  color: var(--text-muted);
}
.legend-item { display: flex; align-items: center; gap: 6px; }
.legend-dot  { width: 10px; height: 10px; border-radius: 50%; }
.legend-dot.blue { background: var(--input-border-user); }
.legend-dot.gray { background: var(--input-border-calc); }

/* ──────────────────────────────────────────────────────────────────────────────
   14. TABELA DE SERVIÇOS EXPANSÍVEL
   Cada serviço tem dois <tr> consecutivos:
     .srv-row       — linha principal sempre visível; onclick dispara toggleServico()
     .srv-expand-tr — linha expandida oculta por padrão (display:none via JS)
   O .srv-chevron exibe ▶ (fechado) ou ▼ (aberto), indicado pelo JS.
   .srv-preco-dest destaca a coluna "Preço sugerido" com fundo âmbar.
   .srv-add-row  é a linha de adição inline (borda tracejada âmbar).
   .srv-table-hint é o texto de dica no rodapé da tabela.
   ────────────────────────────────────────────────────────────────────────────── */
.srv-table { table-layout: auto; }
.srv-table th { white-space: nowrap; }
.srv-table td { vertical-align: middle; }
.th-sub { font-weight: 400; font-size: 10px; text-transform: none; letter-spacing: 0; opacity: 0.75; }

.srv-row { cursor: pointer; transition: background 0.12s; }
.srv-row:hover td { background: var(--primary-light); }
.srv-row-expanded td { background: #F5EFE8; }
.srv-row-expanded:hover td { background: #EFE7DC; }

.srv-chevron {
  color: var(--text-muted);
  font-size: 10px;
  padding-right: 4px !important;
  user-select: none;
  width: 28px;
}
.srv-obs-preview { font-size: 11px; color: var(--text-muted); font-weight: 400; margin-top: 2px; }
.srv-preco-dest  { color: var(--primary-dark); }
.val-pos { color: var(--green); font-weight: 600; }
.val-neg { color: var(--red);   font-weight: 600; }

/* Células editáveis inline na tabela de serviços */
.cell-editable { position: relative; }
.cell-preco-atual { background: rgba(184,151,122,0.06); }
.inline-input {
  background: transparent;
  border: 1px solid transparent;
  border-radius: 4px;
  color: inherit;
  font-family: inherit;
  font-size: inherit;
  font-weight: inherit;
  width: 100%;
  padding: 2px 4px;
  margin: -2px -4px;
  outline: none;
  transition: border-color 0.15s, background 0.15s;
  -moz-appearance: textfield;
}
.inline-input::-webkit-outer-spin-button,
.inline-input::-webkit-inner-spin-button { -webkit-appearance: none; margin: 0; }
.inline-input:hover  { border-color: var(--border); background: rgba(255,255,255,0.8); }
.inline-input:focus  { border-color: var(--primary); background: #fff; box-shadow: 0 0 0 2px rgba(184,151,122,0.18); }
.inline-input-num    { width: 60px; text-align: right; }
.inline-input-moeda  { width: 100px; text-align: right; font-weight: 600; color: var(--primary-dark); }
.inline-input::placeholder { color: var(--text-muted); font-weight: 400; }

.srv-table-hint {
  padding: 9px 16px;
  font-size: 11px;
  color: var(--text-muted);
  text-align: center;
  background: #FDFAF7;
  border-top: 1px solid var(--border);
  font-style: italic;
}

/* Linha de adição inline */
.srv-add-row td {
  background: #FFFBF3;
  border-top: 2px dashed var(--primary);
  border-bottom: 2px dashed var(--primary);
}
.srv-add-row td:first-child { border-left: 2px dashed var(--primary); border-radius: 0; }
.srv-add-row td:last-child  { border-right: 2px dashed var(--primary); }

.srv-inline-input {
  width: 100%;
  padding: 6px 8px;
  border: 1.5px solid var(--input-border-user);
  border-radius: 6px;
  background: white;
  font-family: 'Jost', sans-serif;
  font-size: 13px;
  color: var(--text);
  outline: none;
  min-width: 0;
}
.srv-inline-input:focus { border-color: var(--primary); box-shadow: 0 0 0 3px rgba(184,151,122,0.15); }
.srv-inline-num { width: 80px; }

.mono { font-variant-numeric: tabular-nums; }
.text-center { text-align: center; }

/* Linha expandida */
.srv-expand-tr td { padding: 0 !important; border-bottom: 2px solid var(--primary) !important; }
.srv-expand-td { background: #FDFBF8 !important; }

.expand-content {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 0;
  padding: 20px;
  gap: 20px;
}
@media (max-width: 1000px) { .expand-content { grid-template-columns: 1fr; } }

.expand-col { display: flex; flex-direction: column; gap: 0; }

.expand-section {
  background: white;
  border: 1px solid var(--border);
  border-radius: 10px;
  padding: 16px;
  margin-bottom: 16px;
}
.expand-section:last-child { margin-bottom: 0; }
.expand-section-title {
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 1px;
  text-transform: uppercase;
  color: var(--primary-dark);
  margin-bottom: 12px;
}

/* Wrapper do painel expandido — envolve as colunas + observações */
.expand-wrap { display: flex; flex-direction: column; }

/* Formulário inline para adicionar insumo */
.expand-add-row {
  display: flex;
  gap: 8px;
  align-items: center;
  padding: 10px 0 4px;
  flex-wrap: wrap;
}
.exp-add-select {
  flex: 1;
  min-width: 160px;
  padding: 6px 8px;
  border: 1.5px solid var(--input-border-user);
  border-radius: 5px;
  background: var(--input-user);
  font-family: 'Jost', sans-serif;
  font-size: 12px;
  color: var(--text);
}
.exp-add-qtd {
  width: 70px;
  padding: 6px 8px;
  border: 1.5px solid var(--input-border-user);
  border-radius: 5px;
  background: var(--input-user);
  font-family: 'Jost', sans-serif;
  font-size: 12px;
  color: var(--text);
}

/* Seção de observações abaixo das colunas */
.expand-obs-section {
  padding: 16px 20px 20px;
  border-top: 1px solid var(--border);
  background: #FDFBF8;
}
.expand-obs-input {
  width: 100%;
  min-height: 68px;
  resize: vertical;
  border: 1.5px solid var(--input-border-user);
  border-radius: 6px;
  background: var(--input-user);
  font-family: 'Jost', sans-serif;
  font-size: 13px;
  color: var(--text);
  padding: 10px 12px;
  outline: none;
  transition: border-color .15s;
  line-height: 1.5;
}
.expand-obs-input:focus { border-color: var(--primary); }
.expand-obs-input::placeholder { color: var(--text-muted); }
.text-center { text-align: center; }

/* Tabela de composição inline */
.comp-table { font-size: 12px; }
.comp-table th { font-size: 10px; }
.comp-select {
  width: 100%;
  padding: 5px 7px;
  border: 1.5px solid var(--input-border-user);
  border-radius: 5px;
  background: var(--input-user);
  font-family: 'Jost', sans-serif;
  font-size: 12px;
  color: var(--text);
}
.comp-input {
  width: 80px;
  padding: 5px 7px;
  border: 1.5px solid var(--input-border-user);
  border-radius: 5px;
  background: var(--input-user);
  font-family: 'Jost', sans-serif;
  font-size: 12px;
  color: var(--text);
}
.comp-total { color: var(--primary-dark); }
.comp-total-row td {
  background: var(--primary-light);
  border-top: 1px solid var(--border);
  font-size: 13px;
  padding: 8px 14px;
}

/* Tabela memória de cálculo */
.calc-memo-table {
  width: 100%;
  border-collapse: collapse;
  font-size: 12px;
}
.calc-step-header td {
  background: var(--primary-deep);
  color: #F5EFE8;
  padding: 6px 12px;
  font-weight: 600;
  font-size: 11px;
  letter-spacing: 0.5px;
}
.calc-step-row td { padding: 7px 12px; border-bottom: 1px solid #F5F0EA; }
.calc-step-row:last-child td { border-bottom: none; }
.calc-item-label   { color: var(--text); width: 38%; }
.calc-item-formula { color: var(--text-muted); width: 38%; font-style: italic; }
.calc-item-valor   { text-align: right; color: var(--text); font-weight: 600; width: 24%; white-space: nowrap; }
.calc-destaque     { color: var(--primary-dark); font-size: 14px; }
.calc-subtotal td {
  padding: 8px 12px;
  background: var(--primary-light);
  font-weight: 600;
  font-size: 13px;
  border-top: 1px solid var(--border);
}
.calc-subtotal td:last-child { text-align: right; }
.calc-header-atual td { background: #5A7A65; } /* verde escuro — separa bloco do preço atual */
.calc-destaque-atual  { color: #2E6B40; font-size: 14px; }
.calc-subtotal-atual td { background: rgba(107,158,122,0.12); color: #2E6B40; }

/* ──────────────────────────────────────────────────────────────────────────────
   15. CÉLULAS EDITÁVEIS E CALCULADAS — Aba Serviços
   .cell-edit  — célula clicável que abre edição inline (cursor pointer, sublinhado pontilhado)
   .cell-calc  — célula com cálculo automático (cursor help, fundo âmbar suave ao hover)
   .cell-edit-val — span interno ao .cell-edit que exibe o valor atual
   .cell-edit-input — <input> injetado por editarCampo() ao clicar em .cell-edit

   Indicadores no cabeçalho:
   .th-edit      — cabeçalho de coluna editável
   .th-calc      — cabeçalho de coluna calculada
   .th-edit-hint — ícone ✎ no cabeçalho editável
   .th-calc-hint — ícone ⊕ no cabeçalho calculado
   ────────────────────────────────────────────────────────────────────────────── */

/* ── Célula editável ────────────────────────────────────────────────────────
   Em repouso: fundo azul-acinzentado suave (mesma linguagem visual dos inputs
   de usuário — --input-user) + linha de base via box-shadow inset para sinalizar
   "este campo é preenchível" (padrão Material Design, amplamente reconhecido).
   No hover: fundo mais intenso, linha de base sólida e ícone ✎ no canto. */
.cell-edit {
  cursor: pointer;
  position: relative;
  background: #F0F5FF;
  box-shadow: inset 0 -2px 0 rgba(140,170,228,0.45);
  transition: background 0.12s, box-shadow 0.12s;
}

/* Ícone de lápis: invisível em repouso, aparece no hover */
.cell-edit::after {
  content: '✎';
  position: absolute;
  top: 4px;
  right: 6px;
  font-size: 10px;
  line-height: 1;
  color: #7B9FD4;
  opacity: 0;
  transition: opacity 0.12s;
  pointer-events: none;
}

.cell-edit:hover {
  background: #DDE8FF !important;
  box-shadow: inset 0 -2px 0 #8CAAE4 !important;
}
.cell-edit:hover::after { opacity: 1; }

/* ── Célula calculada ───────────────────────────────────────────────────────
   Hover âmbar + contorno tracejado sinaliza "calculado — passe o mouse
   para ver o racional" (cor quente contrasta com o azul das editáveis). */
.cell-calc {
  cursor: help;
  position: relative;
  transition: background 0.12s;
}
.cell-calc:hover {
  background: #FFF5E6 !important;
  outline: 1px dashed var(--primary);
  outline-offset: -2px;
}

/* ── Input injetado ao clicar em .cell-edit ─────────────────────────────── */
.cell-edit-input {
  width: 100%;
  min-width: 60px;
  padding: 4px 8px;
  border: none;
  border-bottom: 2px solid var(--primary);
  border-radius: 0;
  background: #EEF3FF;
  font-family: 'Jost', sans-serif;
  font-size: 13px;
  color: var(--text);
  outline: none;
}

/* ── Ícones nos cabeçalhos ──────────────────────────────────────────────── */
.th-edit-hint { font-size: 10px; color: #7B9FD4; opacity: 0.8; font-style: normal; }
.th-calc-hint { font-size: 10px; color: var(--primary); opacity: 0.8; font-style: normal; }
.th-edit { cursor: default; }
.th-calc { cursor: default; }

/* ──────────────────────────────────────────────────────────────────────────────
   16. TOOLTIP FLUTUANTE DE CÁLCULO — Aba Serviços
   #srv-tooltip é criado por initTooltip() e posicionado por showTipFor().
   Fica fixo no documento (position:absolute no body), flutua abaixo da célula.
   .tip-section — sub-título dentro do tooltip
   .tip-formula — linha com a fórmula em destaque (monoespaçado)
   .tip-table   — mini-tabela de composição dentro do tooltip
   .tip-total   — linha de total da tip-table
   .tip-note    — nota explicativa em menor destaque
   .tip-empty   — linha de "sem dados" na tip-table
   ────────────────────────────────────────────────────────────────────────────── */

#srv-tooltip {
  display: none;
  position: absolute;
  z-index: 9999;
  max-width: 420px;
  min-width: 240px;
  background: #2C2018;
  color: #F2ECE6;
  border-radius: 10px;
  padding: 14px 16px;
  font-family: 'Jost', sans-serif;
  font-size: 12px;
  line-height: 1.55;
  box-shadow: 0 8px 28px rgba(44,32,24,0.28);
  pointer-events: none;
}
#srv-tooltip b {
  font-size: 13px;
  font-family: 'Cormorant Garamond', serif;
  font-weight: 700;
  color: #D4B79A;
  display: block;
  margin-bottom: 6px;
}
.tip-section {
  font-size: 10px;
  font-weight: 700;
  letter-spacing: 0.8px;
  text-transform: uppercase;
  color: #B8977A;
  margin: 10px 0 4px;
}
.tip-formula {
  display: block;
  background: rgba(255,255,255,0.06);
  border-left: 2px solid #B8977A;
  padding: 6px 10px;
  border-radius: 0 5px 5px 0;
  font-variant-numeric: tabular-nums;
  margin: 4px 0 6px;
  font-size: 12px;
}
.tip-note {
  font-size: 10.5px;
  color: rgba(242,236,230,0.6);
  margin: 3px 0 6px;
  line-height: 1.45;
}
.tip-table {
  width: 100%;
  border-collapse: collapse;
  margin: 4px 0 6px;
  font-size: 11.5px;
}
.tip-table td {
  padding: 4px 8px;
  border-bottom: 1px solid rgba(255,255,255,0.08);
  color: #E8DED5;
}
.tip-table td:last-child { text-align: right; font-variant-numeric: tabular-nums; }
.tip-total td {
  border-top: 1px solid rgba(184,151,122,0.5) !important;
  border-bottom: none !important;
  color: #D4B79A;
  font-weight: 600;
  padding-top: 6px;
}
.tip-empty { color: rgba(242,236,230,0.4) !important; font-style: italic; text-align: center !important; }

/* ──────────────────────────────────────────────────────────────────────────────
   16B. STATUS CELL — Aba Serviços
   .srv-status-cell — td que contém o status composto
   .srv-status      — wrapper do texto de status (display inline-flex com pipe separators)
   Variantes de cor: green / yellow / red / empty
   .ss-nivel, .ss-sep, .ss-margem, .ss-diff, .ss-lucro — partes internas do status
   ────────────────────────────────────────────────────────────────────────────── */

.srv-status-cell {
  padding: 6px 10px !important;
  white-space: nowrap;
}
.srv-status {
  display: inline-flex;
  align-items: center;
  gap: 5px;
  font-size: 12px;
  line-height: 1.3;
  padding: 4px 10px;
  border-radius: 6px;
  font-variant-numeric: tabular-nums;
}
.srv-status-empty {
  font-size: 11.5px;
  color: var(--text-muted);
  font-style: italic;
}
.srv-status-green  { background: rgba(107,158,122,0.12); color: #3B7A52; }
.srv-status-yellow { background: rgba(201,150,58,0.12);  color: #8A5F10; }
.srv-status-red    { background: rgba(192,89,74,0.12);   color: #9B3226; }

.ss-nivel  { font-weight: 700; font-size: 12px; }
.ss-sep    { opacity: 0.35; font-size: 11px; }
.ss-margem { font-size: 11.5px; }
.ss-diff   { font-size: 11.5px; }
.ss-lucro  { font-size: 11.5px; }
.ss-pos    { color: inherit; }
.ss-neg    { opacity: 0.85; }

/* ──────────────────────────────────────────────────────────────────────────────
   17. UTILITÁRIOS
   Classes auxiliares usadas inline no HTML gerado por app.js:
     .gap-actions  — flex row com gap para botões de ação (Editar + Excluir)
     .text-right   — alinha conteúdo à direita (valores monetários)
     .text-muted   — aplica cor muted (campos vazios ou não preenchidos)
     .mono         — fonte monoespaçada para valores numéricos (alinha decimais)
     .val-pos      — verde (lucro positivo, diferença favorável)
     .val-neg      — vermelho (prejuízo, diferença desfavorável)
   ────────────────────────────────────────────────────────────────────────────── */
.gap-actions { display: flex; gap: 6px; }
.text-right  { text-align: right; }
.text-muted  { color: var(--text-muted); }
hr { border: none; border-top: 1px solid var(--border); margin: 16px 0; }
.w-full  { width: 100%; }
.mt-12   { margin-top: 12px; }
.pt-16   { padding-top: 16px; }
.param-form { padding: 20px; }

