/* ─── CRM Contacts Section ────────────────────────────────────────────────── */

.crm-section {
  margin-bottom: 4px;
}

/* Collapsible header */
.crm-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: 2px;
}

.crm-toggle {
  display: flex;
  align-items: center;
  gap: 6px;
  background: none;
  border: none;
  cursor: pointer;
  padding: 4px 0;
  color: inherit;
  flex: 1;
  text-align: left;
}
.crm-toggle:hover .kb-section-label { color: #1a6b3a; }

.crm-toggle-icon {
  font-size: 9px;
  color: #aaa;
  width: 10px;
  display: inline-block;
}

.crm-count {
  font-size: 11px;
  color: #aaa;
  font-weight: 400;
  margin-left: 2px;
}

.crm-add-btn {
  font-size: 11px;
  padding: 2px 10px;
  border: 1px solid #1a6b3a;
  border-radius: 4px;
  background: none;
  color: #1a6b3a;
  cursor: pointer;
  font-weight: 600;
}
.crm-add-btn:hover { background: #1a6b3a; color: #fff; }

/* Body */
.crm-body {
  padding-top: 4px;
}

.crm-loading,
.crm-empty {
  font-size: 12px;
  color: #aaa;
  padding: 4px 0;
}

.crm-form-divider {
  font-size: 11px;
  color: #bbb;
  text-align: center;
  margin: 8px 0;
}

/* Contact rows */
.crm-contact-row {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  padding: 7px 0;
  border-bottom: 1px solid #f0f0f0;
  gap: 8px;
}
.crm-contact-row:last-child { border-bottom: none; }

/* Domain agent row — slightly different bg */
.crm-domain-agent {
  background: #f8fcf9;
  margin: 0 -2px;
  padding: 7px 2px;
  border-radius: 4px;
  border-bottom: 1px solid #e8f0ea;
}

.crm-contact-info { flex: 1; min-width: 0; }

.crm-contact-name {
  font-size: 13px;
  font-weight: 600;
  color: #222;
  display: flex;
  align-items: center;
  gap: 5px;
  flex-wrap: wrap;
}

.crm-contact-meta {
  font-size: 11px;
  color: #666;
  margin-top: 2px;
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
}

.crm-link {
  color: #1a6b3a;
  text-decoration: none;
}
.crm-link:hover { text-decoration: underline; }

.crm-contact-actions {
  display: flex;
  gap: 4px;
  flex-shrink: 0;
  padding-top: 1px;
}

.crm-edit-btn,
.crm-unlink-btn,
.crm-save-domain-btn {
  background: none;
  border: none;
  cursor: pointer;
  font-size: 13px;
  color: #bbb;
  padding: 2px 4px;
  border-radius: 3px;
  line-height: 1;
}
.crm-edit-btn:hover        { color: #333; background: #f0f0f0; }
.crm-unlink-btn:hover      { color: #c0392b; background: #fdf0f0; }
.crm-save-domain-btn:hover { color: #1a6b3a; background: #e8f5ee; }

/* Role badges */
.crm-role-badge {
  font-size: 9px;
  font-weight: 700;
  letter-spacing: 0.05em;
  text-transform: uppercase;
  padding: 2px 5px;
  border-radius: 3px;
  white-space: nowrap;
}
.crm-role-listing_agent { background: #e8f5ee; color: #1a6b3a; }
.crm-role-referrer      { background: #e8f0fa; color: #1a4a8a; }
.crm-role-buyer_agent   { background: #fdf3e8; color: #c4841a; }

/* Domain source badge */
.crm-domain-badge {
  font-size: 9px;
  font-weight: 700;
  letter-spacing: 0.05em;
  text-transform: uppercase;
  padding: 2px 5px;
  border-radius: 3px;
  background: #e8f5ee;
  color: #1ea765;
}

/* Form */
.crm-form-inner {
  background: #f9f9f9;
  border: 1px solid #e8e8e8;
  border-radius: 6px;
  padding: 12px;
  margin-top: 8px;
}

.crm-form-title {
  font-size: 10px;
  font-weight: 700;
  letter-spacing: 0.07em;
  text-transform: uppercase;
  color: #aaa;
  margin-bottom: 10px;
}

.crm-form-row {
  display: flex;
  gap: 8px;
  margin-bottom: 6px;
}
.crm-form-row .kb-field-wrap { flex: 1; }

.crm-form-actions {
  display: flex;
  gap: 8px;
  margin-top: 12px;
  align-items: center;
  flex-wrap: wrap;
}

.crm-save-btn {
  padding: 6px 14px;
  background: #1a6b3a;
  color: #fff;
  border: none;
  border-radius: 5px;
  font-size: 12px;
  font-weight: 600;
  cursor: pointer;
}
.crm-save-btn:hover { background: #155c30; }

.crm-cancel-btn {
  padding: 6px 12px;
  background: none;
  border: 1px solid #ddd;
  border-radius: 5px;
  font-size: 12px;
  color: #666;
  cursor: pointer;
}
.crm-cancel-btn:hover { background: #f0f0f0; }

.crm-delete-btn {
  margin-left: auto;
  padding: 6px 12px;
  background: none;
  border: 1px solid #e8b4b4;
  border-radius: 5px;
  font-size: 12px;
  color: #c0392b;
  cursor: pointer;
}
.crm-delete-btn:hover { background: #fdf0f0; }

/* Existing contact search */
.crm-search-results {
  margin-top: 4px;
  max-height: 130px;
  overflow-y: auto;
  border: 1px solid #e8e8e8;
  border-radius: 4px;
  background: #fff;
}
.crm-search-results:empty { display: none; }

.crm-search-item {
  padding: 6px 10px;
  font-size: 12px;
  cursor: pointer;
  border-bottom: 1px solid #f4f4f4;
}
.crm-search-item:last-child { border-bottom: none; }
.crm-search-item:hover { background: #f0f7f3; }

/* ─── Duplicate warning ──────────────────────────────────────────────────────── */
.crm-duplicate-warning {
  background: #fff8e6;
  border: 1px solid #f0c040;
  border-radius: 5px;
  padding: 8px 10px;
  margin-bottom: 8px;
  font-size: 12px;
}
.crm-dup-title {
  font-weight: 600;
  color: #9a6500;
  margin-bottom: 5px;
}
.crm-dup-item {
  padding: 4px 6px;
  border-radius: 3px;
  cursor: pointer;
  color: #333;
}
.crm-dup-item:hover { background: #fdefc0; }

/* ─── Contact notes panel ────────────────────────────────────────────────────── */
.crm-notes-panel {
  background: #f8f9fa;
  border: 1px solid #e8e8e8;
  border-radius: 5px;
  padding: 10px 12px;
  margin: 4px 0 8px 0;
}
.crm-notes-title {
  font-size: 10px;
  font-weight: 700;
  letter-spacing: 0.07em;
  text-transform: uppercase;
  color: #aaa;
  margin-bottom: 8px;
}
.crm-notes-input-row {
  display: flex;
  gap: 6px;
  margin-bottom: 8px;
}
.crm-notes-input-row .kb-input {
  flex: 1;
  font-size: 12px;
  padding: 5px 8px;
}
.crm-note-add-btn {
  padding: 5px 10px;
  background: #1a6b3a;
  color: #fff;
  border: none;
  border-radius: 4px;
  font-size: 12px;
  cursor: pointer;
  white-space: nowrap;
}
.crm-note-add-btn:hover { background: #155c30; }
.crm-note-entry {
  padding: 5px 0;
  border-bottom: 1px solid #efefef;
  font-size: 12px;
}
.crm-note-entry:last-child { border-bottom: none; }
.crm-note-meta {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-bottom: 2px;
}
.crm-note-date {
  font-size: 10px;
  color: #aaa;
}
.crm-note-prop {
  color: #1a6b3a;
  font-style: normal;
}
.crm-note-delete {
  background: none;
  border: none;
  cursor: pointer;
  font-size: 11px;
  color: #ccc;
  padding: 0 2px;
}
.crm-note-delete:hover { color: #c0392b; }
.crm-note-text { color: #333; line-height: 1.4; }
.crm-notes-btn {
  background: none;
  border: none;
  cursor: pointer;
  font-size: 13px;
  color: #bbb;
  padding: 2px 4px;
  border-radius: 3px;
}
.crm-notes-btn:hover { color: #1a6b3a; background: #e8f5ee; }

/* ─── Organisation typeahead ─────────────────────────────────────────────────── */
.crm-org-create { color: #1a6b3a; font-style: italic; }
.crm-org-results { max-height: 140px; }

/* ─── Role badges — new roles ────────────────────────────────────────────────── */
.crm-role-vendor       { background: #fdf3e8; color: #c4841a; }
.crm-role-purchaser    { background: #e8f0fa; color: #1a4a8a; }
.crm-role-agent        { background: #e8f5ee; color: #1a6b3a; }
.crm-role-buyers_agent { background: #fdf3e8; color: #c4841a; }
.crm-role-referrer     { background: #f0e8fa; color: #6c3483; }
.crm-role-solicitor    { background: #fdf0f0; color: #c0392b; }
