/* Venue CRM · builds on styles.css + admin.css */

.wrap.wide { max-width: 1040px; }

/* toolbar */
.crm-toolbar {
  display: flex; flex-wrap: wrap; gap: 10px; align-items: center;
  margin: 6px 0 4px;
}
.crm-toolbar #crm-search { flex: 1 1 220px; min-width: 180px; }
.crm-toolbar input, .crm-toolbar select {
  padding: 10px 12px; border: 1px solid var(--line); border-radius: 10px;
  font-size: 15px; background: #fff; color: var(--ink);
}
.crm-toolbar #crm-add { margin-left: auto; white-space: nowrap; }

/* venue cards */
.crm-list { display: grid; grid-template-columns: repeat(auto-fill, minmax(300px, 1fr)); gap: 14px; }
.venue-card {
  background: var(--card); border-radius: var(--radius); box-shadow: var(--shadow);
  padding: 16px; cursor: pointer; border: 1px solid transparent;
  transition: border-color .12s, transform .12s;
  display: flex; flex-direction: column; gap: 8px;
}
.venue-card:hover { border-color: var(--gold-soft); transform: translateY(-1px); }
.venue-card h3 { margin: 0; font-size: 17px; color: var(--navy); }
.venue-card .vc-meta { color: var(--muted); font-size: 13px; }
.venue-card .vc-contact { font-size: 13px; color: var(--ink); }
.venue-card .vc-row { display: flex; align-items: center; justify-content: space-between; gap: 8px; }
.venue-card .vc-icons { display: flex; gap: 8px; font-size: 13px; }
.venue-card .vc-icons span { opacity: .4; }
.venue-card .vc-icons span.on { opacity: 1; }

