/* ───────────── Botões ───────────── */

.btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: var(--espaco-sm);
  min-height: 44px;
  padding: 10px 20px;
  border-radius: var(--raio-md);
  font-size: var(--t-sm);
  font-weight: 600;
  transition: background var(--transicao), opacity var(--transicao);
  white-space: nowrap;
}

.btn-largo { width: 100%; }

.btn-primario {
  background: var(--cor-primaria);
  color: #fff;
}
.btn-primario:hover { background: var(--cor-primaria-hover); }

.btn-secundario {
  background: var(--cor-superficie);
  color: var(--cor-texto);
  border: 1px solid var(--cor-borda);
}
.btn-secundario:hover { background: var(--cor-fundo); }

.btn-perigo {
  background: var(--cor-perigo);
  color: #fff;
}
.btn-perigo:hover { opacity: .9; }

.btn-fantasma {
  background: transparent;
  color: var(--cor-texto-secundario);
}
.btn-fantasma:hover { background: var(--cor-primaria-light); color: var(--cor-primaria); }

.btn:disabled, .btn.carregando {
  opacity: .7;
  cursor: not-allowed;
}

.btn .spinner { display: none; }
.btn.carregando .spinner { display: inline-block; }
.btn.carregando .btn-texto { visibility: hidden; position: absolute; }
.btn.carregando { position: relative; }

.spinner {
  width: 16px;
  height: 16px;
  border: 2px solid rgba(255,255,255,.4);
  border-top-color: #fff;
  border-radius: 50%;
  animation: girar .6s linear infinite;
}

.btn-secundario .spinner, .btn-fantasma .spinner {
  border: 2px solid rgba(15,76,92,.25);
  border-top-color: var(--cor-primaria);
}

@keyframes girar {
  to { transform: rotate(360deg); }
}

/* ───────────── Cards ───────────── */

.card {
  background: var(--cor-superficie);
  border: 1px solid var(--cor-borda);
  border-radius: var(--raio-lg);
  padding: var(--espaco-lg);
  box-shadow: var(--sombra-sm);
}

.card-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
  gap: var(--espaco-md);
}

.card-titulo {
  font-size: var(--t-sm);
  color: var(--cor-texto-secundario);
  margin-bottom: var(--espaco-xs);
}

.card-valor {
  font-size: var(--t-2xl);
  font-weight: 700;
  color: var(--cor-texto);
}

/* ───────────── Badges ───────────── */

.badge {
  display: inline-flex;
  align-items: center;
  padding: 2px 10px;
  border-radius: var(--raio-full);
  font-size: var(--t-xs);
  font-weight: 600;
}

