/* design-kit/css/portal-setup-progress.css
   Numbered onboarding-progress band shown on /portal/new and /portal/<slug>.
   All visual tokens via tokens.css. */

.tcp-setup-progress {
  background: var(--tdl-surf-1);
  border: 1px solid var(--tdl-hairline);
  border-radius: var(--tdl-radius-lg, 8px);
  padding: var(--tdl-space-5, 20px) var(--tdl-space-6, 24px);
  margin-bottom: var(--tdl-space-6, 24px);
}

.tcp-setup-progress__header {
  display: flex;
  align-items: baseline;
  justify-content: space-between;
  gap: var(--tdl-space-4, 16px);
  margin-bottom: var(--tdl-space-4, 16px);
  padding-bottom: var(--tdl-space-3, 12px);
  border-bottom: 1px solid var(--tdl-hairline);
}

.tcp-setup-progress__title {
  font-family: var(--tdl-font-display);
  font-weight: 900;
  font-size: 14px;
  letter-spacing: 0.02em;
  color: var(--tdl-fg);
  margin: 0;
  text-transform: uppercase;
}

.tcp-setup-progress__list {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: var(--tdl-space-3, 12px);
  list-style: none;
  margin: 0;
  padding: 0;
  position: relative;
}

.tcp-setup-progress__step {
  display: flex;
  align-items: flex-start;
  gap: var(--tdl-space-3, 12px);
  padding: var(--tdl-space-3, 12px) var(--tdl-space-4, 16px);
  background: var(--tdl-surf-2);
  border: 1px solid var(--tdl-hairline);
  border-radius: var(--tdl-radius-md, 6px);
  transition: border-color var(--tdl-dur-fast, 140ms) ease;
}

.tcp-setup-progress__step.is-done {
  border-color: var(--tdl-pos);
  background: var(--tdl-pos-bg-soft);
}

.tcp-setup-progress__step.is-current {
  border-color: var(--tdl-accent);
  background: var(--tdl-neg-bg-soft);
}

.tcp-setup-progress__step.is-pending {
  opacity: 0.55;
}

.tcp-setup-progress__marker {
  flex-shrink: 0;
  width: 28px;
  height: 28px;
  border-radius: 50%;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-family: var(--tdl-font-display);
  font-weight: 900;
  font-size: 12px;
  color: var(--tdl-fg-3);
  background: var(--tdl-surf-3);
  border: 1px solid var(--tdl-hairline-2);
}

.is-done .tcp-setup-progress__marker {
  background: var(--tdl-pos);
  color: var(--tdl-bg);
  border-color: var(--tdl-pos);
}

.is-current .tcp-setup-progress__marker {
  background: var(--tdl-accent);
  color: var(--tdl-accent-fg);
  border-color: var(--tdl-accent);
  animation: tcpPulse 2s infinite;
}

@keyframes tcpPulse {
  0%, 100% { box-shadow: 0 0 0 0 rgba(255, 64, 0, 0.5); }
  50% { box-shadow: 0 0 0 6px rgba(255, 64, 0, 0); }
}

.tcp-setup-progress__copy {
  display: flex;
  flex-direction: column;
  gap: 2px;
  min-width: 0;
}

.tcp-setup-progress__step-label {
  font-family: var(--tdl-font-display);
  font-weight: 900;
  font-size: 11px;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: var(--tdl-fg);
}

.is-pending .tcp-setup-progress__step-label { color: var(--tdl-fg-3); }

.tcp-setup-progress__step-sub {
  font-family: var(--tdl-font-body);
  font-size: 11px;
  color: var(--tdl-fg-4);
  line-height: 1.4;
}

@media (max-width: 720px) {
  .tcp-setup-progress__list { grid-template-columns: 1fr 1fr; }
}
