/* Blueprint Marketplace overlay — browse + detail surface inside .overlay. */

.mp-host {
  display: flex;
  flex-direction: column;
  gap: var(--sp-5);
}

.mp-loading,
.mp-error {
  color: var(--c-ink-3);
  font-size: var(--fs-normal);
  padding: var(--sp-4) 0;
}
.mp-error {
  color: var(--c-splash-red);
  background: var(--c-error-soft);
  border: var(--bw) solid var(--c-error-line);
  border-radius: var(--r-sm);
  padding: var(--sp-3) var(--sp-4);
}

.mp {
  display: flex;
  flex-direction: column;
  gap: var(--sp-5);
}

.mp-bar {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: var(--sp-4);
  flex-wrap: wrap;
}
.mp-bar__left { display: flex; flex-direction: column; gap: var(--sp-1); }
.mp-bar__right { display: flex; align-items: center; gap: var(--sp-3); flex-wrap: wrap; }
.mp-eyebrow {
  font-size: var(--fs-2xs);
  text-transform: uppercase;
  letter-spacing: 0.06em;
  color: var(--c-ink-3);
  font-weight: var(--fw-semibold);
}
.mp-bar__sub { font-size: var(--fs-sm); margin: 0; max-width: 540px; }

.mp-search {
  display: flex;
  align-items: center;
  gap: var(--sp-2);
  padding: 0 var(--sp-3);
  border: var(--border);
  border-radius: var(--r-pill);
  background: var(--c-surface);
  color: var(--c-ink-3);
}
.mp-search__input {
  border: none;
  background: transparent;
  outline: none;
  height: 32px;
  width: 220px;
  font-size: var(--fs-normal);
  color: var(--c-ink);
}
.mp-sort { height: 32px; width: auto; padding-right: var(--sp-2); }

.mp-body {
  display: grid;
  grid-template-columns: 200px 1fr;
  gap: var(--sp-5);
  align-items: start;
}
@media (max-width: 720px) {
  .mp-body { grid-template-columns: 1fr; }
}

.mp-side {
  display: flex;
  flex-direction: column;
  gap: var(--sp-4);
  position: sticky;
  top: 0;
}
.mp-side__group { display: flex; flex-direction: column; gap: var(--sp-1); }
.mp-side__label {
  font-size: var(--fs-2xs);
  text-transform: uppercase;
  letter-spacing: 0.06em;
  color: var(--c-ink-3);
  font-weight: var(--fw-semibold);
  margin-bottom: var(--sp-1);
}
.mp-side__item {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--sp-2);
  padding: var(--sp-1) var(--sp-2);
  border: none;
  background: transparent;
  color: var(--c-ink-2);
  font-size: var(--fs-sm);
  border-radius: var(--r-sm);
  cursor: pointer;
  text-align: left;
}
.mp-side__item:hover { background: var(--c-surface-hover); }
.mp-side__item.is-active { background: var(--c-surface-2); color: var(--c-ink); font-weight: var(--fw-semibold); }
.mp-side__count { font-size: var(--fs-2xs); }
.mp-side__tags { display: flex; flex-wrap: wrap; gap: var(--sp-1); }
.mp-side__tag {
  display: inline-flex;
  align-items: center;
  gap: var(--sp-1);
  padding: 2px var(--sp-2);
  border: var(--border);
  border-radius: var(--r-pill);
  background: var(--c-surface);
  color: var(--c-ink-2);
  font-size: var(--fs-2xs);
  cursor: pointer;
}
.mp-side__tag:hover { background: var(--c-surface-hover); }
.mp-side__tag.is-active { background: var(--c-accent); color: var(--c-ink-inv); border-color: var(--c-accent); }

.mp-main { display: flex; flex-direction: column; gap: var(--sp-4); }
.mp-main__head { display: flex; align-items: center; justify-content: space-between; }

.mp-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(280px, 1fr));
  gap: var(--sp-4);
}

