/* ============================================================
   CCW Portal — Empty States
   ============================================================ */

/* ── Base Empty State ─────────────────────────────────────── */
.ccw-empty {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  text-align: center;
  padding: var(--space-16) var(--space-8);
  gap: var(--space-4);
}

.ccw-empty--sm {
  padding: var(--space-10) var(--space-6);
}

.ccw-empty--compact {
  padding: var(--space-8) var(--space-4);
  gap: var(--space-2);
}

/* ── Illustration / Icon ──────────────────────────────────── */
.ccw-empty__icon {
  width: 72px;
  height: 72px;
  display: flex;
  align-items: center;
  justify-content: center;
  border-radius: var(--radius-2xl);
  background-color: var(--color-bg-tertiary);
  color: var(--color-text-tertiary);
  margin-bottom: var(--space-2);
}

.ccw-empty--sm .ccw-empty__icon {
  width: 48px;
  height: 48px;
  border-radius: var(--radius-xl);
}

.ccw-empty__icon svg {
  width: 36px;
  height: 36px;
}

.ccw-empty--sm .ccw-empty__icon svg {
  width: 24px;
  height: 24px;
}

/* ── Text ─────────────────────────────────────────────────── */
.ccw-empty__title {
  font-size: var(--text-lg);
  font-weight: var(--font-weight-semibold);
  color: var(--color-text-primary);
  margin-bottom: var(--space-1);
}

.ccw-empty--sm .ccw-empty__title {
  font-size: var(--text-base);
}

.ccw-empty--compact .ccw-empty__title {
  font-size: var(--text-sm);
}

.ccw-empty__desc {
  font-size: var(--text-sm);
  color: var(--color-text-secondary);
  line-height: var(--line-height-relaxed);
  max-width: 380px;
}

.ccw-empty--compact .ccw-empty__desc {
  font-size: var(--text-xs);
}

/* ── Actions ──────────────────────────────────────────────── */
.ccw-empty__actions {
  display: flex;
  align-items: center;
  gap: var(--space-3);
  margin-top: var(--space-2);
  flex-wrap: wrap;
  justify-content: center;
}

/* ── Contextual variants ──────────────────────────────────── */
.ccw-empty--filtered .ccw-empty__icon {
  background-color: var(--color-info-bg);
  color: var(--color-info);
}

.ccw-empty--error .ccw-empty__icon {
  background-color: var(--color-error-bg);
  color: var(--color-error);
}

.ccw-empty--success .ccw-empty__icon {
  background-color: var(--color-success-bg);
  color: var(--color-success);
}

/* ── Table empty state (inside table body) ────────────────── */
.ccw-table-empty {
  text-align: center;
  padding: var(--space-10) var(--space-4);
}

.ccw-table-empty td {
  color: var(--color-text-tertiary);
  font-size: var(--text-sm);
}

/* ── Inline empty (small, in-context) ────────────────────── */
.ccw-inline-empty {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: var(--space-2);
  padding: var(--space-4);
  color: var(--color-text-tertiary);
  font-size: var(--text-sm);
  font-style: italic;
}
