/* Crianex CRM — standalone page styles (extends styles.css tokens, dark admin surface) */

.crm-page {
  position: absolute; inset: 0;
  display: flex; flex-direction: column;
  background: var(--bg);
  color: var(--text);
  overflow: hidden;
}

/* ── Top header ── */
.crm-head {
  display: flex; align-items: center; gap: 14px;
  padding: 14px 22px;
  border-bottom: 1px solid var(--line);
  background: var(--bg-elev);
  flex-shrink: 0;
}
.crm-head .brand { display: flex; align-items: center; gap: 10px; font-weight: 600; font-size: 15px; letter-spacing: -0.01em; }
.crm-head h1 { font-size: 16px; font-weight: 500; letter-spacing: -0.015em; }
.crm-head .crumb { font-family: var(--font-mono); font-size: 11px; color: var(--text-faint); letter-spacing: 0.04em; }
.crm-head .grow { flex: 1; }

/* segmented view toggle */
.crm-seg { display: inline-flex; background: var(--bg-soft); border: 1px solid var(--line); border-radius: 9px; padding: 3px; gap: 2px; }
.crm-seg button {
  display: inline-flex; align-items: center; gap: 7px;
  padding: 6px 13px; border: 0; border-radius: 6px;
  background: transparent; color: var(--text-muted);
  font-family: inherit; font-size: 12.5px; font-weight: 500; cursor: pointer;
  transition: background 0.12s, color 0.12s;
}
.crm-seg button.on { background: var(--bg-elev); color: var(--text); box-shadow: var(--shadow-1); }

/* ── Filter / control bar ── */
.crm-bar {
  display: flex; align-items: center; gap: 10px; flex-wrap: wrap;
  padding: 12px 22px;
  border-bottom: 1px solid var(--line);
  background: var(--bg);
  flex-shrink: 0;
}
.crm-bar .label-mono {
  font-family: var(--font-mono); font-size: 10px; letter-spacing: 0.1em;
  text-transform: uppercase; color: var(--text-faint); margin-right: 2px;
}
.crm-bar .vline { width: 1px; height: 22px; background: var(--line); }
.crm-bar .grow { flex: 1; }

.crm-search {
  display: inline-flex; align-items: center; gap: 8px;
  background: var(--bg-elev); border: 1px solid var(--line);
  border-radius: 8px; padding: 7px 11px; min-width: 220px;
  color: var(--text-faint);
}
.crm-search input { background: transparent; border: 0; outline: none; font-family: inherit; font-size: 13px; color: var(--text); flex: 1; width: 100%; }

.crm-prodchip {
  display: inline-flex; align-items: center; gap: 7px;
  padding: 6px 11px; border-radius: 100px;
  border: 1px solid var(--line); background: var(--bg-elev);
  color: var(--text-muted); font-family: inherit; font-size: 12.5px; font-weight: 500;
  cursor: pointer; transition: border-color 0.12s, color 0.12s, background 0.12s;
}
.crm-prodchip:hover { color: var(--text); border-color: var(--line-strong); }
.crm-prodchip .swatch { width: 8px; height: 8px; border-radius: 50%; }
.crm-prodchip.on { color: var(--text); border-color: transparent; }
.crm-prodchip .ct { font-family: var(--font-mono); font-size: 10px; opacity: 0.7; }

.crm-select {
  background: var(--bg-elev); border: 1px solid var(--line); border-radius: 8px;
  padding: 7px 11px; font-family: inherit; font-size: 12.5px; color: var(--text);
  outline: none; cursor: pointer;
}
.crm-select:focus { border-color: var(--purple); }

/* small stat strip */
.crm-stats { display: flex; gap: 22px; padding: 10px 22px; border-bottom: 1px solid var(--line); background: var(--bg-elev); flex-shrink: 0; }
.crm-stats .stat .k { font-family: var(--font-mono); font-size: 9.5px; letter-spacing: 0.1em; text-transform: uppercase; color: var(--text-faint); }
.crm-stats .stat .v { font-size: 17px; font-weight: 600; letter-spacing: -0.02em; margin-top: 2px; }
.crm-stats .stat .v small { font-size: 11px; color: var(--text-muted); font-weight: 500; }