.mp-card {
  display: flex;
  flex-direction: column;
  gap: var(--sp-2);
  padding: var(--sp-4);
  border: var(--border);
  border-radius: var(--r-lg);
  background: var(--c-surface);
}
.mp-card__head { display: flex; align-items: center; justify-content: space-between; }
.mp-card__cat {
  font-size: var(--fs-2xs);
  text-transform: uppercase;
  letter-spacing: 0.05em;
  font-weight: var(--fw-semibold);
  color: var(--c-accent);
}
.mp-card__imports { font-size: var(--fs-2xs); }
.mp-card__title { margin: 0; font-size: var(--fs-md); font-weight: var(--fw-semibold); }
.mp-card__desc { margin: 0; font-size: var(--fs-sm); color: var(--c-ink-2); flex: 1; display: -webkit-box; -webkit-line-clamp: 2; -webkit-box-orient: vertical; overflow: hidden; }
.mp-card__tags { display: flex; flex-wrap: wrap; gap: var(--sp-1); }
.mp-tag {
  padding: 1px var(--sp-2);
  border-radius: var(--r-pill);
  background: var(--c-surface-2);
  color: var(--c-ink-3);
  font-size: var(--fs-2xs);
}
.mp-card__foot { display: flex; align-items: center; justify-content: space-between; gap: var(--sp-2); margin-top: var(--sp-1); }
.mp-card__org { display: flex; align-items: center; gap: var(--sp-2); min-width: 0; }
.mp-card__avatar {
  width: 22px;
  height: 22px;
  border-radius: 50%;
  object-fit: cover;
  flex-shrink: 0;
}
.mp-card__avatar--ph {
  display: flex;
  align-items: center;
  justify-content: center;
  background: var(--c-surface-2);
  color: var(--c-ink-3);
  font-size: var(--fs-2xs);
  font-weight: var(--fw-semibold);
}
.mp-card__org-name { font-size: var(--fs-sm); color: var(--c-ink-3); white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.mp-card__actions { display: flex; gap: var(--sp-1); flex-shrink: 0; }

.mp-empty {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: var(--sp-2);
  padding: var(--sp-8) var(--sp-4);
  text-align: center;
  color: var(--c-ink-3);
}
.mp-empty h3 { margin: 0; font-size: var(--fs-md); }
.mp-empty p { margin: 0; }

.mp-pager {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: var(--sp-3);
  padding: var(--sp-2) 0;
}

/* ---- Detail ---- */

.mp-detail { display: flex; flex-direction: column; gap: var(--sp-4); }
.mp-detail__bar {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--sp-3);
  flex-wrap: wrap;
}
.mp-detail__title { font-size: var(--fs-lg); font-weight: var(--fw-semibold); flex: 1; min-width: 200px; }
.mp-detail__actions { display: flex; gap: var(--sp-2); }
.mp-detail__meta { display: flex; align-items: center; gap: var(--sp-3); flex-wrap: wrap; }
.mp-detail__desc { margin: 0; font-size: var(--fs-normal); color: var(--c-ink-2); }
.mp-detail__preview-label { font-size: var(--fs-2xs); text-transform: uppercase; letter-spacing: 0.06em; font-weight: var(--fw-semibold); margin-bottom: var(--sp-2); }
.mp-detail__preview {
  border: var(--border);
  border-radius: var(--r-lg);
  padding: var(--sp-4);
  background: var(--c-surface);
  overflow: auto;
}
.mp-detail__grid { max-width: 640px; margin: 0 auto; }
.mp-detail__instructions {
  margin: 0 auto var(--sp-4);
  max-width: 640px;
}
.mp-detail__instructions .bp-surface-instructions__text {
  min-height: auto;
  cursor: default;
}
.mp-detail__fields { display: flex; flex-direction: column; gap: var(--sp-1); }
.mp-detail__field-list {
  display: flex;
  flex-wrap: wrap;
  gap: var(--sp-2);
}
.mp-detail__field {
  display: inline-flex;
  align-items: center;
  gap: var(--sp-2);
  padding: var(--sp-1) var(--sp-3);
  border: var(--border);
  border-radius: var(--r-pill);
  background: var(--c-surface);
  font-size: var(--fs-sm);
}
.mp-detail__field .muted { font-size: var(--fs-2xs); }

/* ---- Share warning ---- */

.mp-share-warning {
  display: flex;
  gap: var(--sp-3);
  padding: var(--sp-3) var(--sp-4);
  background: color-mix(in srgb, var(--c-splash-amber) 8%, var(--c-surface));
  border: 1px solid color-mix(in srgb, var(--c-splash-amber) 30%, transparent);
  border-radius: var(--r-md);
  font-size: var(--fs-sm);
  color: var(--c-text-2);
}
.mp-share-warning__icon {
  flex-shrink: 0;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 20px;
  height: 20px;
  border-radius: 50%;
  background: var(--c-splash-amber);
  color: #fff;
  font-weight: var(--fw-bold);
  font-size: var(--fs-sm);
}
.mp-share-warning__text strong { color: var(--c-text-1); }
