/* components/organisms/record-detail.css — RecordDetail (O11).
 *
 * Fase AW: modal centrado largo do "Detalhes do Registro" cruzado.
 * Anti-bug dark mode (regra Fase AR): transition só opacity/transform.
 */

.cmp-record-detail {
  position: fixed;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -47%);
  width: min(1080px, 96vw);
  max-height: 88vh;
  display: flex;
  flex-direction: column;
  background: var(--surface-strong);
  border: 1px solid var(--border);
  border-radius: var(--radius-lg);
  box-shadow: var(--shadow-modal);
  z-index: var(--z-modal);
  opacity: 0;
  overflow: hidden;
  transition: opacity 0.18s var(--ease-out), transform 0.18s var(--ease-out);
}
.cmp-record-detail--open {
  opacity: 1;
  transform: translate(-50%, -50%);
}

/* O header (SectionBanner) fica fixo no topo; o corpo rola. */
.cmp-record-detail > .cmp-section-banner {
  flex-shrink: 0;
  border-radius: var(--radius-lg) var(--radius-lg) 0 0;
}

.cmp-record-detail__body {
  overflow-y: auto;
  padding: var(--space-4) var(--space-5) var(--space-5);
  display: flex;
  flex-direction: column;
  gap: var(--space-5);
}

/* ── Resumo: KPIs (esq) + gráfico (dir) ── */
.cmp-record-detail__summary {
  display: grid;
  grid-template-columns: 1.4fr 1fr;
  gap: var(--space-4);
  align-items: stretch;
}
.cmp-record-detail__kpis {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: var(--space-3);
}
.cmp-record-detail__chart {
  display: flex;
  flex-direction: column;
  border: 1px solid var(--border);
  border-radius: var(--radius-md);
  background: var(--surface-card);
  padding: var(--space-3) var(--space-4);
  min-height: 184px;
}
.cmp-record-detail__chart-cap {
  font-size: var(--text-xs);
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.06em;
  color: var(--text-muted);
  margin-bottom: var(--space-2);
}
.cmp-record-detail__chart-canvas {
  position: relative;
  flex: 1 1 auto;
  min-height: 150px;
}

/* ── Origem: registro clicado (destaque violeta) ── */
.cmp-record-detail__origem {
  border: 1px solid var(--tbl-accent);
  border-left-width: 3px;
  border-radius: var(--radius-md);
  background: var(--surface-card);
  padding: var(--space-4);
}
.cmp-record-detail__origem-title {
  font-family: var(--font-display);
  font-size: var(--text-md);
  font-weight: 600;
  color: var(--text);
  margin-bottom: var(--space-3);
}
.cmp-record-detail__fields {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(260px, 1fr));
  gap: 0 var(--space-5);
  margin: 0;
}
.cmp-record-detail__fields dt {
  font-size: var(--text-xs);
  font-weight: 600;
  color: var(--text-muted);
  text-transform: uppercase;
  letter-spacing: 0.04em;
  margin-top: var(--space-2);
}
.cmp-record-detail__fields dd {
  margin: 2px 0 0;
  font-size: var(--text-base);
  color: var(--text);
  word-break: break-word;
}

/* ── Seções vinculadas ── */
.cmp-record-detail__section {
  display: flex;
  flex-direction: column;
}
.cmp-record-detail__section .cmp-section-banner {
  border-radius: var(--radius-md) var(--radius-md) 0 0;
}
.cmp-record-detail__section-table {
  margin-top: calc(-1 * var(--space-1));
}

/* Sub-tabelas crescem naturalmente — o scroll é o do corpo do modal (1 só). */
.cmp-record-detail .cmp-data-table__wrap {
  max-height: none;
}

/* ── Responsivo ── */
@media (max-width: 760px) {
  .cmp-record-detail__summary { grid-template-columns: 1fr; }
}
@media (max-width: 480px) {
  .cmp-record-detail__kpis { grid-template-columns: 1fr; }
  .cmp-record-detail__fields { grid-template-columns: 1fr; }
}