.badge-sucesso { background: var(--cor-sucesso-light); color: var(--cor-sucesso); }
.badge-perigo  { background: var(--cor-perigo-light);  color: var(--cor-perigo); }
.badge-aviso   { background: #FEF3E2; color: var(--cor-aviso); }
.badge-info    { background: #E8F2FB; color: var(--cor-info); }
.badge-neutro  { background: var(--cor-fundo); color: var(--cor-texto-secundario); }

/* ───────────── Barra de progresso ───────────── */

.barra-progresso {
  width: 100%;
  height: 8px;
  background: var(--cor-borda);
  border-radius: var(--raio-full);
  overflow: hidden;
}

.barra-progresso-fill {
  height: 100%;
  background: var(--cor-primaria);
  border-radius: var(--raio-full);
  transition: width var(--transicao);
}

.barra-progresso-fill.completa { background: var(--cor-sucesso); }

/* ───────────── Drag handle ───────────── */

.drag-handle {
  cursor: grab;
  color: var(--cor-texto-terciario);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 20px;
}
.drag-handle:active { cursor: grabbing; }

tr.linha-arrastando, .kanban-card.arrastando {
  opacity: 0.5;
}

/* ───────────── Kanban ───────────── */

.kanban-colunas {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: var(--espaco-md);
}

@media (max-width: 1024px) {
  .kanban-colunas { grid-template-columns: 1fr; }
}

.kanban-coluna {
  background: var(--cor-fundo);
  border: 1px solid var(--cor-borda);
  border-radius: var(--raio-lg);
  padding: var(--espaco-sm);
  min-height: 200px;
}

.kanban-coluna h3 {
  font-size: var(--t-sm);
  padding: var(--espaco-sm);
  color: var(--cor-texto-secundario);
}

.kanban-lista {
  display: flex;
  flex-direction: column;
  gap: var(--espaco-sm);
  min-height: 80px;
}

.kanban-card {
  background: var(--cor-superficie);
  border: 1px solid var(--cor-borda);
  border-radius: var(--raio-md);
  padding: var(--espaco-sm);
  box-shadow: var(--sombra-sm);
  cursor: grab;
  font-size: var(--t-sm);
}
.kanban-card:active { cursor: grabbing; }
.kanban-card h4 { font-size: var(--t-sm); margin-bottom: 4px; }
.kanban-card .card-fase { color: var(--cor-texto-terciario); font-size: var(--t-xs); margin-bottom: 6px; }

/* ───────────── Toasts ───────────── */

.toast-container {
  position: fixed;
  bottom: var(--espaco-lg);
  right: var(--espaco-lg);
  display: flex;
  flex-direction: column;
  gap: var(--espaco-sm);
  z-index: 100;
  max-width: 360px;
}

.toast {
  background: var(--cor-superficie);
  border: 1px solid var(--cor-borda);
  border-left: 4px solid var(--cor-info);
  border-radius: var(--raio-md);
  box-shadow: var(--sombra-lg);
  padding: var(--espaco-md);
  font-size: var(--t-sm);
  color: var(--cor-texto);
  animation: entrar-toast .25s ease;
}

.toast-sucesso { border-left-color: var(--cor-sucesso); }
.toast-erro { border-left-color: var(--cor-perigo); }
.toast-aviso { border-left-color: var(--cor-aviso); }

@keyframes entrar-toast {
  from { opacity: 0; transform: translateY(8px); }
  to { opacity: 1; transform: translateY(0); }
}

/* ───────────── Placeholder de módulo futuro ───────────── */

.placeholder-modulo {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  text-align: center;
  padding: var(--espaco-2xl);
  min-height: 360px;
  color: var(--cor-texto-secundario);
}

.placeholder-modulo svg {
  width: 64px;
  height: 64px;
  color: var(--cor-primaria);
  margin-bottom: var(--espaco-md);
  opacity: .6;
}

.placeholder-modulo h2 {
  margin-bottom: var(--espaco-xs);
}

.placeholder-modulo .badge {
  margin-top: var(--espaco-md);
}

/* ───────────── Form auxiliares ───────────── */

.campo {
  margin-bottom: var(--espaco-md);
}

.campo-senha-wrap {
  position: relative;
}

.campo-senha-wrap input {
  padding-right: 44px;
}

.botao-olho {
  position: absolute;
  right: 8px;
  top: 50%;
  transform: translateY(-50%);
  width: 32px;
  height: 32px;
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--cor-texto-terciario);
  border-radius: var(--raio-sm);
}
.botao-olho:hover { color: var(--cor-texto); }
.icone-tema-escuro { display: none; }
[data-tema="escuro"] .icone-tema-claro { display: none; }
[data-tema="escuro"] .icone-tema-escuro { display: block; }

.botao-olho .icone-fechado { display: block; }
.botao-olho .icone-aberto { display: none; }
.botao-olho.mostrando .icone-fechado { display: none; }
.botao-olho.mostrando .icone-aberto { display: block; }

.erro-campo {
  color: var(--cor-perigo);
  font-size: var(--t-xs);
  margin-top: var(--espaco-xs);
}

.medidor-forca {
  display: flex;
  gap: 4px;
  margin-top: var(--espaco-xs);
}

.medidor-forca span {
  flex: 1;
  height: 4px;
  border-radius: var(--raio-full);
  background: var(--cor-borda);
}

.medidor-forca.f1 span:nth-child(1) { background: var(--cor-perigo); }
.medidor-forca.f2 span:nth-child(-n+2) { background: var(--cor-aviso); }
.medidor-forca.f3 span:nth-child(-n+3) { background: var(--cor-aviso); }
.medidor-forca.f4 span:nth-child(-n+4) { background: var(--cor-sucesso); }
.medidor-forca.f5 span { background: var(--cor-sucesso); }

.checkbox-linha {
  display: flex;
  align-items: center;
  gap: var(--espaco-sm);
  margin-bottom: var(--espaco-md);
}
.checkbox-linha input { width: auto; }
.checkbox-linha label { margin-bottom: 0; }

/* ───────────── Modal ───────────── */

.modal-backdrop {
  position: fixed;
  inset: 0;
  background: rgba(0,0,0,.5);
  display: none;
  align-items: center;
  justify-content: center;
  z-index: 90;
  padding: var(--espaco-md);
}

.modal-backdrop.aberto { display: flex; }

.modal-caixa {
  background: var(--cor-superficie);
  border-radius: var(--raio-lg);
  box-shadow: var(--sombra-lg);
  padding: var(--espaco-lg);
  max-width: 420px;
  width: 100%;
}

.modal-acoes {
  display: flex;
  gap: var(--espaco-sm);
  justify-content: flex-end;
  margin-top: var(--espaco-lg);
}

/* ───────────── Abas ───────────── */

.abas {
  display: flex;
  gap: var(--espaco-sm);
  border-bottom: 1px solid var(--cor-borda);
  margin-bottom: var(--espaco-lg);
  overflow-x: auto;
}

.aba-item {
  padding: 10px 16px;
  font-size: var(--t-sm);
  font-weight: 500;
  color: var(--cor-texto-secundario);
  border-bottom: 2px solid transparent;
  white-space: nowrap;
  min-height: 44px;
  display: flex;
  align-items: center;
}

.aba-item:hover { color: var(--cor-texto); }

.aba-item.ativa {
  color: var(--cor-primaria);
  border-bottom-color: var(--cor-primaria);
  font-weight: 600;
}

.aba-painel { display: none; }
.aba-painel.ativa { display: block; }
.aba-painel.grid-arquivos.ativa { display: grid; }

/* ───────────── Upload / Arquivos (Fase 7) ───────────── */

.zona-upload {
  border: 2px dashed var(--cor-borda);
  border-radius: var(--raio-lg);
  padding: var(--espaco-xl);
  text-align: center;
  cursor: pointer;
  transition: border-color var(--transicao), background var(--transicao);
  color: var(--cor-texto-secundario);
}

.zona-upload svg { margin: 0 auto var(--espaco-sm); color: var(--cor-primaria); opacity: .6; }

.zona-upload:hover, .zona-upload.arrastando {
  border-color: var(--cor-primaria);
  background: var(--cor-primaria-light);
}

.lista-progresso-upload {
  margin-top: var(--espaco-sm);
  display: flex;
  flex-direction: column;
  gap: var(--espaco-xs);
}

.item-progresso-upload {
  display: flex;
  align-items: center;
  gap: var(--espaco-sm);
  font-size: var(--t-sm);
  padding: 6px 0;
}

.item-progresso-upload .barra-progresso { flex: 1; }

.grid-arquivos {
  grid-template-columns: repeat(auto-fill, minmax(160px, 1fr));
  gap: var(--espaco-md);
}

.cartao-arquivo {
  background: var(--cor-superficie);
  border: 1px solid var(--cor-borda);
  border-radius: var(--raio-md);
  overflow: hidden;
  box-shadow: var(--sombra-sm);
  display: flex;
  flex-direction: column;
}

.cartao-arquivo-preview {
  height: 110px;
  background: var(--cor-fundo);
  display: flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  overflow: hidden;
}

.cartao-arquivo-preview img { width: 100%; height: 100%; object-fit: cover; }
.cartao-arquivo-preview svg { width: 40px; height: 40px; color: var(--cor-texto-terciario); }

.cartao-arquivo-info {
  padding: 8px 10px;
  font-size: var(--t-xs);
}

.cartao-arquivo-nome {
  font-weight: 600;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  color: var(--cor-texto);
}

.cartao-arquivo-acoes {
  display: flex;
  gap: 4px;
  padding: 6px 8px;
  border-top: 1px solid var(--cor-borda);
}

.cartao-arquivo-acoes button {
  flex: 1;
  padding: 4px;
  font-size: var(--t-xs);
  border-radius: var(--raio-sm);
  color: var(--cor-texto-secundario);
}
.cartao-arquivo-acoes button:hover { background: var(--cor-primaria-light); color: var(--cor-primaria); }

/* ───────────── Galeria / Comparador antes-depois ───────────── */

.galeria-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(180px, 1fr));
  gap: var(--espaco-md);
}

