/* ==========================================================================
   HAVN Buyer Manager — v2.2.49
   Inherits the Mission Control design tokens (--mc-*). Loaded after
   havn-mission-control.css so it can lean on the same surfaces/borders.
   ========================================================================== */

/* ---- board + grid ---- */
.havn-buyer-board { padding: 0; }

.havn-buyer-grid {
	display: grid;
	grid-template-columns: repeat(auto-fill, minmax(320px, 1fr));
	gap: 16px;
}

/* ---- card ---- */
.havn-buyer-card {
	display: flex;
	flex-direction: column;
	gap: 12px;
	background: var(--mc-bg-3);
	border: 1px solid var(--mc-border);
	border-radius: var(--mc-radius);
	padding: 16px;
	transition: border-color .15s ease, transform .15s ease;
}
.havn-buyer-card:hover { border-color: var(--mc-border-2); transform: translateY(-1px); }
.havn-buyer-card[data-urgency="hot"]      { border-left: 3px solid #E0857B; }
.havn-buyer-card[data-urgency="warm"]     { border-left: 3px solid var(--mc-warn); }
.havn-buyer-card[data-urgency="watching"] { border-left: 3px solid var(--mc-info); }

.havn-buyer-card-top { display: flex; align-items: flex-start; justify-content: space-between; gap: 10px; }
.havn-buyer-ident { display: flex; align-items: center; gap: 11px; min-width: 0; }
.havn-buyer-avatar {
	flex: 0 0 auto;
	width: 40px; height: 40px;
	display: grid; place-items: center;
	border-radius: 50%;
	background: var(--mc-accent-soft);
	color: var(--mc-accent);
	font-weight: 700; font-size: 14px;
	letter-spacing: .02em;
}
.havn-buyer-id-text { min-width: 0; }
.havn-buyer-name { font-weight: 600; font-size: 15px; color: var(--mc-text); white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.havn-buyer-contact { font-size: 12px; color: var(--mc-text-3); white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }

.havn-buyer-urgency {
	flex: 0 0 auto;
	font-size: 11px; font-weight: 600;
	padding: 3px 9px; border-radius: 999px;
	text-transform: uppercase; letter-spacing: .04em;
}
.havn-buyer-urgency-hot      { background: color-mix(in srgb, #E0857B, transparent 82%); color: #E0857B; }
.havn-buyer-urgency-warm     { background: color-mix(in srgb, var(--mc-warn), transparent 82%); color: var(--mc-warn); }
.havn-buyer-urgency-watching { background: color-mix(in srgb, var(--mc-info), transparent 82%); color: var(--mc-info); }

/* ---- meta rows ---- */
.havn-buyer-meta { display: flex; flex-direction: column; gap: 6px; }
.havn-buyer-meta-row { display: flex; gap: 10px; font-size: 13px; align-items: baseline; }
.havn-buyer-lbl { flex: 0 0 64px; color: var(--mc-text-3); font-size: 12px; }
.havn-buyer-val { color: var(--mc-text-2); min-width: 0; }
.havn-buyer-warn { color: #E0857B; font-style: normal; font-size: 12px; }
.havn-buyer-dim  { color: var(--mc-text-3); font-style: normal; font-size: 12px; }

.havn-buyer-tags { display: flex; flex-wrap: wrap; gap: 6px; }
.havn-buyer-tag {
	font-size: 11px; color: var(--mc-text-2);
	background: var(--mc-surface); border: 1px solid var(--mc-border);
	padding: 2px 8px; border-radius: 999px;
}

/* ---- match bar + matches ---- */
.havn-buyer-matchbar {
	display: flex; align-items: center; gap: 8px;
	width: 100%;
	background: var(--mc-surface);
	border: 1px solid var(--mc-border);
	border-radius: 10px;
	padding: 9px 12px;
	color: var(--mc-text-2);
	font: inherit; font-size: 13px; font-weight: 500;
	cursor: pointer;
	transition: background .15s ease, border-color .15s ease;
}
.havn-buyer-matchbar.has-matches { color: var(--mc-text); border-color: color-mix(in srgb, var(--mc-success), transparent 65%); }
.havn-buyer-matchbar:hover { background: var(--mc-surface-2); }
.havn-buyer-matchbar-dot { width: 7px; height: 7px; border-radius: 50%; background: var(--mc-text-3); flex: 0 0 auto; }
.havn-buyer-matchbar.has-matches .havn-buyer-matchbar-dot { background: var(--mc-success); box-shadow: 0 0 0 3px color-mix(in srgb, var(--mc-success), transparent 80%); }
.havn-buyer-matchbar-text { flex: 1 1 auto; text-align: left; }
.havn-buyer-matchbar-chev { transition: transform .15s ease; font-size: 18px; line-height: 1; color: var(--mc-text-3); }
.havn-buyer-matchbar.is-open .havn-buyer-matchbar-chev { transform: rotate(90deg); }

.havn-buyer-matches { display: flex; flex-direction: column; gap: 6px; }
.havn-buyer-match {
	display: flex; align-items: center; justify-content: space-between; gap: 10px;
	padding: 9px 11px;
	background: var(--mc-surface);
	border: 1px solid var(--mc-border);
	border-radius: 9px;
}
.havn-buyer-match-info { min-width: 0; display: flex; flex-direction: column; gap: 2px; }
.havn-buyer-match-info strong { font-size: 13px; font-weight: 600; color: var(--mc-text); white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.havn-buyer-match-info span { font-size: 12px; color: var(--mc-text-3); }
.havn-buyer-match-right { display: flex; align-items: center; gap: 8px; flex: 0 0 auto; }
.havn-buyer-score {
	font-size: 12px; font-weight: 700; color: var(--mc-success);
	background: color-mix(in srgb, var(--mc-success), transparent 85%);
	padding: 2px 7px; border-radius: 6px;
}
.havn-buyer-link {
	font-size: 12px; color: var(--mc-text-2); text-decoration: none;
	border: 1px solid var(--mc-border); border-radius: 7px; padding: 3px 9px;
}
.havn-buyer-link:hover { color: var(--mc-text); border-color: var(--mc-border-2); }
.havn-buyer-book {
	font: inherit; font-size: 12px; font-weight: 600;
	color: var(--mc-accent); background: var(--mc-accent-soft);
	border: 1px solid color-mix(in srgb, var(--mc-accent), transparent 70%);
	border-radius: 7px; padding: 3px 9px; cursor: pointer; white-space: nowrap;
}
.havn-buyer-book:hover { background: color-mix(in srgb, var(--mc-accent), transparent 78%); }
.havn-buyer-nomatch, .havn-buyer-nofilter { font-size: 13px; color: var(--mc-text-3); padding: 8px 2px; }
.havn-buyer-nofilter { text-align: center; padding: 28px 0; }

/* ---- card actions ---- */
.havn-buyer-actions { display: flex; gap: 8px; margin-top: 2px; }
.havn-buyer-act {
	flex: 1 1 auto;
	font: inherit; font-size: 12.5px; font-weight: 600;
	color: var(--mc-text-2);
	background: var(--mc-surface);
	border: 1px solid var(--mc-border);
	border-radius: 8px; padding: 8px 6px; cursor: pointer;
	transition: background .15s ease, color .15s ease, border-color .15s ease;
}
.havn-buyer-act:hover { background: var(--mc-surface-2); color: var(--mc-text); }
.havn-buyer-act-primary { color: var(--mc-accent); border-color: color-mix(in srgb, var(--mc-accent), transparent 70%); }
.havn-buyer-act-primary:hover { background: var(--mc-accent-soft); }
.havn-buyer-act-primary:disabled { opacity: .4; cursor: not-allowed; }
.havn-buyer-act-danger:hover { color: #E0857B; border-color: color-mix(in srgb, #E0857B, transparent 60%); }
.havn-buyer-act-danger { flex: 0 0 auto; }
.havn-buyer-act-primary, .havn-buyer-act:nth-child(2) { flex: 1 1 auto; }

/* ==========================================================================
   Add / edit modal
   ========================================================================== */
.havn-buyer-modal[hidden] { display: none; }
.havn-buyer-modal {
	position: fixed; inset: 0; z-index: 100000;
	display: flex; align-items: flex-start; justify-content: center;
	padding: 6vh 16px 16px;
	overflow-y: auto;
}
.havn-buyer-modal-backdrop { position: fixed; inset: 0; background: rgba(0,0,0,.6); backdrop-filter: blur(3px); }
.havn-buyer-modal-panel {
	position: relative;
	width: 100%; max-width: 560px;
	background: var(--mc-bg-2);
	border: 1px solid var(--mc-border-2);
	border-radius: var(--mc-radius-lg);
	box-shadow: var(--mc-shadow);
	color: var(--mc-text);
	font: 14px/1.5 Inter, system-ui, sans-serif;
}
.havn-buyer-modal-head {
	display: flex; align-items: center; justify-content: space-between;
	padding: 18px 20px; border-bottom: 1px solid var(--mc-border);
}
.havn-buyer-modal-head h3 { margin: 0; font-size: 17px; font-weight: 600; font-family: Fraunces, Georgia, serif; }
.havn-buyer-modal-x {
	display: grid; place-items: center; width: 32px; height: 32px;
	background: transparent; border: 1px solid var(--mc-border);
	border-radius: 8px; color: var(--mc-text-2); cursor: pointer;
}
.havn-buyer-modal-x:hover { color: var(--mc-text); border-color: var(--mc-border-2); }
.havn-buyer-modal-x svg { width: 16px; height: 16px; }
body.havn-buyer-modal-open { overflow: hidden; }

/* ---- form ---- */
.havn-buyer-form { padding: 18px 20px 20px; display: flex; flex-direction: column; gap: 14px; }
.havn-buyer-field-row { display: flex; gap: 12px; }
.havn-buyer-field { display: flex; flex-direction: column; gap: 5px; flex: 1 1 0; min-width: 0; }
.havn-buyer-field-grow { flex: 2 1 0; }
.havn-buyer-field > span { font-size: 12px; color: var(--mc-text-3); font-weight: 500; }
.havn-buyer-field > span em { color: var(--mc-accent); font-style: normal; }
.havn-buyer-hint { color: var(--mc-text-3) !important; font-size: 11px; }
.havn-buyer-field input,
.havn-buyer-field select,
.havn-buyer-field textarea {
	width: 100%;
	background: var(--mc-bg-3);
	border: 1px solid var(--mc-border);
	border-radius: 9px;
	padding: 9px 11px;
	color: var(--mc-text);
	font: inherit; font-size: 13.5px;
	transition: border-color .15s ease, box-shadow .15s ease;
}
.havn-buyer-field textarea { resize: vertical; min-height: 44px; }
.havn-buyer-field input:focus,
.havn-buyer-field select:focus,
.havn-buyer-field textarea:focus {
	outline: none;
	border-color: color-mix(in srgb, var(--mc-accent), transparent 40%);
	box-shadow: 0 0 0 3px var(--mc-accent-soft);
}
.havn-buyer-field select { appearance: none; cursor: pointer; }

.havn-buyer-fieldset { border: 0; padding: 0; margin: 0; display: flex; flex-direction: column; gap: 7px; }
.havn-buyer-fieldset legend { padding: 0; font-size: 12px; color: var(--mc-text-3); font-weight: 500; }
.havn-buyer-checks { display: flex; flex-wrap: wrap; gap: 7px; }
.havn-buyer-check { display: inline-flex; align-items: center; gap: 6px; cursor: pointer; }
.havn-buyer-check input { position: absolute; opacity: 0; width: 0; height: 0; }
.havn-buyer-check span {
	font-size: 12.5px; color: var(--mc-text-2);
	background: var(--mc-surface);
	border: 1px solid var(--mc-border);
	padding: 6px 11px; border-radius: 999px;
	transition: all .12s ease;
}
.havn-buyer-check input:checked + span {
	color: var(--mc-accent);
	background: var(--mc-accent-soft);
	border-color: color-mix(in srgb, var(--mc-accent), transparent 55%);
}
.havn-buyer-check input:focus-visible + span { box-shadow: 0 0 0 3px var(--mc-accent-soft); }

.havn-buyer-form-actions { display: flex; justify-content: flex-end; gap: 10px; margin-top: 4px; }

/* ---- buyer card is clickable (opens the drawer) ---- */
.havn-buyer-card { cursor: pointer; }
.havn-buyer-card:hover { border-color: color-mix(in srgb, var(--mc-accent), transparent 55%); }
.havn-buyer-card a, .havn-buyer-card button { cursor: pointer; }

/* ---- buyer detail drawer (v2.2.60) ---- */
.havn-buyer-drawer .havn-buyer-drawer-matches { display: flex; flex-direction: column; gap: 10px; }
.havn-buyer-drawer .havn-buyer-match { background: var(--mc-surface); border: 1px solid var(--mc-border); border-radius: 10px; padding: 10px 12px; }
.havn-buyer-drawer-notes { margin-bottom: 18px; }
.havn-buyer-drawer-notes textarea {
	width: 100%; box-sizing: border-box;
	background: var(--mc-surface); border: 1px solid var(--mc-border);
	border-radius: 9px; color: inherit; font: inherit; padding: 10px 12px; resize: vertical;
}
.havn-buyer-log { list-style: none; margin: 8px 0 0; padding: 0; display: flex; flex-direction: column; gap: 0; }
.havn-buyer-log-row {
	display: flex; flex-direction: column; gap: 2px;
	padding: 10px 2px; border-bottom: 1px solid var(--mc-border);
}
.havn-buyer-log-row:last-child { border-bottom: 0; }
.havn-buyer-log-when { font-size: 11px; font-weight: 700; color: var(--mc-text-3); }
.havn-buyer-log-body { font-size: 13px; }

/* light-mode legibility for the body-level buyer drawer content */
body.havn-mc-light .havn-buyer-drawer .havn-mc-ed-lbl,
body.havn-mc-light .havn-buyer-drawer .havn-buyer-log-when { color: #5B6473; }
body.havn-mc-light .havn-buyer-drawer .havn-mc-ed-row,
body.havn-mc-light .havn-buyer-drawer .havn-buyer-log-row { border-bottom-color: rgba(15,23,42,.10); }
body.havn-mc-light .havn-buyer-drawer .havn-buyer-drawer-notes textarea { background: #F6F7F9; border-color: rgba(15,23,42,.12); }

/* ---- responsive ---- */
@media (max-width: 640px) {
	.havn-buyer-grid { grid-template-columns: 1fr; }
	.havn-buyer-field-row { flex-direction: column; gap: 14px; }
}
