/* /assets/metrix.css — Metrik & Monitoring (tema terang selaras index) */

/* Layout umum */
.lead{color:var(--muted);margin:0 0 18px}

/* ===== Panel kontrol ===== */
.ctrl-grid{
  display:grid; gap:12px;
  grid-template-columns: repeat(4, minmax(220px,1fr));
  align-items:start;
}
@media (max-width:1024px){ .ctrl-grid{ grid-template-columns:repeat(2, minmax(220px,1fr)); } }
@media (max-width:640px){  .ctrl-grid{ grid-template-columns:1fr; } }

.fld{display:flex;flex-direction:column;gap:6px}
.fld > span{font-size:13px;color:var(--muted)}

input{
  padding:12px 14px;
  border:1px solid var(--line);
  border-radius:12px;
  background:var(--card);
  color:var(--fg);
  box-shadow:none;
}
input::placeholder{color:var(--muted)}

.switch{display:flex;align-items:center;gap:10px;font-weight:600}
.action{display:flex;gap:8px;align-items:end}

/* ===== Progress bar ===== */
.progress{
  height:8px;
  background:var(--card);
  border:1px solid var(--line);
  border-radius:999px;
  overflow:hidden;
  margin-top:10px;
}
.progress .bar{
  height:100%; width:0%;
  background: linear-gradient(90deg, color-mix(in oklab, var(--brand) 70%, #fff), var(--brand));
  transition:width .25s ease;
}
.progress.slim{
  height:10px; border-radius:999px; overflow:hidden;
  background:var(--card); border:1px solid var(--line);
}
.progress.slim .bar{ height:100%; width:0%; transition:width .5s ease; border-radius:999px; }
.progress.slim .bar.ok{   background:linear-gradient(90deg,#22c55e,#16a34a); }
.progress.slim .bar.warn{ background:linear-gradient(90deg,#eab308,#ca8a04); }
.progress.slim .bar.bad{  background:linear-gradient(90deg,#ef4444,#b91c1c); }

/* ===== KPI ringkas ===== */
.grid3-kpi{
  display:grid; gap:12px; margin:12px 0;
  grid-template-columns:repeat(3,minmax(180px,1fr));
}
@media (max-width:820px){ .grid3-kpi{ grid-template-columns:1fr; } }

.kpi{ text-align:center }
.kpi-val{ font-size:28px; font-weight:800; line-height:1; }
.kpi-label{ color:var(--muted); margin-top:4px; }

/* ===== Hasil per-endpoint ===== */
.results{ display:grid; gap:12px; }

.card-row{
  display:grid; gap:12px; align-items:flex-start;
  grid-template-columns:220px 1fr auto;
  border:1px solid var(--line);
  background:var(--card);
  border-radius:12px;
  padding:12px 14px;
}
@media (max-width:720px){ .card-row{ grid-template-columns:1fr } }

.label{ font-weight:700 }
.mini { font-size:12.5px }
.muted{ color:var(--muted) }

/* Pill & Badge (terang, tidak ada latar gelap) */
.pill{
  display:inline-block;
  background: color-mix(in oklab, var(--brand) 10%, var(--card));
  border:1px solid var(--line);
  color:var(--fg);
  padding:2px 10px;
  border-radius:999px;
  font-size:12.5px;
}

.badge{
  display:inline-block;
  padding:2px 10px;
  border-radius:999px;
  border:1px solid var(--line);
  background: var(--card);
  font-size:12.5px;
  font-weight:700;
}
.badge.ok   { color:var(--ok);   background: color-mix(in oklab, var(--ok)   12%, var(--card)); }
.badge.warn { color:var(--warn); background: color-mix(in oklab, var(--warn) 12%, var(--card)); }
.badge.bad  { color:var(--bad);  background: color-mix(in oklab, var(--bad)  12%, var(--card)); }
.skip{ color:#7a8baa; }        /* status skip netral */
.badge.skip{ color:#7a8baa; background: color-mix(in oklab, #7a8baa 12%, var(--card)); }

/* ===== Kode / payload ===== */
.code{
  font-family: ui-monospace, SFMono-Regular, Menlo, Consolas, "Liberation Mono", monospace;
  font-size:12.5px; white-space:pre-wrap; word-break:break-word;
  background:var(--card);
  border:1px solid var(--line);
  border-radius:12px;
  padding:8px 10px;
}

/* ===== Grid util ===== */
.grid2{ display:grid; grid-template-columns:1fr 1fr; gap:12px; }
@media (max-width:820px){ .grid2{ grid-template-columns:1fr; } }

/* ===== Meter (live monitor) ===== */
.live-grid{
  display:grid;
  grid-template-columns: repeat(5, 1fr);
  gap:12px;
  margin-bottom:14px;
}
@media (max-width:980px){ .live-grid{ grid-template-columns: 1fr 1fr; } }
@media (max-width:560px){ .live-grid{ grid-template-columns: 1fr; } }

.meter .meter-top{ display:flex; align-items:center; justify-content:space-between; margin-bottom:6px; }
.meter .meter-val{ font-weight:800; color:var(--fg); }