.galeria-foto {
  border-radius: var(--raio-md);
  overflow: hidden;
  cursor: pointer;
  position: relative;
  aspect-ratio: 4/3;
  border: 2px solid transparent;
}
.galeria-foto img { width: 100%; height: 100%; object-fit: cover; }
.galeria-foto.selecionada { border-color: var(--cor-destaque); }
.galeria-foto-data {
  position: absolute; bottom: 0; left: 0; right: 0;
  background: rgba(0,0,0,.55); color: #fff;
  font-size: var(--t-xs); padding: 4px 6px;
}

.comparador-antes-depois {
  position: relative;
  width: 100%;
  max-width: 800px;
  margin: 0 auto;
  aspect-ratio: 4/3;
  overflow: hidden;
  border-radius: var(--raio-lg);
  user-select: none;
}
.comparador-antes-depois img {
  position: absolute; top: 0; left: 0;
  width: 100%; height: 100%; object-fit: cover;
}
.comparador-antes-depois .img-depois {
  clip-path: inset(0 0 0 50%);
}
.comparador-slider {
  position: absolute; top: 0; bottom: 0; left: 50%;
  width: 4px; background: #fff;
  cursor: ew-resize;
  transform: translateX(-2px);
}
.comparador-slider::after {
  content: "⇔";
  position: absolute; top: 50%; left: 50%;
  transform: translate(-50%, -50%);
  background: #fff; color: var(--cor-primaria);
  width: 32px; height: 32px; border-radius: 50%;
  display: flex; align-items: center; justify-content: center;
  font-weight: 700;
}

