/* ============================================================
   21-progress-tracker.css — active build progress tracker
   Module: <section id="active-builds">
   Data + render: js/progress-tracker.js
   ============================================================ */

#active-builds { background: var(--c-white); }

.bt-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: var(--s-4);
}
@media (max-width: 880px) { .bt-grid { grid-template-columns: 1fr; } }

.bt-card {
  background: var(--c-bg);
  border: 1px solid var(--c-line);
  border-radius: var(--radius-lg);
  padding: var(--s-5);
  position: relative;
}
.bt-live-dot {
  position: absolute;
  top: 18px; right: 18px;
  display: inline-flex;
  align-items: center;
  gap: 6px;
  font-size: 0.7rem;
  font-weight: 800;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--c-green);
}
.bt-live-dot::before {
  content: "";
  width: 8px; height: 8px;
  background: var(--c-green);
  border-radius: 50%;
  animation: pulse 1.6s infinite;
}

.bt-card-head {
  margin-bottom: var(--s-3);
}
.bt-location {
  font-family: var(--f-display);
  font-size: 1.4rem;
  font-weight: 800;
  color: var(--c-ink);
  margin-bottom: 2px;
}
.bt-type {
  font-size: 0.92rem;
  color: var(--c-muted);
}

.bt-stages {
  display: grid;
  grid-template-columns: repeat(5, 1fr);
  gap: 4px;
  margin: var(--s-3) 0 6px;
}
.bt-stage {
  text-align: center;
}
.bt-stage-dot {
  width: 100%;
  height: 6px;
  border-radius: 3px;
  background: var(--c-line);
  margin-bottom: 6px;
  transition: background 0.3s ease;
}
.bt-stage.is-done .bt-stage-dot,
.bt-stage.is-current .bt-stage-dot { background: var(--c-green); }
.bt-stage.is-current .bt-stage-dot {
  background: linear-gradient(90deg, var(--c-green) 0%, var(--c-green) 50%, var(--c-yellow) 50%, var(--c-yellow) 100%);
  box-shadow: 0 0 0 2px rgba(249, 199, 79, 0.25);
}
.bt-stage-label {
  font-size: 0.72rem;
  font-weight: 700;
  color: var(--c-muted);
  text-transform: uppercase;
  letter-spacing: 0.08em;
}
.bt-stage.is-current .bt-stage-label { color: var(--c-ink); }

.bt-meta {
  display: flex;
  justify-content: space-between;
  margin-top: var(--s-3);
  padding-top: var(--s-3);
  border-top: 1px solid var(--c-line);
  font-size: 0.88rem;
}
.bt-meta-item strong {
  display: block;
  color: var(--c-blue);
  font-size: 1.05rem;
  font-weight: 800;
  margin-bottom: 2px;
}
.bt-meta-item span { color: var(--c-muted); font-size: 0.78rem; text-transform: uppercase; letter-spacing: 0.08em; }

.bt-next {
  margin-top: var(--s-3);
  padding: 10px 12px;
  background: var(--c-card);
  border-radius: var(--radius);
  font-size: 0.88rem;
}
.bt-next strong { color: var(--c-blue); display: block; font-size: 0.74rem; letter-spacing: 0.14em; text-transform: uppercase; margin-bottom: 2px; }
