/* Shared hub / dev bookmark panel cards (PulsePoint hub + dev hub) */
.demo-roster-grid,
.hub-panel-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(300px, 1fr));
  gap: 16px;
}

.demo-roster-card,
.hub-panel-card {
  background: linear-gradient(
    145deg,
    rgba(45, 212, 191, 0.08) 0%,
    rgba(255, 255, 255, 0.03) 45%
  );
  border: 1px solid rgba(45, 212, 191, 0.22);
  border-radius: 16px;
  padding: 16px 16px 14px;
}

.hub-panel-card.tone-purple {
  border-color: rgba(168, 85, 247, 0.28);
  background: linear-gradient(
    145deg,
    rgba(168, 85, 247, 0.1) 0%,
    rgba(255, 255, 255, 0.03) 50%
  );
}

.hub-panel-card.tone-amber {
  border-color: rgba(251, 191, 36, 0.28);
  background: linear-gradient(
    145deg,
    rgba(251, 191, 36, 0.08) 0%,
    rgba(255, 255, 255, 0.03) 50%
  );
}

.hub-panel-card.tone-blue {
  border-color: rgba(59, 130, 246, 0.28);
  background: linear-gradient(
    145deg,
    rgba(59, 130, 246, 0.08) 0%,
    rgba(255, 255, 255, 0.03) 50%
  );
}

.hub-panel-card.tone-green {
  border-color: rgba(52, 211, 153, 0.28);
  background: linear-gradient(
    145deg,
    rgba(52, 211, 153, 0.1) 0%,
    rgba(255, 255, 255, 0.03) 50%
  );
}

.demo-roster-head,
.hub-panel-head {
  display: flex;
  align-items: flex-start;
  gap: 12px;
  margin-bottom: 10px;
}

.demo-roster-emoji,
.hub-panel-emoji {
  font-size: 2rem;
  line-height: 1;
  flex-shrink: 0;
}

.demo-roster-name,
.hub-panel-title {
  font-size: 1.05rem;
  font-weight: 700;
  margin: 0 0 4px;
  color: inherit;
}

.demo-roster-meta,
.hub-panel-meta {
  font-size: 0.78rem;
  margin: 0;
  opacity: 0.75;
}

.demo-roster-bip,
.hub-panel-body {
  font-size: 0.82rem;
  line-height: 1.45;
  margin: 0 0 12px;
  opacity: 0.85;
}

.demo-roster-actions,
.hub-panel-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}

.demo-roster-btn,
.hub-panel-btn {
  display: inline-flex;
  align-items: center;
  padding: 8px 12px;
  border-radius: 8px;
  border: 1px solid rgba(148, 163, 184, 0.35);
  background: rgba(15, 23, 42, 0.35);
  color: inherit;
  font-size: 0.8rem;
  font-weight: 600;
  text-decoration: none;
  transition: border-color 0.15s, background 0.15s;
}

.demo-roster-btn:hover,
.hub-panel-btn:hover {
  border-color: rgba(168, 85, 247, 0.55);
  background: rgba(168, 85, 247, 0.12);
}

.demo-roster-btn.primary,
.hub-panel-btn.primary {
  border-color: rgba(168, 85, 247, 0.55);
  background: rgba(168, 85, 247, 0.18);
}

.demo-roster-source,
.hub-panel-source {
  margin-top: 10px;
  font-size: 0.7rem;
  opacity: 0.55;
}
