/* ════════════════════════════════════════════════════════════════════
   TuXiaomi · Captación · CSS

   Todo está scoped a #sec-cap para no afectar al resto del dashboard.
   Las variables CSS se redeclaran localmente con el tema light.
   ════════════════════════════════════════════════════════════════════ */

#sec-cap {
  /* Paleta light, coherente con TuXiaomi (mismas brand colors) */
  --cap-bg:      #f8fafc;
  --cap-panel:   #ffffff;
  --cap-panel-2: #f1f5f9;
  --cap-border:  #e2e8f0;
  --cap-text:    #1e293b;
  --cap-muted:   #64748b;
  --cap-accent:  #2563eb;   /* azul corporativo TuXiaomi */
  --cap-wa:      #25d366;   /* verde WhatsApp */
  --cap-blue:    #2563eb;
  --cap-red:     #dc2626;
  --cap-yellow:  #d97706;
  --cap-green:   #059669;
  --cap-purple:  #7c3aed;
  --cap-orange:  #ea580c;

  color: var(--cap-text);
  font-size: 14px;
}

/* ─── Sub-navegación dentro de la pestaña ─── */
#sec-cap .cap-nav {
  display: flex;
  gap: 4px;
  border-bottom: 2px solid var(--cap-border);
  margin-bottom: 18px;
  overflow-x: auto;
  flex-wrap: nowrap;
}
#sec-cap .cap-navbtn {
  background: none;
  border: none;
  color: var(--cap-muted);
  padding: 11px 16px;
  cursor: pointer;
  font-size: 13px;
  font-weight: 600;
  border-bottom: 3px solid transparent;
  white-space: nowrap;
  transition: all 0.15s;
  margin-bottom: -2px;
  position: relative;
}
#sec-cap .cap-navbtn:hover { color: var(--cap-text); }
#sec-cap .cap-navbtn.active {
  color: var(--cap-accent);
  border-bottom-color: var(--cap-accent);
}
#sec-cap .cap-badge {
  display: none;
  background: var(--cap-red);
  color: #fff;
  font-size: 10px;
  font-weight: 700;
  padding: 2px 6px;
  border-radius: 10px;
  margin-left: 6px;
}

/* ─── Vistas (una activa a la vez) ─── */
#sec-cap .cap-view { display: none; }
#sec-cap .cap-view.active { display: block; }

/* ─── Paneles ─── */
#sec-cap .cap-panel {
  background: var(--cap-panel);
  border: 1px solid var(--cap-border);
  border-radius: 12px;
  padding: 18px 20px;
  margin-bottom: 14px;
}
#sec-cap .cap-panel h2 {
  margin: 0 0 14px;
  font-size: 15px;
  font-weight: 700;
  color: var(--cap-text);
}
#sec-cap .cap-panel h3 {
  margin: 0 0 12px;
  font-size: 14px;
  font-weight: 700;
  color: var(--cap-text);
}

/* ─── KPIs ─── */
#sec-cap .cap-kpi-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(150px, 1fr));
  gap: 12px;
  margin-bottom: 14px;
}
#sec-cap .cap-kpi {
  background: var(--cap-panel);
  border: 1px solid var(--cap-border);
  border-radius: 10px;
  padding: 16px;
}
#sec-cap .cap-kpi-label {
  font-size: 11px;
  font-weight: 700;
  color: var(--cap-muted);
  text-transform: uppercase;
  letter-spacing: 0.6px;
  margin-bottom: 6px;
}
#sec-cap .cap-kpi-value {
  font-size: 22px;
  font-weight: 900;
  color: var(--cap-text);
}
#sec-cap .cap-kpi-sub {
  font-size: 11px;
  color: var(--cap-muted);
  margin-top: 4px;
}
#sec-cap .cap-kpi.blue   .cap-kpi-value { color: var(--cap-blue); }
#sec-cap .cap-kpi.green  .cap-kpi-value { color: var(--cap-green); }
#sec-cap .cap-kpi.red    .cap-kpi-value { color: var(--cap-red); }
#sec-cap .cap-kpi.yellow .cap-kpi-value { color: var(--cap-yellow); }
#sec-cap .cap-kpi.purple .cap-kpi-value { color: var(--cap-purple); }
#sec-cap .cap-kpi.orange .cap-kpi-value { color: var(--cap-orange); }

/* ─── Filtros (barra arriba del listado) ─── */
#sec-cap .cap-filters {
  display: flex;
  gap: 10px;
  flex-wrap: wrap;
  align-items: center;
  margin-bottom: 14px;
}
#sec-cap .cap-filters input,
#sec-cap .cap-filters select {
  padding: 8px 12px;
  border: 1px solid var(--cap-border);
  border-radius: 8px;
  font-size: 13px;
  background: var(--cap-panel);
  color: var(--cap-text);
  outline: none;
  font-family: inherit;
}
#sec-cap .cap-filters input:focus,
#sec-cap .cap-filters select:focus { border-color: var(--cap-accent); }
#sec-cap .cap-filters input[type="text"] { min-width: 220px; flex: 1; }
#sec-cap .cap-pill {
  background: #eff6ff;
  color: var(--cap-blue);
  font-size: 12px;
  font-weight: 700;
  padding: 6px 12px;
  border-radius: 20px;
  margin-left: auto;
}

