/* ═══════════════════════════════════════════
   STAGE PILLS (used everywhere)
═══════════════════════════════════════════ */
.stage-pill {
  font-size: 10px; font-weight: 600;
  padding: 2px 7px; border-radius: 20px;
  letter-spacing: 0.04em; text-transform: uppercase; white-space: nowrap;
  display: inline-block;
}
.sp-new       { background: #f1f5f9; color: #64748b; }
.sp-visit     { background: #eff6ff; color: #2563eb; }
.sp-estimate  { background: #e0f2fe; color: #0284c7; }
.sp-sold      { background: #f0fdf4; color: #16a34a; }
.sp-preprod   { background: #fffbeb; color: #b45309; }
.sp-scheduled { background: #fff7ed; color: #c2410c; }
.sp-inprog    { background: var(--brass-pill); color: var(--brass-lo); }
.sp-punch     { background: #fefce8; color: #854d0e; }
.sp-complete  { background: #f0fdf4; color: #15803d; }
.sp-lost      { background: #fef2f2; color: #dc2626; }
.sp-cancelled { background: #f8fafc; color: #94a3b8; }

/* Contact type pills */
.ctp-lead     { background: #eff6ff; color: #2563eb; font-size: 10px; font-weight: 600; padding: 2px 8px; border-radius: 20px; text-transform: uppercase; letter-spacing: 0.05em; display: inline-block; }
.ctp-customer { background: #f0fdf4; color: #16a34a; font-size: 10px; font-weight: 600; padding: 2px 8px; border-radius: 20px; text-transform: uppercase; letter-spacing: 0.05em; display: inline-block; }

/* Status pills for contacts */
.csp-new       { background: #f1f5f9; color: #475569; font-size: 10px; font-weight: 600; padding: 2px 7px; border-radius: 20px; letter-spacing: 0.04em; display: inline-block; }
.csp-contacted { background: #eff6ff; color: #2563eb; font-size: 10px; font-weight: 600; padding: 2px 7px; border-radius: 20px; letter-spacing: 0.04em; display: inline-block; }
.csp-converted { background: #f0fdf4; color: #16a34a; font-size: 10px; font-weight: 600; padding: 2px 7px; border-radius: 20px; letter-spacing: 0.04em; display: inline-block; }
.csp-lost      { background: #fef2f2; color: #dc2626; font-size: 10px; font-weight: 600; padding: 2px 7px; border-radius: 20px; letter-spacing: 0.04em; display: inline-block; }

/* Service tags */
.stag {
  font-family: var(--font-mono); font-size: 9.5px;
  padding: 1px 6px; border-radius: 4px;
  background: var(--surface-hi); border: 1px solid var(--border);
  color: var(--text-2); text-transform: uppercase; letter-spacing: 0.06em;
  display: inline-block;
}

/* ═══════════════════════════════════════════
   PANELS / CARDS
═══════════════════════════════════════════ */
.panel {
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: var(--r-lg); padding: 18px;
}
.panel-title { font-family: var(--font-display); font-size: 15px; font-weight: 600; color: var(--text-1); margin-bottom: 14px; }

.detail-card {
  background: var(--surface); border: 1px solid var(--border);
  border-radius: var(--r-lg); padding: 20px; margin-bottom: 14px;
}
.detail-card-title {
  font-family: var(--font-mono); font-size: 10px;
  text-transform: uppercase; letter-spacing: 0.14em;
  color: var(--text-3); margin-bottom: 14px;
}

/* ═══════════════════════════════════════════
   DETAIL FIELD GRID
═══════════════════════════════════════════ */
.detail-field-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 10px 20px; }
.detail-field label { display: block; font-size: 11px; color: var(--text-3); margin-bottom: 3px; }
.detail-field .val { font-size: 13.5px; color: var(--text-1); font-weight: 500; }
.detail-field .val.mono { font-family: var(--font-mono); font-size: 12px; }

/* ═══════════════════════════════════════════
   BADGES (legacy / compat)
═══════════════════════════════════════════ */
.badge {
  font-size: 10px; font-weight: 600; padding: 2px 7px; border-radius: 20px;
  letter-spacing: 0.04em; display: inline-block;
}
.badge-new     { background: #f1f5f9; color: #64748b; }
.badge-warning { background: #fffbeb; color: #b45309; }
.badge-active  { background: #f0fdf4; color: #16a34a; }
.badge-lost    { background: #fef2f2; color: #dc2626; }
.badge-neutral { background: #f8fafc; color: #94a3b8; }
.badge-brass   { background: var(--brass-pill); color: var(--brass-lo); }

/* ═══════════════════════════════════════════
   FORMS
═══════════════════════════════════════════ */
.form-group { margin-bottom: 16px; }
.form-group label {
  display: block; font-size: 12px; font-weight: 500;
  color: var(--text-2); margin-bottom: 5px; letter-spacing: 0.01em;
}
.form-control {
  width: 100%; padding: 8px 12px;
  border: 1px solid var(--border); border-radius: var(--r-sm);
  font-size: 13.5px; color: var(--text-1);
  background: var(--surface); outline: none;
  transition: border-color 0.15s;
  appearance: none;
}
select.form-control {
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='11' height='11' viewBox='0 0 24 24' fill='none' stroke='%239aabb8' stroke-width='2.5' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='6 9 12 15 18 9'/%3E%3C/svg%3E");
  background-repeat: no-repeat;
  background-position: right 10px center;
  padding-right: 30px;
}
.form-control:focus { border-color: var(--brass); box-shadow: 0 0 0 3px var(--brass-soft); }
textarea.form-control { min-height: 80px; resize: vertical; }

.form-row { display: grid; grid-template-columns: 1fr 1fr; gap: 16px; }
.form-actions { display: flex; gap: 10px; padding-top: 20px; margin-top: 8px; border-top: 1px solid var(--border-lo); }

/* ═══════════════════════════════════════════
   TABLES
═══════════════════════════════════════════ */
.table-wrap { border: 1px solid var(--border); border-radius: var(--r-md); overflow: hidden; }
table { width: 100%; border-collapse: collapse; }
th { font-family: var(--font-mono); font-size: 10px; text-transform: uppercase; letter-spacing: 0.1em; color: var(--text-3); padding: 10px 14px; text-align: left; background: var(--surface-hi); border-bottom: 1px solid var(--border); }
td { padding: 11px 14px; font-size: 13px; border-bottom: 1px solid var(--border-lo); vertical-align: middle; }
tr:last-child td { border-bottom: none; }
tr:hover td { background: var(--surface-hi); }
td a { color: var(--brass); }
td a:hover { color: var(--brass-lo); }

/* ═══════════════════════════════════════════
   SECTION HEADERS
═══════════════════════════════════════════ */
.sec-hd { display: flex; align-items: center; justify-content: space-between; margin-bottom: 14px; }
.sec-title { font-family: var(--font-display); font-size: 17px; font-weight: 600; color: var(--text-1); }
.sec-link { font-size: 12px; font-weight: 500; color: var(--brass); cursor: pointer; }
.sec-link:hover { color: var(--brass-lo); }

/* ═══════════════════════════════════════════
   FILTER TABS (pill style)
═══════════════════════════════════════════ */
.filter-tabs { display: flex; gap: 5px; flex-wrap: wrap; margin-bottom: 14px; }
.ftab {
  display: flex; align-items: center; gap: 5px;
  padding: 5px 11px; border-radius: 20px;
  border: 1px solid var(--border);
  background: var(--surface);
  font-size: 12px; font-weight: 500; color: var(--text-2);
  cursor: pointer; transition: all 0.12s;
}
.ftab:hover { border-color: var(--text-3); color: var(--text-1); }
.ftab.active { background: var(--text-1); border-color: var(--text-1); color: #fff; }
.ftab-dot { width: 6px; height: 6px; border-radius: 50%; }
.ftab-n { font-family: var(--font-mono); font-size: 10px; opacity: 0.6; }

/* ═══════════════════════════════════════════
   TABS
═══════════════════════════════════════════ */
.tab-bar { display: flex; border-bottom: 1px solid var(--border); margin-bottom: 22px; }
.tab-btn {
  padding: 10px 18px; font-size: 13px; font-weight: 500;
  color: var(--text-2); border: none; background: none;
  cursor: pointer; border-bottom: 2px solid transparent;
  transition: color 0.12s, border-color 0.12s; margin-bottom: -1px;
}
.tab-btn:hover { color: var(--text-1); }
.tab-btn.active { color: var(--brass); border-bottom-color: var(--brass); }
.tab-panel { display: none; }
.tab-panel.active { display: block; }

/* ═══════════════════════════════════════════
   INLINE PAYMENT / NOTE ITEMS
═══════════════════════════════════════════ */
.payment-item {
  display: flex; justify-content: space-between; align-items: center;
  padding: 9px 11px; background: var(--surface-hi);
  border-radius: 6px; border: 1px solid var(--border-lo);
}
.payment-type  { font-size: 12px; font-weight: 600; color: var(--text-1); }
.payment-ref   { font-family: var(--font-mono); font-size: 10px; color: var(--text-3); }
.payment-amount { font-family: var(--font-display); font-size: 15px; font-weight: 600; color: var(--text-1); }

/* ═══════════════════════════════════════════
   EMPTY STATES
═══════════════════════════════════════════ */
.empty { display: flex; flex-direction: column; align-items: center; padding: 48px 24px; color: var(--text-3); gap: 8px; }
.empty svg { width: 32px; height: 32px; opacity: 0.3; }
.empty p { font-size: 13px; }

.empty-state { display: flex; flex-direction: column; align-items: center; justify-content: center; padding: 48px 24px; gap: 10px; }
.empty-state-title { font-family: var(--font-display); font-size: 16px; font-weight: 600; color: var(--text-2); }
.empty-state-text  { font-size: 13px; color: var(--text-3); }
.empty-state-text a { color: var(--brass); }

/* ═══════════════════════════════════════════
   DETAIL LAYOUT GRIDS
═══════════════════════════════════════════ */
.job-detail-grid { display: grid; grid-template-columns: 1fr 300px; gap: 20px; align-items: start; }
.dash-grid       { display: grid; grid-template-columns: 1fr 308px; gap: 20px; align-items: start; }
.side-stack      { display: flex; flex-direction: column; gap: 16px; }
.cd-avatar { width: 56px; height: 56px; border-radius: 50%; display: flex; align-items: center; justify-content: center; font-weight: 700; font-size: 19px; flex-shrink: 0; }
.cd-name  { font-family: var(--font-display); font-size: 22px; font-weight: 700; color: var(--text-1); }
.cd-sub   { font-size: 12.5px; color: var(--text-2); margin-top: 3px; }
.cd-grid  { display: grid; grid-template-columns: 1fr 300px; gap: 20px; align-items: start; }
.two-col         { display: grid; grid-template-columns: 1fr 1fr; gap: 20px; align-items: start; }
.prop-detail-grid { display: grid; grid-template-columns: 1fr 280px; gap: 20px; align-items: start; }
.sidebar-layout { display: grid; grid-template-columns: 1fr 280px; gap: 22px; align-items: start; }

/* ═══════════════════════════════════════════
   OLD CARD COMPAT
═══════════════════════════════════════════ */
.card {
  background: var(--surface); border: 1px solid var(--border);
  border-radius: var(--r-lg);
}
.card-header { padding: 14px 18px; border-bottom: 1px solid var(--border-lo); }
.card-title  { font-family: var(--font-display); font-size: 15px; font-weight: 600; color: var(--text-1); }
.card-body   { padding: 16px 18px; }
.card.card-body { padding: 16px 18px; }

.section-header { display: flex; align-items: center; justify-content: space-between; margin-bottom: 14px; }
.section-title  { font-family: var(--font-display); font-size: 16px; font-weight: 600; color: var(--text-1); }

.detail-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 12px 20px; }
.detail-item {}
.detail-label { font-size: 11px; color: var(--text-3); font-family: var(--font-mono); text-transform: uppercase; letter-spacing: 0.1em; margin-bottom: 3px; }
.detail-value { font-size: 13.5px; color: var(--text-1); font-weight: 500; }
.detail-value a { color: var(--brass); }
.detail-value a:hover { color: var(--brass-lo); }

/* ═══════════════════════════════════════════
   MISC UTILITIES
═══════════════════════════════════════════ */
.mono { font-family: var(--font-mono); }
.divider { height: 1px; background: var(--border-lo); margin: 16px 0; }
.text-3 { color: var(--text-3); }
.text-2 { color: var(--text-2); }

.filter-bar { display: flex; gap: 10px; flex-wrap: wrap; margin-bottom: 18px; align-items: center; }
.actions { display: flex; gap: 8px; align-items: center; }
.page-header { display: flex; align-items: center; justify-content: space-between; margin-bottom: 22px; }
.page-title  { font-family: var(--font-display); font-size: 24px; font-weight: 700; color: var(--text-1); }
.page-subtitle { font-size: 13px; color: var(--text-2); margin-top: 3px; }

/* ═══════════════════════════════════════════
   PHOTO & DOC GRID
═══════════════════════════════════════════ */
.photo-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(110px, 1fr)); gap: 8px; }
.photo-thumb {
  border-radius: var(--r-sm); aspect-ratio: 1; background: var(--surface-hi);
  border: 1px solid var(--border); display: flex; flex-direction: column;
  align-items: center; justify-content: center; gap: 6px;
  cursor: pointer; transition: border-color 0.12s; overflow: hidden;
}
.photo-thumb:hover { border-color: var(--brass); }
.photo-thumb svg { width: 22px; height: 22px; color: var(--text-3); }
.photo-label { font-family: var(--font-mono); font-size: 8px; text-transform: uppercase; letter-spacing: 0.1em; color: var(--text-3); }

.doc-row {
  display: flex; gap: 10px; align-items: center; padding: 9px 12px;
  background: var(--surface-hi); border-radius: var(--r-sm);
  border: 1px solid var(--border-lo); margin-bottom: 7px;
  cursor: pointer; transition: border-color 0.12s;
}
.doc-row:hover { border-color: var(--brass); }
.doc-icon {
  width: 28px; height: 28px; border-radius: var(--r-sm);
  background: var(--border-lo); display: flex; align-items: center; justify-content: center; flex-shrink: 0;
}
.doc-icon svg { width: 14px; height: 14px; color: var(--text-2); }
.doc-name { font-size: 12.5px; font-weight: 500; color: var(--text-1); }
.doc-meta { font-family: var(--font-mono); font-size: 10px; color: var(--text-3); margin-top: 2px; }
