/* ════════════════════════════════════════════════════════════════════════════
   calls.css — estilos exclusivos del módulo Llamadas
   ════════════════════════════════════════════════════════════════════════════ */

/* ── callEditorModal: form/edit-area como flex-column para scroll + footer sticky ── */
#callEditorForm {
  flex: 1 1 auto;
  min-height: 0;
  overflow: hidden;
  display: flex;
  flex-direction: column;
}
#callEditorForm.d-none { display: none !important; }
#callEditArea:not(.d-none) {
  flex: 1 1 auto;
  min-height: 0;
  display: flex;
  flex-direction: column;
  overflow: hidden;
}

/* ── Tab pane layout ─────────────────────────────────────────────────────── */
#pills-calls {
  --calls-fs: 1;
  flex-direction: column;
  height: calc(100vh - 110px);
  overflow: hidden;
}
#pills-calls.active { display: flex !important; }

/* ── Contact picker (callEditorModal) ────────────────────────────────────── */
.calls-contact-results {
  background: #2b3035;
  border: 1px solid rgba(255,255,255,.15);
  border-radius: .375rem;
  margin-top: .25rem;
  overflow: hidden;
}
.calls-contact-option {
  display: flex;
  flex-direction: column;
  width: 100%;
  text-align: left;
  padding: .5rem .75rem;
  border: 0;
  background: transparent;
  color: #fff;
  border-bottom: 1px solid rgba(255,255,255,.07);
  transition: background .15s;
  cursor: pointer;
}
.calls-contact-option:last-child { border-bottom: 0; }
.calls-contact-option:hover      { background: rgba(255,255,255,.08); }
.calls-contact-option-title { font-weight: 600; font-size: .88rem; }
.calls-contact-option-copy  { font-size: .77rem; color: rgba(255,255,255,.5); margin-top: .05rem; }

/* ── Linked preview / block ──────────────────────────────────────────────── */
.calls-linked-preview {
  background: rgba(13,110,253,.12);
  border: 1px solid rgba(13,110,253,.3);
  border-radius: .375rem;
  padding: .6rem .85rem;
  margin-top: .5rem;
  color: #fff;
}
.calls-linked-block {
  background: rgba(13,110,253,.12);
  border: 1px solid rgba(13,110,253,.3);
  border-radius: .375rem;
  padding: .5rem .75rem;
  margin-top: .35rem;
}
.calls-linked-title { font-size: .84rem; font-weight: 600; color: #9ec5fe; }
.calls-linked-copy  { font-size: .76rem; color: rgba(255,255,255,.5); margin-top: .05rem; }

/* ── Chips (internos, contacto, etc.) ────────────────────────────────────── */
.calls-chip {
  display: inline-flex;
  align-items: center;
  gap: .25rem;
  font-size: .78rem;
  padding: .2rem .5rem;
  border-radius: .3rem;
  background: rgba(255,255,255,.08);
  border: 1px solid rgba(255,255,255,.12);
  color: rgba(255,255,255,.8);
  white-space: nowrap;
}
.calls-chip.is-linked {
  background: rgba(13,110,253,.18);
  border-color: rgba(13,110,253,.35);
  color: #9ec5fe;
}
button.calls-chip { cursor: pointer; transition: background .15s, border-color .15s; }
button.calls-chip:hover { background: rgba(255,255,255,.14); border-color: rgba(255,255,255,.25); }
button.calls-chip.is-selected {
  background: rgba(25,135,84,.25);
  border-color: rgba(25,135,84,.5);
  color: #75b798;
  font-weight: 600;
}
.calls-chip--selectable { cursor: pointer; }
.calls-chip--selectable:hover:not(.is-selected) { background: rgba(255,255,255,.12); border-color: rgba(255,255,255,.22); }
.calls-chip-tick { font-size: .65rem; margin-left: .1rem; vertical-align: middle; }

/* ── Auto-save indicator ─────────────────────────────────────────────────── */
.calls-autosave-indicator {
  font-size: .75rem;
  font-weight: 500;
  padding: .15rem .45rem;
  border-radius: .3rem;
  transition: opacity .3s;
  white-space: nowrap;
  display: inline-flex;
  align-items: center;
}
.calls-autosave-indicator.is-pending { color: rgba(255,255,255,.45); }
.calls-autosave-indicator.is-saved   { color: #75b798; }
.calls-autosave-indicator.is-error   { color: #f1aeb5; }

#callWorkspaceFooter {
  justify-content: space-between;
}
.calls-footer-left,
.calls-footer-right {
  display: flex;
  align-items: center;
  gap: .4rem;
}
.calls-save-btn {
  min-width: 9rem;
  justify-content: center;
}

/* ── Comments card inside modals ─────────────────────────────────────────── */
#callEditorModal .notes-side-card-head,
#taskModal .notes-side-card-head,
#editFormModal .notes-side-card-head {
  background: rgba(255,255,255,.03);
  border-bottom: 1px solid rgba(255,255,255,.08);
}
#callEditorModal .calls-comments-card,
#taskModal .calls-comments-card,
#editFormModal .calls-comments-card {
  background: #2b3035;
  border: 1px solid rgba(255,255,255,.1);
  border-radius: .5rem;
}
#callsList .dtv-row    { cursor: default; }
#callsList .dtv-name-btn { cursor: pointer; }

