/* States — empty / loading / error
 * Source: docs/superpowers/plans/2026-04-18-app-polish-maximization.md Theme 3A
 * Tokens: web/static/css/_tokens.css
 *
 * Three reusable display states:
 *   .state--empty   : zero-data surface (designed, not bare <p>)
 *   .state--loading : async work in flight (spinner + label)
 *   .state--error   : recoverable failure (alert icon + recovery action)
 *
 * Macros: empty_state(), loading_state(), error_state() in _macros.html.
 */
.state {
  display: flex;
  flex-direction: column;
  align-items: center;
  text-align: center;
  padding: var(--space-12) var(--space-6);
  gap: var(--space-3);
  color: var(--text-muted);
}
.state__illustration {
  color: var(--text-muted);
}
.state__icon {
  width: 40px;
  height: 40px;
}
.state__icon--error {
  color: var(--danger);
}
.state__headline {
  font-size: var(--text-lg);
  font-weight: var(--weight-semibold);
  color: var(--text);
  margin: var(--space-0);
}
.state__body {
  font-size: var(--text-sm);
  max-width: 28rem;
  margin: var(--space-0);
  line-height: 1.5;
}
.state__action {
  margin-top: var(--space-3);
}
.state__raw-error {
  margin-top: var(--space-4);
  text-align: left;
  width: 100%;
  max-width: 32rem;
}
.state__raw-error summary {
  cursor: pointer;
  font-size: var(--text-xs);
  color: var(--text-muted);
}
.state__raw-error pre {
  background: var(--surface-inset);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  padding: var(--space-3);
  font-family: var(--font-mono);
  font-size: var(--text-xs);
  overflow-x: auto;
  margin-top: var(--space-2);
}
.state__spinner {
  width: 32px;
  height: 32px;
  border: 2px solid var(--border);
  border-top-color: var(--primary);
  border-radius: var(--radius-circle);
  animation: state-spin 600ms linear infinite;
}

@keyframes state-spin {
  to { transform: rotate(360deg); }
}

@media (prefers-reduced-motion: reduce) {
  .state__spinner {
    animation: none;
    border-top-color: var(--primary-soft);
  }
}

/* Compact inline empty state — for sections inside larger pages
 * (leadership tiles, sidebars). Same visual language, less padding. */
.state--inline {
  padding: var(--space-6) var(--space-4);
  gap: var(--space-2);
}
.state--inline .state__icon {
  width: 28px;
  height: 28px;
}
.state--inline .state__headline {
  font-size: var(--text-base);
}
