@import url('./theme.css');
@import url('./app.css');
@import url('./premium.css');

/* v03.1 - Taxonomia de ativos conforme capítulo 7 */
.taxonomy-strip {
  display: grid;
  grid-template-columns: repeat(8, minmax(110px, 1fr));
  gap: 10px;
  overflow-x: auto;
  padding-bottom: 4px;
}
.taxonomy-level {
  border: 1px solid var(--border, var(--line));
  border-radius: 16px;
  padding: 12px;
  background: linear-gradient(180deg, #ffffff, #f8fafc);
  min-height: 94px;
}
.taxonomy-level span {
  width: 28px;
  height: 28px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border-radius: 10px;
  background: #1e293b;
  color: #fff;
  font-weight: 800;
  margin-bottom: 8px;
}
.taxonomy-level strong,
.taxonomy-level small { display: block; }
.taxonomy-level small { color: var(--muted); margin-top: 4px; line-height: 1.35; }
.tree-node { margin: 0 0 8px; }
.tree-item {
  display: flex;
  align-items: flex-start;
  gap: 10px;
  border: 1px solid var(--border, var(--line));
  border-radius: 14px;
  padding: 10px;
  background: #fff;
}
.tree-level {
  min-width: 26px;
  height: 26px;
  border-radius: 9px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  color: #fff;
  background: var(--primary);
  font-weight: 800;
}
.tree-children {
  margin-left: 18px;
  padding-left: 14px;
  border-left: 2px dashed #cbd5e1;
  margin-top: 8px;
}
.tree-inactive { opacity: .58; background: #f8fafc; }
.tree-item small { color: var(--muted); }

/* Fatia 3 - Editor de atuações por parte */
.atuacao-tempo-painel {
  display: grid;
  grid-template-columns: minmax(0, 1.2fr) minmax(220px, .8fr);
  gap: 16px;
  align-items: start;
  margin-bottom: 16px;
}
.atuacao-tempo-painel.tempo-estourado {
  border-color: #ef4444;
  background: #fef2f2;
}
.atuacao-tempo-numeros {
  display: grid;
  gap: 8px;
  font-size: 14px;
}
.atuacao-tempo-numeros span {
  display: flex;
  justify-content: space-between;
  gap: 12px;
  padding: 8px 10px;
  border-radius: 12px;
  background: #f8fafc;
}
.atuacao-alerta {
  grid-column: 1 / -1;
  border: 1px solid #fecaca;
  color: #991b1b;
  background: #fff1f2;
  border-radius: 14px;
  padding: 10px 12px;
  font-size: 13px;
  font-weight: 700;
}
.atuacoes-editor-head { margin: 18px 0 12px; }
.atuacoes-container {
  display: grid;
  gap: 16px;
}
.atuacao-card {
  border-color: #fed7aa;
  background: #fffaf5;
}
.atuacao-card-head {
  display: flex;
  justify-content: space-between;
  gap: 12px;
  align-items: flex-start;
  margin-bottom: 12px;
}
.atuacao-local-selecionado {
  border: 1px solid var(--line);
  border-radius: 14px;
  padding: 10px 12px;
  background: #fff;
  color: var(--muted);
  margin-bottom: 10px;
}
.atuacao-local-selecionado strong { color: var(--text); }
.atuacao-local-selecionado small { display: block; margin-top: 3px; color: var(--muted); }
.atuacao-tree {
  max-height: 280px;
  overflow: auto;
  border: 1px solid var(--line);
  border-radius: 16px;
  background: #fff;
  padding: 10px;
}
.atuacao-tree-node { margin-bottom: 8px; }
.atuacao-tree-item {
  width: 100%;
  display: flex;
  align-items: flex-start;
  gap: 10px;
  border: 1px solid var(--line);
  border-radius: 14px;
  padding: 10px;
  background: #fff;
  color: var(--text);
  text-align: left;
  cursor: pointer;
}
.atuacao-tree-item:hover,
.atuacao-tree-item.selected {
  border-color: var(--primary);
  background: var(--primary-soft);
}
.atuacao-tree-item small { color: var(--muted); }
.atuacao-pecas {
  border-top: 1px dashed #fdba74;
  margin-top: 14px;
  padding-top: 14px;
}
.atuacao-pecas-table table { min-width: 760px; }
.atuacao-pecas-table .peca-qtd { width: 95px; }
.atuacao-pecas-table .peca-un { width: 80px; }

@media (max-width: 1200px) { .taxonomy-strip { grid-template-columns: repeat(4, minmax(140px, 1fr)); } }
@media (max-width: 760px) {
  .taxonomy-strip { grid-template-columns: repeat(2, minmax(140px, 1fr)); }
  .atuacao-tempo-painel { grid-template-columns: 1fr; }
  .atuacao-card-head { flex-direction: column; }
}

/* v07 - Programação + Hora-homem */
.header-actions {
  display: flex;
  gap: 12px;
  align-items: center;
  flex-wrap: wrap;
  justify-content: flex-end;
}
.programacao-grid {
  display: grid;
  grid-template-columns: minmax(0, 1.25fr) minmax(360px, .75fr);
  gap: 18px;
  align-items: start;
}
.section-head {
  display: flex;
  justify-content: space-between;
  gap: 16px;
  align-items: flex-start;
  margin-bottom: 16px;
}
.section-head h2 {
  margin: 4px 0 4px;
  font-size: 22px;
  letter-spacing: -.4px;
}
.section-head p { margin: 0; color: var(--muted); }
.programacao-list {
  display: grid;
  gap: 12px;
  max-height: 620px;
  overflow: auto;
  padding-right: 4px;
}
.program-card {
  display: flex;
  justify-content: space-between;
  gap: 14px;
  align-items: center;
  padding: 16px;
  border: 1px solid var(--line);
  border-radius: 20px;
  background: linear-gradient(180deg, #ffffff, #f8fafc);
  box-shadow: 0 12px 28px rgba(15,23,42,.05);
}
.program-card h3 {
  margin: 8px 0 6px;
  font-size: 18px;
}
.program-card p {
  margin: 0 0 8px;
  color: #334155;
}
.program-card-main { min-width: 0; }
.exception-box {
  padding: 14px;
  border-radius: 18px;
  background: #fff7ed;
  border: 1px solid #fed7aa;
}
.exception-box label {
  display: flex;
  gap: 10px;
  align-items: center;
  font-weight: 850;
  color: #9a3412;
  margin-bottom: 10px;
}
@media (max-width: 1200px) {
  .programacao-grid { grid-template-columns: 1fr; }
}
@media (max-width: 760px) {
  .header-actions { justify-content: stretch; width: 100%; }
  .header-actions .input, .header-actions .btn { width: 100%; }
  .section-head { flex-direction: column; }
  .program-card { flex-direction: column; align-items: stretch; }
}

/* v08 - Ordens de Serviço + Execução */
.os-control-panel {
  margin-top: 18px;
  position: relative;
  overflow: hidden;
}
.os-control-panel::before {
  content: '';
  position: absolute;
  inset: 0 0 auto auto;
  width: 220px;
  height: 220px;
  background: radial-gradient(circle, rgba(255,122,24,.18), transparent 68%);
  pointer-events: none;
}
.os-ready-card {
  border-left: 5px solid var(--primary, #f97316);
}
.filters-row {
  display: grid;
  grid-template-columns: minmax(260px, 1fr) minmax(180px, 260px);
  gap: 12px;
  margin-bottom: 14px;
}
.action-stack {
  display: flex;
  gap: 8px;
  flex-wrap: wrap;
  justify-content: flex-end;
}
.detail-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 12px;
}
.timeline-row {
  border-left: 3px solid var(--primary, #f97316);
  padding: 8px 0 8px 12px;
  margin: 8px 0;
}
.timeline-row strong,
.timeline-row span,
.timeline-row small {
  display: block;
}
.timeline-row small,
.timeline-row p {
  color: var(--muted);
  margin: 3px 0 0;
}
.os-table td { vertical-align: top; }
@media (max-width: 1100px) {
  .detail-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); }
}
@media (max-width: 760px) {
  .filters-row { grid-template-columns: 1fr; }
  .detail-grid { grid-template-columns: 1fr; }
  .action-stack { justify-content: flex-start; }
}

/* v08.1 - Equipe multi-manutentor */
.check-list {
  display: grid;
  gap: 10px;
  max-height: 260px;
  overflow: auto;
  padding: 4px;
}
.check-row {
  display: flex;
  gap: 12px;
  align-items: center;
  padding: 12px 14px;
  border: 1px solid var(--border, #e2e8f0);
  border-radius: 16px;
  background: rgba(255,255,255,.72);
  cursor: pointer;
  transition: .18s ease;
}
.check-row:hover { transform: translateY(-1px); box-shadow: var(--shadow-sm, 0 8px 22px rgba(15,23,42,.08)); }
.check-row input { width: 18px; height: 18px; accent-color: var(--primary, #f97316); }
.check-row span { display: grid; gap: 3px; }
.check-row small { color: var(--muted, #64748b); }
.executor-grid { display: grid; gap: 12px; }
.executor-card {
  border: 1px solid var(--border, #e2e8f0);
  border-radius: 18px;
  padding: 14px;
  background: linear-gradient(135deg, rgba(255,255,255,.95), rgba(248,250,252,.78));
  box-shadow: var(--shadow-sm, 0 8px 22px rgba(15,23,42,.08));
}
.executor-head { display:flex; justify-content:space-between; gap:12px; align-items:flex-start; margin-bottom:10px; }
.executor-actions { display:flex; gap:8px; flex-wrap:wrap; justify-content:flex-end; }

/* v09 - Configurações PCM / Otimizador */
.option-card {
  display: block;
  border: 1px solid rgba(148, 163, 184, .28);
  border-radius: 22px;
  padding: 18px;
  background: linear-gradient(180deg, rgba(255,255,255,.95), rgba(248,250,252,.92));
  box-shadow: 0 14px 34px rgba(15, 23, 42, .08);
  cursor: pointer;
  transition: transform .16s ease, box-shadow .16s ease, border-color .16s ease;
  min-height: 190px;
}
.option-card input { display: none; }
.option-card:hover { transform: translateY(-2px); box-shadow: 0 20px 42px rgba(15, 23, 42, .13); }
.option-card.active { border-color: #f97316; box-shadow: 0 20px 46px rgba(249, 115, 22, .18); }
.option-icon {
  width: 44px;
  height: 44px;
  border-radius: 14px;
  display: grid;
  place-items: center;
  background: linear-gradient(135deg, #0f172a, #1e3a8a);
  color: #fff;
  font-weight: 800;
  margin-bottom: 14px;
}
.option-card.active .option-icon { background: linear-gradient(135deg, #f97316, #ea580c); }
.option-card h3 { margin: 0 0 8px; font-size: 1.05rem; color: #0f172a; }
.option-card p { margin: 0; color: #64748b; line-height: 1.45; }
.optimizer-banner {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  padding: 14px 16px;
  border-radius: 18px;
  background: linear-gradient(135deg, rgba(15,23,42,.06), rgba(249,115,22,.08));
  border: 1px solid rgba(249,115,22,.20);
  margin-bottom: 16px;
}
.optimizer-banner strong { color: #0f172a; }
.optimizer-actions { display: flex; gap: 8px; flex-wrap: wrap; }
@media (max-width: 920px) {
  .optimizer-banner { align-items: flex-start; flex-direction: column; }
}

/* v10.12.6 - destaque visual para possível duplicidade no Painel PCM */
.linha-duplicidade td {
  background: rgba(255, 247, 230, 0.65);
}
.text-warning {
  color: #a44900;
  font-weight: 700;
}
