.cat-tabs {
  display: flex;
  flex-wrap: wrap;
  gap: 0.45rem;
  margin-bottom: 1rem;
  padding: 0.5rem;
  background: var(--bg-inset);
  border-radius: var(--radius);
  border: 1px solid var(--border);
}

.cat-tab {
  padding: 0.48rem 0.9rem;
  border-radius: var(--radius-sm);
  border: 1px solid var(--border);
  background: var(--bg-card);
  font-size: 0.8125rem;
  font-weight: 600;
  color: var(--text-muted);
  transition:
    background var(--t-fast) var(--ease),
    border-color var(--t-fast) var(--ease),
    color var(--t-fast) var(--ease);
}

.cat-tab:hover:not(:disabled) {
  border-color: var(--border-strong);
  color: var(--text);
  background: var(--bg-card-hover);
}

.cat-tab.is-active {
  border-color: var(--accent);
  background: var(--bg-card-hover);
  color: var(--text);
}

.cat-tab.used {
  opacity: 0.4;
  cursor: not-allowed;
}

.decision-cards {
  display: grid;
  gap: 1rem;
}
@media (min-width: 800px) {
  .decision-cards {
    grid-template-columns: repeat(3, 1fr);
  }
}

.decision-card {
  border: 1px solid var(--border);
  border-radius: var(--radius);
  padding: 1.1rem;
  background: var(--bg-card);
  display: flex;
  flex-direction: column;
  gap: 0.5rem;
  box-shadow: var(--shadow);
  transition:
    border-color var(--t-fast) var(--ease),
    background var(--t-fast) var(--ease);
}

.decision-card:hover {
  border-color: var(--border-strong);
  background: var(--bg-card-hover);
}

.decision-card h3 {
  font-size: 1rem;
  display: flex;
  align-items: center;
  gap: 0.35rem;
}

.decision-card .cost {
  font-size: 0.875rem;
  font-weight: 700;
  color: var(--text-muted);
}

.decision-card .summary {
  font-size: 0.8125rem;
  color: var(--text-muted);
  flex: 1;
  line-height: 1.45;
}

.decision-card .desc {
  font-size: 0.8125rem;
  color: var(--text-soft);
  white-space: pre-line;
  line-height: 1.45;
}

.decision-card .btn-primary {
  margin-top: auto;
}
