/* public/css/dashboard.css */

/* Widget card */
.dashboard-widget {
  background: var(--color-bg-card);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-lg);
  overflow: hidden;
}

.dashboard-widget__header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: var(--spacing-md) var(--spacing-lg);
  border-bottom: 1px solid var(--color-border);
  background: var(--color-bg-subtle);
}

.dashboard-widget__title {
  font-size: var(--font-size-lg);
  font-weight: 600;
  margin: 0;
}

.dashboard-widget__badge {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 24px;
  height: 24px;
  padding: 0 var(--spacing-sm);
  border-radius: var(--radius-full);
  font-size: var(--font-size-xs);
  font-weight: 700;
  color: white;
  background: var(--color-text-muted);
}

.dashboard-widget__badge--warning {
  background: var(--color-warning);
}

.dashboard-widget__badge--error {
  background: var(--color-error);
}

.dashboard-widget__badge--info {
  background: var(--color-info);
}

.dashboard-widget__body {
  padding: 0;
}

.dashboard-widget__empty {
  padding: var(--spacing-lg);
  font-size: var(--font-size-sm);
}

/* Widget items (rows) */
.dashboard-item {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: var(--spacing-sm) var(--spacing-lg);
  border-bottom: 1px solid var(--color-border);
  gap: var(--spacing-sm);
  transition: background var(--transition-fast);
  cursor: pointer;
  text-decoration: none;
  color: inherit;
}

.dashboard-item:last-child {
  border-bottom: none;
}

.dashboard-item:hover {
  background: var(--color-bg-subtle);
  text-decoration: none;
}

.dashboard-item__main {
  flex: 1;
  min-width: 0;
}

.dashboard-item__title {
  font-weight: 500;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.dashboard-item__meta {
  font-size: var(--font-size-xs);
  color: var(--color-text-secondary);
  margin-top: 2px;
}

.dashboard-item__right {
  flex-shrink: 0;
  text-align: right;
}

.dashboard-item__amount {
  font-weight: 600;
  font-size: var(--font-size-sm);
}

.dashboard-item__date {
  font-size: var(--font-size-xs);
  color: var(--color-text-secondary);
}

/* Urgency colors */
.dashboard-item--overdue {
  border-left: 3px solid var(--color-error);
}

.dashboard-item--soon,
.dashboard-item--warning {
  border-left: 3px solid var(--color-warning);
}

.dashboard-item--critical {
  border-left: 3px solid var(--color-error);
}

/* Appointment type indicators */
.dashboard-item__type {
  display: inline-block;
  width: 8px;
  height: 8px;
  border-radius: var(--radius-full);
  margin-right: var(--spacing-sm);
  flex-shrink: 0;
}

.dashboard-item__type--ceremony {
  background: var(--color-primary);
}

.dashboard-item__type--meeting {
  background: var(--color-info);
}

.dashboard-item__type--scheduleMeeting {
  background: var(--color-success);
}

.dashboard-item__type--blocker {
  background: var(--color-text-muted);
}

/* Action tag (next steps) */
.dashboard-item__action {
  display: inline-block;
  font-size: var(--font-size-xs);
  font-weight: 500;
  padding: 2px var(--spacing-sm);
  border-radius: var(--radius-sm);
  background: var(--color-primary-light);
  color: var(--color-primary-dark);
  white-space: nowrap;
}

/* Days badge */
.dashboard-item__days {
  font-size: var(--font-size-xs);
  font-weight: 600;
  padding: 2px var(--spacing-sm);
  border-radius: var(--radius-sm);
  white-space: nowrap;
}

.dashboard-item__days--normal {
  background: var(--color-bg-subtle);
  color: var(--color-text-secondary);
}

.dashboard-item__days--warning {
  background: var(--color-warning-light);
  color: var(--color-warning);
}

.dashboard-item__days--critical {
  background: var(--color-error-light);
  color: var(--color-error);
}
