/* Phase 2 component starters. Brief v2 §6 component library is larger;
 * this covers what Phase 1 actually renders (Banner, Button, Toast, KPI card,
 * ProgressBar, Skeleton, EmptyState, ErrorBanner). Full library lands in Phase 2.
 */

.btn {
  display: inline-flex; align-items: center; justify-content: center;
  min-height: var(--touch-target);
  padding: 0 var(--space-4);
  background: var(--color-info);
  color: var(--color-neutral-0);
  border: 1px solid var(--color-info);
  border-radius: var(--radius-md);
  font: var(--font-weight-medium) var(--font-size-base)/1 var(--font-family-sans);
  cursor: pointer;
  transition: background var(--motion-fast), border-color var(--motion-fast), transform var(--motion-fast);
}
.btn:hover   { background: #1d4ed8; }
.btn:active  { transform: translateY(1px); }
.btn[disabled] { opacity: 0.55; cursor: not-allowed; }
.btn--ghost {
  background: transparent; color: var(--text-primary);
  border-color: var(--surface-border);
}
.btn--ghost:hover { background: var(--surface-muted); }
.btn--danger {
  background: var(--color-danger); border-color: var(--color-danger);
}
.btn--danger:hover { background: #991b1b; }

.banner {
  display: flex; gap: var(--space-3); align-items: flex-start;
  padding: var(--space-4);
  border: 1px solid transparent;
  border-radius: var(--radius-md);
  margin: var(--space-3) 0;
  font-size: var(--font-size-sm);
  line-height: var(--line-height-body);
}
.banner--info    { background: var(--color-info-bg);    border-color: var(--color-info-border);    color: var(--color-info); }
.banner--success { background: var(--color-success-bg); border-color: var(--color-success-border); color: var(--color-success); }
.banner--warn    { background: var(--color-warn-bg);    border-color: var(--color-warn-border);    color: var(--color-warn); }
.banner--danger  { background: var(--color-danger-bg);  border-color: var(--color-danger-border);  color: var(--color-danger); }
.banner__title   { font-weight: var(--font-weight-semi); margin: 0 0 var(--space-1); }
.banner__body    { margin: 0; color: var(--text-primary); }
.banner__list    { margin: var(--space-2) 0 0 var(--space-4); padding: 0; font-family: var(--font-family-mono); font-size: var(--font-size-xs); }

.toast {
  position: fixed; bottom: var(--space-5); right: var(--space-5);
  padding: var(--space-3) var(--space-4);
  background: var(--color-neutral-90); color: var(--color-neutral-0);
  border-radius: var(--radius-md); box-shadow: var(--shadow-lg);
  font-size: var(--font-size-sm);
  opacity: 0; transform: translateY(8px);
  transition: opacity var(--motion-base), transform var(--motion-base);
}
.toast--visible { opacity: 1; transform: none; }

.kpi {
  background: var(--surface-card);
  border: 1px solid var(--surface-border);
  border-radius: var(--radius-lg);
  padding: var(--space-4);
  box-shadow: var(--shadow-xs);
}
.kpi__label { font-size: var(--font-size-xs); color: var(--text-muted); text-transform: uppercase; letter-spacing: 0.04em; }
.kpi__value { font-size: var(--font-size-xl); font-weight: var(--font-weight-semi); margin-top: var(--space-1); line-height: var(--line-height-tight); }
.kpi__delta { font-size: var(--font-size-sm); margin-top: var(--space-1); }
.kpi__delta--up   { color: var(--color-success); }
.kpi__delta--down { color: var(--color-danger); }

.progress {
  width: 100%; height: 8px;
  background: var(--surface-muted);
  border-radius: var(--radius-pill);
  overflow: hidden;
}
.progress__fill {
  height: 100%; background: var(--color-info);
  transition: width var(--motion-base);
}

.skeleton {
  background: linear-gradient(90deg, var(--surface-muted) 0%, var(--color-neutral-20) 50%, var(--surface-muted) 100%);
  background-size: 200% 100%;
  border-radius: var(--radius-sm);
  animation: skeleton-shimmer 1.2s ease-in-out infinite;
}
@keyframes skeleton-shimmer {
  0%   { background-position: 200% 0; }
  100% { background-position: -200% 0; }
}
@media (prefers-reduced-motion: reduce) {
  .skeleton { animation: none; background: var(--surface-muted); }
}

.empty {
  text-align: center;
  padding: var(--space-7) var(--space-4);
  color: var(--text-secondary);
}
.empty__title { margin: 0 0 var(--space-2); color: var(--text-primary); }

.pill {
  display: inline-flex; align-items: center; gap: var(--space-1);
  padding: 2px var(--space-2);
  border-radius: var(--radius-pill);
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-semi);
  background: var(--surface-muted);
  color: var(--text-primary);
}
.pill--success { background: var(--color-success-bg); color: var(--color-success); }
.pill--warn    { background: var(--color-warn-bg);    color: var(--color-warn); }
.pill--danger  { background: var(--color-danger-bg);  color: var(--color-danger); }
.pill--info    { background: var(--color-info-bg);    color: var(--color-info); }

/* Modal */
.modal-backdrop {
  position: fixed; inset: 0;
  background: rgba(15, 23, 42, 0.45);
  display: flex; align-items: center; justify-content: center;
  padding: var(--space-4);
  z-index: 1000;
}
.modal {
  background: var(--surface-card); color: var(--text-primary);
  border-radius: var(--radius-lg);
  box-shadow: var(--shadow-lg);
  padding: var(--space-5);
  max-width: 520px; width: 100%;
  max-height: calc(100vh - var(--space-8));
  overflow-y: auto;
}
.modal__title   { margin: 0 0 var(--space-3); font-size: var(--font-size-md); }
.modal__body    { margin-bottom: var(--space-4); }
.modal__actions { display: flex; gap: var(--space-2); justify-content: flex-end; }

/* Toast root */
#toast-root {
  position: fixed; bottom: var(--space-5); right: var(--space-5);
  display: flex; flex-direction: column; gap: var(--space-2);
  z-index: 1100; pointer-events: none;
}
#toast-root .toast { pointer-events: auto; position: static; }
.toast--success { background: var(--color-success); }
.toast--warn    { background: var(--color-warn); }
.toast--danger  { background: var(--color-danger); }