/* ── Main header wrapper (compact toggle + name) ─────────────────────────── */
.dtv-main-header {
  display: flex;
  align-items: center;
  gap: .25rem;
  width: 100%;
  min-width: 0;
}
/* Nombre solo toma su ancho de contenido — el espacio libre queda para el collapse */
.dtv-main-header .dtv-name-btn {
  flex: 0 0 auto;
  max-width: 72%;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

/* ── Compact toggle chevron per row ──────────────────────────────────────── */
/* ── Compact toggle — Bootstrap 5.3 collapse nativo ─────────────────────── */
.call-compact-toggle {
  display: none;         /* oculto en full mode; se inyecta sin d-none en compact */
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
  width: 1.4rem;
  height: 1.4rem;
  background: none;
  border: none;
  padding: 0;
  border-radius: 50%;
  color: rgba(148,163,184,.4);
  cursor: pointer;
  transition: color .15s, background .15s;
}
.call-compact-toggle:hover { color: #93c5fd; background: rgba(147,197,253,.1); }
.call-compact-toggle i     { font-size: .64rem; transition: transform .2s ease; }
/* Bootstrap actualiza aria-expanded → rotamos el chevron */
.call-compact-toggle[aria-expanded="true"] i { transform: rotate(180deg); }
.call-compact-toggle[aria-expanded="true"]   { color: rgba(147,197,253,.7); }
/* Visible en modo compacto */
#callsList.calls-list--compact .call-compact-toggle { display: inline-flex; }

/* ── Font scale ──────────────────────────────────────────────────────────── */
#pills-calls .dtv-meta-chip { font-size: calc(0.71rem * var(--calls-fs, 1)); }

/* ── Layout toggle active ────────────────────────────────────────────────── */
#callsLayoutToggle.is-active { color: #93c5fd !important; }

/* ── Search highlight ────────────────────────────────────────────────────── */
mark.call-hl {
  background: rgba(250,204,21,.28);
  color: #fde68a;
  border-radius: 2px;
  padding: 0;
  font-style: normal;
  font-weight: inherit;
}

/* ── Single-column grid (acciones inline en el header, igual que phones) ─── */
.calls-dtv-row         { grid-template-columns: 1fr !important; }
.calls-cols-header     { grid-template-columns: 1fr; }
.calls-dtv-row .dtv-col--main { grid-column: 1; }

/* Acciones inline dentro de dtv-main-header (igual que .ph-actions en phones) */
.call-row-actions {
  flex-shrink: 0;
  display: flex;
  align-items: center;
  gap: .22rem;
  margin-left: auto;
}

/* Botones siempre visibles */
.dtv-row .call-row-actions .btn,
.dtv-row .call-row-actions .call-comments-btn {
  transition: color .13s, background .13s, border-color .13s;
}

/* ── Estado en el header (badge compacto inline) ─────────────────────────── */
.call-hdr-status {
  font-size: .6rem !important;
  padding: .1rem .38rem !important;
  border-radius: .28rem !important;
  flex-shrink: 0;
  letter-spacing: .01em;
}

/* ── Prioridad: borde izquierdo del contenedor ───────────────────────────── */
.calls-dtv-row.calls-row--media { border-left: 3px solid rgba(234,179,8,.7); }
.calls-dtv-row.calls-row--alta  { border-left: 3px solid rgba(239,68,68,.7); }

/* ── Row body — diseño horizontal moderno ────────────────────────────────── */
.call-row-body {
  display: flex;
  flex-direction: column;
  gap: .32rem;
  margin-top: .22rem;
  padding-bottom: .24rem;
}

/* Línea horizontal de chips (flex-wrap adaptativo) */
.call-row-line {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: .18rem .25rem;
  min-width: 0;
}

/* Iniciales en el chip de asignado (bold, pequeñas) */
.call-chip-inits {
  font-size: .62rem;
  font-weight: 700;
  margin-right: .15rem;
  opacity: .85;
}

/* Observaciones: label + texto completo */
.call-row-obs {
  display: flex;
  flex-direction: column;
  gap: .22rem;
  padding: .32rem .42rem;
  background: rgba(255, 255, 255, .025);
  border: 1px solid rgba(148, 163, 184, .1);
  border-radius: .38rem;
  min-width: 0;
  width: 100%;
  box-sizing: border-box;
}
.call-row-obs-label {
  font-size: calc(0.6rem * var(--calls-fs, 1));
  font-weight: 700;
  letter-spacing: .06em;
  text-transform: uppercase;
  color: rgba(148, 163, 184, .42);
  line-height: 1;
}
.call-row-obs-text {
  font-size: calc(0.73rem * var(--calls-fs, 1));
  color: rgba(203, 213, 225, .65);
  line-height: 1.55;
  white-space: pre-wrap;
  word-break: break-word;
  text-transform: none;
}

/* Compact mode: Bootstrap collapse maneja show/hide; solo ajustes cosméticos */
#callsList.calls-list--compact .dtv-row:not(:has(.collapse.show)) { min-height: 36px; }

/* Cursor pointer en la zona muerta del header (indica que es colapsable) */
#callsList.calls-list--compact .dtv-main-header { cursor: pointer; }

/* ── Tag chips in list ───────────────────────────────────────────────────── */
.call-tag {
  display: inline-flex;
  align-items: center;
  padding: .1rem .48rem;
  border-radius: 999px;
  border: 1px solid transparent;
  font-size: calc(.67rem * var(--calls-fs, 1));
  font-weight: 500;
  white-space: nowrap;
  line-height: 1.4;
}
.call-tag--neutral {
  background: rgba(100,116,139,.15);
  border-color: rgba(100,116,139,.28);
  color: #cbd5e1;
}
.call-tags-row { gap: .2rem .22rem; }


/* ── Comments button in list row ─────────────────────────────────────────── */
.call-comments-btn {
  display: inline-flex;
  align-items: center;
  gap: .25rem;
  color: rgba(148,163,184,.5) !important;
  border-color: transparent !important;
  background: transparent !important;
  transition: color .13s, background .13s, border-color .13s !important;
}
.call-comments-btn:hover {
  color: #cbd5e1 !important;
  background: rgba(255,255,255,.06) !important;
}
/* Con comentarios: el botón neutral, solo el badge llama la atención */
.call-comments-btn--has {
  color: rgba(203,213,225,.7) !important;
  background: transparent !important;
  border-color: transparent !important;
}
.call-comments-btn--has:hover {
  background: rgba(255,255,255,.07) !important;
}

/* Badge del contador — rojo llamativo */
.call-comment-badge {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  background: #ef4444;
  color: #fff;
  border-radius: 999px;
  font-size: .58rem;
  font-weight: 700;
  padding: .04rem .36rem;
  min-width: 1.15rem;
  line-height: 1.35;
  box-shadow: 0 1px 4px rgba(239,68,68,.45);
}

/* ── Comments tab badge (workspace modal) ────────────────────────────────── */
.fv2-tab-badge {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  background: rgba(99,179,237,.22);
  color: #7dd3fc;
  border-radius: 999px;
  font-size: .62rem;
  font-weight: 700;
  padding: .05rem .38rem;
  min-width: 1.2rem;
  line-height: 1.35;
  margin-left: .22rem;
}

/* ════════════════════════════════════════════════════════════════════════════
   Multi-user picker  (chip-input style)
   ════════════════════════════════════════════════════════════════════════════ */

/* Chip-row (always visible — acts like a tag input) */
.call-upick-chip-row {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: .25rem;
  background: rgba(15,23,42,.92);
  border: 1px solid rgba(148,163,184,.22);
  border-radius: .42rem;
  padding: .28rem .55rem;
  min-height: 2.4rem;
  cursor: text;
  transition: border-color .13s;
}
.call-upick-chip-row:focus-within,
.call-upick-chip-row.is-open {
  border-color: rgba(96,165,250,.55);
}

/* Chip per selected user */
.call-upick-chip-item {
  display: inline-flex;
  align-items: center;
  gap: .2rem;
  background: rgba(59,130,246,.18);
  border: 1px solid rgba(59,130,246,.32);
  border-radius: .3rem;
  color: #93c5fd;
  font-size: .76rem;
  font-weight: 500;
  padding: .1rem .42rem;
  white-space: nowrap;
  user-select: none;
}
.call-upick-chip-avatar {
  width: 1.1rem;
  height: 1.1rem;
  border-radius: 50%;
  background: rgba(59,130,246,.32);
  color: #93c5fd;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-size: .56rem;
  font-weight: 700;
  flex-shrink: 0;
}
.call-upick-chip-remove {
  background: none;
  border: none;
  padding: 0;
  color: rgba(147,197,253,.48);
  cursor: pointer;
  font-size: .58rem;
  line-height: 1;
  transition: color .12s;
  margin-left: .06rem;
}
.call-upick-chip-remove:hover { color: #f87171; }

/* Search input inside chip row */
.call-upick-chip-input {
  flex: 1 1 80px;
  min-width: 60px;
  background: transparent;
  border: none;
  outline: none;
  color: #e2e8f0;
  font-size: .83rem;
  padding: .08rem 0;
}
.call-upick-chip-input::placeholder { color: rgba(148,163,184,.3); }

/* Chevron at end of chip row */
.call-upick-chip-chevron {
  color: rgba(148,163,184,.38);
  font-size: .68rem;
  flex-shrink: 0;
  margin-left: auto;
  transition: transform .15s;
  pointer-events: none;
}
.call-upick-chip-row.is-open .call-upick-chip-chevron { transform: rotate(180deg); }

/* Panel — positioned via JS (position:fixed) */
.call-upick-panel {
  position: fixed;
  z-index: 1060;
  background: #1e293b;
  border: 1px solid rgba(148,163,184,.22);
  border-radius: .42rem;
  box-shadow: 0 8px 28px rgba(0,0,0,.45), 0 2px 8px rgba(0,0,0,.3);
  overflow: hidden;
  min-width: 180px;
}
.call-upick-panel.d-none { display: none !important; }

/* Search inside panel */
.call-upick-search-wrap {
  display: flex;
  align-items: center;
  gap: .35rem;
  padding: .42rem .65rem;
  border-bottom: 1px solid rgba(148,163,184,.1);
  background: rgba(255,255,255,.025);
}
.call-upick-search-wrap i { color: rgba(148,163,184,.45); font-size: .75rem; flex-shrink: 0; }
.call-upick-panel-search {
  flex: 1;
  background: transparent;
  border: none;
  outline: none;
  color: #e2e8f0;
  font-size: .82rem;
}
.call-upick-panel-search::placeholder { color: rgba(148,163,184,.32); }

/* Options list */
.call-upick-options {
  max-height: 220px;
  overflow-y: auto;
  padding: .22rem 0;
  scrollbar-width: thin;
  scrollbar-color: rgba(148,163,184,.18) transparent;
}
.call-upick-opt {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: .38rem;
  width: 100%;
  text-align: left;
  padding: .38rem .65rem;
  background: transparent;
  border: none;
  color: rgba(203,213,225,.78);
  font-size: .83rem;
  cursor: pointer;
  transition: background .12s;
}
.call-upick-opt:hover { background: rgba(255,255,255,.07); color: #e2e8f0; }
.call-upick-opt.is-selected {
  background: rgba(59,130,246,.12);
  color: #93c5fd;
  font-weight: 600;
}

/* Option left group: avatar + name */
.call-upick-opt-left {
  display: flex;
  align-items: center;
  gap: .35rem;
  min-width: 0;
}
.call-upick-opt-avatar {
  width: 1.45rem;
  height: 1.45rem;
  border-radius: 50%;
  background: rgba(100,116,139,.25);
  color: #94a3b8;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-size: .65rem;
  font-weight: 700;
  flex-shrink: 0;
  transition: background .12s, color .12s;
}
.call-upick-opt.is-selected .call-upick-opt-avatar {
  background: rgba(59,130,246,.28);
  color: #93c5fd;
}
.call-upick-opt-name {
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

/* Checkmark icon */
.call-upick-opt-check {
  font-size: .78rem;
  color: #4ade80;
  flex-shrink: 0;
  opacity: 0;
  transition: opacity .12s;
}
.call-upick-opt.is-selected .call-upick-opt-check { opacity: 1; }

/* "Sin asignar" separator at top of list */
.call-upick-opt--none {
  border-bottom: 1px solid rgba(148,163,184,.1);
  margin-bottom: .18rem;
  color: rgba(148,163,184,.5);
  font-style: italic;
  font-size: .8rem;
}
.call-upick-opt--none:hover { background: rgba(255,255,255,.04); color: #94a3b8; }


/* ════════════════════════════════════════════════════════════════════════════
   Cloud save button — callEditorModal header
   ════════════════════════════════════════════════════════════════════════════ */

.call-cloud-save-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 2.1rem;
  height: 2.1rem;
  background: rgba(255,255,255,.06);
  border: 1px solid rgba(148,163,184,.22);
  border-radius: .42rem;
  color: rgba(148,163,184,.65);
  font-size: 1rem;
  cursor: pointer;
  transition: background .13s, color .13s, border-color .13s;
  flex-shrink: 0;
}
.call-cloud-save-btn:hover {
  background: rgba(59,130,246,.15);
  border-color: rgba(59,130,246,.4);
  color: #93c5fd;
}
.call-cloud-save-btn:disabled { opacity: .45; cursor: default; }

/* Success state */
.call-cloud-save-btn.call-cloud-save--ok {
  background: rgba(16,185,129,.18);
  border-color: rgba(16,185,129,.45);
  color: #4ade80;
}
/* Error state */
.call-cloud-save-btn.call-cloud-save--err {
  background: rgba(239,68,68,.15);
  border-color: rgba(239,68,68,.4);
  color: #f87171;
}

/* Spin animation while saving */
@keyframes call-cloud-spin {
  from { transform: translateY(0);   opacity: 1; }
  50%  { transform: translateY(-2px); opacity: .7; }
  to   { transform: translateY(0);   opacity: 1; }
}
.call-cloud-save--spin {
  animation: call-cloud-spin .8s ease infinite;
  display: inline-block;
}


/* ════════════════════════════════════════════════════════════════════════════
   Assignee filter picker — chip-input style (igual que el asignar)
   ════════════════════════════════════════════════════════════════════════════ */

.call-afpick { position: relative; }

/* Chip row (siempre visible) */
.call-afpick-row {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: .22rem;
  background: rgba(15,23,42,.7);
  border: 1px solid rgba(148,163,184,.18);
  border-radius: .38rem;
  padding: .3rem .55rem;
  min-height: 2.25rem;
  cursor: pointer;
  transition: border-color .13s;
  user-select: none;
}
.call-afpick-row:hover    { border-color: rgba(148,163,184,.35); }
.call-afpick-row.is-open  { border-color: rgba(96,165,250,.55); }

.call-afpick-placeholder {
  font-size: .78rem;
  color: rgba(148,163,184,.32);
  flex: 1;
}
.call-afpick-chevron {
  color: rgba(148,163,184,.32);
  font-size: .65rem;
  flex-shrink: 0;
  margin-left: auto;
  transition: transform .15s;
  pointer-events: none;
}
.call-afpick-row.is-open .call-afpick-chevron { transform: rotate(180deg); }

/* Contador de selección en el row (reemplaza chips individuales) */
.call-afpick-count-wrap {
  display: inline-flex;
  align-items: center;
  gap: .3rem;
}
.call-afpick-count-label {
  font-size: .78rem;
  color: #93c5fd;
  font-weight: 600;
  white-space: nowrap;
}
.call-afpick-count-clear {
  background: none;
  border: none;
  padding: 0 .1rem;
  color: rgba(147, 197, 253, .45);
  cursor: pointer;
  font-size: .58rem;
  line-height: 1;
  transition: color .12s;
}
.call-afpick-count-clear:hover { color: #f87171; }

/* Panel */
.call-afpick-panel {
  position: absolute;
  top: calc(100% + 3px);
  left: 0;
  right: 0;
  z-index: 400;
  background: #1e293b;
  border: 1px solid rgba(148,163,184,.22);
  border-radius: .42rem;
  box-shadow: 0 8px 28px rgba(0,0,0,.45);
  overflow: hidden;
}
.call-afpick-panel.d-none { display: none !important; }

.call-afpick-search-wrap {
  display: flex;
  align-items: center;
  gap: .32rem;
  padding: .38rem .6rem;
  border-bottom: 1px solid rgba(148,163,184,.1);
  background: rgba(255,255,255,.02);
}
.call-afpick-search-wrap i { color: rgba(148,163,184,.4); font-size: .72rem; flex-shrink: 0; }
.call-afpick-search {
  flex: 1; background: transparent; border: none; outline: none;
  color: #e2e8f0; font-size: .78rem;
}
.call-afpick-search::placeholder { color: rgba(148,163,184,.28); }

.call-afpick-options {
  max-height: 260px;
  overflow-y: auto;
  padding: .2rem 0;
  scrollbar-width: thin;
  scrollbar-color: rgba(148,163,184,.18) transparent;
}

/* Separador entre opciones especiales y usuarios */
.call-afpick-sep {
  height: 1px;
  background: rgba(148,163,184,.1);
  margin: .18rem .6rem;
}

/* Opción genérica */
.call-afpick-opt {
  display: flex;
  align-items: center;
  gap: .35rem;
  width: 100%;
  text-align: left;
  padding: .34rem .6rem;
  background: transparent;
  border: none;
  color: rgba(203,213,225,.72);
  font-size: .78rem;
  cursor: pointer;
  transition: background .12s;
}
.call-afpick-opt:hover                { background: rgba(255,255,255,.06); color: #e2e8f0; }
.call-afpick-opt.is-selected          { background: rgba(59,130,246,.1); color: #93c5fd; font-weight: 500; }
.call-afpick-opt--special.is-selected { background: rgba(168,85,247,.1); color: #d8b4fe; }

.call-afpick-opt-icon {
  font-size: .7rem; flex-shrink: 0; opacity: .65;
}
.call-afpick-opt-avatar {
  width: 1.3rem; height: 1.3rem; border-radius: 50%;
  background: rgba(100,116,139,.25); color: #94a3b8;
  display: inline-flex; align-items: center; justify-content: center;
  font-size: .58rem; font-weight: 700; flex-shrink: 0;
  transition: background .12s, color .12s;
}
.call-afpick-opt.is-selected .call-afpick-opt-avatar { background: rgba(59,130,246,.28); color: #93c5fd; }
.call-afpick-opt-name { flex: 1; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.call-afpick-opt-check {
  font-size: .7rem; color: #4ade80; flex-shrink: 0;
  opacity: 0; transition: opacity .12s;
}
.call-afpick-opt.is-selected .call-afpick-opt-check { opacity: 1; }


/* ── Header: estado select + asignación picker ────────────────────────────── */

/* Select de estado en el header */
.calls-hdr-select {
  height: 2rem;
  padding: 0 .6rem;
  border-radius: .35rem;
  border: 1px solid rgba(148, 163, 184, .22);
  background: rgba(15, 23, 42, .85);
  color: #e2e8f0;
  font-size: .78rem;
  cursor: pointer;
  outline: none;
  transition: border-color .13s;
  /* quita la flecha nativa en algunos browsers y usa apariencia limpia */
  -webkit-appearance: none;
  appearance: none;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='6'%3E%3Cpath d='M0 0l5 6 5-6z' fill='rgba(148,163,184,.55)'/%3E%3C/svg%3E");
  background-repeat: no-repeat;
  background-position: right .52rem center;
  padding-right: 1.6rem;
  color-scheme: dark;
}
.calls-hdr-select:hover  { border-color: rgba(148, 163, 184, .42); }
.calls-hdr-select:focus  { border-color: rgba(96, 165, 250, .55); }

/* Wrapper afpick en el header: ancho fijo y panel posicionado correctamente */
.calls-hdr-afpick {
  position: relative;
}
.calls-hdr-afpick .call-afpick-row {
  height: 2rem;
  padding: 0 .55rem;
  flex-wrap: nowrap;
  overflow: hidden;
  min-width: 130px;
  max-width: 240px;
}
/* Panel del afpick en header: abre hacia abajo, ancho mínimo */
.calls-hdr-afpick .call-afpick-panel {
  left: 0;
  right: auto;
  min-width: 220px;
  top: calc(100% + 4px);
}

/* Divisor entre filtros y botones de acción */
.calls-hdr-divider {
  width: 1px;
  height: 1.5rem;
  background: rgba(148, 163, 184, .18);
  flex-shrink: 0;
}


/* ── Chips coloreados en la lista ────────────────────────────────────────── */
.calls-chip--phone {
  background: rgba(59, 130, 246, .14);
  border-color: rgba(59, 130, 246, .32);
  color: #93c5fd;
}
.calls-chip--phone i { color: #93c5fd; }

.calls-chip--asig {
  background: rgba(16, 185, 129, .12);
  border-color: rgba(16, 185, 129, .3);
  color: #6ee7b7;
}
.calls-chip--asig i { color: #6ee7b7; }

.calls-chip--fecha {
  background: rgba(100, 116, 139, .18);
  border-color: rgba(100, 116, 139, .32);
  color: #cbd5e1;
}
.calls-chip--fecha i { color: #94a3b8; }


/* ── Badges siempre visibles en dtv-main-header ──────────────────────────── */

/* "hace Xd" — badge azul entre chevron y nombre */
.call-hdr-time-badge {
  display: inline-flex;
  align-items: center;
  gap: .18rem;
  padding: .12rem .45rem;
  border-radius: 6px;
  background: rgba(59, 130, 246, .14);
  border: 1px solid rgba(59, 130, 246, .3);
  color: #93c5fd;
  font-size: .68rem;
  font-weight: 600;
  white-space: nowrap;
  flex-shrink: 0;
  letter-spacing: .01em;
  cursor: default;
}
.call-hdr-time-badge i { font-size: .6rem; opacity: .8; }

/* Avatar del asignado — entre chevron y nombre */
.call-hdr-person-badge {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: .12rem;
  width: 1.45rem;
  height: 1.45rem;
  border-radius: 50%;
  background: rgba(59, 130, 246, .22);
  border: 1px solid rgba(59, 130, 246, .38);
  color: #93c5fd;
  font-size: .62rem;
  font-weight: 700;
  flex-shrink: 0;
  cursor: default;
  letter-spacing: 0;
}
.call-hdr-person-badge .call-hdr-person-extra {
  font-size: .54rem;
  font-weight: 600;
  opacity: .8;
}

/* ── Botón "Asignarme" — editor modal y workspace ────────────────────────── */
.call-assign-me-btn {
  display: inline-flex;
  align-items: center;
  gap: .28rem;
  margin-top: .35rem;
  padding: .18rem .55rem;
  border-radius: .32rem;
  border: 1px solid rgba(148, 163, 184, .2);
  background: transparent;
  color: rgba(148, 163, 184, .55);
  font-size: .73rem;
  font-weight: 500;
  cursor: pointer;
  transition: border-color .13s, color .13s, background .13s;
  white-space: nowrap;
}
.call-assign-me-btn:hover {
  border-color: rgba(96, 165, 250, .45);
  color: #93c5fd;
  background: rgba(59, 130, 246, .08);
}
.call-assign-me-btn.is-me {
  border-color: rgba(16, 185, 129, .38);
  color: #6ee7b7;
  background: rgba(16, 185, 129, .1);
}
.call-assign-me-btn.is-me:hover {
  border-color: rgba(239, 68, 68, .38);
  color: #f87171;
  background: rgba(239, 68, 68, .08);
}


/* ── Responsive ──────────────────────────────────────────────────────────── */

/* 768px–991px: pantallas medianas-chicas */
@media (max-width: 991.98px) {
  .calls-hdr-select {
    height: 1.88rem;
    font-size: .75rem;
    padding: 0 .5rem;
    padding-right: 1.5rem;
  }
  .calls-hdr-afpick .call-afpick-row {
    min-width: 108px;
    max-width: 185px;
    height: 1.88rem;
  }
  #pills-calls .tab-section-header .btn-label { display: none; }
  .call-row-body { gap: .26rem; }
  .calls-chip { font-size: .74rem; }
}

/* ≤ 767px: móvil */
@media (max-width: 767.98px) {
  .calls-hdr-select {
    height: 1.75rem;
    font-size: .72rem;
    padding: 0 .42rem;
    padding-right: 1.3rem;
  }
  .calls-hdr-afpick .call-afpick-row {
    min-width: 88px;
    max-width: 148px;
    height: 1.75rem;
    font-size: .72rem;
  }
  .call-hdr-time-badge { display: none; }
  .call-hdr-person-badge { width: 1.3rem; height: 1.3rem; font-size: .57rem; }
  .dtv-main-header .dtv-name-btn { max-width: 54%; font-size: .83rem; }
  .call-row-body { gap: .2rem; margin-top: .14rem; }
  .call-row-line { gap: .12rem .16rem; }
  .calls-chip { font-size: .7rem; padding: .13rem .36rem; }
  .call-tag { padding: .07rem .34rem; }
  .call-row-tags-strip { padding: .11rem .42rem .15rem; }
  .call-row-obs { padding: .24rem .32rem; gap: .16rem; }
  .call-row-obs-text { font-size: calc(.7rem * var(--calls-fs, 1)); }
  .ph-font-size-ctrl { display: none; }
}
