/* ================================================================
   Macondo display — Badge, Tag, Status, Indicator, Avatar
   ================================================================ */

/* ---------- Badge ---------- */
.sp-badge {
  display: inline-flex;
  width: fit-content;
  flex-shrink: 0;
  align-items: center;
  justify-content: center;
  gap: var(--space-100);
  height: var(--space-900);
  padding: var(--space-200) var(--space-300);
  box-sizing: border-box;
  border: 1px solid;
  border-radius: var(--border-radius-full);
  font-family: var(--font-sans);
  font-size: var(--caption-font-size);
  line-height: var(--caption-line-height);
  font-weight: var(--font-weight-medium);
  white-space: nowrap;
}
.sp-badge--sm { height: var(--space-600); padding: var(--space-100) var(--space-200); }

.sp-badge--success { border-color: var(--success-border); background: var(--success-surface); color: var(--success-text); }
.sp-badge--critical { border-color: var(--critical-border); background: var(--critical-surface); color: var(--critical-text); }
.sp-badge--info { border-color: var(--info-border); background: var(--info-surface); color: var(--info-text); }
.sp-badge--warning { border-color: var(--warning-border); background: var(--warning-surface); color: var(--warning-text); }
.sp-badge--default1 { border-color: var(--brand-ash-border); background: var(--brand-ash-surface); color: var(--brand-ash-text); }
.sp-badge--default2 { border-color: var(--border-secondary); background: var(--surface-primary); color: var(--typography-primary); }
.sp-badge--progress { border-color: var(--brand-turquoise-border); background: var(--brand-turquoise-surface); color: var(--brand-turquoise-text); }
.sp-badge--attention { border-color: var(--brand-orange-border); background: var(--brand-orange-surface); color: var(--brand-orange-text); }

/* Badge with leading indicator dot keeps primary text */
.sp-badge--indicator { color: var(--typography-primary); gap: var(--space-200); }

/* ---------- Indicator dot ---------- */
.sp-indicator { display: inline-block; width: var(--space-150); height: var(--space-150); flex-shrink: 0; border-radius: var(--border-radius-full); }
.sp-indicator--success { background: var(--success-text); }
.sp-indicator--critical { background: var(--critical-text); }
.sp-indicator--info { background: var(--info-text); }
.sp-indicator--warning { background: var(--warning-text); }
.sp-indicator--default1 { background: var(--brand-ash-text); }
.sp-indicator--default2 { background: var(--typography-primary); }
.sp-indicator--progress { background: var(--brand-turquoise-text); }
.sp-indicator--attention { background: var(--brand-orange-text); }
/* Tones (Status) — solid 500-step hues */
.sp-indicator--turquoise { background: var(--turquoise-500); }
.sp-indicator--ash { background: var(--ash-500); }
.sp-indicator--violet { background: var(--violet-500); }
.sp-indicator--pink { background: var(--pink-500); }
.sp-indicator--orange { background: var(--orange-500); }
.sp-indicator--bronze { background: var(--bronze-500); }
.sp-indicator--yellow { background: var(--yellow-500); }
.sp-indicator--red { background: var(--red-500); }
.sp-indicator--green { background: var(--green-500); }
.sp-indicator--blue { background: var(--blue-500); }

/* ---------- Status (dot in tinted halo + label) ---------- */
.sp-status { display: inline-flex; width: fit-content; align-items: center; gap: var(--space-200); color: var(--typography-primary); font-size: var(--callout-font-size); line-height: var(--callout-line-height); }
.sp-status--sm { font-size: var(--caption-font-size); line-height: var(--caption-line-height); }
.sp-status__halo { display: flex; align-items: center; justify-content: center; flex-shrink: 0; padding: var(--space-050); border-radius: var(--border-radius-full); }
.sp-status--sm .sp-status__halo { background: transparent !important; }
.sp-status__halo--turquoise { background: var(--brand-turquoise-surface); }
.sp-status__halo--ash { background: var(--brand-ash-surface); }
.sp-status__halo--violet { background: var(--brand-violet-surface); }
.sp-status__halo--pink { background: var(--brand-pink-surface); }
.sp-status__halo--orange { background: var(--brand-orange-surface); }
.sp-status__halo--bronze { background: var(--brand-bronze-surface); }
.sp-status__halo--yellow { background: var(--brand-yellow-surface); }
.sp-status__halo--red { background: var(--brand-red-surface); }
.sp-status__halo--green { background: var(--success-surface); }
.sp-status__halo--blue { background: var(--brand-blue-surface); }

/* ---------- Tag ---------- */
.sp-tag {
  display: inline-flex;
  align-items: center;
  gap: var(--space-100);
  height: var(--space-800);
  padding: var(--space-100) var(--space-200) var(--space-100) var(--space-300);
  box-sizing: border-box;
  border: 1px solid var(--border-secondary);
  border-radius: var(--border-radius-200);
  background: var(--surface-secondary);
  color: var(--typography-primary);
  font-family: var(--font-sans);
  font-size: var(--caption-font-size);
  line-height: var(--caption-line-height);
  font-weight: var(--font-weight-medium);
  white-space: nowrap;
}
.sp-tag__label { max-width: var(--space-3200); overflow: hidden; text-overflow: ellipsis; }
.sp-tag--disabled { opacity: 0.5; pointer-events: none; }

/* ---------- Avatar ---------- */
.sp-avatar {
  position: relative;
  display: inline-flex;
  width: var(--space-800);
  height: var(--space-800);
  flex-shrink: 0;
  border-radius: var(--border-radius-full);
  user-select: none;
}
.sp-avatar img { width: 100%; height: 100%; border-radius: var(--border-radius-full); object-fit: cover; }
.sp-avatar__fallback {
  display: flex;
  width: 100%;
  height: 100%;
  align-items: center;
  justify-content: center;
  border-radius: var(--border-radius-full);
  background: var(--surface-hover);
  color: var(--typography-tertiary);
  font-size: var(--caption-font-size);
  font-weight: var(--font-weight-medium);
}
.sp-avatar--lg { width: var(--space-1000); height: var(--space-1000); }
.sp-avatar--lg .sp-avatar__fallback { font-size: var(--callout-font-size); }
.sp-avatar__badge {
  position: absolute;
  right: 0;
  bottom: 0;
  z-index: 1;
  width: var(--space-200);
  height: var(--space-200);
  border-radius: var(--border-radius-full);
  background: var(--success-fill);
  box-shadow: 0 0 0 1px var(--surface-primary);
}