/* ─── Tabla ─── */
#sec-cap .cap-table-wrap {
  overflow-x: auto;
  background: var(--cap-panel);
  border: 1px solid var(--cap-border);
  border-radius: 12px;
}
#sec-cap .cap-table {
  width: 100%;
  border-collapse: collapse;
  font-size: 13px;
}
#sec-cap .cap-table thead { background: var(--cap-panel-2); }
#sec-cap .cap-table th {
  padding: 11px 14px;
  text-align: left;
  font-weight: 700;
  color: var(--cap-muted);
  font-size: 11px;
  text-transform: uppercase;
  letter-spacing: 0.5px;
  border-bottom: 2px solid var(--cap-border);
  white-space: nowrap;
  cursor: pointer;
  user-select: none;
}
#sec-cap .cap-table th:hover { color: var(--cap-text); }
#sec-cap .cap-table td {
  padding: 10px 14px;
  border-bottom: 1px solid #f1f5f9;
  vertical-align: middle;
}
#sec-cap .cap-table tr:last-child td { border-bottom: none; }
#sec-cap .cap-table tr:hover td { background: #f8fafc; }
#sec-cap .cap-tienda {
  cursor: pointer;
  color: var(--cap-blue);
  font-weight: 600;
}
#sec-cap .cap-tienda:hover { text-decoration: underline; }
#sec-cap .cap-actions { display: flex; gap: 4px; }

/* ─── Badges (prioridad y estado) ─── */
#sec-cap .cap-pri {
  display: inline-block;
  font-size: 11px;
  font-weight: 700;
  padding: 3px 8px;
  border-radius: 5px;
  min-width: 30px;
  text-align: center;
  color: #fff;
}
#sec-cap .cap-pri-aplus { background: var(--cap-red); }
#sec-cap .cap-pri-a     { background: var(--cap-orange); }
#sec-cap .cap-pri-bplus { background: var(--cap-blue); }
#sec-cap .cap-pri-b     { background: var(--cap-muted); }
#sec-cap .cap-pri-c     { background: #94a3b8; }

#sec-cap .cap-estado {
  display: inline-block;
  font-size: 11px;
  font-weight: 700;
  padding: 3px 9px;
  border-radius: 20px;
  white-space: nowrap;
}
#sec-cap .cap-est-sin_contactar { background: #f1f5f9; color: var(--cap-muted); }
#sec-cap .cap-est-contactado    { background: #eff6ff; color: var(--cap-blue); }
#sec-cap .cap-est-sin_respuesta { background: #faf5ff; color: var(--cap-purple); }
#sec-cap .cap-est-negociacion   { background: #fefce8; color: var(--cap-yellow); }
#sec-cap .cap-est-convertido    { background: #f0fdf4; color: var(--cap-green); }
#sec-cap .cap-est-descartado    { background: #fef2f2; color: var(--cap-red); }

/* ─── Botones ─── */
#sec-cap .cap-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 6px 12px;
  border-radius: 7px;
  font-size: 12px;
  font-weight: 700;
  cursor: pointer;
  border: 1px solid var(--cap-border);
  background: var(--cap-panel);
  color: var(--cap-text);
  text-decoration: none;
  transition: all 0.15s;
  white-space: nowrap;
}
#sec-cap .cap-btn:hover { border-color: #94a3b8; }
#sec-cap .cap-btn-primary {
  background: var(--cap-accent);
  color: #fff;
  border-color: var(--cap-accent);
}
#sec-cap .cap-btn-primary:hover { background: #1d4ed8; border-color: #1d4ed8; }
#sec-cap .cap-btn-wa {
  background: var(--cap-wa);
  color: #fff;
  border-color: var(--cap-wa);
}
#sec-cap .cap-btn-wa:hover { background: #1faa53; border-color: #1faa53; }
#sec-cap .cap-btn-danger {
  background: var(--cap-red);
  color: #fff;
  border-color: var(--cap-red);
}
#sec-cap .cap-btn-danger:hover { background: #b91c1c; border-color: #b91c1c; }
#sec-cap .cap-btn-large { padding: 10px 18px; font-size: 13px; }

