:root {
  --bg: #0f1419; --panel: #1a2029; --fg: #e6edf3; --sub: #8b97a7;
  --line: #2a323d; --accent: #4aa8ff;
  --green: #2ecc71; --red: #e74c3c; --grey: #555f6b; --amber: #f1c40f;
}
* { box-sizing: border-box; }
body {
  margin: 0; background: var(--bg); color: var(--fg);
  font: 14px/1.4 system-ui, -apple-system, Segoe UI, Roboto, sans-serif;
}
header {
  display: flex; align-items: center; gap: 24px; padding: 14px 20px;
  background: var(--panel); border-bottom: 1px solid var(--line);
  position: sticky; top: 0; z-index: 10; flex-wrap: wrap;
}
.title { font-size: 20px; font-weight: 600; margin-left: auto; }
.sub { color: var(--sub); font-size: 12px; font-weight: 400; }
.status { display: flex; align-items: center; gap: 12px; }
.light {
  width: 26px; height: 26px; border-radius: 50%; background: var(--grey);
  box-shadow: 0 0 0 0 rgba(0,0,0,0);
}
.light.green { background: var(--green); box-shadow: 0 0 16px 2px var(--green); animation: pulse 1.6s infinite; }
.light.red { background: var(--red); }
.light.amber { background: var(--amber); }
@keyframes pulse { 0%,100%{opacity:1} 50%{opacity:.55} }
#status-line { font-size: 16px; font-weight: 600; }
.ranges button {
  background: var(--panel); color: var(--sub); border: 1px solid var(--line);
  padding: 5px 12px; border-radius: 6px; cursor: pointer; font-size: 13px;
}
.ranges button.active { color: var(--fg); border-color: var(--accent); background: #14304a; }

.cards { display: flex; gap: 12px; padding: 16px 20px 0; flex-wrap: wrap; }
.card {
  background: var(--panel); border: 1px solid var(--line); border-radius: 10px;
  padding: 12px 18px; min-width: 110px; flex: 1;
}
.card .num { font-size: 26px; font-weight: 700; }
.card .lbl { color: var(--sub); font-size: 12px; margin-top: 2px; }

.grid {
  display: grid; grid-template-columns: repeat(2, 1fr); gap: 16px; padding: 16px 20px;
}
.panel {
  background: var(--panel); border: 1px solid var(--line); border-radius: 10px;
  padding: 14px 16px; min-height: 240px;
}
.panel.wide { grid-column: 1 / -1; }
.panel h2 { margin: 0 0 10px; font-size: 14px; font-weight: 600; color: var(--sub); }
canvas { max-height: 300px; }

table { width: 100%; border-collapse: collapse; font-size: 13px; }
th, td { text-align: left; padding: 6px 10px; border-bottom: 1px solid var(--line); }
th { color: var(--sub); font-weight: 600; }
.meet { color: var(--amber); }
footer { color: var(--sub); font-size: 12px; padding: 8px 20px 24px; }

@media (max-width: 760px) { .grid { grid-template-columns: 1fr; } }
