/**
 * detail-temp.css — DS v1.14 dedicado pro parallel build detail-temp/
 *
 * Vive paralelo a scout.css. Tudo prefixado .dt-* pra evitar colisão.
 * Cutover Fase 3 vai mover esses estilos pra scout.css com prefix removido.
 *
 * DS v1.14: zero serif. Sans 800 hero/h2/titles. Mono em chrome estrutural (kicker, h3, header tabela).
 */

/* ─── tokens (fallback se scout.css não carregar) ─── */
.dt-root {
  --dt-bg: var(--bg, #FFFFFF);
  --dt-surface: var(--surface, #F9FAFB);
  --dt-surface-2: var(--surface-2, #F3F4F6);
  --dt-text: var(--text, #1F2937);
  --dt-text-muted: var(--text-muted, #6B7280);
  --dt-text-faint: var(--text-faint, #9CA3AF);
  --dt-gold: var(--gold, #0A9E5E);
  --dt-gold-soft: var(--gold-soft, #ECFDF5);
  --dt-border: var(--border, #E5E7EB);
  --dt-border-strong: var(--border-strong, #D1D5DB);
  --dt-green: var(--green, #10B981);
  --dt-red: var(--red, #EF4444);
  --dt-orange: var(--orange, #F59E0B);
  --dt-yellow: var(--yellow, #EAB308);
  --dt-purple: var(--purple, #8B5CF6);
  --dt-blue: var(--blue, #3B82F6);
  --dt-mono: var(--mono, 'IBM Plex Mono', monospace);
  --dt-sans: var(--sans, 'Inter', sans-serif);

  font-family: var(--dt-sans);
  font-size: 13px;
  line-height: 1.5;
  color: var(--dt-text);
  font-feature-settings: "tnum" 1;
}

/* ═══ Breadcrumb ═══ */
.dt-breadcrumb { background: var(--dt-surface); border-bottom: 1px solid var(--dt-border); padding: 8px 24px; font-family: var(--dt-mono); font-size: 11px; color: var(--dt-text-muted); }
.dt-breadcrumb a { color: var(--dt-text-muted); text-decoration: none; }
.dt-breadcrumb a:hover { color: var(--dt-text); }
.dt-breadcrumb .sep { padding: 0 6px; color: var(--dt-text-faint); }
.dt-breadcrumb .current { color: var(--dt-text); font-weight: 600; }

/* ═══ Entity hero ═══ */
.dt-hero { background: white; padding: 28px 24px 20px; border-bottom: 1px solid var(--dt-border); }
.dt-hero__kicker { font-family: var(--dt-mono); font-size: 11px; font-weight: 700; color: var(--dt-gold); text-transform: uppercase; letter-spacing: 0.08em; margin-bottom: 8px; }
.dt-hero__title { font-family: var(--dt-sans); font-size: 34px; font-weight: 800; letter-spacing: -0.035em; line-height: 1.05; margin: 0 0 8px; color: var(--dt-text); }
.dt-hero__sub { font-family: var(--dt-sans); font-size: 12px; color: var(--dt-text-muted); margin-bottom: 14px; letter-spacing: 0.02em; }
.dt-hero__sub .sep { color: var(--dt-text-faint); padding: 0 8px; }
.dt-hero__sub-link { color: var(--dt-text-muted); text-decoration: none; }
.dt-hero__sub-link:hover { color: var(--dt-text); text-decoration: underline; }
.dt-hero__pills-row { display: flex; flex-wrap: wrap; gap: 6px; align-items: center; }
.dt-hero__actions { margin-left: auto; display: inline-flex; gap: 8px; align-items: center; }

/* ═══ Pills ═══ */
.e-pill { display: inline-flex; align-items: center; padding: 4px 10px; font-family: var(--dt-mono); font-size: 10.5px; font-weight: 600; text-transform: uppercase; letter-spacing: 0.05em; border-radius: 12px; border: 1px solid var(--dt-border); background: white; color: var(--dt-text); }
.e-pill.verdict-target { background: var(--dt-gold-soft); color: var(--dt-gold); border-color: var(--dt-gold); }
.e-pill.verdict-alta { background: #FEF3C7; color: #92400E; border-color: #FCD34D; }
.e-pill.verdict-moderada, .e-pill.verdict-baixa { background: var(--dt-surface); }
.e-pill.verdict-descarte { background: #FEE2E2; color: #991B1B; border-color: #FCA5A5; }
.e-pill.verdict-pending { background: var(--dt-surface); color: var(--dt-text-muted); }
.e-pill.sector { background: var(--dt-surface); }
.e-pill.state { background: var(--dt-gold-soft); color: var(--dt-gold); border-color: var(--dt-gold); }
.e-pill.risk-low { background: var(--dt-gold-soft); color: var(--dt-gold); border-color: var(--dt-gold); }
.e-pill.risk-moderate { background: #FEF3C7; color: #92400E; border-color: #FCD34D; }
.e-pill.risk-high { background: #FEE2E2; color: #991B1B; border-color: #FCA5A5; }
.e-pill.risk-extreme { background: #7F1D1D; color: white; border-color: #7F1D1D; }
.e-pill.rank { background: var(--dt-text); color: white; border-color: var(--dt-text); }
.e-pill.link { background: white; color: var(--dt-text-muted); text-decoration: none; }
.e-pill.link:hover { color: var(--dt-text); }

/* ═══ Metric row ═══ */
.dt-metric-row { display: grid; grid-auto-flow: column; grid-auto-columns: 1fr; gap: 0; border-top: 1px solid var(--dt-border); border-bottom: 1px solid var(--dt-border); background: var(--dt-surface); }
.dt-metric-row--bordered { border: 1px solid var(--dt-border); border-radius: 8px; }
.dt-metric { padding: 14px 16px; border-right: 1px solid var(--dt-border); }
.dt-metric:last-child { border-right: none; }
.dt-metric .lbl { font-family: var(--dt-mono); font-size: 10px; font-weight: 600; color: var(--dt-text-muted); text-transform: uppercase; letter-spacing: 0.06em; margin-bottom: 4px; }
.dt-metric .val { font-family: var(--dt-sans); font-size: 24px; font-weight: 800; color: var(--dt-text); font-feature-settings: "tnum" 1; letter-spacing: -0.02em; line-height: 1.1; }
.dt-metric .val.gold { color: var(--dt-gold); }
.dt-metric .val.high { color: var(--dt-blue); }
.dt-metric .val.warn { color: var(--dt-orange); }
.dt-metric .val.low { color: var(--dt-red); }

/* ═══ Tab nav — fundo surface · ativa branco (continuidade visual com body) ═══ */
/* PR-Lote-A.1 (Kai 2026-07-26): .dt-tab → .tab primitivo (scout.css §C5). Padding/scroll local: */
.dt-root > .tabs { background: var(--dt-surface); padding: 0 24px; overflow-x: auto; scrollbar-width: none; }
.dt-root > .tabs::-webkit-scrollbar { display: none; }
.dt-root > .tabs .tab.is-active { background: var(--dt-bg); }

/* ═══ Tab body — fundo bg (branco) · soldado visualmente com tab ativa ═══ */
.dt-tab-body { padding: 28px 24px 24px; background: var(--dt-bg); min-height: 380px; }
.dt-panel { }

/* ═══ Sblock — h3 mono gold + ações inline na direita ═══ */
.dt-sblock { margin-bottom: 24px; }
.dt-sblock__h { font-family: var(--dt-mono); font-size: 11px; font-weight: 700; color: var(--dt-gold); text-transform: uppercase; letter-spacing: 0.08em; margin-bottom: 12px; display: flex; align-items: center; gap: 8px; }
.dt-sblock__h .count { color: var(--dt-text-muted); font-weight: 500; }
.dt-sblock__h-actions { margin-left: auto; display: inline-flex; gap: 6px; align-items: center; }

/* ═══ Grid 2 col ═══ */
.dt-grid-2 { display: grid; grid-template-columns: 1fr 1fr; gap: 24px; margin-bottom: 24px; }
@media (max-width: 900px) { .dt-grid-2 { grid-template-columns: 1fr; } }

/* ═══ Action bar (deprecated · ações foram movidas pros dt-sblock__h-actions contextuais) ═══ */
.dt-action-bar { display: flex; gap: 8px; margin-bottom: 20px; justify-content: flex-end; align-items: center; }

/* ═══ Buttons ═══ */
.dt-btn { padding: 5px 12px; font-family: var(--dt-sans); font-size: 12px; font-weight: 500; border: 1px solid var(--dt-border); background: white; border-radius: 4px; cursor: pointer; color: var(--dt-text); display: inline-flex; align-items: center; gap: 6px; }
.dt-btn:hover { border-color: var(--dt-border-strong); }
.dt-btn--primary { background: var(--dt-text); color: white; border-color: var(--dt-text); }
.dt-btn--primary:hover { background: #111827; }
.dt-btn--ghost { background: transparent; border-color: transparent; color: var(--dt-text-muted); }
.dt-btn--ghost:hover { color: var(--dt-text); background: var(--dt-surface); }
.dt-btn--icon { padding: 4px 8px; }
.dt-btn--xs { padding: 2px 8px; font-size: 11px; }

.dt-toggle-group { display: inline-flex; border: 1px solid var(--dt-border); border-radius: 4px; overflow: hidden; }
.dt-toggle-group .dt-btn { border: 0; border-radius: 0; }
.dt-toggle-group--xs { border-radius: 3px; }
.dt-toggle-group--xs .dt-btn { padding: 2px 8px; font-size: 11px; }

/* ═══ KV table ═══ */
.dt-kv { width: 100%; border-collapse: collapse; font-size: 12px; }
.dt-kv td { padding: 7px 0; border-bottom: 1px solid var(--dt-border); vertical-align: top; }
.dt-kv td.dt-kv__label { width: 40%; font-family: var(--dt-mono); font-size: 10px; font-weight: 600; color: var(--dt-text-muted); text-transform: uppercase; letter-spacing: 0.04em; padding-right: 12px; }
.dt-kv td.dt-kv__val { font-family: var(--dt-sans); font-size: 12px; color: var(--dt-text); font-feature-settings: "tnum" 1; }
.dt-kv td.dt-kv__val.dim { color: var(--dt-text-faint); }
.dt-kv .num { font-weight: 600; }

/* ═══ Badge ═══ */
.dt-badge { font-family: var(--dt-mono); font-size: 10px; font-weight: 600; padding: 1px 6px; border-radius: 3px; display: inline-block; }
.dt-badge.ok { background: var(--dt-gold-soft); color: var(--dt-gold); }
.dt-badge.warn { background: #FEF3C7; color: #92400E; }
.dt-badge.bad { background: #FEE2E2; color: #991B1B; }
.dt-badge.blue { background: #DBEAFE; color: #1E40AF; }
.dt-badge.purple { background: #EDE9FE; color: #6D28D9; }
.dt-badge.muted { background: var(--dt-surface); color: var(--dt-text-muted); }

/* ═══ Num (col-num) ═══ */
.dt-num { font-family: var(--dt-sans); font-weight: 700; font-feature-settings: "tnum" 1; }
.dt-num.gold { color: var(--dt-gold); }
.dt-num.high { color: var(--dt-blue); }
.dt-num.warn { color: var(--dt-orange); }
.dt-num.low { color: var(--dt-red); }

/* ═══ Data table ═══ */
.dt-table { width: 100%; border-collapse: collapse; font-size: 12px; background: white; border: 1px solid var(--dt-border); border-radius: 8px; overflow: hidden; }
.dt-table th { padding: 9px 12px; background: var(--dt-surface); font-family: var(--dt-mono); font-size: 10px; font-weight: 700; color: var(--dt-text-muted); text-transform: uppercase; letter-spacing: 0.05em; text-align: left; border-bottom: 1px solid var(--dt-border); }
.dt-table td { padding: 9px 12px; font-family: var(--dt-sans); font-size: 12px; border-bottom: 1px solid var(--dt-border); vertical-align: middle; }
.dt-table tr:last-child td { border-bottom: none; }
.dt-table td.num { text-align: right; font-feature-settings: "tnum" 1; font-weight: 600; }
.dt-table--flush { border: 0; border-radius: 0; }

/* ═══ Pill mini ═══ */
.dt-pill-mini { display: inline-block; font-family: var(--dt-mono); font-size: 9px; font-weight: 600; padding: 1px 5px; border-radius: 3px; background: var(--dt-surface); color: var(--dt-text-muted); border: 1px solid var(--dt-border); margin: 1px; }

/* ═══ Card / card-grid ═══ */
.dt-card { background: white; border: 1px solid var(--dt-border); border-radius: 6px; padding: 14px; }
.dt-card__title { font-family: var(--dt-sans); font-size: 13px; font-weight: 700; color: var(--dt-text); letter-spacing: -0.01em; margin-bottom: 4px; }
.dt-card__meta { font-family: var(--dt-mono); font-size: 10px; color: var(--dt-text-muted); text-transform: uppercase; letter-spacing: 0.04em; margin-bottom: 4px; }
.dt-card__body { font-family: var(--dt-sans); font-size: 12px; line-height: 1.65; color: var(--dt-text); }
.dt-card-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(220px, 1fr)); gap: 12px; }

/* ═══ Empty / error / pending ═══ */
.dt-empty { padding: 24px; text-align: center; color: var(--dt-text-muted); font-size: 12px; }
.dt-empty-cta { padding: 32px 24px; text-align: center; background: var(--dt-surface); border: 1px dashed var(--dt-border-strong); border-radius: 8px; }
.dt-empty-cta--small { padding: 16px; }
.dt-empty-cta__title { font-family: var(--dt-sans); font-size: 14px; font-weight: 700; color: var(--dt-text); margin-bottom: 4px; letter-spacing: -0.01em; }
.dt-empty-cta__lead { font-family: var(--dt-sans); font-size: 12px; color: var(--dt-text-muted); margin-bottom: 14px; max-width: 540px; margin-left: auto; margin-right: auto; line-height: 1.5; }
.dt-empty-cta__actions { display: inline-flex; gap: 8px; }
.dt-empty-cta code { font-family: var(--dt-mono); font-size: 11px; background: white; padding: 1px 5px; border-radius: 3px; }

.dt-error { padding: 32px 24px; text-align: center; background: #FEF2F2; border: 1px solid #FCA5A5; border-radius: 8px; }
.dt-error__title { font-family: var(--dt-sans); font-size: 14px; font-weight: 700; color: #991B1B; margin-bottom: 4px; letter-spacing: -0.01em; }
.dt-error__code { font-family: var(--dt-mono); font-size: 11px; color: var(--dt-text-muted); background: white; padding: 8px 12px; border-radius: 4px; display: inline-block; margin-top: 8px; }

.dt-pending { padding: 16px 0; }
.skeleton { background: linear-gradient(90deg, var(--dt-surface) 0%, var(--dt-surface-2) 50%, var(--dt-surface) 100%); background-size: 200% 100%; animation: dt-skel-shimmer 1.5s ease-in-out infinite; border-radius: 4px; }
.dt-skel-line { height: 12px; margin-bottom: 8px; }
.dt-skel-line.short { width: 40%; }
.dt-skel-line.mid { width: 70%; }
@keyframes dt-skel-shimmer { 0% { background-position: 200% 0; } 100% { background-position: -200% 0; } }

/* ═══ Callout ═══ */
.dt-callout { background: var(--dt-surface); border-left: 3px solid var(--dt-gold); padding: 16px 20px; border-radius: 0 6px 6px 0; margin: 16px 0; font-size: 13px; line-height: 1.65; }
.dt-callout__h { font-family: var(--dt-mono); font-size: 11px; font-weight: 700; color: var(--dt-gold); text-transform: uppercase; letter-spacing: 0.08em; margin-bottom: 8px; }
.dt-callout__body p { margin-bottom: 8px; }
.dt-callout__body p:last-child { margin-bottom: 0; }
.dt-callout__meta { font-family: var(--dt-mono); font-size: 10px; color: var(--dt-text-muted); }

/* ═══ Link ═══ */
.dt-link { color: var(--dt-gold); font-weight: 600; text-decoration: none; }
.dt-link:hover { text-decoration: underline; }
.dt-link-mini { color: var(--dt-gold); font-family: var(--dt-mono); font-size: 10px; text-decoration: none; }

/* ═══ Meta caption ═══ */
.dt-meta { font-family: var(--dt-mono); font-size: 10px; color: var(--dt-text-muted); margin-top: 8px; }

/* ═══ CNAEs ═══ */
.dt-cnae-principal { display: flex; gap: 16px; align-items: baseline; padding: 12px 16px; background: var(--dt-surface); border: 1px solid var(--dt-border); border-radius: 6px; margin-bottom: 12px; }
.dt-cnae-code { font-family: var(--dt-mono); font-size: 14px; font-weight: 600; color: var(--dt-text); background: var(--dt-gold-soft); padding: 4px 10px; border-radius: 4px; }
.dt-cnae-desc { font-family: var(--dt-sans); font-size: 13px; color: var(--dt-text); }
.dt-cnae-sec-list { display: flex; flex-wrap: wrap; gap: 6px; }
.dt-cnae-chip { font-family: var(--dt-mono); font-size: 11px; background: white; border: 1px solid var(--dt-border); padding: 4px 10px; border-radius: 12px; color: var(--dt-text-muted); display: inline-flex; gap: 6px; align-items: center; }
.dt-cnae-chip code { color: var(--dt-text); font-weight: 600; }

/* ═══ Brand grid + cards ═══ */
.dt-brand-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(180px, 1fr)); gap: 16px; }
.dt-brand-card { background: white; border: 1px solid var(--dt-border); border-radius: 8px; padding: 16px 14px 14px; position: relative; }
.dt-brand-card:hover { border-color: var(--dt-border-strong); }
.dt-brand-card.primary { border-color: var(--dt-gold); border-width: 2px; padding: 15px 13px 13px; }
.dt-brand-logo { display: block; width: 100%; aspect-ratio: 1 / 1; object-fit: contain; background: white; border: 1px solid var(--dt-border); border-radius: 4px; margin-bottom: 10px; padding: 8px; }
.dt-brand-logo-placeholder { display: flex; align-items: center; justify-content: center; aspect-ratio: 1 / 1; background: var(--dt-surface); border: 1px solid var(--dt-border); border-radius: 4px; font-family: var(--dt-sans); font-weight: 800; font-size: 48px; color: var(--dt-text-faint); margin-bottom: 10px; letter-spacing: -0.04em; }
.dt-brand-card__name { font-family: var(--dt-sans); font-size: 13px; font-weight: 600; color: var(--dt-text); margin-bottom: 4px; }
.dt-brand-card__meta { font-family: var(--dt-mono); font-size: 10px; color: var(--dt-text-muted); text-transform: uppercase; letter-spacing: 0.05em; }
.dt-brand-card__action { position: absolute; top: 6px; right: 6px; opacity: 0; }
.dt-brand-card:hover .dt-brand-card__action { opacity: 1; }
.dt-brand-card__primary-mark { position: absolute; top: 6px; left: 6px; font-family: var(--dt-mono); font-size: 9px; font-weight: 700; color: var(--dt-gold); background: var(--dt-gold-soft); padding: 2px 5px; border-radius: 3px; text-transform: uppercase; letter-spacing: 0.05em; }

/* ═══ Offer grid + list ═══ */
.dt-offer-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 24px; }
@media (max-width: 900px) { .dt-offer-grid { grid-template-columns: 1fr; } }
.dt-offer-list { background: white; border: 1px solid var(--dt-border); border-radius: 8px; }
.dt-offer-list__head { padding: 10px 14px; background: var(--dt-surface); border-bottom: 1px solid var(--dt-border); font-family: var(--dt-mono); font-size: 11px; font-weight: 700; color: var(--dt-text); text-transform: uppercase; letter-spacing: 0.05em; display: flex; align-items: center; gap: 8px; }
.dt-offer-list__head .count { color: var(--dt-text-muted); font-weight: 500; }
.dt-offer-list__head .src { margin-left: auto; font-size: 10px; font-weight: 500; color: var(--dt-text-faint); text-transform: none; letter-spacing: 0; }
.dt-offer-item { padding: 12px 14px; border-bottom: 1px solid var(--dt-border); }
.dt-offer-item:last-child { border-bottom: none; }
.dt-offer-item__top { display: flex; align-items: baseline; gap: 8px; margin-bottom: 4px; flex-wrap: wrap; }
.dt-offer-item__name { font-family: var(--dt-sans); font-size: 13px; font-weight: 600; color: var(--dt-text); }
.dt-offer-item__category { font-family: var(--dt-mono); font-size: 10px; color: var(--dt-text-muted); background: var(--dt-surface); padding: 1px 6px; border-radius: 3px; text-transform: uppercase; letter-spacing: 0.04em; }
.dt-offer-item__src-badge { font-family: var(--dt-mono); font-size: 9px; font-weight: 700; padding: 1px 5px; border-radius: 3px; text-transform: uppercase; letter-spacing: 0.05em; margin-left: auto; }
.dt-offer-item__src-badge.llm { color: var(--dt-blue); background: #EFF6FF; }
.dt-offer-item__src-badge.firecrawl { color: var(--dt-purple); background: #F3E8FF; }
.dt-offer-item__src-badge.manual { color: var(--dt-gold); background: var(--dt-gold-soft); }
.dt-offer-item__desc { font-family: var(--dt-sans); font-size: 12px; color: var(--dt-text-muted); line-height: 1.5; }

/* ═══ Chart card + bars ═══ */
.dt-chart-card { background: white; border: 1px solid var(--dt-border); border-radius: 8px; padding: 20px; }
.dt-bars-chart { display: grid; grid-template-columns: repeat(5, 1fr); gap: 16px; align-items: end; height: 200px; }
.dt-bar-group { display: flex; flex-direction: column; align-items: center; gap: 6px; }
.dt-bar-year { font-family: var(--dt-mono); font-size: 9px; color: var(--dt-text-muted); }
.dt-bars { display: flex; align-items: flex-end; gap: 3px; height: 160px; }
.dt-bar { width: 16px; }
.dt-bar-vals { font-family: var(--dt-mono); font-size: 9px; color: var(--dt-text); }
.dt-chart-legend { display: flex; gap: 16px; margin-top: 16px; font-family: var(--dt-mono); font-size: 10px; color: var(--dt-text-muted); text-transform: uppercase; letter-spacing: 0.05em; justify-content: center; }
.dt-legend-sw { display: inline-block; width: 10px; height: 10px; vertical-align: middle; margin-right: 4px; }
.dt-chart-meta { margin-top: 12px; font-family: var(--dt-mono); font-size: 10px; color: var(--dt-text-muted); text-align: center; }
.dt-chart-placeholder { border: 1px dashed var(--dt-border-strong); border-radius: 6px; padding: 32px; text-align: center; background: var(--dt-surface); font-family: var(--dt-mono); font-size: 11px; color: var(--dt-text-muted); }

/* ═══ Gauge ═══ */
.dt-gauge { height: 6px; background: var(--dt-surface-2); border-radius: 3px; overflow: hidden; margin-top: 4px; width: 80%; }
.dt-gauge-fill { height: 100%; background: var(--dt-gold); }
.dt-gauge-fill.blue { background: var(--dt-blue); }
.dt-gauge-fill.warn { background: var(--dt-orange); }
.dt-gauge-fill.low { background: var(--dt-red); }

/* ═══ KPI grid (separadores via box-shadow inset — sem área cinza vazia na última linha) ═══ */
.dt-kpi-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(140px, 1fr)); gap: 0; background: white; border: 1px solid var(--dt-border); border-radius: 6px; overflow: hidden; }
.dt-kpi-cell { background: white; padding: 12px; box-shadow: -1px 0 0 var(--dt-border), 0 -1px 0 var(--dt-border); }
.dt-kpi-cell__lbl { font-family: var(--dt-mono); font-size: 9px; font-weight: 600; color: var(--dt-text-muted); text-transform: uppercase; letter-spacing: 0.06em; margin-bottom: 2px; }
.dt-kpi-cell__val { font-family: var(--dt-sans); font-size: 18px; font-weight: 800; letter-spacing: -0.02em; }

/* ═══ Reforma hero ═══ */
.dt-reforma-hero { display: grid; grid-template-columns: repeat(3, 1fr); gap: 16px; }
.dt-reforma-card { background: white; border: 1px solid var(--dt-border); border-radius: 8px; padding: 16px; text-align: center; }
.dt-rc-lbl { font-family: var(--dt-mono); font-size: 10px; font-weight: 700; color: var(--dt-text-muted); text-transform: uppercase; letter-spacing: 0.06em; margin-bottom: 6px; }
.dt-rc-val { font-family: var(--dt-sans); font-size: 36px; font-weight: 800; letter-spacing: -0.03em; line-height: 1; margin-bottom: 8px; }
.dt-rc-val.gold { color: var(--dt-gold); }
.dt-rc-val.high { color: var(--dt-blue); }
.dt-rc-val.warn { color: var(--dt-orange); }
.dt-rc-val.low { color: var(--dt-red); }
.dt-rc-sub { font-family: var(--dt-mono); font-size: 10px; color: var(--dt-text-muted); margin-top: 6px; }

/* ═══ Delta alíquota ═══ */
.dt-delta-card { background: white; border: 1px solid var(--dt-border); border-radius: 8px; padding: 20px; }
.dt-delta-grid { display: grid; grid-template-columns: 1fr auto 1fr; gap: 24px; align-items: center; }
.dt-delta-lbl { font-family: var(--dt-mono); font-size: 10px; color: var(--dt-text-muted); text-transform: uppercase; letter-spacing: 0.06em; margin-bottom: 4px; }
.dt-delta-val { font-family: var(--dt-sans); font-size: 38px; font-weight: 800; letter-spacing: -0.03em; }
.dt-delta-val.warn { color: var(--dt-orange); }
.dt-delta-val .pct { font-size: 24px; color: var(--dt-text-muted); }
.dt-delta-sub { font-family: var(--dt-mono); font-size: 10px; color: var(--dt-text-muted); margin-top: 6px; }
.dt-delta-arrow { font-family: var(--dt-sans); font-size: 28px; color: var(--dt-text-faint); font-weight: 800; }
.dt-delta-summary { margin-top: 18px; padding: 12px; border-left: 3px solid; border-radius: 0 6px 6px 0; font-family: var(--dt-sans); font-size: 13px; }
.dt-delta-summary.warn { background: #FEF3C7; border-left-color: var(--dt-orange); }
.dt-delta-summary.gold { background: var(--dt-gold-soft); border-left-color: var(--dt-gold); }

/* ═══ Impact cards ═══ */
.dt-impact-list { display: grid; grid-template-columns: 1fr; gap: 8px; }
.dt-impact-card { background: white; padding: 12px 16px; border-radius: 0 6px 6px 0; border-left: 3px solid; }
.dt-impact-card--negativo { border-left-color: var(--dt-red); }
.dt-impact-card--positivo { border-left-color: var(--dt-gold); }
.dt-impact-card--neutro { border-left-color: var(--dt-orange); }
.dt-impact-lbl { font-family: var(--dt-mono); font-size: 10px; font-weight: 700; text-transform: uppercase; letter-spacing: 0.06em; margin-bottom: 4px; }
.dt-impact-card--negativo .dt-impact-lbl { color: var(--dt-red); }
.dt-impact-card--positivo .dt-impact-lbl { color: var(--dt-gold); }
.dt-impact-card--neutro .dt-impact-lbl { color: var(--dt-orange); }
.dt-impact-text { font-family: var(--dt-sans); font-size: 12px; line-height: 1.6; }

/* ═══ Notes list ═══ */
.dt-notes-list { padding-left: 20px; font-family: var(--dt-sans); font-size: 12px; line-height: 1.65; color: var(--dt-text); }
.dt-notes-list li { margin-bottom: 4px; }

/* ═══ Risk scores ═══ */
.dt-risk-scores { display: grid; grid-template-columns: repeat(4, 1fr); gap: 12px; }
.dt-risk-card { background: white; border: 1px solid var(--dt-border); border-radius: 6px; padding: 14px; text-align: center; }
.dt-risk-card .dt-rc-lbl { font-family: var(--dt-mono); font-size: 10px; font-weight: 600; color: var(--dt-text-muted); text-transform: uppercase; letter-spacing: 0.06em; margin-bottom: 6px; }
.dt-risk-card .dt-rc-val { font-family: var(--dt-sans); font-size: 28px; font-weight: 800; letter-spacing: -0.025em; line-height: 1; }

/* ═══ Maturity grid (TI) ═══ */
.dt-maturity-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(140px, 1fr)); gap: 12px; }
.dt-maturity-card { background: white; border: 1px solid var(--dt-border); border-radius: 6px; padding: 12px; }
.dt-mc-lbl { font-family: var(--dt-mono); font-size: 10px; font-weight: 600; color: var(--dt-text-muted); text-transform: uppercase; letter-spacing: 0.06em; margin-bottom: 6px; }
.dt-mc-val { font-family: var(--dt-sans); font-size: 14px; font-weight: 700; text-transform: capitalize; }
.dt-mc-basic { color: var(--dt-red); }
.dt-mc-exploring { color: var(--dt-orange); }
.dt-mc-hybrid { color: var(--dt-yellow); }
.dt-mc-advanced { color: var(--dt-blue); }
.dt-mc-mature { color: var(--dt-gold); }

/* ═══ News list ═══ */
.dt-news-list { background: white; border: 1px solid var(--dt-border); border-radius: 6px; }
.dt-news-item { padding: 12px 14px; border-bottom: 1px solid var(--dt-border); display: flex; gap: 12px; }
.dt-news-item:last-child { border-bottom: none; }
.dt-news-date { font-family: var(--dt-mono); font-size: 10px; color: var(--dt-text-muted); width: 90px; flex-shrink: 0; padding-top: 2px; }
.dt-news-body { flex: 1; }
.dt-news-link { color: var(--dt-text); text-decoration: none; display: block; }
.dt-news-link:hover { color: var(--dt-gold); }
.dt-news-link:hover .dt-news-title { text-decoration: underline; }
.dt-news-title { font-family: var(--dt-sans); font-size: 13px; font-weight: 600; margin-bottom: 2px; }
.dt-news-meta { font-family: var(--dt-mono); font-size: 10px; color: var(--dt-text-muted); text-transform: uppercase; letter-spacing: 0.04em; margin-bottom: 4px; }
.dt-news-summary { font-family: var(--dt-sans); font-size: 12px; color: var(--dt-text-muted); line-height: 1.5; }
.dt-news-foot { margin-top: 12px; display: flex; gap: 8px; justify-content: center; }

/* ═══ Embed grid (sociais) ═══ */
.dt-embed-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 16px; }
@media (max-width: 900px) { .dt-embed-grid { grid-template-columns: 1fr; } }
.dt-embed { background: white; border: 1px solid var(--dt-border); border-radius: 8px; overflow: hidden; }
.dt-embed__head { padding: 8px 12px; display: flex; align-items: center; gap: 8px; }
.dt-embed--ig .dt-embed__head { background: linear-gradient(45deg, #FED373, #F15245, #D92E7F, #9B36B7, #515ECF); }
.dt-embed--tw .dt-embed__head { background: var(--dt-text); }
.dt-embed--li .dt-embed__head { background: #0A66C2; }
.dt-embed__title { font-family: var(--dt-sans); font-size: 11px; font-weight: 700; color: white; letter-spacing: -0.01em; }
.dt-embed__handle { margin-left: auto; color: rgba(255,255,255,0.85); font-family: var(--dt-mono); font-size: 10px; text-decoration: none; }
.dt-embed__body { padding: 16px; text-align: center; background: var(--dt-surface); min-height: 240px; display: flex; flex-direction: column; align-items: center; justify-content: center; gap: 8px; }
.dt-embed__placeholder-lbl { font-family: var(--dt-mono); font-size: 10px; color: var(--dt-text-muted); }
.dt-embed__desc { font-family: var(--dt-sans); font-size: 12px; color: var(--dt-text); max-width: 220px; line-height: 1.5; }
.dt-embed__meta { font-family: var(--dt-mono); font-size: 9px; color: var(--dt-text-faint); margin-top: 8px; }

/* ═══ People grid + card ═══ */
.dt-people-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(260px, 1fr)); gap: 12px; }
.dt-person-card { background: white; border: 1px solid var(--dt-border); border-radius: 6px; padding: 14px; display: flex; gap: 12px; }
.dt-person-card--gold { border-left: 3px solid var(--dt-gold); }
.dt-person-card--blue { border-left: 3px solid var(--dt-blue); }
.dt-person-avatar { width: 44px; height: 44px; border-radius: 50%; background: var(--dt-surface); display: flex; align-items: center; justify-content: center; font-family: var(--dt-sans); font-weight: 800; font-size: 14px; color: var(--dt-text-muted); flex-shrink: 0; letter-spacing: -0.02em; }
.dt-person-info { flex: 1; min-width: 0; }
.dt-person-name { font-family: var(--dt-sans); font-size: 13px; font-weight: 700; color: var(--dt-text); letter-spacing: -0.01em; margin-bottom: 2px; }
.dt-person-role { font-family: var(--dt-sans); font-size: 11px; color: var(--dt-text-muted); margin-bottom: 4px; }
.dt-person-stage { margin-bottom: 4px; }
.dt-person-meta { font-family: var(--dt-mono); font-size: 10px; color: var(--dt-text-faint); text-transform: uppercase; letter-spacing: 0.04em; }

/* ═══ Table card (paginated) ═══ */
.dt-table-card { background: white; border: 1px solid var(--dt-border); border-radius: 8px; overflow: hidden; }
.dt-table-filters { padding: 10px 12px; background: var(--dt-surface); border-bottom: 1px solid var(--dt-border); display: flex; gap: 8px; align-items: center; }
.dt-input-search { flex: 1; padding: 6px 10px; font-family: var(--dt-sans); font-size: 12px; border: 1px solid var(--dt-border); border-radius: 4px; background: white; color: var(--dt-text); }
.dt-input-search:focus { outline: none; border-color: var(--dt-gold); }
.dt-select { padding: 6px 10px; font-family: var(--dt-mono); font-size: 11px; border: 1px solid var(--dt-border); border-radius: 4px; background: white; color: var(--dt-text); }
.dt-pagination { padding: 8px 12px; background: var(--dt-surface); border-top: 1px solid var(--dt-border); display: flex; gap: 8px; align-items: center; font-family: var(--dt-mono); font-size: 10px; color: var(--dt-text-muted); }
.dt-pagination-controls { margin-left: auto; display: flex; gap: 4px; }

/* ═══ Funnel ═══ */
.dt-funnel-card { background: white; border: 1px solid var(--dt-border); border-radius: 6px; padding: 14px; }
.dt-funnel-bar { display: flex; height: 8px; border-radius: 4px; overflow: hidden; margin-bottom: 12px; }
.dt-funnel-seg--identificado { background: #9CA3AF; }
.dt-funnel-seg--conectado { background: var(--dt-blue); }
.dt-funnel-seg--qualificado { background: var(--dt-purple); }
.dt-funnel-seg--contactado { background: #D97706; }
.dt-funnel-seg--agendado { background: var(--dt-gold); }
.dt-funnel-seg--em_andamento { background: var(--dt-orange); }
.dt-funnel-seg--nutrir { background: #EC4899; }
.dt-funnel-legend { display: flex; gap: 16px; font-family: var(--dt-mono); font-size: 10px; color: var(--dt-text-muted); text-transform: uppercase; letter-spacing: 0.05em; margin-bottom: 16px; flex-wrap: wrap; }
.dt-dot { display: inline-block; width: 8px; height: 8px; border-radius: 50%; vertical-align: middle; margin-right: 4px; }
.dt-dot--identificado { background: #9CA3AF; }
.dt-dot--conectado { background: var(--dt-blue); }
.dt-dot--qualificado { background: var(--dt-purple); }
.dt-dot--contactado { background: #D97706; }
.dt-dot--agendado { background: var(--dt-gold); }
.dt-dot--em_andamento { background: var(--dt-orange); }
.dt-dot--nutrir { background: #EC4899; }

/* ═══════════════════════════════════════════════════════════════════════════
 * v25.4.0 cutover Detail — additions
 * ═══════════════════════════════════════════════════════════════════════════ */

/* Hero title hyperlink (Mira-Subset pattern · target=_blank pro site_url) */
.dt-hero__title-link { color: inherit; text-decoration: none; border-bottom: 1px dashed transparent; transition: border-color 120ms ease; }
.dt-hero__title-link:hover { border-bottom-color: var(--dt-gold); }

/* Table wrapper pra responsive horizontal scroll */
.dt-table-wrap { width: 100%; overflow-x: auto; -webkit-overflow-scrolling: touch; }

/* ─── Tab Contratos · Orion header ─── */
.dt-orion-header { background: linear-gradient(180deg, var(--dt-gold-soft, #ECFDF5) 0%, transparent 60%); }
.dt-orion-score-row { display: flex; align-items: center; gap: 16px; margin: 8px 0 14px; flex-wrap: wrap; }
.dt-orion-score { display: flex; align-items: baseline; gap: 2px; }
.dt-orion-score__val { font-family: var(--dt-sans); font-size: 36px; font-weight: 800; line-height: 1; letter-spacing: -0.04em; color: var(--dt-text); font-feature-settings: "tnum" 1; }
.dt-orion-score__max { font-family: var(--dt-mono); font-size: 13px; font-weight: 500; color: var(--dt-text-muted); }
.dt-orion-score__meta { font-family: var(--dt-mono); font-size: 10px; color: var(--dt-text-muted); margin-left: auto; }
.dt-orion-flags { display: flex; flex-wrap: wrap; gap: 6px; margin-top: 4px; }
.dt-orion-flag { display: inline-flex; align-items: center; gap: 5px; font-family: var(--dt-mono); font-size: 10px; font-weight: 600; padding: 4px 8px; border-radius: 12px; border: 1px solid var(--dt-border); background: white; color: var(--dt-text-muted); text-transform: uppercase; letter-spacing: 0.04em; }
.dt-orion-flag__dot { font-family: var(--dt-mono); font-size: 12px; line-height: 1; font-weight: 700; }
.dt-orion-flag--on-positive { color: #0A9E5E; border-color: #A7F3D0; background: #ECFDF5; }
.dt-orion-flag--on-positive .dt-orion-flag__dot { color: #0A9E5E; }
.dt-orion-flag--on-negative { color: #B91C1C; border-color: #FECACA; background: #FEF2F2; }
.dt-orion-flag--on-negative .dt-orion-flag__dot { color: #B91C1C; }
.dt-orion-flag--off { opacity: 0.55; }
.dt-orion-flag--off .dt-orion-flag__dot { color: var(--dt-text-faint, #9CA3AF); }

/* ─── Tab Contratos · tabela ─── */
.dt-contratos-table { table-layout: auto; }
.dt-contratos-table th { white-space: nowrap; }
.dt-contract-operator strong { font-weight: 700; color: var(--dt-text); }
.dt-contract-cnpj { font-family: var(--dt-mono); font-size: 10px; color: var(--dt-text-faint, #9CA3AF); }
.dt-contract-segment { font-family: var(--dt-mono); font-size: 10px; color: var(--dt-text-muted); text-transform: uppercase; letter-spacing: 0.04em; }
.dt-contract-asset { font-size: 11px; color: var(--dt-text-muted); margin-top: 2px; }
.dt-contract-status { font-family: var(--dt-mono); font-size: 9px; font-weight: 700; padding: 2px 7px; border-radius: 3px; text-transform: uppercase; letter-spacing: 0.06em; }
.dt-contract-status--active { background: #ECFDF5; color: #0A9E5E; }
.dt-contract-status--expired { background: var(--dt-surface, #F9FAFB); color: var(--dt-text-muted); }
.dt-contract-status--cancelled { background: #FEF2F2; color: #B91C1C; }
.dt-contract-status--rumored { background: #FEF3C7; color: #92400E; }
.dt-contract-status--unknown { background: var(--dt-surface, #F9FAFB); color: var(--dt-text-faint, #9CA3AF); }
.dt-contract-conf { font-family: var(--dt-mono); font-size: 10px; font-weight: 600; padding: 1px 6px; border-radius: 3px; text-transform: lowercase; }
.dt-contract-conf--high { background: #ECFDF5; color: #0A9E5E; }
.dt-contract-conf--medium { background: #FEF3C7; color: #92400E; }
.dt-contract-conf--low { background: #FEF2F2; color: #B91C1C; }
.dt-contract-conf--inferred { background: var(--dt-surface, #F9FAFB); color: var(--dt-text-muted); font-style: italic; }
.dt-contract-source-link { color: var(--dt-text); text-decoration: none; border-bottom: 1px dotted var(--dt-border-strong, #D1D5DB); }
.dt-contract-source-link:hover { color: var(--dt-gold); border-bottom-color: var(--dt-gold); }
.dt-contract-source-text { color: var(--dt-text-muted); }

/* ─── Toast (placeholders backend-dep "Em breve") ─── */
.dt-toast { position: fixed; right: 24px; bottom: 24px; max-width: 380px; min-width: 220px; background: var(--dt-text, #1F2937); color: white; padding: 12px 16px; border-radius: 8px; box-shadow: 0 10px 30px rgba(0,0,0,0.18); z-index: 9999; font-family: var(--dt-sans); transform: translateY(0); opacity: 1; transition: opacity 300ms ease, transform 300ms ease; }
.dt-toast--fade { opacity: 0; transform: translateY(12px); }
.dt-toast__title { font-weight: 700; font-size: 13px; margin-bottom: 4px; }
.dt-toast__sub { font-size: 11px; line-height: 1.4; opacity: 0.85; }
.dt-toast--soon { border-left: 3px solid var(--dt-gold, #0A9E5E); }

/* ─── Modal Importar JSON (Oferta tab) ─── */
.dt-modal-overlay { position: fixed; inset: 0; background: rgba(17, 24, 39, 0.55); display: flex; align-items: center; justify-content: center; z-index: 9000; padding: 24px; }
.dt-modal { background: white; border-radius: 10px; max-width: 720px; width: 100%; max-height: 90vh; overflow-y: auto; box-shadow: 0 20px 50px rgba(0,0,0,0.25); padding: 24px; font-family: var(--dt-sans); }
.dt-modal__h { display: flex; align-items: flex-start; justify-content: space-between; gap: 12px; margin-bottom: 6px; }
.dt-modal__title { font-family: var(--dt-sans); font-size: 18px; font-weight: 800; letter-spacing: -0.025em; color: var(--dt-text); }
.dt-modal__close { background: transparent; border: none; cursor: pointer; font-size: 24px; line-height: 1; color: var(--dt-text-muted); padding: 0 4px; }
.dt-modal__close:hover { color: var(--dt-text); }
.dt-modal__lead { font-size: 12px; color: var(--dt-text-muted); margin-bottom: 18px; line-height: 1.5; }
.dt-modal__section { margin-bottom: 16px; }
.dt-modal__label { font-family: var(--dt-mono); font-size: 10px; font-weight: 700; color: var(--dt-text-muted); text-transform: uppercase; letter-spacing: 0.05em; margin-bottom: 6px; }
.dt-modal__textarea { width: 100%; padding: 10px 12px; border: 1px solid var(--dt-border); border-radius: 6px; font-family: var(--dt-mono); font-size: 11px; line-height: 1.5; resize: vertical; box-sizing: border-box; }
.dt-modal__textarea--prompt { background: var(--dt-surface, #F9FAFB); margin-bottom: 6px; }
.dt-modal__textarea--input { background: white; }
.dt-modal__preview { margin-top: 8px; font-size: 12px; }
.dt-modal__ok { color: #0A9E5E; background: #ECFDF5; padding: 8px 12px; border-radius: 6px; }
.dt-modal__ok .mono { font-family: var(--dt-mono); font-size: 11px; color: var(--dt-text); margin-left: 6px; }
.dt-modal__err { color: #B91C1C; background: #FEF2F2; padding: 8px 12px; border-radius: 6px; font-family: var(--dt-mono); font-size: 11px; }
.dt-modal__actions { display: flex; gap: 8px; justify-content: flex-end; padding-top: 8px; border-top: 1px solid var(--dt-border); margin-top: 6px; }
.dt-modal__actions .dt-btn--primary[disabled] { opacity: 0.5; cursor: not-allowed; }

/* ─── Pending/skeleton (lazy load tab Contratos) ─── */
/* PR-PERF v25.4.24 cluster C14: bloco duplicado .dt-pending/.dt-skel-line/skel-shimmer-keyframe removido (era cópia literal de L180-187 com width 35%/60% sobrescrevendo silenciosamente 40%/70%) */