.lightbox-overlay {
  position: fixed; inset: 0; background: rgba(0,0,0,.9);
  display: none; align-items: center; justify-content: center;
  z-index: 200; flex-direction: column;
}
.lightbox-overlay.aberto { display: flex; }
.lightbox-overlay img { max-width: 90vw; max-height: 80vh; object-fit: contain; }
.lightbox-controles { display: flex; gap: var(--espaco-md); margin-top: var(--espaco-md); }
.lightbox-controles button { color: #fff; }
.lightbox-fechar { position: absolute; top: 16px; right: 16px; color: #fff; }

/* ───────────────────────────── Cronograma (Fase 8) ───────────────────────────── */

.gantt-scroll {
  overflow-x: auto; overflow-y: hidden;
  border: 1px solid var(--cor-borda); border-radius: var(--raio-md);
}
.gantt-container { position: relative; }
.gantt-ruler { position: relative; height: 28px; border-bottom: 1px solid var(--cor-borda); }
.gantt-ruler-marca {
  position: absolute; top: 0; bottom: 0; border-left: 1px solid var(--cor-borda);
  font-size: var(--t-xs); color: var(--cor-texto-terciario);
  padding: 4px 0 0 6px; white-space: nowrap;
}
.gantt-linhas { position: relative; }
.gantt-linha { position: relative; height: 56px; border-bottom: 1px solid var(--cor-borda); }
.gantt-linha:nth-child(even) { background: var(--cor-fundo); }
.gantt-linha-label {
  position: sticky; left: 0; top: 4px; z-index: 5; cursor: pointer;
  display: inline-block; max-width: 220px;
  padding: 4px 8px; margin: 4px 0 0 0;
  background: var(--cor-superficie); border-right: 1px solid var(--cor-borda);
  border-radius: var(--raio-sm);
  font-size: var(--t-xs); font-weight: 600;
  white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
}
.gantt-barra { position: absolute; height: 14px; border-radius: 4px; cursor: pointer; }
.gantt-barra-previsto { top: 8px; background: var(--cor-primaria-light); border: 1px solid var(--cor-primaria); }
.gantt-barra-previsto.atrasada { border-style: dashed; border-color: var(--cor-perigo); background: var(--cor-perigo-light); }
.gantt-barra-realizado { top: 28px; background: var(--cor-sucesso); opacity: .85; }
.gantt-barra-realizado.concluida-com-atraso { background: var(--cor-aviso); }
.gantt-handle { position: absolute; top: 0; bottom: 0; width: 8px; cursor: ew-resize; z-index: 2; }
.gantt-handle-esquerda { left: -3px; }
.gantt-handle-direita { right: -3px; }
.gantt-label-atraso {
  position: absolute; top: 8px; font-size: 10px;
  color: var(--cor-perigo); white-space: nowrap; line-height: 14px;
}
.gantt-linha-hoje {
  position: absolute; top: 0; bottom: 0; width: 2px;
  background: var(--cor-perigo); z-index: 4; pointer-events: none;
}
.gantt-linha-hoje::before {
  content: "Hoje"; position: absolute; top: -16px; left: -14px;
  font-size: 10px; color: var(--cor-perigo); white-space: nowrap;
}
.legenda-cor { display: inline-block; width: 10px; height: 10px; border-radius: 2px; margin-right: 4px; vertical-align: middle; }
.legenda-previsto { background: var(--cor-primaria-light); border: 1px solid var(--cor-primaria); }
.legenda-realizado { background: var(--cor-sucesso); }
.legenda-atraso { background: var(--cor-perigo-light); border: 1px dashed var(--cor-perigo); }
.legenda-linha-hoje { display: inline-block; width: 10px; height: 2px; background: var(--cor-perigo); vertical-align: middle; margin-right: 4px; }

.gantt-tooltip {
  position: fixed; display: none; background: var(--cor-texto); color: var(--cor-fundo);
  padding: 8px 10px; border-radius: var(--raio-sm); font-size: var(--t-xs);
  z-index: 300; max-width: 260px; box-shadow: var(--sombra-md); pointer-events: none;
}
.gantt-tooltip.visivel { display: block; }

.calendario-cabecalho {
  display: grid; grid-template-columns: repeat(7, 1fr);
  font-size: var(--t-xs); color: var(--cor-texto-terciario);
  text-align: center; padding-bottom: 4px;
}
.calendario-grade { display: grid; grid-template-columns: repeat(7, 1fr); gap: 4px; }
.calendario-dia {
  min-height: 88px; border: 1px solid var(--cor-borda); border-radius: var(--raio-sm);
  padding: 4px; font-size: var(--t-xs); cursor: pointer;
  display: flex; flex-direction: column; gap: 2px;
  background: var(--cor-superficie);
}
.calendario-dia:hover { border-color: var(--cor-primaria); }
.calendario-dia.fora-do-mes { opacity: .35; }
.calendario-dia.hoje { border-color: var(--cor-primaria); border-width: 2px; }
.calendario-dia-numero { font-weight: 600; }
.calendario-evento {
  display: flex; align-items: center; gap: 4px; font-size: 10px;
  background: var(--cor-fundo); border-radius: 4px; padding: 1px 4px;
  overflow: hidden; text-overflow: ellipsis; white-space: nowrap;
}
.calendario-evento svg { flex-shrink: 0; width: 10px; height: 10px; }
.calendario-evento-mais { font-size: 10px; color: var(--cor-texto-terciario); }

.timeline-lista { position: relative; padding-left: 28px; }
.timeline-lista::before { content: ""; position: absolute; left: 9px; top: 0; bottom: 0; width: 2px; background: var(--cor-borda); }
.timeline-item { position: relative; padding-bottom: 20px; }
.timeline-item::before {
  content: ""; position: absolute; left: -23px; top: 2px;
  width: 10px; height: 10px; border-radius: 50%;
  background: var(--cor-primaria); border: 2px solid var(--cor-superficie);
}
.timeline-item-data { font-size: var(--t-xs); color: var(--cor-texto-terciario); }
.timeline-item-titulo a { color: var(--cor-texto); text-decoration: none; font-weight: 600; }
.timeline-item-titulo a:hover { color: var(--cor-primaria); }

/* ───────────────────────────── Calculadoras (Fase 9) ───────────────────────────── */

.calc-form { display: grid; grid-template-columns: repeat(auto-fit, minmax(180px, 1fr)); gap: var(--espaco-md); }
.calc-resultado {
  margin-top: var(--espaco-lg); padding: var(--espaco-md);
  background: var(--cor-primaria-light); border-radius: var(--raio-md);
  display: grid; grid-template-columns: repeat(auto-fit, minmax(160px, 1fr)); gap: var(--espaco-md);
}
.calc-resultado-label { font-size: var(--t-xs); color: var(--cor-texto-secundario); }
.calc-resultado-valor { font-size: var(--t-lg); font-weight: 700; color: var(--cor-texto); }
.calc-aviso-parametro {
  background: var(--cor-perigo-light); color: var(--cor-perigo);
  padding: var(--espaco-md); border-radius: var(--raio-md); margin-bottom: var(--espaco-md);
  display: flex; align-items: center; gap: var(--espaco-sm);
}
.calc-aviso-amarelo {
  background: rgba(243, 156, 18, .15); color: var(--cor-aviso);
  border: 1px solid var(--cor-aviso); padding: var(--espaco-md);
  border-radius: var(--raio-md); margin-top: var(--espaco-md);
  display: flex; align-items: center; gap: var(--espaco-sm);
}
.calc-lista-itens { display: flex; flex-direction: column; gap: var(--espaco-sm); margin-top: var(--espaco-md); }
.calc-item-orcamento {
  display: grid; grid-template-columns: 2fr 1fr 1fr 1fr auto; gap: var(--espaco-sm);
  align-items: end; padding: var(--espaco-sm); border: 1px solid var(--cor-borda); border-radius: var(--raio-sm);
}
.calc-item-orcamento .campo { margin-bottom: 0; }

/* ───────────────────────────── Editor 3D (Fase 12) ───────────────────────────── */

.editor2d-toolbar {
  display: flex; align-items: center; gap: var(--espaco-sm); flex-wrap: wrap;
  margin-bottom: var(--espaco-md); padding-bottom: var(--espaco-md);
  border-bottom: 1px solid var(--cor-borda);
}
.separador-toolbar { width: 1px; height: 24px; background: var(--cor-borda); }
.ferramenta-2d.ativa { background: var(--cor-primaria); color: #fff; border-color: var(--cor-primaria); }

.editor2d-area { position: relative; }
#canvas2d {
  display: block; width: 100%; max-width: 900px; height: 560px;
  background: var(--cor-superficie); border: 1px solid var(--cor-borda); border-radius: var(--raio-md);
  cursor: crosshair;
}

.painel-comodo {
  position: absolute; top: 16px; right: 16px; width: 280px;
  background: var(--cor-superficie); border: 1px solid var(--cor-borda); border-radius: var(--raio-md);
  box-shadow: var(--sombra-lg); padding: var(--espaco-md); z-index: 10;
}
.painel-comodo select[multiple] { height: auto; }

.container3d {
  width: 100%; height: 560px; border-radius: var(--raio-md); overflow: hidden;
  background: #1c1b1a;
}

.legenda-3d { display: flex; gap: var(--espaco-md); flex-wrap: wrap; align-items: center; font-size: var(--t-xs); color: var(--cor-texto-secundario); }
.legenda-cor-3d { display: inline-block; width: 12px; height: 12px; border-radius: 3px; margin-right: 4px; vertical-align: middle; }