/* duplicate banner */
.crm-dupe-banner {
  display: flex; align-items: center; gap: 12px;
  margin: 12px 22px 0; padding: 11px 14px;
  background: rgba(245,158,11,0.12); border: 1px solid rgba(245,158,11,0.3);
  border-radius: 10px; font-size: 12.5px; color: var(--text);
}
.crm-dupe-banner .dot { width: 7px; height: 7px; border-radius: 50%; background: #f59e0b; flex-shrink: 0; }
.crm-dupe-banner button {
  margin-left: auto; background: transparent; border: 1px solid rgba(245,158,11,0.4);
  color: #f59e0b; border-radius: 7px; padding: 5px 11px; font-family: inherit;
  font-size: 12px; font-weight: 500; cursor: pointer;
}
.crm-dupe-banner button:hover { background: rgba(245,158,11,0.15); }

/* ── scroll body ── */
.crm-body { flex: 1; overflow: auto; padding: 16px 22px 28px; }

/* ── Kanban ── */
.crm-kanban { display: flex; gap: 14px; align-items: flex-start; min-height: 100%; }
.crm-col {
  flex: 1 1 0; min-width: 250px;
  background: var(--bg-soft); border-radius: 12px; padding: 10px;
  display: flex; flex-direction: column; gap: 9px;
  border: 1px solid transparent; transition: border-color 0.12s, background 0.12s;
}
.crm-col.drop-active { border-color: var(--purple); background: var(--accent-soft); }
.crm-col-head { display: flex; align-items: center; gap: 9px; padding: 4px 4px 2px; }
.crm-col-head .dot { width: 9px; height: 9px; border-radius: 50%; flex-shrink: 0; }
.crm-col-head .title { font-size: 13px; font-weight: 600; letter-spacing: -0.01em; }
.crm-col-head .ct { font-family: var(--font-mono); font-size: 10px; color: var(--text-faint); background: var(--bg-elev); border: 1px solid var(--line); padding: 1px 6px; border-radius: 100px; }
.crm-col-head .gear { margin-left: auto; background: transparent; border: 0; color: var(--text-faint); cursor: pointer; padding: 3px; border-radius: 6px; display: grid; place-items: center; }
.crm-col-head .gear:hover { color: var(--text); background: var(--bg-elev); }
.crm-col-sub { font-family: var(--font-mono); font-size: 10px; color: var(--text-faint); padding: 0 4px; letter-spacing: 0.02em; }
.crm-col-total {
  display: flex; align-items: center; justify-content: space-between;
  padding: 6px 8px; margin: 0 1px; border-radius: 7px; background: var(--bg-elev);
  border: 1px solid var(--line);
  font-family: var(--font-mono); font-size: 10.5px; color: var(--text-muted);
}
.crm-col-total b { color: var(--text); font-weight: 600; }

/* lead card */
.crm-card {
  background: var(--bg-elev); border: 1px solid var(--line); border-radius: 10px;
  padding: 12px; display: flex; flex-direction: column; gap: 9px; cursor: grab;
  transition: transform 0.14s, box-shadow 0.14s, border-color 0.14s;
}
.crm-card:hover { transform: translateY(-1px); box-shadow: var(--shadow-2); border-color: var(--line-strong); }
.crm-card.dragging { opacity: 0.35; cursor: grabbing; }
.crm-card .top { display: flex; align-items: flex-start; gap: 10px; }
.crm-avatar {
  width: 32px; height: 32px; border-radius: 9px; flex-shrink: 0;
  display: grid; place-items: center; font-family: var(--font-mono); font-size: 11px; font-weight: 600;
  color: #fff;
}
.crm-card .who { min-width: 0; flex: 1; }
.crm-card .company { font-size: 13.5px; font-weight: 600; letter-spacing: -0.01em; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.crm-card .person { font-size: 11.5px; color: var(--text-muted); margin-top: 1px; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.crm-card .agewarn { color: #f59e0b; }

.crm-prods { display: flex; flex-wrap: wrap; gap: 5px; }
.crm-prodtag {
  display: inline-flex; align-items: center; gap: 5px;
  font-family: var(--font-mono); font-size: 9.5px; letter-spacing: 0.04em;
  padding: 2px 7px; border-radius: 5px; font-weight: 500;
}
.crm-prodtag .d { width: 5px; height: 5px; border-radius: 50%; }

.crm-card .meta-row {
  display: flex; align-items: center; justify-content: space-between;
  padding-top: 9px; border-top: 1px solid var(--line);
}
.crm-pedidos { font-family: var(--font-mono); font-size: 10px; color: var(--text-muted); display: inline-flex; align-items: center; gap: 5px; }
.crm-pedidos .badge { background: var(--accent-soft); color: var(--purple); border: 1px solid var(--accent-line); border-radius: 100px; padding: 1px 6px; font-weight: 600; }
.crm-card .val { font-family: var(--font-mono); font-size: 12px; font-weight: 600; color: var(--text); }

.crm-actions { display: flex; align-items: center; gap: 6px; }
.crm-iconbtn {
  width: 28px; height: 28px; border-radius: 7px; display: grid; place-items: center;
  border: 1px solid var(--line); background: var(--bg); color: var(--text-muted);
  cursor: pointer; transition: all 0.12s; text-decoration: none;
}
.crm-iconbtn:hover { color: var(--text); border-color: var(--line-strong); transform: translateY(-1px); }
.crm-iconbtn.wa:hover { background: #25D366; border-color: #25D366; color: #fff; }
.crm-iconbtn.mail:hover { background: var(--purple); border-color: var(--purple); color: #fff; }
.crm-card .respo { font-family: var(--font-mono); font-size: 10px; color: var(--text-faint); }

.crm-addcard {
  background: transparent; border: 1px dashed var(--line-strong); border-radius: 9px;
  color: var(--text-faint); padding: 9px; font-family: inherit; font-size: 12px; cursor: pointer;
  transition: color 0.12s, border-color 0.12s;
}
.crm-addcard:hover { color: var(--text); border-color: var(--purple); }

.crm-addcol {
  flex: 0 0 60px; align-self: stretch; min-height: 120px;
  background: transparent; border: 1px dashed var(--line-strong); border-radius: 12px;
  color: var(--text-faint); cursor: pointer; display: grid; place-items: center;
  font-family: var(--font-mono); font-size: 11px; writing-mode: vertical-rl; letter-spacing: 0.1em;
  transition: color 0.12s, border-color 0.12s;
}
.crm-addcol:hover { color: var(--text); border-color: var(--purple); }

/* ── Table view ── */
.crm-table-wrap { border: 1px solid var(--line); border-radius: 12px; overflow: hidden; background: var(--bg-elev); }
.crm-table { width: 100%; border-collapse: collapse; font-size: 13px; }
.crm-table th {
  text-align: left; font-family: var(--font-mono); font-size: 10px; letter-spacing: 0.08em;
  text-transform: uppercase; color: var(--text-faint); font-weight: 500;
  padding: 11px 14px; border-bottom: 1px solid var(--line); background: var(--bg-soft);
  white-space: nowrap; cursor: pointer; user-select: none;
}
.crm-table th.no-sort { cursor: default; }
.crm-table th .sortcaret { opacity: 0.4; margin-left: 4px; font-size: 9px; }
.crm-table th.sorted .sortcaret { opacity: 1; color: var(--purple); }
.crm-table td { padding: 11px 14px; border-bottom: 1px solid var(--line); vertical-align: middle; }
.crm-table tbody tr { transition: background 0.1s; }
.crm-table tbody tr.lead-row { cursor: pointer; }
.crm-table tbody tr.lead-row:hover { background: var(--bg-soft); }
.crm-table tbody tr:last-child td { border-bottom: 0; }
.crm-tname { font-weight: 600; letter-spacing: -0.01em; }
.crm-tsub { font-size: 11.5px; color: var(--text-muted); font-family: var(--font-mono); }
.crm-tstage { display: inline-flex; align-items: center; gap: 6px; font-size: 12px; }
.crm-tstage .d { width: 7px; height: 7px; border-radius: 50%; }
.crm-texpand { background: transparent; border: 0; color: var(--text-faint); cursor: pointer; padding: 2px; display: inline-flex; transition: transform 0.15s; }
.crm-texpand.open { transform: rotate(90deg); color: var(--text); }
.crm-subrow td { background: var(--bg); padding: 0; }
.crm-subrow .inner { padding: 4px 14px 10px 52px; display: flex; flex-direction: column; gap: 6px; }
.crm-pedido-line {
  display: grid; grid-template-columns: 90px 1fr 90px 90px; gap: 12px; align-items: center;
  padding: 7px 10px; background: var(--bg-soft); border: 1px solid var(--line); border-radius: 8px; font-size: 12px;
}
.crm-pedido-line .msg { color: var(--text-muted); white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.crm-table .col-actions { display: flex; gap: 6px; }

/* ── Column editor modal ── */
.crm-coleditor { display: flex; flex-direction: column; gap: 10px; }
.crm-colrow {
  display: flex; flex-direction: column; gap: 10px;
  background: var(--bg-soft); border: 1px solid var(--line); border-radius: 10px; padding: 12px;
  transition: border-color 0.12s, box-shadow 0.12s;
}
.crm-colrow.dragging { opacity: 0.4; }
.crm-colrow.drop-before { box-shadow: -3px 0 0 var(--purple); }
.crm-colrow.drop-after { box-shadow: 3px 0 0 var(--purple); }
.crm-colrow .r1 { display: flex; align-items: center; gap: 10px; }
.crm-colrow .handle { color: var(--text-faint); cursor: grab; display: inline-flex; }
.crm-colrow input.cname {
  flex: 1; background: var(--bg); border: 1px solid var(--line); border-radius: 7px;
  padding: 7px 10px; font-family: inherit; font-size: 13px; font-weight: 500; color: var(--text); outline: none;
}
.crm-colrow input.cname:focus { border-color: var(--purple); }
.crm-colrow .del { background: transparent; border: 0; color: var(--text-faint); cursor: pointer; padding: 5px; border-radius: 6px; }
.crm-colrow .del:hover { color: var(--pink); background: var(--hot-soft); }
.crm-swatches { display: flex; gap: 6px; }
.crm-swatch { width: 22px; height: 22px; border-radius: 6px; border: 2px solid transparent; cursor: pointer; padding: 0; }
.crm-swatch.on { border-color: var(--text); box-shadow: 0 0 0 2px var(--bg-soft); }
.crm-colrow .crit { display: grid; grid-template-columns: 1fr 1fr; gap: 8px; }
.crm-colrow .crit .f { display: flex; flex-direction: column; gap: 4px; }
.crm-colrow .crit label { font-family: var(--font-mono); font-size: 9px; letter-spacing: 0.08em; text-transform: uppercase; color: var(--text-faint); }
.crm-colrow .crit textarea {
  background: var(--bg); border: 1px solid var(--line); border-radius: 7px; padding: 6px 9px;
  font-family: inherit; font-size: 12px; color: var(--text); outline: none; resize: none; min-height: 46px; line-height: 1.4;
}
.crm-colrow .crit textarea:focus { border-color: var(--purple); }

/* ── Drawer (lead detail) extends .admin-drawer ── */
.crm-drawer { width: 480px; }
.crm-drawer-actions { display: flex; gap: 8px; margin-top: 16px; }
.crm-drawer-actions a, .crm-drawer-actions button {
  flex: 1; display: inline-flex; align-items: center; justify-content: center; gap: 7px;
  padding: 9px; border-radius: 9px; font-family: inherit; font-size: 12.5px; font-weight: 500;
  cursor: pointer; text-decoration: none; border: 1px solid var(--line); background: var(--bg); color: var(--text);
  transition: all 0.12s;
}
.crm-drawer-actions a.wa:hover { background: #25D366; border-color: #25D366; color: #fff; }
.crm-drawer-actions a.mail:hover { background: var(--purple); border-color: var(--purple); color: #fff; }
.crm-drawer-actions button.call:hover { background: var(--bg-soft); border-color: var(--line-strong); }

.crm-deal {
  border: 1px solid var(--line); border-radius: 10px; padding: 12px; background: var(--bg-soft);
  display: flex; flex-direction: column; gap: 7px;
}
.crm-deal .dh { display: flex; align-items: center; gap: 9px; }
.crm-deal .dh .pname { font-size: 13px; font-weight: 600; }
.crm-deal .dh .pval { margin-left: auto; font-family: var(--font-mono); font-size: 12px; font-weight: 600; }
.crm-deal .dmeta { font-family: var(--font-mono); font-size: 10.5px; color: var(--text-faint); }
.crm-deal .dmsg { font-size: 12.5px; color: var(--text-muted); line-height: 1.5; }

.crm-kv { display: flex; gap: 22px; flex-wrap: wrap; }
.crm-kv .k { font-family: var(--font-mono); font-size: 9.5px; letter-spacing: 0.08em; text-transform: uppercase; color: var(--text-faint); }
.crm-kv .v { font-size: 13px; margin-top: 3px; }

.crm-section-h { display: flex; align-items: center; gap: 9px; margin-bottom: 11px; }
.crm-section-h h4 { font-size: 12.5px; font-weight: 600; }
.crm-section-h .pill { font-family: var(--font-mono); font-size: 9.5px; background: var(--bg-soft); border: 1px solid var(--line); color: var(--text-muted); padding: 1px 7px; border-radius: 100px; }

/* empty */
.crm-empty { text-align: center; padding: 60px 20px; color: var(--text-muted); }
.crm-empty .ico { width: 46px; height: 46px; border-radius: 12px; display: grid; place-items: center; background: var(--bg-soft); border: 1px solid var(--line); margin: 0 auto 14px; color: var(--text-faint); }

@media (max-width: 760px) {
  .crm-stats { display: none; }
  .crm-kanban { flex-direction: column; }
  .crm-col { width: 100%; }
}
