/* ─────────────────────────────────────────────────────────────
   Done4U CRM — Design System
   Black sidebar · White content · Typography-first
   ───────────────────────────────────────────────────────────── */

/* ── Sidebar nav ─────────────────────────────────────────────── */
.nav-item {
  display: flex;
  align-items: center;
  gap: 0.625rem;
  padding: 0.5rem 0.75rem;
  border-radius: 0.5rem;
  font-size: 0.8125rem;
  font-weight: 500;
  color: #71717a;
  transition: color 0.12s, background-color 0.12s;
  text-decoration: none;
  border-left: 2px solid transparent;
  white-space: nowrap;
}
.nav-item:hover {
  color: #ffffff;
  background-color: rgba(255, 255, 255, 0.07);
}
.nav-active {
  color: #ffffff !important;
  background-color: rgba(255, 255, 255, 0.1) !important;
  border-left-color: #ffffff !important;
}

/* ── Buttons ──────────────────────────────────────────────────── */
.btn {
  display: inline-flex;
  align-items: center;
  gap: 0.375rem;
  padding: 0.5rem 1rem;
  font-size: 0.875rem;
  font-weight: 600;
  border-radius: 0.5rem;
  border: none;
  cursor: pointer;
  transition: background-color 0.12s, color 0.12s, box-shadow 0.12s;
  text-decoration: none;
  white-space: nowrap;
}
.btn-primary {
  background-color: #18181b;
  color: #ffffff;
}
.btn-primary:hover {
  background-color: #27272a;
}
.btn-secondary {
  background-color: #ffffff;
  color: #3f3f46;
  border: 1px solid #e4e4e7;
  padding: calc(0.5rem - 1px) calc(1rem - 1px);
}
.btn-secondary:hover {
  background-color: #f4f4f5;
}
.btn-danger {
  background-color: #fef2f2;
  color: #dc2626;
}
.btn-danger:hover {
  background-color: #fee2e2;
}
.btn-sm {
  padding: 0.3rem 0.75rem;
  font-size: 0.8125rem;
}

/* ── Form inputs ──────────────────────────────────────────────── */
.field-input {
  width: 100%;
  padding: 0.5rem 0.75rem;
  background-color: #ffffff;
  border: 1px solid #d4d4d8;
  border-radius: 0.5rem;
  font-size: 0.875rem;
  color: #18181b;
  outline: none;
  transition: border-color 0.12s, box-shadow 0.12s;
}
.field-input::placeholder {
  color: #a1a1aa;
}
.field-input:focus {
  border-color: #18181b;
  box-shadow: 0 0 0 2px rgba(24, 24, 27, 0.08);
}
select.field-input {
  cursor: pointer;
}

/* ── Field label ──────────────────────────────────────────────── */
.field-label {
  display: block;
  font-size: 0.75rem;
  font-weight: 600;
  color: #71717a;
  text-transform: uppercase;
  letter-spacing: 0.06em;
  margin-bottom: 0.375rem;
}

/* ── Cards ────────────────────────────────────────────────────── */
.card {
  background-color: #ffffff;
  border: 1px solid #d4d4d8;
  border-radius: 0.75rem;
  box-shadow: 0 1px 4px rgba(0, 0, 0, 0.06), 0 1px 2px rgba(0, 0, 0, 0.04);
}

/* ── Page headers ─────────────────────────────────────────────── */
.page-eyebrow {
  font-size: 0.6875rem;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.1em;
  color: #a1a1aa;
  margin-bottom: 0.2rem;
}
.page-title {
  font-size: 1.5rem;
  font-weight: 900;
  color: #18181b;
  letter-spacing: -0.025em;
  line-height: 1.15;
}

/* ── Section label ────────────────────────────────────────────── */
.section-label {
  font-size: 0.6875rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  color: #a1a1aa;
  margin-bottom: 1rem;
}

/* ── Data table ───────────────────────────────────────────────── */
.data-table {
  width: 100%;
  border-collapse: collapse;
  font-size: 0.875rem;
}
.data-table thead tr {
  background-color: #f4f4f5;
  border-bottom: 1px solid #d4d4d8;
}
.data-table thead th {
  padding: 0.625rem 1rem;
  font-size: 0.6875rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.07em;
  color: #71717a;
  text-align: left;
}
.data-table tbody td {
  padding: 0.75rem 1rem;
  font-size: 0.875rem;
  color: #3f3f46;
  vertical-align: middle;
}
.data-table tbody tr {
  border-bottom: 1px solid #e4e4e7;
  transition: background-color 0.1s;
}
.data-table tbody tr:last-child {
  border-bottom: none;
}
.data-table tbody tr:hover {
  background-color: #fafafa;
}

/* ── Status + outcome badges ──────────────────────────────────── */
.badge {
  display: inline-flex;
  align-items: center;
  padding: 0.2rem 0.6rem;
  border-radius: 9999px;
  font-size: 0.6875rem;
  font-weight: 600;
  letter-spacing: 0.01em;
}

/* ── KPI stat card ────────────────────────────────────────────── */
.stat-card {
  background: #ffffff;
  border: 1px solid #d4d4d8;
  border-radius: 0.75rem;
  padding: 1.25rem 1.5rem;
  box-shadow: 0 1px 4px rgba(0, 0, 0, 0.06), 0 1px 2px rgba(0, 0, 0, 0.04);
}

/* ── Divider ──────────────────────────────────────────────────── */
.divider {
  border: none;
  border-top: 1px solid #f4f4f5;
  margin: 1.5rem 0;
}

/* ── Scrollbar ────────────────────────────────────────────────── */
::-webkit-scrollbar { width: 5px; height: 5px; }
::-webkit-scrollbar-track { background: transparent; }
::-webkit-scrollbar-thumb { background: #d4d4d8; border-radius: 3px; }
::-webkit-scrollbar-thumb:hover { background: #a1a1aa; }

/* ── HTMX ─────────────────────────────────────────────────────── */
.htmx-indicator { opacity: 0; transition: opacity 200ms ease-in; }
.htmx-request .htmx-indicator { opacity: 1; }
.htmx-request.htmx-indicator  { opacity: 1; }