/* status badge / pills */
.badge-status {
  display: inline-block; font-size: 12px; font-weight: 700; letter-spacing: .3px;
  padding: 3px 10px; border-radius: 999px; white-space: nowrap;
}
/* fit tags (solo singer + backing tracks suitability) */
.fit-tag {
  display: inline-block; font-size: 11px; font-weight: 700; letter-spacing: .3px;
  padding: 2px 9px; border-radius: 999px; white-space: nowrap;
}
.fit-solo    { background: var(--avail-bg); color: var(--avail); }
.fit-mixed   { background: #fff3da; color: #9a6a12; }
.fit-band    { background: #f0eef6; color: #6b5fa0; }
.fit-unknown { background: #eef0f3; color: #707684; }
.fit-tag.ev-type { background: #ece7f6; color: #5a4b9a; margin-right: 6px; }

.st-new       { background: #eef0f6; color: #4a5170; }
.st-contacted { background: #fff3da; color: #9a6a12; }
.st-responded { background: #e2effd; color: #1f5fa6; }
.st-booked    { background: var(--avail-bg); color: var(--avail); }
.st-declined  { background: #f3e7e7; color: #98575a; }

/* stat grid tweak: make stats clickable filters */
.stat-grid .stat { cursor: pointer; }
.stat-grid .stat.active { outline: 2px solid var(--gold); }

/* modal */
.crm-modal {
  position: fixed; inset: 0; background: rgba(22,27,51,.55);
  display: flex; align-items: flex-start; justify-content: center;
  padding: 24px 14px; overflow-y: auto; z-index: 50;
}
/* Two-class selector so "hidden" reliably beats .crm-modal's display:flex
   (otherwise the empty modal overlay shows on every page and won't close). */
.crm-modal.hidden { display: none; }
.crm-modal-card {
  background: var(--bg); border-radius: 16px; width: 100%; max-width: 640px;
  box-shadow: 0 20px 60px rgba(0,0,0,.3); position: relative;
  padding: 22px; margin: auto;
}
.crm-close {
  position: absolute; top: 12px; right: 14px; border: none; background: none;
  font-size: 28px; line-height: 1; cursor: pointer; color: var(--muted);
}
.crm-close:hover { color: var(--ink); }

.crm-modal h2 { margin: 0 6px 2px 0; color: var(--navy); font-size: 22px; padding-right: 30px; }
.crm-sub { color: var(--muted); font-size: 14px; margin: 0 0 14px; }

.crm-block { background: var(--card); border-radius: 12px; padding: 14px 16px; margin-bottom: 14px; box-shadow: var(--shadow); }
.crm-block h4 { margin: 0 0 10px; font-size: 14px; text-transform: uppercase; letter-spacing: .5px; color: var(--muted); }

/* link buttons */
.link-row { display: flex; flex-wrap: wrap; gap: 8px; }
.link-btn {
  display: inline-flex; align-items: center; gap: 6px; text-decoration: none;
  padding: 9px 14px; border-radius: 10px; font-size: 14px; font-weight: 600;
  border: 1px solid var(--line); background: #fff; color: var(--navy); cursor: pointer;
}
.link-btn:hover { border-color: var(--gold); }
.link-btn.disabled { opacity: .4; pointer-events: none; }
.link-btn.ig { background: #fdeef5; border-color: #f3cfe1; }
.link-btn.fb { background: #eaf1fb; border-color: #cfddf3; }

/* status pipeline buttons */
.pipeline { display: flex; flex-wrap: wrap; gap: 8px; }
.pipe-btn {
  border: 1px solid var(--line); background: #fff; border-radius: 999px;
  padding: 7px 14px; font-size: 13px; font-weight: 600; cursor: pointer; color: var(--muted);
}
.pipe-btn.active { color: #fff; border-color: transparent; }
.pipe-btn.active[data-s="new"]       { background: #6b7194; }
.pipe-btn.active[data-s="contacted"] { background: #c99016; }
.pipe-btn.active[data-s="responded"] { background: #2f78c4; }
.pipe-btn.active[data-s="booked"]    { background: var(--avail); }
.pipe-btn.active[data-s="declined"]  { background: #a86b6e; }

/* message composer */
.channel-tabs { display: flex; gap: 8px; margin-bottom: 10px; }
.channel-tabs button {
  flex: 1; border: 1px solid var(--line); background: #fff; border-radius: 10px;
  padding: 9px; font-weight: 600; cursor: pointer; color: var(--muted);
}
.channel-tabs button.active { background: var(--navy); color: #fff; border-color: var(--navy); }
.msg-subject { font-size: 13px; color: var(--muted); margin: 0 0 6px; }
.msg-box {
  width: 100%; border: 1px solid var(--line); border-radius: 10px; padding: 12px;
  font: inherit; font-size: 14px; line-height: 1.5; background: #fff; color: var(--ink);
  resize: vertical; min-height: 200px;
}
.msg-subjlabel { display: block; font-size: 12px; color: var(--muted); margin-bottom: 8px; }
.msg-subjlabel input {
  width: 100%; margin-top: 4px; padding: 9px 11px; border: 1px solid var(--line);
  border-radius: 9px; font: inherit; font-size: 14px; background: #fff; color: var(--ink);
}
.msg-actions { display: flex; flex-wrap: wrap; gap: 8px; margin-top: 10px; }
.link-btn.send { background: var(--navy); color: #fff; border-color: var(--navy); }
.link-btn.send:hover { background: var(--navy-2); border-color: var(--navy-2); }
.link-btn.send:disabled { opacity: .6; cursor: default; }
.check { display: flex; align-items: center; gap: 8px; font-size: 14px; }
.check input { width: auto; }
.activity li.act-reply { background: #e2effd; border-radius: 8px; padding: 8px 10px; border-bottom: none; }
.msg-hint { font-size: 12px; color: var(--muted); margin-top: 8px; }
.copied-flash { color: var(--avail); font-weight: 700; font-size: 13px; }

/* activity log */
.activity { list-style: none; margin: 0; padding: 0; }
.activity li { padding: 8px 0; border-bottom: 1px solid var(--line); font-size: 13px; }
.activity li:last-child { border-bottom: none; }
.activity .a-ts { color: var(--muted); font-size: 12px; }
.note-row { display: flex; gap: 8px; margin-bottom: 10px; }
.note-row input { flex: 1; padding: 9px 12px; border: 1px solid var(--line); border-radius: 10px; font: inherit; }

/* edit fields */
.edit-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 10px; }
.edit-grid label { font-size: 13px; color: var(--muted); display: flex; flex-direction: column; gap: 4px; }
.edit-grid label.full { grid-column: 1 / -1; }
.edit-grid input, .edit-grid select, .edit-grid textarea {
  padding: 9px 11px; border: 1px solid var(--line); border-radius: 9px; font: inherit; font-size: 14px;
  background: #fff; color: var(--ink);
}
.danger-link { background: none; border: none; color: #b3403f; cursor: pointer; font-size: 13px; text-decoration: underline; padding: 0; }

@media (max-width: 560px) {
  .edit-grid { grid-template-columns: 1fr; }
  .crm-toolbar #crm-add { margin-left: 0; flex: 1 1 100%; }
}