/* ─── Form grid (modal) ─── */
#sec-cap .cap-form-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 14px;
  margin-bottom: 16px;
}
#sec-cap .cap-form-group { display: flex; flex-direction: column; }
#sec-cap .cap-form-group.full { grid-column: 1 / -1; }
#sec-cap .cap-form-group label {
  font-size: 11px;
  font-weight: 700;
  color: var(--cap-muted);
  text-transform: uppercase;
  letter-spacing: 0.4px;
  margin-bottom: 5px;
}
#sec-cap .cap-form-group input,
#sec-cap .cap-form-group select,
#sec-cap .cap-form-group textarea {
  padding: 9px 12px;
  border: 1px solid var(--cap-border);
  border-radius: 8px;
  font-size: 13px;
  background: var(--cap-panel);
  color: var(--cap-text);
  outline: none;
  font-family: inherit;
}
#sec-cap .cap-form-group input:focus,
#sec-cap .cap-form-group select:focus,
#sec-cap .cap-form-group textarea:focus { border-color: var(--cap-accent); }
#sec-cap .cap-form-group textarea { resize: vertical; min-height: 60px; }

/* ─── Modal ─── */
.cap-modal-bg {
  display: none;
  position: fixed;
  inset: 0;
  background: rgba(15, 23, 42, 0.6);
  z-index: 1000;
  align-items: flex-start;
  justify-content: center;
  padding: 30px 20px;
  overflow-y: auto;
}
.cap-modal-bg.show { display: flex; }
.cap-modal {
  background: var(--cap-bg, #f8fafc);
  border-radius: 14px;
  width: 100%;
  max-width: 720px;
  padding: 22px;
  box-shadow: 0 24px 80px rgba(0, 0, 0, 0.25);
  color: var(--cap-text, #1e293b);
}
.cap-modal-header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-bottom: 18px;
  padding-bottom: 12px;
  border-bottom: 1px solid var(--cap-border, #e2e8f0);
}
.cap-modal-title {
  font-size: 17px;
  font-weight: 800;
  color: var(--cap-text, #1e293b);
}
.cap-modal-close {
  background: none;
  border: none;
  font-size: 24px;
  cursor: pointer;
  color: var(--cap-muted, #64748b);
  line-height: 1;
}
.cap-modal-close:hover { color: var(--cap-red, #dc2626); }
.cap-modal .cap-panel { background: #fff; }

/* ─── Historial ─── */
#sec-cap .cap-historial,
.cap-modal .cap-historial {
  max-height: 320px;
  overflow-y: auto;
  padding-right: 4px;
}
#sec-cap .cap-hist-empty,
.cap-modal .cap-hist-empty {
  padding: 16px;
  text-align: center;
  color: var(--cap-muted, #64748b);
  font-size: 13px;
}
#sec-cap .cap-hist-item,
.cap-modal .cap-hist-item {
  padding: 10px 12px;
  background: #f8fafc;
  border-radius: 8px;
  margin-bottom: 6px;
  border-left: 3px solid var(--cap-accent, #2563eb);
}
.cap-hist-meta {
  font-size: 11px;
  color: var(--cap-muted, #64748b);
  margin-bottom: 4px;
}
.cap-hist-user { font-weight: 700; color: var(--cap-text, #1e293b); }
.cap-hist-text {
  font-size: 13px;
  color: var(--cap-text, #1e293b);
  white-space: pre-wrap;
}

/* ─── Tareas ─── */
#sec-cap .cap-tareas-summary {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(120px, 1fr));
  gap: 10px;
  margin-top: 8px;
}
#sec-cap .cap-tarea-stat {
  padding: 10px 14px;
  border-radius: 8px;
  text-align: center;
  font-size: 13px;
  font-weight: 600;
  border: 1px solid var(--cap-border);
}
#sec-cap .cap-tarea-stat b { font-size: 18px; display: inline-block; margin: 0 4px; }
#sec-cap .cap-tarea-stat-red    { background: #fef2f2; color: var(--cap-red); }
#sec-cap .cap-tarea-stat-orange { background: #fff7ed; color: var(--cap-orange); }
#sec-cap .cap-tarea-stat-yellow { background: #fefce8; color: var(--cap-yellow); }
#sec-cap .cap-tarea-stat-blue   { background: #eff6ff; color: var(--cap-blue); }
#sec-cap .cap-tarea-card {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 10px 12px;
  border: 1px solid var(--cap-border);
  border-radius: 8px;
  margin-bottom: 8px;
  gap: 12px;
}
#sec-cap .cap-tarea-main { flex: 1; min-width: 0; }
#sec-cap .cap-tarea-title { display: flex; gap: 6px; align-items: center; font-size: 13px; cursor: pointer; }
#sec-cap .cap-tarea-title:hover { text-decoration: underline; color: var(--cap-blue); }
#sec-cap .cap-tarea-prov { color: var(--cap-muted); font-size: 12px; }
#sec-cap .cap-tarea-action { font-size: 12px; color: var(--cap-muted); margin: 4px 0; }
#sec-cap .cap-tarea-meta { font-size: 11px; color: var(--cap-muted); }
#sec-cap .cap-tarea-actions { display: flex; gap: 6px; flex-wrap: wrap; align-items: center; }

/* ─── Plantillas ─── */
#sec-cap .cap-plantilla {
  background: var(--cap-panel);
  border: 1px solid var(--cap-border);
  border-radius: 10px;
  padding: 14px;
  margin-bottom: 12px;
}
#sec-cap .cap-plantilla h4 { margin: 0 0 8px; font-size: 13px; }
#sec-cap .cap-plantilla textarea {
  width: 100%;
  min-height: 120px;
  padding: 10px;
  border: 1px solid var(--cap-border);
  border-radius: 8px;
  font-family: inherit;
  font-size: 13px;
  resize: vertical;
  background: var(--cap-panel);
  color: var(--cap-text);
}
#sec-cap .cap-plantilla .hint {
  margin-top: 6px;
  font-size: 11px;
  color: var(--cap-muted);
}

/* ─── Toast ─── */
.cap-toast {
  position: fixed;
  bottom: 22px;
  right: 22px;
  background: var(--cap-green);
  color: #fff;
  padding: 12px 18px;
  border-radius: 10px;
  font-size: 13px;
  font-weight: 600;
  box-shadow: 0 10px 25px rgba(0, 0, 0, 0.18);
  opacity: 0;
  transform: translateY(20px);
  transition: all 0.25s;
  pointer-events: none;
  z-index: 1100;
}
.cap-toast.show { opacity: 1; transform: translateY(0); }
.cap-toast.error { background: var(--cap-red); }

/* ─── Empty state ─── */
#sec-cap .cap-empty {
  padding: 30px;
  text-align: center;
  color: var(--cap-muted);
  font-size: 13px;
}

/* ─── Pipeline bars (dashboard) ─── */
#sec-cap .cap-pipeline-row { margin-bottom: 8px; }
#sec-cap .cap-pipeline-head {
  display: flex;
  justify-content: space-between;
  font-size: 12px;
  margin-bottom: 4px;
  color: var(--cap-text);
}
#sec-cap .cap-pipeline-bg {
  background: var(--cap-panel-2);
  height: 8px;
  border-radius: 4px;
  overflow: hidden;
}
#sec-cap .cap-pipeline-fill {
  height: 100%;
  transition: width 0.3s;
}

/* ─── Recordatorios dashboard ─── */
#sec-cap .cap-recordatorio {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 8px 12px;
  background: var(--cap-panel-2);
  border-radius: 8px;
  margin-bottom: 6px;
  border-left: 3px solid var(--cap-accent);
  cursor: pointer;
}
#sec-cap .cap-recordatorio:hover { background: #e2e8f0; }

/* ─── Embudo y ranking (reportes) ─── */
#sec-cap .cap-embudo-row {
  display: flex;
  align-items: center;
  gap: 10px;
  margin-bottom: 8px;
}
#sec-cap .cap-embudo-label {
  min-width: 140px;
  font-size: 13px;
  font-weight: 600;
}
#sec-cap .cap-embudo-bar-cont {
  flex: 1;
  background: var(--cap-panel-2);
  border-radius: 8px;
  height: 28px;
  overflow: hidden;
  position: relative;
}
#sec-cap .cap-embudo-bar {
  height: 100%;
  transition: width 0.4s;
}
#sec-cap .cap-embudo-text {
  position: absolute;
  inset: 0;
  display: flex;
  align-items: center;
  padding-left: 10px;
  font-size: 12px;
  font-weight: 700;
  color: var(--cap-text);
}

#sec-cap .cap-rank-row {
  display: grid;
  grid-template-columns: 30px 90px 1fr 90px;
  gap: 10px;
  align-items: center;
  padding: 8px 12px;
  margin-bottom: 4px;
  border-radius: 8px;
}
#sec-cap .cap-rank-row:hover { background: var(--cap-panel-2); }
#sec-cap .cap-rank-name { font-weight: 700; }
#sec-cap .cap-rank-bar-container {
  position: relative;
  background: var(--cap-panel-2);
  border-radius: 6px;
  height: 22px;
  overflow: hidden;
}
#sec-cap .cap-rank-bar {
  height: 100%;
  background: var(--cap-accent);
}
#sec-cap .cap-rank-bar-text {
  position: absolute;
  inset: 0;
  display: flex;
  align-items: center;
  padding-left: 8px;
  font-size: 11px;
  font-weight: 600;
  color: var(--cap-text);
}

/* ─── Responsive ─── */
@media (max-width: 760px) {
  #sec-cap .hide-mobile { display: none; }
  #sec-cap .cap-form-grid { grid-template-columns: 1fr; }
  #sec-cap .cap-filters input[type="text"] { width: 100%; }
}
