/* Kalman Commons member directory. Builds on styles.css variables. */

.kc-filters {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(170px, 1fr));
  gap: 12px 16px;
  background: #fff;
  border: 1px solid var(--line);
  border-radius: 14px;
  padding: clamp(16px, 2.4vw, 22px);
  box-shadow: var(--shadow);
  margin-bottom: 8px;
}
.kc-filters label { font-family: var(--ui-font); font-weight: 600; font-size: 12.5px; color: var(--muted); display: block; margin-bottom: 5px; }
.kc-filters input, .kc-filters select {
  width: 100%; font-family: var(--ui-font); font-size: 14px;
  padding: 9px 11px; border: 1px solid var(--line); border-radius: 9px; background: #fff; color: var(--ink);
}
.kc-filters .kc-filter-search { grid-column: 1 / -1; }
.kc-filters input:focus, .kc-filters select:focus { outline: none; border-color: var(--blue); box-shadow: 0 0 0 3px rgba(0,82,120,.12); }

.kc-dir-meta { font-family: var(--ui-font); color: var(--muted); font-size: 14px; margin: 14px 2px 18px; display:flex; gap:14px; align-items:center; flex-wrap:wrap; }
.kc-geo-btn { font-family: var(--ui-font); font-size: 13px; color: var(--blue); background: none; border: 0; cursor: pointer; padding: 0; text-decoration: underline; }

.kc-cards { display: grid; grid-template-columns: repeat(auto-fill, minmax(290px, 1fr)); gap: 18px; }

.kc-card {
  background: #fff; border: 1px solid var(--line); border-radius: 16px;
  padding: 20px; box-shadow: var(--shadow); display: flex; flex-direction: column; gap: 10px;
}
.kc-card-top { display: flex; gap: 13px; align-items: center; }
.kc-avatar {
  width: 52px; height: 52px; border-radius: 999px; flex: none;
  display: flex; align-items: center; justify-content: center;
  color: #fff; font-family: var(--ui-font); font-weight: 700; font-size: 18px; letter-spacing: .5px;
}
.kc-card-name { font-family: var(--ui-font); font-weight: 700; color: var(--navy); font-size: 16px; line-height: 1.2; }
.kc-card-role { font-family: var(--ui-font); color: var(--muted); font-size: 13px; margin-top: 2px; }
.kc-card-headline { color: var(--ink); font-size: 14.5px; line-height: 1.45; }
.kc-chips { display: flex; flex-wrap: wrap; gap: 6px; }
.kc-chip {
  font-family: var(--ui-font); font-size: 11.5px; color: var(--blue);
  background: var(--soft); border: 1px solid var(--line); border-radius: 999px; padding: 3px 10px;
}
.kc-badge { font-family: var(--ui-font); font-size: 11px; font-weight: 700; border-radius: 999px; padding: 3px 10px; text-transform: uppercase; letter-spacing: .03em; }
.kc-badge.sell { background: #e7f3ee; color: #1d6b46; }
.kc-badge.buy { background: #e8f1fb; color: #1d4f8a; }
.kc-badge.both { background: var(--soft); color: var(--navy); }
.kc-card-links { display: flex; gap: 12px; font-family: var(--ui-font); font-size: 13px; }
.kc-card-links a { color: var(--blue); }
.kc-card-foot { margin-top: auto; padding-top: 6px; }
.kc-card-note { font-family: var(--ui-font); font-size: 12.5px; color: var(--muted); margin: 0; }

.kc-empty { text-align: center; color: var(--muted); font-family: var(--ui-font); padding: 40px 10px; }

/* Connect modal */
.kc-modal { position: fixed; inset: 0; background: rgba(16,32,51,.55); display: none; align-items: center; justify-content: center; padding: 18px; z-index: 2000; }
.kc-modal.open { display: flex; }
.kc-modal-box { background: #fff; border-radius: 16px; max-width: 480px; width: 100%; padding: clamp(20px,3vw,30px); box-shadow: var(--shadow); max-height: 90vh; overflow: auto; }
.kc-modal-box h3 { font-family: var(--ui-font); color: var(--navy); margin: 0 0 4px; font-size: 21px; }
.kc-modal-box p.kc-modal-sub { font-family: var(--ui-font); color: var(--muted); font-size: 14px; margin: 0 0 16px; }
.kc-modal-box label { font-family: var(--ui-font); font-weight: 600; font-size: 13px; color: var(--ink); display: block; margin-top: 12px; }
.kc-modal-box input, .kc-modal-box textarea {
  width: 100%; font-family: var(--ui-font); font-size: 15px; padding: 10px 12px;
  border: 1px solid var(--line); border-radius: 10px; margin-top: 5px;
}
.kc-modal-box textarea { min-height: 90px; resize: vertical; }
.kc-modal-actions { display: flex; gap: 10px; margin-top: 18px; }
.kc-modal-actions .button { margin: 0; }
.kc-modal-close { background: #e8f2f6; color: var(--navy); }
