/* sensor_view.css — estilos do painel detalhado de um sensor.
 * Compartilhado entre o dashboard global (embutido inline) e a página
 * de IMEI único (carregado como /static). */

.det-header {
  display: grid; gap: 6px;
  padding-bottom: 14px;
  border-bottom: 1px solid var(--line);
  margin-bottom: 18px;
}
.det-header .imei {
  font-family: ui-monospace, "SFMono-Regular", Consolas, monospace;
  font-size: 22px; font-weight: 800; letter-spacing: -.01em;
}
.det-header .row1 { display: flex; align-items: center; gap: 10px; flex-wrap: wrap; }
.det-header .meta {
  color: var(--muted); font-size: 13px;
  display: flex; flex-wrap: wrap; gap: 6px 14px;
}
.det-header .meta b { color: var(--ink-soft); font-weight: 700; }

.pill {
  display: inline-flex; align-items: center;
  height: 22px; padding: 0 9px;
  border-radius: 999px;
  font-size: 11.5px; font-weight: 800;
  text-transform: uppercase; letter-spacing: .04em;
}
.pill.critical { background: var(--critical-bg); color: var(--critical); }
.pill.warning { background: var(--warning-bg); color: var(--warning); }
.pill.ok { background: var(--ok-bg); color: var(--ok); }
.pill.info { background: var(--info-bg); color: var(--info); }
.pill.neutral { background: var(--neutral-bg); color: var(--ink-soft); }

.card {
  background: var(--panel);
  border: 1px solid var(--line);
  border-radius: var(--radius);
  padding: 16px 18px;
  margin-bottom: 14px;
}
.card h2 {
  margin: 0 0 10px;
  font-size: 13px;
  text-transform: uppercase;
  letter-spacing: .1em;
  color: var(--muted);
}
.card h3 {
  margin: 0 0 4px; font-size: 15px; font-weight: 700;
}

.verdict {
  border-left: 4px solid var(--info);
  padding: 12px 14px;
  background: #fbfaf6;
  border-radius: 8px;
  margin-bottom: 14px;
}
.verdict.critical { border-color: var(--critical); }
.verdict.warning { border-color: var(--warning); }
.verdict.ok { border-color: var(--ok); }
.verdict h3 { margin: 0 0 4px; font-size: 16px; }
.verdict p { margin: 0; color: var(--ink-soft); }

.problem {
  border: 1px solid var(--line);
  border-left: 4px solid var(--warning);
  border-radius: 8px;
  margin-bottom: 10px;
  background: #fffdfa;
}
.problem.critical { border-left-color: var(--critical); }
.problem.warning { border-left-color: var(--warning); }
.problem.info { border-left-color: var(--info); }
.problem .head {
  padding: 12px 14px;
  cursor: pointer;
  display: flex; align-items: center; gap: 10px;
}
.problem .head .icon { width: 18px; text-align: center; color: var(--muted); }
.problem .head h3 { flex: 1; }
.problem .head .code {
  font-family: ui-monospace, monospace;
  font-size: 11px;
  color: var(--muted);
}
.problem .body {
  padding: 0 14px 14px 36px;
  color: var(--ink-soft);
  display: none;
}
.problem.open .body { display: block; }
.problem.open .head .icon::after { content: "▾"; }
.problem:not(.open) .head .icon::after { content: "▸"; }
.problem .body p { margin: 0 0 8px; }
.problem .body .reco {
  margin-top: 8px;
  padding: 8px 10px;
  background: var(--info-bg);
  color: var(--info);
  border-radius: 6px;
  font-size: 13px;
}
.problem .body dl {
  display: grid; grid-template-columns: max-content 1fr; gap: 4px 12px;
  margin: 6px 0 8px;
}
.problem .body dt { color: var(--muted); font-size: 12px; }
.problem .body dd { margin: 0; font-size: 13px; }

table.data {
  width: 100%;
  border-collapse: collapse;
  font-size: 12.5px;
  margin-top: 6px;
}
table.data th, table.data td {
  text-align: left;
  padding: 7px 9px;
  border-bottom: 1px solid var(--line);
  vertical-align: top;
}
table.data th {
  background: #f8f6ef;
  color: var(--ink-soft);
  font-weight: 700;
  font-size: 11px;
  text-transform: uppercase;
  letter-spacing: .04em;
}
table.data tr:last-child td { border-bottom: none; }

.stage {
  display: inline-block;
  width: 22px; height: 22px;
  border-radius: 6px;
  text-align: center; line-height: 22px;
  font-weight: 800; font-size: 12px;
}
.stage.ok { background: var(--ok-bg); color: var(--ok); }
.stage.fail { background: var(--critical-bg); color: var(--critical); }
.stage.warn { background: var(--warning-bg); color: var(--warning); }
.stage.skip { background: var(--neutral-bg); color: var(--muted); }

.mono { font-family: ui-monospace, "SFMono-Regular", Consolas, monospace; }

.kv { display: grid; grid-template-columns: max-content 1fr; gap: 4px 14px; }
.kv dt { color: var(--muted); font-size: 12px; }
.kv dd { margin: 0; font-size: 13px; }

.stats { display: grid; grid-template-columns: repeat(4, 1fr); gap: 10px; }
.stats .stat { background: #fbfaf6; border: 1px solid var(--line); border-radius: 8px; padding: 10px; }
.stats .stat .lbl { color: var(--muted); font-size: 11px; text-transform: uppercase; letter-spacing: .07em; font-weight: 700; }
.stats .stat .val { font-size: 18px; font-weight: 800; margin-top: 4px; }

details.raw { margin-top: 16px; }
details.raw summary { cursor: pointer; color: var(--muted); font-size: 12px; }
details.raw pre {
  background: #1c1f24; color: #e6e1d6;
  padding: 12px; border-radius: 8px;
  font-size: 11px;
  overflow: auto; max-height: 360px;
  white-space: pre-wrap;
}

@media (max-width: 980px) {
  .stats { grid-template-columns: repeat(2, 1fr); }
}