/* Debt-domino */
.domino {
  list-style: none; margin: 0; padding: 0;
  display: flex; flex-direction: column; gap: var(--space-3);
}
.domino__item {
  display: grid; grid-template-columns: minmax(120px, 30%) 1fr; gap: var(--space-3);
  align-items: center;
}
.domino__label {
  font-size: var(--font-size-sm); color: var(--text-secondary);
  overflow: hidden; text-overflow: ellipsis; white-space: nowrap;
}
.progress--domino .progress__fill { background: var(--color-success); }

/* DataTable */
.datatable {
  width: 100%; border-collapse: collapse;
  font-size: var(--font-size-sm);
}
.datatable th, .datatable td {
  padding: var(--space-2) var(--space-3);
  border-bottom: 1px solid var(--surface-border);
  text-align: left; vertical-align: middle;
}
.datatable th {
  background: var(--surface-muted);
  color: var(--text-secondary);
  font-weight: var(--font-weight-semi);
  font-size: var(--font-size-xs);
  text-transform: uppercase; letter-spacing: 0.04em;
}
.datatable__cell--editable { cursor: text; }
.datatable__cell--editable:hover { background: var(--surface-muted); }
.datatable__cell--editing { padding: 0; }
.datatable__cell--error { background: var(--color-danger-bg); color: var(--color-danger); }
.datatable__input {
  width: 100%; height: 100%;
  padding: var(--space-2) var(--space-3);
  font: inherit; color: inherit;
  background: var(--surface-card);
  border: 2px solid var(--color-info);
  border-radius: var(--radius-sm);
  box-sizing: border-box;
}
