/* ============================================================
   TRAVELDESK — Estilos de módulos
   Dashboard, Expedientes, Clientes, etc.
   ============================================================ */

/* ── Vistas ── */
.view { animation: fadeIn 150ms ease; }
@keyframes fadeIn { from { opacity: 0; transform: translateY(4px); } to { opacity: 1; transform: none; } }

/* ============================================================
   DASHBOARD
   ============================================================ */

.dashboard-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  grid-template-rows: auto auto auto;
  gap: var(--space-5);
}

.dashboard-stats {
  grid-column: 1 / -1;
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: var(--space-4);
}

.dash-stat {
  background: white;
  border: 1px solid var(--td-gray-200);
  border-radius: var(--radius-md);
  padding: var(--space-5);
  display: flex;
  align-items: flex-start;
  gap: var(--space-4);
}

.dash-stat-icon {
  width: 44px;
  height: 44px;
  border-radius: var(--radius-md);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 1.3rem;
  flex-shrink: 0;
}

.dash-stat-icon.blue   { background: #DBEAFE; }
.dash-stat-icon.green  { background: #D1FAE5; }
.dash-stat-icon.amber  { background: #FEF3C7; }
.dash-stat-icon.violet { background: #EDE9FE; }

.dash-stat-info { flex: 1; }
.dash-stat-label { font-size: var(--font-size-xs); color: var(--td-gray-500); font-weight: 500; text-transform: uppercase; letter-spacing: 0.04em; }
.dash-stat-value { font-size: 1.6rem; font-weight: 800; color: var(--td-gray-900); line-height: 1.2; margin: var(--space-1) 0; }
.dash-stat-sub { font-size: var(--font-size-xs); color: var(--td-gray-400); }
.dash-stat-sub .up { color: var(--td-success-dark); font-weight: 600; }
.dash-stat-sub .down { color: var(--td-danger); font-weight: 600; }

/* Accesos directos */
.quick-access {
  background: white;
  border: 1px solid var(--td-gray-200);
  border-radius: var(--radius-md);
  overflow: hidden;
}

.quick-access-item {
  display: flex;
  align-items: center;
  gap: var(--space-3);
  padding: var(--space-3) var(--space-4);
  border-bottom: 1px solid var(--td-gray-100);
  cursor: pointer;
  transition: background var(--transition-fast);
  text-decoration: none;
  color: inherit;
}

.quick-access-item:last-child { border-bottom: none; }
.quick-access-item:hover { background: var(--td-gray-50); }

.quick-access-item .qa-icon {
  width: 32px;
  height: 32px;
  border-radius: var(--radius);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 0.9rem;
  flex-shrink: 0;
}

.quick-access-item .qa-content { flex: 1; min-width: 0; }
.quick-access-item .qa-title { font-size: var(--font-size-sm); font-weight: 500; color: var(--td-gray-800); truncate: true; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.quick-access-item .qa-sub { font-size: var(--font-size-xs); color: var(--td-gray-400); }
.quick-access-item .qa-badge { font-size: var(--font-size-xs); }

/* Agenda del día */
.agenda-empty {
  padding: var(--space-8);
  text-align: center;
  color: var(--td-gray-400);
}

.agenda-item {
  display: flex;
  gap: var(--space-3);
  padding: var(--space-3) var(--space-5);
  border-bottom: 1px solid var(--td-gray-100);
}

.agenda-item:last-child { border-bottom: none; }

.agenda-date {
  text-align: center;
  min-width: 40px;
}

.agenda-date .day { font-size: 1.3rem; font-weight: 800; color: var(--td-primary); line-height: 1; }
.agenda-date .month { font-size: var(--font-size-xs); color: var(--td-gray-400); text-transform: uppercase; }

.agenda-content { flex: 1; }
.agenda-title { font-size: var(--font-size-sm); font-weight: 500; color: var(--td-gray-800); }
.agenda-sub { font-size: var(--font-size-xs); color: var(--td-gray-400); margin-top: 2px; }

/* Actividades pendientes en dashboard */
.activity-item {
  display: flex;
  align-items: flex-start;
  gap: var(--space-3);
  padding: var(--space-3) var(--space-5);
  border-bottom: 1px solid var(--td-gray-100);
  cursor: pointer;
  transition: background var(--transition-fast);
}

.activity-item:last-child { border-bottom: none; }
.activity-item:hover { background: var(--td-gray-50); }

.activity-dot {
  width: 8px;
  height: 8px;
  border-radius: 50%;
  margin-top: 5px;
  flex-shrink: 0;
}

.activity-content { flex: 1; }
.activity-title { font-size: var(--font-size-sm); font-weight: 500; color: var(--td-gray-800); }
.activity-meta { font-size: var(--font-size-xs); color: var(--td-gray-400); margin-top: 2px; }
.activity-overdue { color: var(--td-danger); }

/* ============================================================
   EXPEDIENTES
   ============================================================ */

.exp-card {
  background: white;
  border: 1px solid var(--td-gray-200);
  border-radius: var(--radius-md);
  overflow: hidden;
  transition: box-shadow var(--transition), border-color var(--transition);
  cursor: pointer;
}

.exp-card:hover {
  box-shadow: var(--shadow-md);
  border-color: var(--td-gray-300);
}

.exp-card-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: var(--space-4);
  border-bottom: 1px solid var(--td-gray-100);
}

.exp-card-body { padding: var(--space-4); }

.exp-card-footer {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: var(--space-3) var(--space-4);
  background: var(--td-gray-50);
  border-top: 1px solid var(--td-gray-100);
}

/* Fila de expediente en tabla */
.exp-row-status {
  display: flex;
  align-items: center;
  gap: var(--space-2);
  font-size: var(--font-size-sm);
  font-weight: 500;
}

/* Resumen financiero compacto */
.fin-row {
  display: flex;
  gap: var(--space-4);
  flex-wrap: wrap;
}

.fin-col {
  display: flex;
  flex-direction: column;
  gap: 2px;
}

.fin-col .label {
  font-size: var(--font-size-xs);
  color: var(--td-gray-400);
  text-transform: uppercase;
  letter-spacing: 0.04em;
}

.fin-col .value {
  font-size: var(--font-size-sm);
  font-weight: 700;
  color: var(--td-gray-900);
}

.fin-col .value.pending { color: var(--td-warning-dark); }
.fin-col .value.ok { color: var(--td-success-dark); }
.fin-col .value.alert { color: var(--td-danger); }

/* ============================================================
   CLIENTES
   ============================================================ */

.client-avatar-lg {
  width: 56px;
  height: 56px;
  border-radius: 50%;
  background: var(--td-primary);
  color: white;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 1.2rem;
  font-weight: 700;
  flex-shrink: 0;
}

.client-header-row {
  display: flex;
  align-items: center;
  gap: var(--space-4);
}

.client-meta {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-3);
  align-items: center;
}

.client-meta-item {
  display: flex;
  align-items: center;
  gap: var(--space-1);
  font-size: var(--font-size-xs);
  color: var(--td-gray-500);
}

/* ============================================================
   SERVICIOS
   ============================================================ */

.service-row {
  display: flex;
  align-items: center;
  gap: var(--space-3);
  padding: var(--space-3) var(--space-4);
  border-bottom: 1px solid var(--td-gray-100);
  transition: background var(--transition-fast);
}

.service-row:last-child { border-bottom: none; }
.service-row:hover { background: var(--td-gray-50); }

.service-type-icon {
  width: 36px;
  height: 36px;
  border-radius: var(--radius);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 1rem;
  flex-shrink: 0;
}

.service-info { flex: 1; min-width: 0; }
.service-name { font-size: var(--font-size-sm); font-weight: 500; color: var(--td-gray-800); }
.service-detail { font-size: var(--font-size-xs); color: var(--td-gray-400); }
.service-price { text-align: right; flex-shrink: 0; }
.service-price .pvp { font-weight: 700; color: var(--td-gray-900); }
.service-price .neto { font-size: var(--font-size-xs); color: var(--td-gray-400); }

/* Botón agregar servicio */
.add-service-btn {
  display: flex;
  align-items: center;
  gap: var(--space-2);
  padding: var(--space-3) var(--space-4);
  color: var(--td-primary);
  font-size: var(--font-size-sm);
  font-weight: 500;
  cursor: pointer;
  border: none;
  background: none;
  width: 100%;
  text-align: left;
  border-top: 1px dashed var(--td-gray-200);
  transition: background var(--transition-fast);
}

.add-service-btn:hover { background: var(--td-primary-50); }

/* ============================================================
   PRESUPUESTOS
   ============================================================ */

.budget-status {
  display: inline-flex;
  align-items: center;
  gap: var(--space-1);
  padding: 0.25rem var(--space-3);
  border-radius: var(--radius-full);
  font-size: var(--font-size-xs);
  font-weight: 600;
}

.budget-status.borrador   { background: var(--td-gray-100); color: var(--td-gray-600); }
.budget-status.enviado    { background: var(--td-info-light); color: var(--td-info-dark); }
.budget-status.aceptado   { background: var(--td-success-light); color: var(--td-success-dark); }
.budget-status.rechazado  { background: var(--td-danger-light); color: var(--td-danger-dark); }
.budget-status.expirado   { background: var(--td-gray-100); color: var(--td-gray-400); }

/* ============================================================
   FACTURAS
   ============================================================ */

.invoice-total-row {
  display: flex;
  justify-content: flex-end;
  padding: var(--space-4) var(--space-5);
  background: var(--td-gray-50);
  border-top: 2px solid var(--td-gray-200);
}

.invoice-totals {
  display: flex;
  flex-direction: column;
  gap: var(--space-2);
  min-width: 240px;
}

.total-line {
  display: flex;
  justify-content: space-between;
  font-size: var(--font-size-sm);
  color: var(--td-gray-600);
}

.total-line.grand {
  font-weight: 700;
  font-size: var(--font-size-md);
  color: var(--td-gray-900);
  padding-top: var(--space-2);
  border-top: 1px solid var(--td-gray-300);
  margin-top: var(--space-1);
}

/* ============================================================
   CRM — ACTIVIDADES Y NOTAS
   ============================================================ */

.crm-activity {
  display: flex;
  gap: var(--space-3);
  padding: var(--space-3) 0;
  border-bottom: 1px solid var(--td-gray-100);
}

.crm-activity:last-child { border-bottom: none; }

.crm-activity-icon {
  width: 32px;
  height: 32px;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 0.85rem;
  flex-shrink: 0;
  background: var(--td-gray-100);
}

.crm-activity-content { flex: 1; }
.crm-activity-title { font-size: var(--font-size-sm); font-weight: 500; color: var(--td-gray-800); }
.crm-activity-meta { font-size: var(--font-size-xs); color: var(--td-gray-400); margin-top: 2px; }
.crm-activity-desc { font-size: var(--font-size-sm); color: var(--td-gray-600); margin-top: var(--space-1); line-height: 1.5; }

/* Nota de CRM */
.crm-note {
  background: var(--td-accent-50);
  border: 1px solid var(--td-accent-100);
  border-radius: var(--radius);
  padding: var(--space-3) var(--space-4);
  margin-bottom: var(--space-3);
}

.crm-note .note-header {
  display: flex;
  justify-content: space-between;
  margin-bottom: var(--space-2);
}

.crm-note .note-author {
  font-size: var(--font-size-xs);
  font-weight: 600;
  color: var(--td-gray-600);
}

.crm-note .note-date {
  font-size: var(--font-size-xs);
  color: var(--td-gray-400);
}

.crm-note .note-text {
  font-size: var(--font-size-sm);
  color: var(--td-gray-700);
  line-height: 1.6;
}

/* Recordatorio urgente */
.reminder-urgent {
  display: flex;
  align-items: center;
  gap: var(--space-3);
  padding: var(--space-3) var(--space-4);
  background: var(--td-danger-light);
  border: 1px solid #FECACA;
  border-radius: var(--radius);
  margin-bottom: var(--space-2);
}

.reminder-urgent .reminder-icon { font-size: 1.1rem; flex-shrink: 0; }
.reminder-urgent .reminder-text { flex: 1; }
.reminder-urgent .reminder-title { font-size: var(--font-size-sm); font-weight: 600; color: var(--td-danger-dark); }
.reminder-urgent .reminder-client { font-size: var(--font-size-xs); color: var(--td-gray-500); }

/* ============================================================
   CONFIGURACIÓN
   ============================================================ */

.settings-section {
  background: white;
  border: 1px solid var(--td-gray-200);
  border-radius: var(--radius-md);
  overflow: hidden;
  margin-bottom: var(--space-5);
}

.settings-section-header {
  padding: var(--space-4) var(--space-6);
  border-bottom: 1px solid var(--td-gray-200);
  background: var(--td-gray-50);
}

.settings-section-title {
  font-size: var(--font-size-sm);
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.05em;
  color: var(--td-gray-600);
}

.settings-section-desc {
  font-size: var(--font-size-xs);
  color: var(--td-gray-400);
  margin-top: 2px;
}

.settings-section-body {
  padding: var(--space-6);
}

/* Color picker simple */
.color-picker-group {
  display: flex;
  align-items: center;
  gap: var(--space-3);
}

.color-swatch {
  width: 36px;
  height: 36px;
  border-radius: var(--radius);
  border: 2px solid var(--td-gray-200);
  cursor: pointer;
  transition: border-color var(--transition);
}

.color-swatch:hover { border-color: var(--td-gray-400); }
.color-swatch input[type="color"] { opacity: 0; position: absolute; width: 0; height: 0; }

/* Estado item en configuración */
.status-config-item {
  display: flex;
  align-items: center;
  gap: var(--space-3);
  padding: var(--space-3) var(--space-4);
  border: 1px solid var(--td-gray-200);
  border-radius: var(--radius);
  background: white;
  margin-bottom: var(--space-2);
  cursor: grab;
}

.status-config-item:active { cursor: grabbing; }

.status-drag-handle {
  color: var(--td-gray-300);
  cursor: grab;
  font-size: 1.1rem;
}

.status-color-dot {
  width: 12px;
  height: 12px;
  border-radius: 50%;
  flex-shrink: 0;
}

.status-config-name {
  flex: 1;
  font-size: var(--font-size-sm);
  font-weight: 500;
}

/* Logo upload */
.logo-upload-area {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: var(--space-3);
  padding: var(--space-8);
  border: 2px dashed var(--td-gray-300);
  border-radius: var(--radius-md);
  cursor: pointer;
  transition: all var(--transition);
  text-align: center;
}

.logo-upload-area:hover {
  border-color: var(--td-primary);
  background: var(--td-primary-50);
}

.logo-upload-area .upload-icon { font-size: 2rem; opacity: 0.4; }
.logo-upload-area .upload-text { font-size: var(--font-size-sm); color: var(--td-gray-500); }
.logo-upload-area .upload-hint { font-size: var(--font-size-xs); color: var(--td-gray-400); }

.logo-preview {
  width: 120px;
  height: 60px;
  object-fit: contain;
  border: 1px solid var(--td-gray-200);
  border-radius: var(--radius);
  padding: var(--space-2);
}

/* ============================================================
   PROVEEDORES
   ============================================================ */

.supplier-type-badge {
  display: inline-flex;
  align-items: center;
  gap: var(--space-1);
  padding: 0.2rem var(--space-2);
  background: var(--td-gray-100);
  border-radius: var(--radius-sm);
  font-size: var(--font-size-xs);
  color: var(--td-gray-600);
  font-weight: 500;
}

/* ============================================================
   FORMULARIO DE EXPEDIENTE (detalle)
   ============================================================ */

.exp-detail-header {
  background: linear-gradient(135deg, var(--td-primary) 0%, var(--td-primary-light) 100%);
  border-radius: var(--radius-md);
  padding: var(--space-6);
  color: white;
  margin-bottom: var(--space-5);
}

.exp-detail-number {
  font-family: 'Courier New', monospace;
  font-size: 0.75rem;
  font-weight: 700;
  background: rgba(255,255,255,0.15);
  padding: 0.2rem 0.5rem;
  border-radius: var(--radius-sm);
  letter-spacing: 0.05em;
  display: inline-block;
  margin-bottom: var(--space-2);
}

.exp-detail-title {
  font-size: 1.4rem;
  font-weight: 800;
  margin-bottom: var(--space-1);
}

.exp-detail-meta {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-4);
  opacity: 0.8;
  font-size: var(--font-size-sm);
}

.exp-detail-financials {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 0;
  margin-top: var(--space-4);
  border-top: 1px solid rgba(255,255,255,0.15);
  padding-top: var(--space-4);
}

.exp-detail-fin-item {
  text-align: center;
  border-right: 1px solid rgba(255,255,255,0.15);
  padding: 0 var(--space-4);
}

.exp-detail-fin-item:first-child { padding-left: 0; }
.exp-detail-fin-item:last-child { border-right: none; padding-right: 0; }

.exp-detail-fin-label {
  font-size: var(--font-size-xs);
  opacity: 0.6;
  text-transform: uppercase;
  letter-spacing: 0.04em;
}

.exp-detail-fin-value {
  font-size: 1.1rem;
  font-weight: 700;
  margin-top: 2px;
}

.exp-detail-fin-value.amber { color: var(--td-accent-light); }
.exp-detail-fin-value.green { color: #6EE7B7; }
.exp-detail-fin-value.red { color: #FCA5A5; }

/* ============================================================
   NÚMEROS Y MONTOS
   ============================================================ */

.amount-display {
  font-variant-numeric: tabular-nums;
  font-weight: 600;
}

/* ============================================================
   PLAN BADGE (sidebar)
   ============================================================ */

.plan-badge-free    { color: var(--td-gray-400); }
.plan-badge-trial   { color: #A78BFA; }
.plan-badge-starter { color: #60A5FA; }
.plan-badge-pro     { color: var(--td-accent-light); }
.plan-badge-agency  { color: #6EE7B7; }

/* ============================================================
   VIEW LAYOUT (compartido por todos los módulos)
   ============================================================ */

.view-wrap {
  padding: var(--space-6);
  max-width: 1400px;
  margin: 0 auto;
}

.view-header {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: var(--space-4);
  margin-bottom: var(--space-6);
}

.view-title {
  font-size: 1.5rem;
  font-weight: 700;
  color: var(--td-gray-900);
  margin: 0;
}

.view-subtitle {
  font-size: 0.85rem;
  color: var(--td-gray-500);
  margin: 0.25rem 0 0;
}

.view-actions { display: flex; gap: var(--space-2); align-items: center; flex-shrink: 0; }

.view-filters {
  display: flex;
  gap: var(--space-3);
  margin-bottom: var(--space-5);
  flex-wrap: wrap;
  align-items: center;
}

.filter-search { flex: 1; min-width: 200px; max-width: 360px; }

.table-wrap { background: white; border: 1px solid var(--td-gray-200); border-radius: var(--radius-lg); overflow: hidden; }

/* ── Entity name (avatar + text) ── */
.entity-name { display: flex; align-items: center; gap: var(--space-2); }
.avatar-xs { width: 24px; height: 24px; border-radius: 50%; background: var(--td-primary-100); color: var(--td-primary); font-size: 0.6rem; font-weight: 700; display: flex; align-items: center; justify-content: center; }
.avatar-sm { width: 32px; height: 32px; border-radius: 50%; background: var(--td-primary-100); color: var(--td-primary); font-size: 0.72rem; font-weight: 700; display: flex; align-items: center; justify-content: center; flex-shrink: 0; }

/* ── Row actions ── */
.row-actions { display: flex; gap: 2px; opacity: 0; transition: opacity 150ms; }
tr:hover .row-actions { opacity: 1; }

/* ── Code badges ── */
.code-badge { background: var(--td-gray-100); color: var(--td-gray-700); padding: 2px 7px; border-radius: 4px; font-family: monospace; font-size: 0.8rem; font-weight: 600; }
.code-badge-sm { font-size: 0.72rem; padding: 1px 5px; }

/* ── Clickable rows ── */
tr.clickable { cursor: pointer; }
tr.clickable:hover td { background: var(--td-gray-50); }

/* ── Text utilities ── */
.text-warning { color: var(--td-warning); }
.text-success { color: var(--td-success); }
.text-danger  { color: var(--td-danger); }
.text-muted   { color: var(--td-gray-400); }

/* ── Loading ── */
.td-loading { display: flex; align-items: center; justify-content: center; height: 300px; }
.td-spinner { width: 36px; height: 36px; border: 3px solid var(--td-gray-200); border-top-color: var(--td-primary); border-radius: 50%; animation: spin 0.7s linear infinite; }
@keyframes spin { to { transform: rotate(360deg); } }

/* ── Empty state ── */
.td-empty { display: flex; flex-direction: column; align-items: center; justify-content: center; padding: var(--space-16) var(--space-8); gap: var(--space-3); text-align: center; }
.td-empty span { font-size: 3rem; opacity: 0.3; }
.td-empty p { color: var(--td-gray-400); font-size: 0.9rem; margin: 0; }
.td-empty-sm { padding: var(--space-8) var(--space-4); }
.td-empty-sm span { font-size: 2rem; }

/* ── Info banner ── */
.td-info-banner { display: flex; gap: var(--space-3); padding: var(--space-4); background: #EFF6FF; border: 1px solid #BFDBFE; border-radius: var(--radius-md); color: var(--td-gray-600); font-size: 0.85rem; line-height: 1.5; }
.td-info-banner strong { display: block; color: var(--td-gray-800); margin-bottom: 0.25rem; }
.td-info-banner p { margin: 0; }

/* ── Alert ── */
.td-alert { display: flex; align-items: center; gap: var(--space-3); padding: var(--space-3) var(--space-4); border-radius: var(--radius-md); font-size: 0.85rem; margin-bottom: var(--space-4); }
.td-alert-warning { background: #FFFBEB; border: 1px solid #FDE68A; color: #92400E; }

/* ============================================================
   DASHBOARD — nuevo layout
   ============================================================ */

.dash-greeting {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: var(--space-6);
}
.dash-title { font-size: 1.6rem; font-weight: 700; color: var(--td-gray-900); margin: 0; }
.dash-subtitle { color: var(--td-gray-500); margin: 0.25rem 0 0; font-size: 0.9rem; }
.dash-date { color: var(--td-gray-400); font-size: 0.82rem; text-align: right; }

.stats-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: var(--space-4);
  margin-bottom: var(--space-6);
}
.stats-grid-sm { grid-template-columns: repeat(2, 1fr); }
.stats-grid-4 { grid-template-columns: repeat(4, 1fr); }

@media (max-width: 1100px) { .stats-grid { grid-template-columns: repeat(2, 1fr); } .stats-grid-4 { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 600px) { .stats-grid { grid-template-columns: 1fr; } .stats-grid-4 { grid-template-columns: repeat(2, 1fr); } }

.stat-card {
  background: white;
  border: 1px solid var(--td-gray-200);
  border-radius: var(--radius-lg);
  padding: var(--space-5);
  display: flex;
  align-items: flex-start;
  gap: var(--space-3);
  transition: box-shadow 150ms, transform 150ms;
}
.stat-card:hover { box-shadow: var(--shadow-md); transform: translateY(-1px); }

.stat-icon { font-size: 1.6rem; line-height: 1; padding-top: 2px; }
.stat-value { font-size: 1.5rem; font-weight: 800; color: var(--td-gray-900); line-height: 1; }
.stat-label { font-size: 0.78rem; color: var(--td-gray-500); margin-top: 4px; }

.stat-card--primary .stat-value { color: var(--td-primary); }
.stat-card--warning .stat-value { color: #D97706; }
.stat-card--success .stat-value { color: #059669; }
.stat-card--info .stat-value { color: #0891B2; }
.stat-card--accent .stat-value { color: var(--td-accent); }

/* Dashboard body */
.dash-body { display: grid; grid-template-columns: 1fr 340px; gap: var(--space-5); }
@media (max-width: 1100px) { .dash-body { grid-template-columns: 1fr; } }

.dash-col-side { display: flex; flex-direction: column; gap: var(--space-4); }

.dash-card { background: white; border: 1px solid var(--td-gray-200); border-radius: var(--radius-lg); overflow: hidden; }
.dash-card-header { display: flex; align-items: center; justify-content: space-between; padding: var(--space-4) var(--space-5); border-bottom: 1px solid var(--td-gray-100); }
.dash-card-title { font-size: 0.9rem; font-weight: 600; color: var(--td-gray-800); margin: 0; }
.dash-card-body { overflow-x: auto; }

/* Quick actions */
.quick-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 1px; background: var(--td-gray-100); }
.quick-btn { display: flex; flex-direction: column; align-items: center; gap: var(--space-2); padding: var(--space-4); background: white; border: none; cursor: pointer; font-size: 0.8rem; color: var(--td-gray-600); font-family: inherit; transition: background 150ms; text-align: center; }
.quick-btn:hover { background: var(--td-gray-50); color: var(--td-primary); }
.quick-icon { font-size: 1.4rem; }

/* Agenda */
.dash-agenda { padding: var(--space-2); display: flex; flex-direction: column; gap: 1px; }
.agenda-item { display: flex; align-items: flex-start; gap: var(--space-2); padding: var(--space-2) var(--space-3); border-radius: var(--radius-sm); transition: background 150ms; }
.agenda-item:hover { background: var(--td-gray-50); }
.agenda-icon { font-size: 1rem; flex-shrink: 0; padding-top: 1px; }
.agenda-body { flex: 1; min-width: 0; }
.agenda-desc { font-size: 0.82rem; color: var(--td-gray-700); font-weight: 500; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.agenda-meta { font-size: 0.72rem; color: var(--td-gray-400); margin-top: 1px; }

/* ============================================================
   EXPEDIENTES — Cards
   ============================================================ */

.exp-cards { display: grid; grid-template-columns: repeat(auto-fill, minmax(360px, 1fr)); gap: var(--space-4); }

.exp-card {
  background: white;
  border: 1px solid var(--td-gray-200);
  border-radius: var(--radius-lg);
  overflow: hidden;
  transition: box-shadow 150ms, border-color 150ms;
}
.exp-card:hover { box-shadow: var(--shadow-md); border-color: var(--td-primary-200, #BFDBFE); }

.exp-card-header { display: flex; align-items: center; justify-content: space-between; padding: var(--space-3) var(--space-4); border-bottom: 1px solid var(--td-gray-100); }
.exp-card-left { display: flex; align-items: center; gap: var(--space-2); }
.exp-card-actions { display: flex; gap: 2px; opacity: 0; transition: opacity 150ms; }
.exp-card:hover .exp-card-actions { opacity: 1; }

.exp-card-body { padding: var(--space-4); cursor: pointer; }
.exp-dest { display: flex; align-items: baseline; justify-content: space-between; gap: var(--space-2); margin-bottom: var(--space-2); }
.exp-dest-name { font-weight: 700; font-size: 1.05rem; color: var(--td-gray-900); }
.exp-dates { font-size: 0.75rem; color: var(--td-gray-400); white-space: nowrap; }
.exp-client { display: flex; align-items: center; gap: var(--space-2); font-size: 0.85rem; color: var(--td-gray-600); }

.exp-card-footer { padding: var(--space-3) var(--space-4); border-top: 1px solid var(--td-gray-100); background: var(--td-gray-50); }
.exp-financial { display: flex; gap: var(--space-5); }
.exp-fin-item { display: flex; flex-direction: column; gap: 1px; }
.exp-fin-label { font-size: 0.7rem; color: var(--td-gray-400); text-transform: uppercase; letter-spacing: 0.04em; }
.exp-fin-value { font-size: 0.9rem; font-weight: 700; color: var(--td-gray-800); }

/* ============================================================
   EXPEDIENTES — Detalle
   ============================================================ */

.detail-nav { display: flex; align-items: center; gap: var(--space-2); margin-bottom: var(--space-4); }
.detail-header { display: flex; align-items: flex-start; justify-content: space-between; margin-bottom: var(--space-5); }

/* Resumen financiero detalle */
.fin-summary-grid { display: grid; grid-template-columns: repeat(5, 1fr); gap: var(--space-3); margin-bottom: var(--space-5); }
@media (max-width: 1000px) { .fin-summary-grid { grid-template-columns: repeat(3, 1fr); } }

.fin-card { background: white; border: 1px solid var(--td-gray-200); border-radius: var(--radius-md); padding: var(--space-4); text-align: center; }
.fin-card--primary .fin-value { color: var(--td-primary); }
.fin-card--success .fin-value { color: #059669; }
.fin-card--warning .fin-value { color: #D97706; }
.fin-card--info .fin-value { color: #0891B2; }
.fin-card--neutral .fin-value { color: var(--td-gray-700); }
.fin-label { font-size: 0.72rem; color: var(--td-gray-500); text-transform: uppercase; letter-spacing: 0.04em; margin-bottom: 4px; }
.fin-value { font-size: 1.1rem; font-weight: 800; }

/* Tabs detalle */
.detail-tabs { display: flex; gap: 2px; border-bottom: 2px solid var(--td-gray-200); margin-bottom: var(--space-5); overflow-x: auto; }
.tab-btn { background: none; border: none; padding: var(--space-3) var(--space-4); font-family: inherit; font-size: 0.85rem; font-weight: 500; color: var(--td-gray-500); cursor: pointer; border-bottom: 2px solid transparent; margin-bottom: -2px; white-space: nowrap; transition: color 150ms; }
.tab-btn:hover { color: var(--td-primary); }
.tab-btn.active { color: var(--td-primary); border-bottom-color: var(--td-primary); }
.tab-panel { }
.tab-panel.hidden { display: none; }
.tab-panel-header { display: flex; align-items: center; justify-content: space-between; margin-bottom: var(--space-4); }
.tab-panel-header h3 { font-size: 1rem; font-weight: 600; color: var(--td-gray-800); margin: 0; }

/* Info DL */
.info-grid { display: grid; grid-template-columns: 1fr 1fr; gap: var(--space-5); }
.info-section h4 { font-size: 0.9rem; font-weight: 600; color: var(--td-gray-700); margin: 0 0 var(--space-3); }
.info-dl { display: grid; grid-template-columns: auto 1fr; gap: var(--space-1) var(--space-4); }
.info-dl dt { font-size: 0.78rem; color: var(--td-gray-400); text-align: right; padding-top: 1px; white-space: nowrap; }
.info-dl dd { font-size: 0.85rem; color: var(--td-gray-800); margin: 0; }

/* CRM activity items */
.crm-activity-list { display: flex; flex-direction: column; gap: var(--space-2); }
.crm-activity-item { display: flex; align-items: flex-start; gap: var(--space-3); padding: var(--space-3) var(--space-4); background: white; border: 1px solid var(--td-gray-200); border-radius: var(--radius-md); }
.crm-activity-item.done { opacity: 0.5; }
.activity-icon { font-size: 1.2rem; flex-shrink: 0; }
.activity-body { flex: 1; }
.activity-desc { font-size: 0.85rem; font-weight: 500; color: var(--td-gray-800); }
.activity-meta { font-size: 0.75rem; color: var(--td-gray-400); margin-top: 2px; }
.activity-actions { flex-shrink: 0; }

/* Notes */
.notes-list { display: flex; flex-direction: column; gap: var(--space-3); }
.note-item { background: #FFFBEB; border: 1px solid #FDE68A; border-radius: var(--radius-md); padding: var(--space-4); }
.note-header { display: flex; justify-content: space-between; margin-bottom: var(--space-2); }
.note-author { font-size: 0.78rem; font-weight: 600; color: var(--td-gray-600); }
.note-date { font-size: 0.72rem; color: var(--td-gray-400); }
.note-body { font-size: 0.85rem; color: var(--td-gray-700); line-height: 1.5; white-space: pre-wrap; }

/* ============================================================
   CONFIGURACIÓN
   ============================================================ */

.config-sections { display: flex; flex-direction: column; gap: var(--space-6); }

.config-section {
  background: white;
  border: 1px solid var(--td-gray-200);
  border-radius: var(--radius-lg);
  overflow: hidden;
}

.config-section-header {
  padding: var(--space-5) var(--space-6);
  border-bottom: 1px solid var(--td-gray-100);
  background: var(--td-gray-50);
}
.config-section-header h3 { font-size: 1rem; font-weight: 600; color: var(--td-gray-800); margin: 0 0 4px; }
.config-section-header p { font-size: 0.82rem; color: var(--td-gray-500); margin: 0; }

.config-form { padding: var(--space-6); }
.config-form-footer { margin-top: var(--space-5); padding-top: var(--space-4); border-top: 1px solid var(--td-gray-100); display: flex; justify-content: flex-end; }

/* Color inputs */
.color-input-wrap { display: flex; align-items: center; gap: var(--space-2); }
.color-swatch { width: 40px; height: 36px; padding: 2px; border: 1px solid var(--td-gray-300); border-radius: var(--radius-sm); cursor: pointer; background: none; }
.color-swatch-sm { width: 28px; height: 28px; }

/* Logo upload */
.logo-upload-area { border: 2px dashed var(--td-gray-200); border-radius: var(--radius-md); padding: var(--space-8); text-align: center; color: var(--td-gray-500); font-size: 0.85rem; }
.logo-placeholder { font-size: 2.5rem; display: block; margin-bottom: var(--space-2); opacity: 0.3; }
.logo-preview { max-height: 80px; max-width: 200px; object-fit: contain; }

/* Plan info */
.plan-info-card { padding: var(--space-6); }
.plan-info-name { font-size: 1.4rem; font-weight: 800; color: var(--td-primary); margin-bottom: var(--space-1); }
.plan-info-desc { font-size: 0.85rem; color: var(--td-gray-500); margin-bottom: var(--space-4); }
.plan-info-features { display: flex; flex-direction: column; gap: var(--space-2); margin-bottom: var(--space-5); }
.plan-feature { font-size: 0.85rem; color: var(--td-gray-700); }

/* Estados config */
.status-config-list { padding: var(--space-4) var(--space-6); display: flex; flex-direction: column; gap: var(--space-2); }
.status-config-item { display: flex; align-items: center; gap: var(--space-3); }
.status-name-input { flex: 1; }
.form-control-sm { padding: var(--space-1) var(--space-2); font-size: 0.82rem; height: 32px; }

/* Roles */
.roles-list { padding: var(--space-4) var(--space-6); display: flex; flex-direction: column; gap: var(--space-3); }
.role-item { display: flex; align-items: flex-start; gap: var(--space-3); padding: var(--space-3) var(--space-4); background: var(--td-gray-50); border-radius: var(--radius-md); }
.role-icon { font-size: 1.4rem; flex-shrink: 0; }
.role-name { font-weight: 600; font-size: 0.9rem; color: var(--td-gray-800); }
.role-desc { font-size: 0.8rem; color: var(--td-gray-500); margin-top: 2px; line-height: 1.4; }

/* ============================================================
   SERVICIOS — catálogo
   ============================================================ */

.service-types-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(160px, 1fr)); gap: var(--space-4); margin-bottom: var(--space-5); }
.service-type-card { background: white; border: 1px solid var(--td-gray-200); border-radius: var(--radius-lg); padding: var(--space-5); text-align: center; cursor: pointer; transition: box-shadow 150ms, transform 150ms; }
.service-type-card:hover { box-shadow: var(--shadow-md); transform: translateY(-2px); }
.service-type-icon { width: 52px; height: 52px; border-radius: var(--radius-md); display: flex; align-items: center; justify-content: center; font-size: 1.5rem; margin: 0 auto var(--space-3); }
.service-type-name { font-size: 0.85rem; font-weight: 600; color: var(--td-gray-700); }

/* ============================================================
   MODAL — tamaños
   ============================================================ */

.modal-sm { max-width: 420px; }
.modal-lg { max-width: 680px; }

/* ============================================================
   COTIZADOR / PRESUPUESTO EDITOR
   ============================================================ */

.cotizador-wrap {
  padding: 1.5rem;
  max-width: 1120px;
  margin: 0 auto;
  display: flex;
  flex-direction: column;
  gap: 1.125rem;
}

/* Top bar */
.cotizador-topbar {
  display: flex;
  align-items: center;
  gap: 0.75rem;
  background: white;
  border: 1px solid var(--td-gray-200);
  border-radius: 10px;
  padding: 0.65rem 1rem;
  box-shadow: var(--shadow-sm);
}
.cotizador-topbar-center {
  flex: 1;
  display: flex;
  align-items: center;
  gap: 0.75rem;
  min-width: 0;
}
.cotizador-topbar-actions {
  display: flex;
  gap: 0.5rem;
  flex-shrink: 0;
}

/* Section cards */
.cotizador-section {
  background: white;
  border: 1px solid var(--td-gray-200);
  border-radius: 10px;
  padding: 1.25rem 1.5rem;
  box-shadow: var(--shadow-sm);
}
.cotizador-section-title {
  font-weight: 700;
  font-size: 0.78rem;
  color: var(--td-gray-500);
  text-transform: uppercase;
  letter-spacing: 0.06em;
  margin-bottom: 1rem;
}
.cotizador-section-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: 1rem;
}
.cotizador-section-header .cotizador-section-title { margin-bottom: 0; }

/* Header grid */
.cotizador-header-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 0.65rem 1rem;
}
@media (max-width: 900px) {
  .cotizador-header-grid { grid-template-columns: repeat(2, 1fr); }
}

/* Services table */
.cotizador-table thead th { font-size: 0.72rem; padding: 0.5rem 0.75rem; }
.cotizador-table tbody td { padding: 0.55rem 0.75rem; vertical-align: middle; }
.cotizador-table tfoot td { padding: 0.55rem 0.75rem; }
.cot-tfoot-row { background: var(--td-gray-50); }
.cot-tfoot-row td { border-top: 2px solid var(--td-gray-200) !important; font-weight: 600; }

/* Tipo badge */
.tipo-badge {
  width: 32px;
  height: 32px;
  border-radius: 7px;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 1rem;
  flex-shrink: 0;
}

/* PVP preview in modal */
.cotizador-pvp-preview {
  padding: 0.5rem 0.75rem;
  background: var(--td-gray-50);
  border: 1px solid var(--td-gray-200);
  border-radius: 6px;
  font-weight: 700;
  font-size: 1.15rem;
  color: var(--td-primary);
  line-height: 1.8;
}

/* PVP mode tabs */
.pvp-mode-tabs { display: flex; gap: 0; border: 1px solid var(--td-gray-300); border-radius: 7px; overflow: hidden; width: fit-content; }
.pvp-mode-tab { border: none; background: white; padding: 0.35rem 0.75rem; font-size: 0.82rem; font-weight: 500; color: var(--td-gray-600); cursor: pointer; transition: background 120ms, color 120ms; }
.pvp-mode-tab:not(:last-child) { border-right: 1px solid var(--td-gray-300); }
.pvp-mode-tab.active { background: var(--td-primary); color: white; }
.pvp-mode-tab:hover:not(.active) { background: var(--td-gray-100); }

/* Ganancia objetivo inline block */
.ganancia-obj-row { margin-top: 0.6rem; padding-top: 0.5rem; border-top: 1px solid var(--td-gray-200); display: flex; flex-direction: column; gap: 0.35rem; }

/* Cotizador doc buttons */
.cotizador-doc-btn { display: flex; flex-direction: column; align-items: flex-start; gap: 0.2rem; padding: 0.85rem 1rem; background: white; border: 1px solid var(--td-gray-200); border-radius: 9px; cursor: pointer; text-align: left; transition: box-shadow 120ms, border-color 120ms; }
.cotizador-doc-btn:hover { box-shadow: var(--shadow-md); border-color: var(--td-primary-300, #a5b4fc); }
.cotizador-doc-icon { font-size: 1.5rem; line-height: 1; }
.cotizador-doc-title { font-weight: 600; font-size: 0.88rem; color: var(--td-gray-800); }
.cotizador-doc-desc { font-size: 0.75rem; color: var(--td-gray-500); line-height: 1.3; }

/* ============================================================
   PIPELINE — Kanban
   ============================================================ */

.pipeline-stats { display: grid; grid-template-columns: repeat(4, 1fr); gap: 0.75rem; margin-bottom: 1.25rem; }
.pipeline-stat { background: white; border: 1px solid var(--td-gray-200); border-radius: 9px; padding: 0.85rem 1rem; }
.pipeline-stat-label { font-size: 0.72rem; color: var(--td-gray-500); font-weight: 600; text-transform: uppercase; letter-spacing: 0.04em; }
.pipeline-stat-value { font-size: 1.35rem; font-weight: 800; color: var(--td-gray-900); margin-top: 0.2rem; }

.pipeline-board { display: flex; gap: 0.875rem; overflow-x: auto; padding-bottom: 1.5rem; min-height: 400px; }
.pipeline-board::-webkit-scrollbar { height: 6px; }
.pipeline-board::-webkit-scrollbar-thumb { background: var(--td-gray-300); border-radius: 3px; }

.pipeline-col { flex-shrink: 0; width: 252px; display: flex; flex-direction: column; gap: 0.5rem; }
.pipeline-col-header { padding: 0.6rem 0.75rem; background: var(--td-gray-100); border-radius: 8px; display: flex; align-items: center; gap: 0.5rem; }
.pipeline-col-name { font-size: 0.78rem; font-weight: 700; color: var(--td-gray-700); flex: 1; text-transform: uppercase; letter-spacing: 0.04em; }
.pipeline-col-count { background: var(--td-gray-300); color: var(--td-gray-700); font-size: 0.7rem; font-weight: 700; padding: 0.1rem 0.4rem; border-radius: 99px; }
.pipeline-col-total { font-size: 0.72rem; color: var(--td-gray-500); font-weight: 500; }

.pipeline-card { background: white; border: 1px solid var(--td-gray-200); border-left: 4px solid var(--td-gray-300); border-radius: 8px; padding: 0.75rem; cursor: pointer; transition: box-shadow 130ms, transform 130ms; }
.pipeline-card:hover { box-shadow: var(--shadow-md); transform: translateY(-1px); }
.pipeline-card-client { font-weight: 600; font-size: 0.88rem; color: var(--td-gray-900); margin-bottom: 0.2rem; }
.pipeline-card-dest { font-size: 0.8rem; color: var(--td-gray-500); margin-bottom: 0.5rem; }
.pipeline-card-footer { display: flex; align-items: center; justify-content: space-between; margin-top: 0.5rem; }
.pipeline-card-pvp { font-weight: 700; font-size: 0.9rem; color: var(--td-primary); }
.pipeline-card-meta { font-size: 0.72rem; color: var(--td-gray-400); }

/* ============================================================
   CRM — Actividades
   ============================================================ */

.crm-stats { display: grid; grid-template-columns: repeat(3, 1fr); gap: 0.75rem; margin-bottom: 1.25rem; }

.crm-tabs { display: flex; gap: 0; border: 1px solid var(--td-gray-200); border-radius: 8px; overflow: hidden; width: fit-content; margin-bottom: 1rem; }
.crm-tab { border: none; background: white; padding: 0.45rem 1rem; font-size: 0.85rem; font-weight: 500; color: var(--td-gray-600); cursor: pointer; transition: background 120ms; }
.crm-tab:not(:last-child) { border-right: 1px solid var(--td-gray-200); }
.crm-tab.active { background: var(--td-primary); color: white; font-weight: 600; }

.crm-feed { display: flex; flex-direction: column; gap: 0.75rem; }
.crm-item { background: white; border: 1px solid var(--td-gray-200); border-radius: 9px; padding: 0.9rem 1rem; display: flex; gap: 0.875rem; align-items: flex-start; transition: box-shadow 120ms; }
.crm-item:hover { box-shadow: var(--shadow-sm); }
.crm-item-icon { width: 36px; height: 36px; border-radius: 9px; display: flex; align-items: center; justify-content: center; font-size: 1rem; flex-shrink: 0; }
.crm-item-body { flex: 1; min-width: 0; }
.crm-item-header { display: flex; align-items: flex-start; gap: 0.5rem; margin-bottom: 0.25rem; }
.crm-item-client { font-weight: 600; font-size: 0.88rem; color: var(--td-gray-900); }
.crm-item-desc { font-size: 0.83rem; color: var(--td-gray-600); line-height: 1.4; }
.crm-item-meta { font-size: 0.74rem; color: var(--td-gray-400); margin-top: 0.35rem; display: flex; gap: 0.75rem; flex-wrap: wrap; }
.crm-item-next { font-size: 0.74rem; color: var(--td-warning); font-weight: 500; }
.crm-item-actions { display: flex; gap: 0.25rem; flex-shrink: 0; opacity: 0; transition: opacity 120ms; }
.crm-item:hover .crm-item-actions { opacity: 1; }

/* Seguimientos urgency */
.seg-overdue { border-left: 3px solid var(--td-danger); }
.seg-today   { border-left: 3px solid var(--td-warning); }
.seg-week    { border-left: 3px solid var(--td-info); }

/* Totals grid */
.totals-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 0.75rem;
}
@media (max-width: 900px) {
  .totals-grid { grid-template-columns: repeat(2, 1fr); }
}
.totals-block {
  padding: 0.85rem 1rem;
  background: var(--td-gray-50);
  border: 1px solid var(--td-gray-200);
  border-radius: 9px;
}
.totals-block--highlight {
  background: var(--td-primary-50, #f0f4ff);
  border-color: var(--td-primary-200, #c7d2fe);
}
.totals-label {
  font-size: 0.75rem;
  color: var(--td-gray-500);
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.04em;
  margin-bottom: 0.4rem;
  display: flex;
  align-items: center;
}
.totals-amount {
  font-size: 1.5rem;
  font-weight: 800;
  color: var(--td-gray-900);
  line-height: 1;
}
.totals-sub {
  font-size: 0.74rem;
  color: var(--td-gray-400);
  margin-top: 0.3rem;
  line-height: 1.4;
}

/* ── Pipeline drag & drop ── */
.pipeline-card--dragging {
  opacity: 0.4;
  cursor: grabbing !important;
}
.pipeline-col-body.drag-over {
  background: var(--td-primary-50, #eff6ff);
  border: 2px dashed var(--td-primary, #3b82f6);
  border-radius: 8px;
  min-height: 80px;
}
.pipeline-col-body {
  min-height: 60px;
}

/* ── Estados config ── */
.status-config-item .badge {
  min-width: 90px;
  text-align: center;
  font-size: 0.78rem;
  padding: 0.25rem 0.65rem;
  border-radius: 20px;
}

/* ── Importar desde presupuesto ── */
.import-split {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 1rem;
  min-height: 420px;
}
.import-source,
.import-target {
  display: flex;
  flex-direction: column;
  gap: 0.4rem;
  overflow-y: auto;
  max-height: 60vh;
  padding: 0.75rem;
  border: 1.5px solid var(--td-gray-200);
  border-radius: 10px;
  background: var(--td-gray-50);
}
.import-panel-title {
  display: flex;
  align-items: center;
  justify-content: space-between;
  font-size: 0.8rem;
  font-weight: 600;
  color: var(--td-gray-600);
  padding-bottom: 0.5rem;
  border-bottom: 1px solid var(--td-gray-200);
  margin-bottom: 0.25rem;
  position: sticky;
  top: 0;
  background: var(--td-gray-50);
  z-index: 1;
}
.import-bgt-group { margin-bottom: 0.75rem; }
.import-bgt-header {
  display: flex;
  align-items: center;
  gap: 0.5rem;
  padding: 0.45rem 0.6rem;
  background: white;
  border: 1px solid var(--td-gray-200);
  border-radius: 7px 7px 0 0;
  font-size: 0.8rem;
  flex-wrap: wrap;
}
.import-bgt-meta { flex: 1; color: var(--td-gray-400); font-size: 0.75rem; }
.import-svc-list { display: flex; flex-direction: column; }
.import-svc-card {
  display: flex;
  align-items: center;
  gap: 0.55rem;
  padding: 0.45rem 0.6rem;
  background: white;
  border: 1px solid var(--td-gray-200);
  border-left: 3px solid #6b7280;
  font-size: 0.8rem;
  cursor: grab;
  user-select: none;
  transition: box-shadow 100ms, opacity 100ms;
}
.import-svc-card:last-child { border-radius: 0 0 6px 6px; }
.import-svc-card:hover { box-shadow: 0 2px 8px rgba(0,0,0,0.09); z-index: 1; position: relative; }
.import-svc-card.dragging { opacity: 0.35; cursor: grabbing; }
.import-svc-card.imported { opacity: 0.4; background: var(--td-gray-100); pointer-events: none; }
.import-svc-icon { font-size: 1.05rem; flex-shrink: 0; }
.import-svc-info { flex: 1; min-width: 0; }
.import-svc-name { font-weight: 500; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.import-svc-meta {
  display: flex;
  gap: 0.4rem;
  font-size: 0.71rem;
  color: var(--td-gray-500);
  margin-top: 0.1rem;
  flex-wrap: wrap;
  align-items: center;
}
.import-svc-prices { text-align: right; font-size: 0.8rem; flex-shrink: 0; }
.import-add-btn {
  padding: 0.15rem 0.45rem !important;
  font-size: 0.9rem;
  flex-shrink: 0;
  opacity: 0;
  transition: opacity 100ms;
  line-height: 1;
}
.import-svc-card:hover .import-add-btn { opacity: 1; }
.import-target.drag-over {
  background: var(--td-primary-50, #eff6ff);
  border: 2px dashed var(--td-primary, #3b82f6);
}
.import-target-empty {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  flex: 1;
  min-height: 200px;
  color: var(--td-gray-400);
  font-size: 0.83rem;
  text-align: center;
  gap: 0.5rem;
}
.import-target-empty span { font-size: 2rem; }
.import-target-item {
  display: flex;
  align-items: center;
  gap: 0.55rem;
  padding: 0.45rem 0.6rem;
  background: white;
  border: 1px solid var(--td-primary-200, #bfdbfe);
  border-left: 3px solid var(--td-primary, #3b82f6);
  border-radius: 6px;
  font-size: 0.8rem;
  margin-bottom: 0.3rem;
}

/* Modal size xl */
.modal-xl { max-width: 900px !important; width: 96vw !important; }

/* ── Cobros summary bar ── */
.cobros-summary {
  display: flex;
  gap: 1rem;
  padding: 1rem;
  background: var(--td-gray-50, #f9fafb);
  border: 1px solid var(--td-gray-200, #e5e7eb);
  border-radius: 10px;
  margin-bottom: 1.25rem;
  flex-wrap: wrap;
}
.cobro-stat {
  display: flex;
  flex-direction: column;
  gap: 0.15rem;
  min-width: 120px;
}
.cobro-stat-label {
  font-size: 0.7rem;
  text-transform: uppercase;
  letter-spacing: 0.05em;
  color: var(--td-gray-400, #9ca3af);
  font-weight: 600;
}
.cobro-stat-value {
  font-size: 1.1rem;
  font-weight: 700;
  color: var(--td-gray-800, #1f2937);
}
.cobro-stat--ok .cobro-stat-value { color: var(--td-success, #10b981); }
.cobro-stat--warn .cobro-stat-value { color: var(--td-warning, #f59e0b); }
.cobro-stat--danger .cobro-stat-value { color: var(--td-danger, #ef4444); }
.cobro-progress-wrap {
  flex: 1;
  min-width: 180px;
  display: flex;
  flex-direction: column;
  gap: 0.3rem;
  justify-content: center;
}
.cobro-progress-wrap label {
  font-size: 0.7rem;
  text-transform: uppercase;
  letter-spacing: 0.05em;
  color: var(--td-gray-400, #9ca3af);
  font-weight: 600;
}
.cobro-progress-track {
  height: 8px;
  background: var(--td-gray-200, #e5e7eb);
  border-radius: 99px;
  overflow: hidden;
}
.cobro-progress-bar {
  height: 100%;
  border-radius: 99px;
  background: var(--td-success, #10b981);
  transition: width 0.4s ease;
}
.cobro-progress-bar--warn { background: var(--td-warning, #f59e0b); }
.cobro-progress-bar--danger { background: var(--td-danger, #ef4444); }

/* ── Tab badges ── */
.tab-badge {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 18px;
  height: 18px;
  padding: 0 5px;
  border-radius: 99px;
  background: var(--td-gray-200, #e5e7eb);
  color: var(--td-gray-600, #4b5563);
  font-size: 0.65rem;
  font-weight: 700;
  margin-left: 4px;
  vertical-align: middle;
}
.tab-badge--warn { background: #fef3c7; color: #92400e; }
.tab-badge--ok   { background: #d1fae5; color: #065f46; }

/* ── Régimen fiscal badges ── */
.regimen-badge {
  display: inline-block;
  padding: 1px 7px;
  border-radius: 99px;
  font-size: 0.65rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.04em;
}
.regimen-general   { background: #e0f2fe; color: #0369a1; }
.regimen-especial  { background: #fce7f3; color: #9d174d; }
.regimen-dac       { background: #fef9c3; color: #854d0e; }
.regimen-modulos   { background: #f3e8ff; color: #6b21a8; }
.regimen-exento    { background: #dcfce7; color: #166534; }

/* ── Seguimientos ── */
.seg-dot {
  display: inline-block;
  width: 8px;
  height: 8px;
  border-radius: 50%;
  margin-right: 4px;
  vertical-align: middle;
  flex-shrink: 0;
}
.seg-panel {
  background: var(--td-gray-50, #f9fafb);
  border: 1px solid var(--td-gray-200, #e5e7eb);
  border-radius: 10px;
  padding: 1rem;
}
.seg-panel-header {
  display: flex;
  align-items: baseline;
  gap: 0.75rem;
  margin-bottom: 0.9rem;
}
.seg-panel-header h4 {
  margin: 0;
  font-size: 0.9rem;
  font-weight: 700;
  color: var(--td-gray-700, #374151);
}
.seg-cards {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 0.75rem;
}
@media (max-width: 600px) { .seg-cards { grid-template-columns: 1fr; } }

.seg-card {
  border-radius: 8px;
  padding: 0.75rem;
  border: 1.5px solid var(--td-gray-200, #e5e7eb);
  background: white;
  display: flex;
  flex-direction: column;
  gap: 0.25rem;
}
.seg-card--ok      { border-color: #86efac; background: #f0fdf4; }
.seg-card--soon    { border-color: #fde047; background: #fefce8; }
.seg-card--today   { border-color: #fb923c; background: #fff7ed; }
.seg-card--overdue { border-color: #f87171; background: #fef2f2; }
.seg-card--empty   { background: var(--td-gray-50, #f9fafb); border-style: dashed; }

.seg-card-label {
  font-size: 0.68rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.06em;
  color: var(--td-gray-400, #9ca3af);
}
.seg-card-date {
  font-size: 0.95rem;
  font-weight: 700;
  color: var(--td-gray-800, #1f2937);
}
.seg-empty-text { font-weight: 400; font-size: 0.82rem; color: var(--td-gray-300, #d1d5db); }
.seg-card-actions { display: flex; gap: 0.3rem; margin-top: 0.4rem; align-items: center; }
.btn-xs {
  font-size: 0.7rem;
  padding: 2px 8px;
  border-radius: 5px;
  height: auto;
  line-height: 1.6;
}
.seg-urgency-badge {
  display: inline-block;
  padding: 1px 6px;
  border-radius: 99px;
  font-size: 0.62rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.05em;
}
.seg-urgency--overdue { background: #fecaca; color: #991b1b; }
.seg-urgency--today   { background: #fed7aa; color: #9a3412; }
.seg-urgency--soon    { background: #fef08a; color: #854d0e; }

/* ── Documentos ── */
.doc-group {
  margin-bottom: 1rem;
}
.doc-group-label {
  font-size: 0.72rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.06em;
  color: var(--td-gray-400, #9ca3af);
  padding: 0 0 0.4rem;
  border-bottom: 1px solid var(--td-gray-100, #f3f4f6);
  margin-bottom: 0.4rem;
}
.doc-item {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 0.55rem 0.6rem;
  border-radius: 7px;
  background: var(--td-gray-50, #f9fafb);
  border: 1px solid var(--td-gray-100, #f3f4f6);
  margin-bottom: 0.3rem;
  gap: 0.5rem;
}
.doc-item:hover { background: white; border-color: var(--td-gray-200); }
.doc-item .row-actions { opacity: 1; }
.doc-item .doc-app-toggle { opacity: 1; }
.doc-item .doc-app-off   { opacity: .35; }
.doc-item-info { display: flex; flex-direction: column; gap: 0.1rem; flex: 1; min-width: 0; }
.doc-item-name {
  font-size: 0.84rem;
  font-weight: 600;
  color: var(--td-gray-700, #374151);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.doc-item-meta { font-size: 0.72rem; color: var(--td-gray-400, #9ca3af); }

/* ── Plantillas — sub-tabs ── */
.plantillas-tabs {
  display: flex;
  gap: 0.25rem;
  margin-bottom: 1.25rem;
  border-bottom: 2px solid var(--td-gray-200, #e5e7eb);
  padding-bottom: 0;
}
.plantilla-tab {
  background: none;
  border: none;
  cursor: pointer;
  padding: 0.55rem 1.1rem;
  font-size: 0.88rem;
  font-weight: 600;
  color: var(--td-gray-400, #9ca3af);
  border-bottom: 2px solid transparent;
  margin-bottom: -2px;
  transition: color 0.15s, border-color 0.15s;
}
.plantilla-tab:hover { color: var(--td-gray-700, #374151); }
.plantilla-tab.active { color: var(--td-primary, #3b82f6); border-bottom-color: var(--td-primary, #3b82f6); }
.plantilla-panel { min-height: 200px; }
.plantillas-toolbar {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-bottom: 0.75rem;
  gap: 1rem;
}
.plantillas-hint {
  font-size: 0.8rem;
  color: var(--td-gray-400, #9ca3af);
  margin: 0;
}

/* ── WhatsApp templates ── */
.wa-vars-bar {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 0.35rem;
  padding: 0.6rem 0.75rem;
  background: var(--td-gray-50, #f9fafb);
  border: 1px solid var(--td-gray-200, #e5e7eb);
  border-radius: 8px;
  margin-bottom: 1rem;
  font-size: 0.78rem;
}
.wa-vars-label { font-weight: 600; color: var(--td-gray-500, #6b7280); margin-right: 0.25rem; }
.wa-var-chip {
  background: white;
  border: 1px solid var(--td-gray-200, #e5e7eb);
  color: var(--td-primary, #3b82f6);
  border-radius: 4px;
  padding: 1px 6px;
  font-size: 0.72rem;
  font-family: monospace;
  transition: background 0.1s;
}
.wa-var-chip:hover { background: var(--td-primary-50, #eff6ff); border-color: var(--td-primary, #3b82f6); }

.wa-template-list { display: flex; flex-direction: column; gap: 0; }
.wa-cat-group { margin-bottom: 1rem; }
.wa-cat-label {
  font-size: 0.7rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.07em;
  color: var(--td-gray-400, #9ca3af);
  padding-bottom: 0.4rem;
  border-bottom: 1px solid var(--td-gray-100, #f3f4f6);
  margin-bottom: 0.4rem;
  display: flex;
  align-items: center;
  gap: 0.4rem;
}
.wa-cat-count {
  background: var(--td-gray-100, #f3f4f6);
  border-radius: 99px;
  padding: 0 5px;
  font-size: 0.65rem;
  color: var(--td-gray-500, #6b7280);
}
.wa-card {
  background: white;
  border: 1px solid var(--td-gray-200, #e5e7eb);
  border-radius: 8px;
  padding: 0.7rem 0.85rem;
  margin-bottom: 0.4rem;
  transition: border-color 0.15s, box-shadow 0.15s;
}
.wa-card:hover { border-color: var(--td-gray-300); box-shadow: 0 1px 4px rgba(0,0,0,0.06); }
.wa-card-header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-bottom: 0.4rem;
}
.wa-card-left { display: flex; align-items: center; gap: 0.5rem; }
.wa-cat-badge {
  display: inline-block;
  padding: 1px 7px;
  border-radius: 99px;
  font-size: 0.65rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.04em;
  white-space: nowrap;
}
.wa-card-name { font-size: 0.88rem; font-weight: 600; color: var(--td-gray-700, #374151); }
.wa-card-actions { display: flex; gap: 0.15rem; opacity: 0; transition: opacity 0.15s; }
.wa-card:hover .wa-card-actions { opacity: 1; }
.wa-card-preview {
  font-size: 0.78rem;
  color: var(--td-gray-400, #9ca3af);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

/* ── Documentos legales ── */
.legal-docs-grid {
  display: flex;
  flex-direction: column;
  gap: 0.75rem;
}
.legal-doc-card {
  display: flex;
  align-items: center;
  gap: 1rem;
  padding: 1rem 1.25rem;
  background: white;
  border: 1px solid var(--td-gray-200, #e5e7eb);
  border-radius: 10px;
  transition: box-shadow 0.15s;
}
.legal-doc-card:hover { box-shadow: 0 2px 8px rgba(0,0,0,0.07); }
.legal-doc-icon { font-size: 2rem; flex-shrink: 0; }
.legal-doc-info { flex: 1; }
.legal-doc-name { font-size: 0.95rem; font-weight: 700; color: var(--td-gray-800, #1f2937); }
.legal-doc-meta { font-size: 0.75rem; color: var(--td-gray-400, #9ca3af); margin-top: 2px; }
.legal-doc-actions { display: flex; gap: 0.5rem; flex-shrink: 0; flex-wrap: wrap; }

/* ── Generador de documentos ── */
.docgen-section-title {
  font-size: 0.8rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.06em;
  color: var(--td-gray-500, #6b7280);
  padding-bottom: 0.4rem;
  border-bottom: 1px solid var(--td-gray-100, #f3f4f6);
  margin-bottom: 0.75rem;
}

/* ─────────────────────────────────────
   ALERTAS OPERACIONALES (Dashboard)
───────────────────────────────────── */
.alertas-banner {
  margin-bottom: 1.5rem;
  padding: 0.85rem 1.1rem;
  background: #fffbeb;
  border: 1px solid #fbbf24;
  border-radius: 12px;
}
.alertas-banner-title {
  font-size: 0.8rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.06em;
  color: #92400e;
  margin-bottom: 0.75rem;
}
.alertas-cards {
  display: flex;
  flex-wrap: wrap;
  gap: 0.75rem;
}
.alerta-card {
  background: white;
  border: 1px solid #e5e7eb;
  border-radius: 10px;
  padding: 0.65rem 0.85rem;
  min-width: 180px;
  max-width: 320px;
  flex: 1 1 180px;
}
.alerta-card--blue   { border-color: #93c5fd; background: #eff6ff; }
.alerta-card--green  { border-color: #6ee7b7; background: #ecfdf5; }
.alerta-card--cyan   { border-color: #67e8f9; background: #ecfeff; }
.alerta-card--amber  { border-color: #fcd34d; background: #fffbeb; }
.alerta-card--red    { border-color: #fca5a5; background: #fef2f2; }

.alerta-card-header {
  display: flex;
  align-items: center;
  gap: 0.4rem;
  margin-bottom: 0.45rem;
}
.alerta-icon { font-size: 0.95rem; }
.alerta-label {
  font-size: 0.73rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.04em;
  color: #374151;
  flex: 1;
}
.alerta-count {
  background: rgba(0,0,0,0.08);
  border-radius: 99px;
  padding: 1px 7px;
  font-size: 0.7rem;
  font-weight: 700;
  color: #374151;
}
.alerta-exps {
  display: flex;
  flex-direction: column;
  gap: 0.2rem;
}
.alerta-exp-link {
  display: flex;
  align-items: center;
  gap: 0.4rem;
  cursor: pointer;
  padding: 2px 4px;
  border-radius: 5px;
  transition: background 0.12s;
  font-size: 0.78rem;
}
.alerta-exp-link:hover { background: rgba(0,0,0,0.06); }
.alerta-exp-link code {
  font-size: 0.7rem;
  background: rgba(0,0,0,0.07);
  padding: 1px 5px;
  border-radius: 4px;
  color: #1f2937;
  flex-shrink: 0;
}
.alerta-exp-name {
  color: #6b7280;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  max-width: 160px;
}

/* ─────────────────────────────────────
   INFORMES — Análisis de ventas
───────────────────────────────────── */
.informe-kpis {
  display: flex;
  gap: 1rem;
  margin-bottom: 1.5rem;
  flex-wrap: wrap;
}
.informe-kpi {
  flex: 1 1 160px;
  background: white;
  border: 1px solid #e5e7eb;
  border-radius: 10px;
  padding: 0.9rem 1.1rem;
  min-width: 140px;
}
.informe-kpi-label {
  font-size: 0.75rem;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.05em;
  color: #9ca3af;
  margin-bottom: 0.35rem;
}
.informe-kpi-value {
  font-size: 1.45rem;
  font-weight: 800;
  color: #111827;
  letter-spacing: -0.02em;
}

.informe-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 1.25rem;
}
@media (max-width: 768px) {
  .informe-grid { grid-template-columns: 1fr; }
}
.informe-card {
  background: white;
  border: 1px solid #e5e7eb;
  border-radius: 12px;
  padding: 1.1rem 1.25rem 1rem;
}
.informe-card-title {
  font-size: 0.9rem;
  font-weight: 700;
  color: #1f2937;
  margin-bottom: 0.1rem;
}
.informe-card-subtitle {
  font-size: 0.73rem;
  color: #9ca3af;
  margin-bottom: 0.85rem;
}
.informe-chart {
  margin-bottom: 0.5rem;
  overflow: hidden;
}
.informe-card-legend {
  font-size: 0.75rem;
  color: #6b7280;
  display: flex;
  gap: 1rem;
  flex-wrap: wrap;
  margin-top: 0.5rem;
}

/* Donut legend */
.chart-donut-legend {
  display: flex;
  flex-direction: column;
  gap: 0.3rem;
  flex: 1;
  min-width: 120px;
}
.chart-donut-legend-item {
  display: flex;
  align-items: center;
  gap: 0.4rem;
  font-size: 0.75rem;
  color: #374151;
}

/* Margen card */
.informe-margen-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 0.7rem;
}
.informe-margen-stat {
  border: 2px solid #e5e7eb;
  border-radius: 8px;
  padding: 0.6rem 0.8rem;
}
.informe-margen-label {
  font-size: 0.7rem;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.04em;
  color: #9ca3af;
  margin-bottom: 0.25rem;
}
.informe-margen-value {
  font-size: 1.15rem;
  font-weight: 800;
  letter-spacing: -0.02em;
}

/* Bar chart helpers */
.chart-bar-group { display: flex; align-items: flex-end; gap: 0.5rem; }
.chart-label { font-size: 0.7rem; color: #9ca3af; text-align: center; }

/* ── Tab badge verde (cierre completo) ── */
.tab-badge--ok {
  background: var(--td-success, #16a34a) !important;
  color: #fff !important;
}

/* ── Checklist de cierre ── */
.checklist-panel { max-width: 780px; }

.checklist-progress-wrap {
  background: var(--td-gray-50, #f9fafb);
  border: 1px solid var(--td-gray-200, #e5e7eb);
  border-radius: 10px;
  padding: 1rem 1.25rem;
  margin-bottom: 1.25rem;
}

.checklist-progress-meta {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-bottom: 0.5rem;
}

.checklist-progress-label {
  font-size: 0.85rem;
  font-weight: 600;
  color: var(--td-gray-600, #4b5563);
}

.checklist-progress-label--done {
  font-size: 0.85rem;
  font-weight: 600;
  color: var(--td-success, #16a34a);
}

.checklist-progress-pct {
  font-size: 0.85rem;
  font-weight: 700;
  color: var(--td-gray-500, #6b7280);
}

.checklist-progress-pct--done { color: var(--td-success, #16a34a); }

.checklist-progress-track {
  height: 10px;
  background: var(--td-gray-200, #e5e7eb);
  border-radius: 99px;
  overflow: hidden;
}

.checklist-progress-bar {
  height: 100%;
  background: var(--td-primary, #3b82f6);
  border-radius: 99px;
  transition: width 0.3s ease;
}

.checklist-progress-bar--done { background: var(--td-success, #16a34a); }

.checklist-list {
  display: flex;
  flex-direction: column;
  gap: 0;
}

.checklist-item {
  display: grid;
  grid-template-columns: 2rem 1fr 7rem 14rem;
  align-items: center;
  gap: 0.75rem;
  padding: 0.65rem 0.85rem;
  border-radius: 8px;
  transition: background 0.12s;
  border-bottom: 1px solid var(--td-gray-100, #f3f4f6);
}

.checklist-item:last-child { border-bottom: none; }
.checklist-item:hover { background: var(--td-gray-50, #f9fafb); }
.checklist-item.done { background: #f0fdf4; }
.checklist-item.done:hover { background: #dcfce7; }

.checklist-check-wrap {
  display: flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
}

.checklist-check-wrap input[type="checkbox"] {
  width: 1.15rem;
  height: 1.15rem;
  accent-color: var(--td-success, #16a34a);
  cursor: pointer;
}

.checklist-item-name {
  font-size: 0.88rem;
  font-weight: 500;
  color: var(--td-gray-700, #374151);
}

.checklist-item.done .checklist-item-name {
  color: var(--td-success, #16a34a);
  text-decoration: line-through;
  text-decoration-color: #86efac;
}

.checklist-item-date {
  font-size: 0.78rem;
  color: var(--td-success, #16a34a);
  font-weight: 500;
  text-align: right;
}

.checklist-item-date--empty { color: var(--td-gray-300, #d1d5db); }

.checklist-notes {
  font-size: 0.78rem;
  border: 1px solid var(--td-gray-200, #e5e7eb);
  border-radius: 6px;
  padding: 0.3rem 0.6rem;
  color: var(--td-gray-600, #4b5563);
  background: transparent;
  width: 100%;
  outline: none;
  transition: border-color 0.15s;
}

.checklist-notes:focus { border-color: var(--td-primary, #3b82f6); background: #fff; }
.checklist-item.done .checklist-notes { border-color: #bbf7d0; }

/* ── Cuotas y pagadores ── */
.cuotas-section {
  margin-top: 2rem;
  padding-top: 1.5rem;
  border-top: 2px solid var(--td-gray-100, #f3f4f6);
}

.cuotas-section-header {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  gap: 1rem;
  margin-bottom: 0.75rem;
}

.cuotas-section-header h4 {
  margin: 0 0 0.1rem;
  font-size: 0.95rem;
  font-weight: 700;
  color: var(--td-gray-700, #374151);
}

.cuota-row-paid td { background: #f0fdf4; color: var(--td-success, #16a34a); }
.cuota-row-paid td:first-child { border-left: 3px solid var(--td-success, #16a34a); }
.cuota-row-pending td:first-child { border-left: 3px solid var(--td-warning, #f59e0b); }

/* ── Pagadores list ── */
.pagadores-list {
  display: flex;
  flex-direction: column;
  gap: 0.5rem;
  margin-top: 0.25rem;
}

.pagador-item {
  display: flex;
  align-items: center;
  gap: 0.85rem;
  padding: 0.75rem 1rem;
  background: #fff;
  border: 1px solid var(--td-gray-200, #e5e7eb);
  border-radius: 10px;
  transition: box-shadow 0.15s;
}

.pagador-item:hover { box-shadow: 0 2px 8px rgba(0,0,0,0.06); }

.pagador-avatar {
  width: 2.2rem;
  height: 2.2rem;
  border-radius: 50%;
  background: linear-gradient(135deg, var(--td-primary, #3b82f6), #6366f1);
  color: #fff;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 0.72rem;
  font-weight: 700;
  flex-shrink: 0;
  letter-spacing: 0.02em;
}

.pagador-info { flex: 1; min-width: 0; }

.pagador-nombre {
  font-size: 0.9rem;
  font-weight: 600;
  color: var(--td-gray-700, #374151);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.pagador-dni {
  font-size: 0.75rem;
  color: var(--td-gray-400, #9ca3af);
  font-family: monospace;
}

.pagador-amounts {
  display: flex;
  flex-direction: column;
  align-items: flex-end;
  gap: 0.1rem;
  flex-shrink: 0;
}

.pagador-pct {
  font-size: 0.78rem;
  font-weight: 700;
  color: var(--td-gray-500, #6b7280);
  background: var(--td-gray-100, #f3f4f6);
  padding: 1px 7px;
  border-radius: 99px;
}

.pagador-importe {
  font-size: 0.9rem;
  font-weight: 700;
  color: var(--td-gray-800, #1f2937);
}

/* ── Catálogo de servicios v2 ── */

/* Pills de país */
.catalog-pais-pills {
  display: flex; flex-wrap: wrap; gap: 0.5rem;
  margin-bottom: 1.25rem;
}
.catalog-pais-pill {
  display: inline-flex; align-items: center; gap: 0.35rem;
  padding: 0.35rem 0.85rem; border-radius: 999px; font-size: 0.83rem;
  font-weight: 600; cursor: pointer; border: 1.5px solid var(--td-gray-200);
  background: white; color: var(--td-gray-600);
  transition: border-color 0.15s, background 0.15s, color 0.15s;
}
.catalog-pais-pill:hover { border-color: var(--td-primary); color: var(--td-primary); }
.catalog-pais-pill.active {
  background: var(--td-primary); border-color: var(--td-primary);
  color: white;
}
.catalog-pais-pill.active .pill-count { background: rgba(255,255,255,0.25); color: white; }
.pill-count {
  background: var(--td-gray-100); color: var(--td-gray-500);
  border-radius: 999px; padding: 0.05rem 0.45rem;
  font-size: 0.75rem; font-weight: 700; line-height: 1.5;
}

/* Tabs de tipo (6 tipos, scroll horizontal en mobile) */
.catalog-tabs {
  display: flex; gap: 0.15rem; margin-bottom: 1.25rem;
  border-bottom: 2px solid var(--td-gray-200); padding-bottom: 0;
  overflow-x: auto; scrollbar-width: none;
}
.catalog-tabs::-webkit-scrollbar { display: none; }
.catalog-tab {
  background: none; border: none; cursor: pointer; white-space: nowrap;
  padding: 0.5rem 0.9rem; font-size: 0.83rem; font-weight: 600;
  color: var(--td-gray-400); border-bottom: 2px solid transparent;
  margin-bottom: -2px; transition: color 0.15s, border-color 0.15s;
  flex-shrink: 0;
}
.catalog-tab:hover { color: var(--td-gray-700); }
.catalog-tab.active { color: var(--td-primary, #3b82f6); border-bottom-color: var(--td-primary, #3b82f6); }
.catalog-tab-count { opacity: 0.6; font-weight: 400; }

/* Agrupación por ciudad */
.catalog-city-group { margin-bottom: 2rem; }
.catalog-city-header {
  display: flex; align-items: center; justify-content: space-between;
  margin-bottom: 0.75rem; padding-bottom: 0.5rem;
  border-bottom: 1px solid var(--td-gray-100);
}
.catalog-city-name { font-size: 0.95rem; font-weight: 700; color: var(--td-gray-700); }
.catalog-city-count { font-size: 0.78rem; color: var(--td-gray-400); }

/* Grid de cards */
.catalog-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(260px, 1fr));
  gap: 1rem;
}
.catalog-card {
  background: white; border: 1px solid var(--td-gray-200);
  border-radius: 10px; padding: 1rem; display: flex;
  flex-direction: column; gap: 0.4rem;
  transition: box-shadow 0.15s;
}
.catalog-card:hover { box-shadow: 0 3px 12px rgba(0,0,0,0.08); }
.catalog-card-header { display: flex; justify-content: space-between; align-items: flex-start; min-height: 24px; }
.catalog-card-name { font-size: 0.9rem; font-weight: 700; color: var(--td-gray-800); line-height: 1.3; margin-top: 0.2rem; }
.catalog-card-dest { font-size: 0.75rem; color: var(--td-gray-500); }
.catalog-card-detail { font-size: 0.78rem; color: var(--td-gray-500); }
.catalog-card-price { font-size: 0.95rem; font-weight: 700; color: var(--td-primary, #3b82f6); margin-top: 0.25rem; }
.catalog-card-actions { display: flex; gap: 0.35rem; margin-top: auto; padding-top: 0.5rem; justify-content: flex-end; }
.catalog-stars { color: #f59e0b; font-size: 0.8rem; letter-spacing: 1px; }

/* Selector de tipo al crear (grid de 3x2) */
.catalog-type-selector { display: grid; grid-template-columns: repeat(3, 1fr); gap: 0.75rem; }
.catalog-type-btn {
  border: 2px solid var(--td-gray-200); border-radius: 10px;
  padding: 1.1rem 0.75rem; text-align: center; cursor: pointer;
  background: white; transition: border-color 0.15s, background 0.15s;
}
.catalog-type-btn:hover { border-color: var(--td-primary); background: var(--td-primary-50, #eff6ff); }
.catalog-type-btn .cat-icon { font-size: 1.8rem; display: block; margin-bottom: 0.35rem; }
.catalog-type-btn span:last-child { font-size: 0.8rem; font-weight: 600; color: var(--td-gray-700); }

/* ── Buscador global Ctrl+K ── */
.gsearch-overlay {
  position: fixed; inset: 0; background: rgba(0,0,0,0.5);
  z-index: 9999; display: flex; align-items: flex-start;
  justify-content: center; padding-top: 12vh;
  backdrop-filter: blur(2px);
}
.gsearch-overlay.hidden { display: none; }
.gsearch-modal {
  width: min(640px, 92vw); background: white;
  border-radius: 14px; box-shadow: 0 24px 64px rgba(0,0,0,0.2);
  overflow: hidden;
}
.gsearch-input-wrap {
  display: flex; align-items: center; gap: 0.75rem;
  padding: 1rem 1.25rem; border-bottom: 1px solid var(--td-gray-100, #f3f4f6);
}
.gsearch-icon { font-size: 1.1rem; flex-shrink: 0; }
.gsearch-input {
  flex: 1; border: none; outline: none; font-size: 1rem;
  color: var(--td-gray-800, #1f2937); background: transparent;
}
.gsearch-esc {
  font-size: 0.65rem; background: var(--td-gray-100, #f3f4f6);
  color: var(--td-gray-500); border-radius: 4px; padding: 2px 6px;
  font-family: monospace; flex-shrink: 0;
}
.gsearch-results { max-height: 420px; overflow-y: auto; padding: 0.5rem 0; }
.gsearch-group-label {
  font-size: 0.68rem; font-weight: 700; text-transform: uppercase;
  letter-spacing: 0.08em; color: var(--td-gray-400);
  padding: 0.6rem 1.25rem 0.3rem;
}
.gsearch-item {
  display: flex; align-items: center; gap: 0.75rem;
  padding: 0.65rem 1.25rem; cursor: pointer; transition: background 0.1s;
}
.gsearch-item:hover { background: var(--td-gray-50, #f9fafb); }
.gsearch-item-body { flex: 1; min-width: 0; }
.gsearch-item-title { font-size: 0.88rem; font-weight: 600; color: var(--td-gray-800); white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.gsearch-item-sub { font-size: 0.75rem; color: var(--td-gray-400); margin-top: 1px; }
.gsearch-arrow { color: var(--td-gray-300); font-size: 0.85rem; flex-shrink: 0; }
.gsearch-empty { padding: 2rem 1.25rem; text-align: center; color: var(--td-gray-400); font-size: 0.88rem; }

/* ── Timeline de estados ── */
.estado-timeline {
  background: var(--td-gray-50, #f9fafb);
  border: 1px solid var(--td-gray-200, #e5e7eb);
  border-radius: 10px;
  padding: 1rem;
  margin-bottom: 1.25rem;
}
.estado-timeline-header {
  display: flex; align-items: center; justify-content: space-between;
  margin-bottom: 0.9rem;
}
.estado-timeline-header h4 { margin: 0; font-size: 0.88rem; font-weight: 700; color: var(--td-gray-700); }
.timeline-list { display: flex; flex-direction: column; gap: 0; position: relative; }
.timeline-item { display: flex; gap: 0.65rem; position: relative; padding-bottom: 0.85rem; }
.timeline-item:last-child { padding-bottom: 0; }
.timeline-dot {
  width: 12px; height: 12px; border-radius: 50%; flex-shrink: 0;
  margin-top: 3px; border: 2px solid white; box-shadow: 0 0 0 1px rgba(0,0,0,0.1);
  position: relative; z-index: 1;
}
.timeline-line {
  position: absolute; left: 5px; top: 15px; bottom: 0;
  width: 2px; background: var(--td-gray-200, #e5e7eb);
}
.timeline-content { flex: 1; min-width: 0; }
.timeline-header-row { display: flex; justify-content: space-between; align-items: baseline; gap: 0.5rem; flex-wrap: wrap; }
.timeline-estado { font-size: 0.85rem; }
.timeline-date { font-size: 0.72rem; color: var(--td-gray-400); flex-shrink: 0; }
.timeline-note { font-size: 0.78rem; color: var(--td-gray-600); margin: 2px 0; }
.timeline-user { font-size: 0.7rem; color: var(--td-gray-400); }

/* ── Facturas detail & print ── */
.fac-detail-header { display:flex; justify-content:space-between; align-items:flex-start; gap:1rem; margin-bottom:1.25rem; flex-wrap:wrap; }
.fac-detail-num { font-family:monospace; font-size:1.3rem; font-weight:700; color:var(--td-primary); }
.fac-items-table { width:100%; border-collapse:collapse; margin:1rem 0; font-size:0.88rem; }
.fac-items-table th { background:var(--td-gray-50,#f9fafb); padding:0.5rem 0.75rem; text-align:left; font-size:0.78rem; color:var(--td-gray-500); border-bottom:1px solid var(--td-gray-200,#e5e7eb); }
.fac-items-table td { padding:0.5rem 0.75rem; border-bottom:1px solid var(--td-gray-100,#f3f4f6); }
.fac-totals { margin-top:1rem; display:flex; flex-direction:column; align-items:flex-end; gap:0.25rem; font-size:0.88rem; }
.fac-totals-row { display:flex; gap:2rem; justify-content:flex-end; }
.fac-totals-total { font-weight:700; font-size:1rem; color:var(--td-primary); border-top:2px solid var(--td-primary); padding-top:0.4rem; }

/* Notas de abono */
.fac-row-abono { background: #fff5f5 !important; }
.fac-row-abono:hover { background: #fee2e2 !important; }
.code-badge-abono { background: #fee2e2 !important; color: #dc2626 !important; border-color: #fca5a5 !important; }
.badge-abono { background: #fee2e2; color: #dc2626; border: 1px solid #fca5a5; border-radius: var(--radius-full,9999px); padding: 2px 8px; font-size: 0.72rem; font-weight: 700; }
.fac-abono-banner { display:flex; gap:0.75rem; align-items:flex-start; padding:0.75rem 1rem; background:#fff5f5; border:1px solid #fca5a5; border-radius:var(--radius-md); color:#991b1b; font-size:0.84rem; }
.fac-detail-num--abono { color: var(--td-danger) !important; }
.btn-warning { background: #f59e0b; color: white; border: none; padding: 0.45rem 1rem; border-radius: var(--radius-md); font-size: 0.85rem; font-weight: 600; cursor: pointer; }
.btn-warning:hover { background: #d97706; }

/* Factura form — line items table */
.fac-form-table-wrap { overflow-x:auto; border:1px solid var(--td-gray-200); border-radius:var(--radius-md); }
.fac-form-table { width:100%; border-collapse:collapse; font-size:0.82rem; }
.fac-form-table th { background:var(--td-gray-50,#f9fafb); padding:7px 10px; text-align:left; font-size:0.75rem; font-weight:700; color:var(--td-gray-500); text-transform:uppercase; letter-spacing:0.04em; border-bottom:1px solid var(--td-gray-200); white-space:nowrap; }
.fac-form-table td { padding:5px 8px; border-bottom:1px solid var(--td-gray-100,#f3f4f6); vertical-align:middle; }
.fac-form-table tr:last-child td { border-bottom:none; }
.fac-form-table .form-control-sm { padding:4px 8px; font-size:0.82rem; height:2rem; }

/* Factura form — totals panel */
.fac-form-totals { margin-top:0.5rem; padding:0.75rem 1rem; background:var(--td-gray-50,#f9fafb); border:1px solid var(--td-gray-200); border-radius:var(--radius-md); display:flex; flex-direction:column; gap:0.4rem; font-size:0.85rem; }
.fac-form-totals-row { display:flex; justify-content:space-between; align-items:center; gap:1rem; color:var(--td-gray-600); }
.fac-form-totals-total { font-weight:700; font-size:1rem; color:var(--td-primary); border-top:1px solid var(--td-gray-200); padding-top:0.5rem; margin-top:0.15rem; }
.fac-form-totals-total span:last-child { font-family:monospace; }

/* ── Pasajeros ── */
.pax-stats { display:flex; gap:1rem; flex-wrap:wrap; margin-bottom:1rem; }
.pax-stat { background:var(--td-gray-50,#f9fafb); border:1px solid var(--td-gray-200,#e5e7eb); border-radius:0.5rem; padding:0.75rem 1rem; flex:1; min-width:120px; text-align:center; }
.pax-stat-val { font-size:1.4rem; font-weight:700; color:var(--td-primary); }
.pax-stat-lbl { font-size:0.72rem; color:var(--td-gray-400); margin-top:0.15rem; }
.pax-alert-banner { background:#fffbeb; border:1px solid #fcd34d; border-radius:0.5rem; padding:0.75rem 1rem; margin-bottom:1rem; }
.pax-alert-title { font-weight:600; color:#92400e; font-size:0.88rem; margin-bottom:0.4rem; }
.pax-alert-list { display:flex; flex-wrap:wrap; gap:0.4rem; }
.pax-alert-item { background:#fef3c7; color:#78350f; font-size:0.78rem; padding:0.2rem 0.6rem; border-radius:0.25rem; cursor:pointer; }
.pax-detail-section { margin-bottom:1.25rem; }
.pax-detail-section-title { font-size:0.72rem; font-weight:700; text-transform:uppercase; letter-spacing:0.05em; color:var(--td-gray-400); margin-bottom:0.6rem; border-bottom:1px solid var(--td-gray-100,#f3f4f6); padding-bottom:0.3rem; }
.pax-detail-grid { display:grid; grid-template-columns:1fr 1fr; gap:0.75rem; }
.pax-detail-field { display:flex; flex-direction:column; gap:0.15rem; }
.pax-detail-label { font-size:0.72rem; color:var(--td-gray-400); }
.pax-detail-value { font-size:0.88rem; color:var(--td-gray-700,#374151); font-weight:500; }
.pax-trips-list { display:flex; flex-wrap:wrap; gap:0.5rem; }

/* ── Caja ── */
.caja-stats { display:grid; grid-template-columns:repeat(3,1fr); gap:1rem; margin-bottom:1.25rem; }
.caja-stat { border-radius:0.625rem; padding:1rem 1.25rem; }
.caja-stat--saldo { background:#eff6ff; border:1px solid #bfdbfe; }
.caja-stat--ingreso { background:#f0fdf4; border:1px solid #bbf7d0; }
.caja-stat--gasto { background:#fef2f2; border:1px solid #fecaca; }
.caja-stat-label { font-size:0.72rem; color:var(--td-gray-500); text-transform:uppercase; letter-spacing:0.05em; }
.caja-stat-value { font-size:1.5rem; font-weight:700; margin-top:0.2rem; }
.caja-stat--saldo .caja-stat-value { color:#1d4ed8; }
.caja-stat--ingreso .caja-stat-value { color:#15803d; }
.caja-stat--gasto .caja-stat-value { color:#dc2626; }
.badge-ingreso { background:#dcfce7; color:#166534; font-size:0.72rem; padding:0.15rem 0.5rem; border-radius:0.25rem; font-weight:600; }
.badge-gasto { background:#fee2e2; color:#991b1b; font-size:0.72rem; padding:0.15rem 0.5rem; border-radius:0.25rem; font-weight:600; }
/* ── Tesorería ── */
.tesoreria-grid { display:grid; grid-template-columns:1fr 1fr; gap:1.25rem; margin-top:1rem; }
.tesoreria-col { background:var(--td-gray-50,#f9fafb); border:1px solid var(--td-gray-200,#e5e7eb); border-radius:0.625rem; padding:1rem; }
.tesoreria-col-title { font-weight:700; font-size:0.88rem; margin-bottom:0.75rem; display:flex; align-items:center; gap:0.4rem; }
.tesoreria-item { display:flex; justify-content:space-between; align-items:center; padding:0.5rem 0; border-bottom:1px solid var(--td-gray-100,#f3f4f6); font-size:0.82rem; gap:0.5rem; }
.tesoreria-item:last-child { border-bottom:none; }
.tesoreria-item-left { display:flex; flex-direction:column; gap:0.1rem; }
.tesoreria-item-date { font-size:0.72rem; color:var(--td-gray-400); }
.tesoreria-item-amount { font-weight:600; white-space:nowrap; }
.tesoreria-item-amount--cobro { color:#15803d; }
.tesoreria-item-amount--pago { color:#dc2626; }
.tesoreria-item--overdue { background:#fef2f2; margin:0 -0.5rem; padding:0.5rem; border-radius:0.25rem; }
.tesoreria-kpis { display:grid; grid-template-columns:repeat(3,1fr); gap:1rem; margin-bottom:1.25rem; }
.tesoreria-kpi { background:white; border:1px solid var(--td-gray-200,#e5e7eb); border-radius:0.625rem; padding:0.875rem 1rem; text-align:center; }
.tesoreria-kpi-label { font-size:0.72rem; color:var(--td-gray-400); text-transform:uppercase; letter-spacing:0.04em; }
.tesoreria-kpi-value { font-size:1.35rem; font-weight:700; margin-top:0.15rem; }
/* ── Contabilidad resumen ── */
.cont-table { width:100%; border-collapse:collapse; font-size:0.85rem; margin-top:1rem; }
.cont-table th { background:var(--td-gray-50,#f9fafb); padding:0.5rem 0.75rem; text-align:left; font-size:0.75rem; color:var(--td-gray-500); border-bottom:2px solid var(--td-gray-200,#e5e7eb); }
.cont-table td { padding:0.5rem 0.75rem; border-bottom:1px solid var(--td-gray-100,#f3f4f6); }

/* ── Vuelos del día ── */
.vuelos-hoy-section { margin-bottom:1.5rem; }
.vuelos-hoy-title { font-weight:700; font-size:0.88rem; color:var(--td-gray-700,#374151); margin-bottom:0.75rem; display:flex; align-items:center; gap:0.5rem; }
.vuelos-hoy-count { background:#dbeafe; color:#1d4ed8; font-size:0.72rem; padding:0.1rem 0.45rem; border-radius:99px; font-weight:700; }
.vuelos-hoy-grid { display:grid; grid-template-columns:repeat(auto-fill, minmax(280px, 1fr)); gap:0.75rem; }
.vuelo-card { background:#fff; border:1px solid #bfdbfe; border-radius:0.625rem; padding:1rem; box-shadow:0 1px 3px rgba(0,0,0,0.04); }
.vuelo-card--placeholder { border-style:dashed; background:#f8fafc; }
.vuelo-card-head { display:flex; align-items:center; gap:0.5rem; margin-bottom:0.75rem; }
.vuelo-icon { font-size:1.25rem; flex-shrink:0; }
.vuelo-ruta { font-weight:700; font-size:0.9rem; color:#1e3a5f; flex:1; }
.vuelo-hora { font-size:0.78rem; color:#6b7280; white-space:nowrap; font-weight:600; background:#f0f9ff; padding:0.15rem 0.4rem; border-radius:0.25rem; }
.vuelo-card-body { display:flex; flex-direction:column; gap:0.35rem; margin-bottom:0.75rem; }
.vuelo-detail { display:flex; gap:0.5rem; font-size:0.82rem; align-items:baseline; }
.vuelo-lbl { color:var(--td-gray-400); min-width:78px; font-size:0.72rem; text-transform:uppercase; letter-spacing:0.04em; flex-shrink:0; }
.vuelo-card-footer { display:flex; gap:0.5rem; align-items:center; border-top:1px solid #f0f4f8; padding-top:0.6rem; margin-top:0.25rem; }
/* ── WhatsApp buttons ── */
.btn-wa {
  background: #25D366;
  color: #fff;
  border: none;
  text-decoration: none;
  display: inline-flex;
  align-items: center;
  gap: 0.3rem;
  font-weight: 600;
  transition: background 0.15s;
}
.btn-wa:hover { background: #1ebe5d; color: #fff; text-decoration: none; }
.wa-inline-link {
  margin-left: 0.4rem;
  font-size: 1rem;
  text-decoration: none;
  opacity: 0.85;
  vertical-align: middle;
  transition: opacity 0.15s;
}
.wa-inline-link:hover { opacity: 1; }

/* ── Vuelos del día — tarjetas con gradiente (dashboard) ── */
.vuelo-hoy-card { background: white; border: 1px solid var(--td-gray-200, #e5e7eb); border-radius: 0.625rem; overflow: hidden; transition: box-shadow 0.15s; }
.vuelo-hoy-card:hover { box-shadow: 0 4px 12px rgba(0,0,0,0.08); }
.vuelo-hoy-header { background: linear-gradient(135deg, #1e3a5f 0%, #3b82f6 100%); color: white; padding: 0.75rem 1rem; display: flex; align-items: center; gap: 0.75rem; flex-wrap: wrap; }
.vuelo-hoy-ruta { display: flex; align-items: center; gap: 0.4rem; font-weight: 700; font-size: 1rem; }
.vuelo-hoy-iata { font-family: monospace; font-size: 1.1rem; letter-spacing: 0.05em; }
.vuelo-hoy-arrow { opacity: 0.7; font-size: 0.9rem; }
.vuelo-hoy-hora { font-size: 0.82rem; background: rgba(255,255,255,0.2); padding: 0.15rem 0.5rem; border-radius: 0.25rem; margin-left: auto; }
.vuelo-hoy-loc { font-size: 0.75rem; background: rgba(255,255,255,0.15); color: white; border: 1px solid rgba(255,255,255,0.3); padding: 0.1rem 0.4rem; border-radius: 0.25rem; font-family: monospace; letter-spacing: 0.1em; }
.vuelo-hoy-body { padding: 0.75rem 1rem; }
.vuelo-hoy-client { display: flex; align-items: center; gap: 0.5rem; margin-bottom: 0.4rem; font-size: 0.85rem; font-weight: 500; }
.vuelo-hoy-avatar { width: 24px; height: 24px; border-radius: 50%; background: #dbeafe; color: #1d4ed8; font-size: 0.65rem; font-weight: 700; display: flex; align-items: center; justify-content: center; flex-shrink: 0; }
.vuelo-hoy-aerolinea { font-size: 0.78rem; color: var(--td-gray-500, #6b7280); }
.vuelo-hoy-sindetalle { font-size: 0.75rem; color: var(--td-gray-400, #9ca3af); margin-top: 0.3rem; font-style: italic; }

/* ── Catalog card extras ── */
.catalog-card-pq { font-size:0.75rem; color:var(--td-gray-500); margin-top:0.35rem; font-style:italic; line-height:1.4; }
.catalog-card-traslado { font-size:0.75rem; color:#92400e; background:#fef3c7; border-radius:0.25rem; padding:0.15rem 0.4rem; margin-top:0.35rem; display:inline-block; }
.catalog-card-ruta { font-size:0.78rem; color:var(--td-gray-600); margin-top:0.35rem; font-weight:500; }

/* ── Destinos tab ── */
.dest-pills { display:flex; flex-wrap:wrap; gap:0.5rem; margin-bottom:1.25rem; }
.dest-pill { padding:0.35rem 0.9rem; border-radius:99px; border:1.5px solid var(--td-gray-200,#e5e7eb); background:white; font-size:0.82rem; cursor:pointer; font-weight:500; transition:all 0.15s; }
.dest-pill.active { background:var(--td-primary,#3b82f6); color:white; border-color:var(--td-primary,#3b82f6); }
.dest-pill:hover:not(.active) { border-color:var(--td-primary,#3b82f6); color:var(--td-primary,#3b82f6); }
.dest-section { background:white; border:1px solid var(--td-gray-200,#e5e7eb); border-radius:0.625rem; margin-bottom:1rem; overflow:hidden; }
.dest-section-header { padding:0.75rem 1rem; background:var(--td-gray-50,#f9fafb); font-weight:600; font-size:0.88rem; cursor:pointer; display:flex; justify-content:space-between; align-items:center; }
.dest-section-body { padding:1rem; }
.dest-ciudad-card { background:var(--td-gray-50,#f9fafb); border:1px solid var(--td-gray-100,#f3f4f6); border-radius:0.5rem; padding:0.75rem; margin-bottom:0.75rem; }
.dest-ciudad-name { font-weight:600; font-size:0.88rem; margin-bottom:0.5rem; display:flex; justify-content:space-between; align-items:center; }
.dest-list-item { display:flex; align-items:center; gap:0.5rem; padding:0.4rem 0; border-bottom:1px solid var(--td-gray-100,#f3f4f6); font-size:0.85rem; }
.dest-list-item:last-child { border-bottom:none; }
.dest-list-item .dest-item-text { flex:1; }
.dest-list-edit { transition:border-color .12s,background .12s; }
.dest-list-edit:hover { border-color:var(--td-gray-300,#d1d5db) !important; background:var(--td-gray-50,#f9fafb) !important; }
.dest-list-edit:focus { border-color:var(--td-primary,#4814A0) !important; background:white !important; outline:none; }

/* ── Vista compacta tipo GIAV ── */
.td-table { width:100%; border-collapse:separate; border-spacing:0; background:white; border:1px solid var(--td-gray-200,#e5e7eb); border-radius:8px; overflow:hidden; font-size:.85rem; }
.td-table thead th { background:var(--td-gray-50,#f9fafb); padding:.55rem .75rem; text-align:left; font-size:.72rem; font-weight:700; color:var(--td-gray-600,#475569); text-transform:uppercase; letter-spacing:.04em; border-bottom:1px solid var(--td-gray-200,#e5e7eb); position:sticky; top:0; }
.td-table tbody td { padding:.55rem .75rem; border-bottom:1px solid var(--td-gray-100,#f3f4f6); color:var(--td-gray-800,#1f2937); }
.td-table tbody tr:last-child td { border-bottom:none; }
.td-table tbody tr:hover { background:var(--td-gray-50,#f9fafb); }
.view-mode-toggle .btn-primary { background:var(--td-primary,#4814A0); color:white; }

/* ── Feature flags toggles ── */
.features-grid { display:flex; flex-direction:column; gap:.5rem; }
.feature-row { display:flex; justify-content:space-between; align-items:center; gap:1rem; padding:.85rem 1rem; border:1px solid var(--td-gray-200,#e5e7eb); border-radius:8px; background:white; }
.feature-info { flex:1; min-width:0; }
.feature-label { font-weight:600; font-size:.9rem; color:var(--td-gray-900); }
.feature-desc  { font-size:.78rem; color:var(--td-gray-500); margin-top:.2rem; line-height:1.5; }
.feature-toggle { position:relative; width:44px; height:24px; flex-shrink:0; cursor:pointer; }
.feature-toggle.is-disabled { opacity:.45; cursor:not-allowed; }
.feature-toggle input { opacity:0; width:0; height:0; }
.feature-slider { position:absolute; inset:0; background:#cbd5e1; border-radius:24px; transition:background .15s; }
.feature-slider::before { content:""; position:absolute; left:3px; top:3px; width:18px; height:18px; background:white; border-radius:50%; transition:transform .15s; box-shadow:0 1px 2px rgba(0,0,0,.2); }
.feature-toggle input:checked + .feature-slider { background:var(--td-primary,#4814A0); }
.feature-toggle input:checked + .feature-slider::before { transform:translateX(20px); }

/* ── Rediseño Destinos v2 ── */
.dest-vars-hint { background:#eff6ff; border:1px solid #bfdbfe; color:#1e40af; border-radius:.5rem; padding:.6rem .85rem; margin-bottom:1rem; font-size:.82rem; line-height:1.5; }
.dest-vars-hint code { background:white; color:var(--td-primary,#4814A0); padding:1px 6px; border-radius:4px; font-size:.78rem; font-weight:600; margin:0 1px; border:1px solid #ddd6fe; }
.dest-section-hint { font-size:.8rem; color:var(--td-gray-600); margin:0 0 .85rem; line-height:1.5; padding:.5rem .75rem; background:var(--td-gray-50,#f9fafb); border-left:3px solid var(--td-gray-300,#d1d5db); border-radius:0 4px 4px 0; }
.dest-tgroup { background:var(--td-gray-50,#f9fafb); border:1px solid var(--td-gray-200,#e5e7eb); border-radius:8px; padding:.85rem 1rem; margin-bottom:.75rem; }
.dest-tgroup-head { margin-bottom:.65rem; padding-bottom:.55rem; border-bottom:1px solid var(--td-gray-200,#e5e7eb); }
.dest-tgroup-title { font-weight:700; font-size:.88rem; color:var(--td-gray-900); }
.dest-tgroup-desc { font-size:.75rem; color:var(--td-gray-500); margin-top:2px; line-height:1.4; }
.dest-tgroup-body { display:flex; flex-direction:column; gap:.6rem; }
.dest-titem { display:flex; flex-direction:column; gap:.25rem; }
.dest-titem-label { font-size:.78rem; color:var(--td-gray-700); font-weight:600; }
.dest-ciudad-card { background:white; border:1px solid var(--td-gray-200,#e5e7eb); border-radius:.5rem; padding:.85rem 1rem; margin-bottom:.7rem; }
.dest-ciudad-head { display:flex; justify-content:space-between; align-items:center; }
.dest-ciudad-name { font-weight:700; font-size:.92rem; color:var(--td-gray-900); }
.dest-ciudad-reco { resize:vertical; font-size:.85rem; flex:1; }
.dest-reco-row { display:flex; gap:.5rem; align-items:flex-start; margin-bottom:.4rem; }
.dest-reco-num { flex-shrink:0; width:22px; height:22px; border-radius:50%; background:var(--td-primary,#4814A0); color:white; font-size:.7rem; font-weight:700; display:flex; align-items:center; justify-content:center; margin-top:6px; }
.dest-reco-del { flex-shrink:0; align-self:center; }

/* ── Image Picker ── */
.imgpick { font-size:.88rem; }
.imgpick-tabs { display:flex; gap:.25rem; border-bottom:2px solid var(--td-gray-200,#e5e7eb); margin-bottom:1rem; }
.imgpick-tab { background:none; border:none; padding:.6rem .9rem; cursor:pointer; font-size:.86rem; color:var(--td-gray-600); border-bottom:2px solid transparent; margin-bottom:-2px; font-weight:500; }
.imgpick-tab.active { color:var(--td-primary,#4814A0); border-bottom-color:var(--td-primary,#4814A0); font-weight:700; }
.imgpick-tab:hover:not(.active) { color:var(--td-gray-900); background:var(--td-gray-50); }
.imgpick-panel { min-height:300px; }
.imgpick-searchbar { display:flex; gap:.5rem; margin-bottom:1rem; }
.imgpick-searchbar .form-control { flex:1; }
.imgpick-results { min-height:240px; }
.imgpick-grid { display:grid; grid-template-columns:repeat(auto-fill,minmax(150px,1fr)); gap:.6rem; }
.imgpick-card { position:relative; cursor:pointer; border:2px solid transparent; border-radius:6px; overflow:hidden; aspect-ratio:4/3; background:var(--td-gray-100,#f3f4f6); transition:transform .12s,border-color .12s; }
.imgpick-card:hover { border-color:var(--td-primary,#4814A0); transform:scale(1.02); }
.imgpick-card img { width:100%; height:100%; object-fit:cover; display:block; }
.imgpick-card-attr { position:absolute; bottom:0; left:0; right:0; background:linear-gradient(transparent,rgba(0,0,0,.7)); color:white; font-size:.66rem; padding:14px 6px 4px; opacity:0; transition:opacity .12s; }
.imgpick-card:hover .imgpick-card-attr { opacity:1; }
.imgpick-attr-note { font-size:.7rem; color:var(--td-gray-400); margin-top:.75rem; text-align:center; font-style:italic; }
.imgpick-loading, .imgpick-empty, .imgpick-error { padding:2.5rem 1rem; text-align:center; color:var(--td-gray-500); font-size:.88rem; }
.imgpick-error { color:var(--td-warning,#d97706); }
.imgpick-upload-zone { border:2px dashed var(--td-gray-300,#d1d5db); border-radius:8px; padding:2.5rem 1rem; text-align:center; transition:all .15s; background:var(--td-gray-50,#f9fafb); cursor:pointer; }
.imgpick-upload-zone.drag-over { border-color:var(--td-primary,#4814A0); background:#eff6ff; }
.imgpick-upload-content > div { line-height:1.5; }

/* ── Banner Positioner ── */
.banner-pos-frame { position:relative; width:100%; aspect-ratio:3/1; border-radius:8px; overflow:hidden; background:#1f2937; border:2px solid var(--td-primary,#4814A0); user-select:none; }
.banner-pos-overlay { position:absolute; inset:0; pointer-events:none; background:linear-gradient(180deg,transparent 0%,transparent 80%,rgba(0,0,0,.35) 100%); display:flex; align-items:flex-end; justify-content:center; padding:.5rem; }
.banner-pos-hint { color:white; font-size:.7rem; font-weight:600; background:rgba(0,0,0,.5); padding:3px 10px; border-radius:99px; }
.banner-mini-preview { transition:opacity .15s; }
.banner-mini-preview:hover { opacity:.9; }

/* ── Inline status select (expedientes list) ── */
.status-inline-select { box-shadow:none; outline:none; line-height:1.3; max-width:140px; }
.status-inline-select:focus { outline:none; box-shadow:none; }

/* ── Cuotas pendientes widget (dashboard) ── */
.cuotas-pendientes-list { border:1px solid var(--td-gray-200,#e5e7eb); border-radius:0.5rem; overflow:hidden; }
.cuota-pendiente-item { display:flex; align-items:center; justify-content:space-between; padding:0.5rem 0.75rem; border-bottom:1px solid var(--td-gray-100,#f3f4f6); border-left:3px solid transparent; }
.cuota-pendiente-item:last-child { border-bottom:none; }
.cuota-pendiente--red { border-left-color:#dc2626; }
.cuota-pendiente--red .cuota-pendiente-fecha { color:#dc2626; }
.cuota-pendiente--amber { border-left-color:#d97706; }
.cuota-pendiente-fecha { font-size:0.78rem; font-weight:600; min-width:72px; flex-shrink:0; }
.cuota-pendiente-info { display:flex; flex-direction:column; flex:1; padding:0 0.75rem; gap:0.1rem; }
.cuota-pendiente-info span { font-size:0.82rem; font-weight:500; }
.cuota-pendiente-importe { font-weight:700; color:var(--td-primary,#3b82f6); font-size:0.85rem; white-space:nowrap; }

/* ── Checklist incompleto widget (dashboard) ── */
.checklist-dash-row { display:flex; flex-direction:column; gap:0.25rem; padding:0.4rem 0.5rem; border-radius:6px; }
.checklist-dash-row:hover { background:var(--td-gray-50,#f9fafb); }
.checklist-dash-meta { display:flex; align-items:center; gap:0.4rem; }
.checklist-dash-bar-wrap { display:flex; align-items:center; gap:0.5rem; }

/* ── Filtro chips de tipo de servicio ── */
.svc-type-chips { display:flex; flex-wrap:wrap; gap:0.4rem; padding:0.5rem 0 0.75rem; }
.svc-chip { padding:0.25rem 0.65rem; border-radius:999px; font-size:0.75rem; font-weight:500; border:1px solid var(--td-gray-200,#e5e7eb); background:#fff; color:var(--td-gray-600,#4b5563); cursor:pointer; transition:background 0.15s, color 0.15s; }
.svc-chip:hover { background:var(--td-gray-50,#f9fafb); }
.svc-chip--active { background:var(--td-primary,#3b82f6); color:#fff; border-color:var(--td-primary,#3b82f6); }

/* ── Drag & drop servicios ── */
.svc-draggable-row { transition: background 0.12s; }
.svc-draggable-row:hover .svc-drag-handle { color: var(--td-gray-400, #9ca3af) !important; }
.svc-drag-handle:active { cursor: grabbing; }
.svc-row--dragging { opacity: 0.38; background: var(--td-gray-50, #f9fafb) !important; }
.svc-row--drag-over-top { box-shadow: inset 0 3px 0 0 var(--td-primary, #3b82f6); }
.svc-row--drag-over-bot { box-shadow: inset 0 -3px 0 0 var(--td-primary, #3b82f6); }

/* ── Botón atrás (topbar) ── */
.btn-back { display:inline-flex; align-items:center; gap:0.3rem; padding:0.3rem 0.65rem; border-radius:6px; border:1px solid var(--td-gray-200,#e5e7eb); background:#fff; color:var(--td-gray-600,#4b5563); font-size:0.8rem; font-weight:500; cursor:pointer; transition:all .15s; white-space:nowrap; }
.btn-back:hover { background:var(--td-gray-50,#f9fafb); color:var(--td-gray-800,#1f2937); border-color:var(--td-gray-300,#d1d5db); }

/* ── Agenda items clickeables ── */
.agenda-item--clickable:hover { background:var(--td-gray-50,#f9fafb); border-radius:6px; }

/* ── CHATBOT ── */
#chatbot-wrapper {
  position: fixed;
  bottom: 0;
  right: 24px;
  z-index: 9999;
  display: flex;
  flex-direction: column;
  align-items: flex-end;
}

/* Tab de "Asistencia rápida" — siempre visible en la parte inferior */
.chatbot-tab {
  display: flex;
  align-items: center;
  gap: 7px;
  background: #4814A0;
  color: white;
  border-radius: 10px 10px 0 0;
  padding: 7px 14px 7px 12px;
  cursor: pointer;
  font-size: 0.82rem;
  font-weight: 600;
  font-family: 'Inter', sans-serif;
  box-shadow: 0 -2px 12px rgba(72,20,160,.25);
  transition: background .15s;
  user-select: none;
}
.chatbot-tab:hover { background: #5a1fc4; }
.chatbot-tab-icon { font-size: 1rem; }
.chatbot-tab-label { letter-spacing: 0.01em; }
.chatbot-tab-dismiss {
  background: none; border: none; color: rgba(255,255,255,.6);
  cursor: pointer; font-size: 0.85rem; padding: 0 0 0 4px;
  line-height: 1; display: flex; align-items: center;
}
.chatbot-tab-dismiss:hover { color: white; }
/* Cuando el panel está abierto, resalta el tab */
.chatbot-tab-open { background: #3a0f80; }

.chatbot-panel {
  position: relative;
  bottom: auto;
  right: auto;
  margin-bottom: 0;
  width: 360px;
  max-height: 520px;
  background: #fff;
  border-radius: 16px;
  box-shadow: 0 8px 40px rgba(0,0,0,.18);
  z-index: 9998;
  display: flex;
  flex-direction: column;
  overflow: hidden;
  transition: opacity .2s, transform .2s;
}
.chatbot-closed { opacity: 0; transform: translateY(12px) scale(.97); pointer-events: none; max-height: 0; }
.chatbot-open   { opacity: 1; transform: translateY(0) scale(1); pointer-events: all; max-height: 520px; }

.chatbot-header {
  background: linear-gradient(135deg, #4814A0, #6b21a8);
  padding: 14px 16px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  color: white;
}
.chatbot-header-info { display: flex; align-items: center; gap: 10px; }
.chatbot-avatar { font-size: 28px; }
.chatbot-name { font-weight: 700; font-size: .95rem; }
.chatbot-status { font-size: .72rem; color: #d1c4e9; }
.chatbot-close { background: none; border: none; color: rgba(255,255,255,.7); font-size: 18px; cursor: pointer; line-height: 1; padding: 2px 6px; border-radius: 4px; }
.chatbot-close:hover { color: white; background: rgba(255,255,255,.15); }

.chatbot-messages {
  flex: 1;
  overflow-y: auto;
  padding: 14px;
  display: flex;
  flex-direction: column;
  gap: 10px;
  max-height: 300px;
  background: #f9fafb;
}

.chatbot-msg { display: flex; gap: 8px; max-width: 85%; }
.chatbot-msg--bot  { align-self: flex-start; }
.chatbot-msg--user { align-self: flex-end; flex-direction: row-reverse; }

.chatbot-bubble {
  padding: 9px 13px;
  border-radius: 14px;
  font-size: .875rem;
  line-height: 1.45;
}
.chatbot-msg--bot  .chatbot-bubble { background: white; border: 1px solid #e5e7eb; color: #1f2937; border-radius: 4px 14px 14px 14px; }
.chatbot-msg--user .chatbot-bubble { background: #FF8200; color: white; border-radius: 14px 4px 14px 14px; }

.chatbot-typing { display: flex; gap: 5px; align-items: center; padding: 10px 13px; }
.chatbot-dot { width: 7px; height: 7px; border-radius: 50%; background: #9ca3af; animation: chatbot-bounce .9s infinite; }
.chatbot-dot:nth-child(2) { animation-delay: .15s; }
.chatbot-dot:nth-child(3) { animation-delay: .3s; }
@keyframes chatbot-bounce { 0%,80%,100% { transform: translateY(0); } 40% { transform: translateY(-6px); } }

.chatbot-suggestions {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
  padding: 8px 14px;
  border-top: 1px solid #f3f4f6;
  background: white;
}
.chatbot-pill {
  background: #f3f4f6;
  border: 1px solid #e5e7eb;
  border-radius: 20px;
  padding: 4px 10px;
  font-size: .78rem;
  cursor: pointer;
  color: #374151;
  transition: background .15s;
}
.chatbot-pill:hover { background: #fff7ed; border-color: #FF8200; color: #FF8200; }

.chatbot-input-row {
  display: flex;
  gap: 8px;
  padding: 10px 14px;
  border-top: 1px solid #e5e7eb;
  background: white;
}
#chatbot-input {
  flex: 1;
  border: 1px solid #e5e7eb;
  border-radius: 20px;
  padding: 8px 14px;
  font-size: .875rem;
  outline: none;
  transition: border-color .15s;
}
#chatbot-input:focus { border-color: #4814A0; }
#chatbot-send {
  background: #4814A0;
  color: white;
  border: none;
  border-radius: 50%;
  width: 36px;
  height: 36px;
  cursor: pointer;
  font-size: 14px;
  display: flex; align-items: center; justify-content: center;
  transition: background .15s;
}
#chatbot-send:hover { background: #3b0f87; }

.chatbot-wa-btn {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  background: #25D366;
  color: white;
  border: none;
  border-radius: 20px;
  padding: 6px 14px;
  font-size: .82rem;
  font-weight: 600;
  cursor: pointer;
  text-decoration: none;
  margin-top: 6px;
}

/* ============================================================
   CENTRO DE AYUDA
   ============================================================ */

/* Layout principal */
.ayuda-layout {
  display: flex;
  gap: 2rem;
  align-items: flex-start;
}

.ayuda-main {
  flex: 1;
  min-width: 0;
}

.ayuda-sidebar {
  min-width: 240px;
  width: 260px;
  flex-shrink: 0;
  position: sticky;
  top: 1rem;
}

/* Input de búsqueda */
.ayuda-search-wrap {
  position: relative;
}

.ayuda-search-input {
  width: 100%;
  padding: 0.7rem 1rem;
  font-size: 0.95rem;
  border: 1.5px solid var(--td-gray-200, #e5e7eb);
  border-radius: 10px;
  background: #fff;
  color: var(--td-gray-800, #1f2937);
  transition: border-color 0.15s, box-shadow 0.15s;
  box-sizing: border-box;
  outline: none;
}

.ayuda-search-input:focus {
  border-color: #FF8200;
  box-shadow: 0 0 0 3px rgba(255, 130, 0, 0.12);
}

/* Ítems del listado */
.ayuda-articles-list {
  display: flex;
  flex-direction: column;
  gap: 0.4rem;
}

.ayuda-article-item {
  background: #fff;
  border: 1px solid var(--td-gray-200, #e5e7eb);
  border-left: 3px solid transparent;
  border-radius: 8px;
  padding: 0.75rem 1rem;
  cursor: pointer;
  transition: border-color 0.15s, background 0.15s, box-shadow 0.15s;
  outline: none;
}

.ayuda-article-item:hover,
.ayuda-article-item:focus {
  border-left-color: #FF8200;
  background: #fffbf7;
  box-shadow: 0 2px 8px rgba(255, 130, 0, 0.08);
}

.ayuda-article-item--active {
  border-left-color: #FF8200;
  background: #fff7ef;
}

/* Sidebar */
.ayuda-sidebar-section {
  background: #fff;
  border: 1px solid var(--td-gray-200, #e5e7eb);
  border-radius: 10px;
  padding: 1rem;
}

.ayuda-sidebar-title {
  font-size: 0.75rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.06em;
  color: var(--td-gray-400, #9ca3af);
  margin-bottom: 0.6rem;
}

.ayuda-cats {
  display: flex;
  flex-direction: column;
  gap: 0.25rem;
}

.ayuda-cat-btn {
  display: flex;
  align-items: center;
  gap: 0.5rem;
  width: 100%;
  padding: 0.45rem 0.65rem;
  border-radius: 6px;
  border: none;
  background: transparent;
  color: var(--td-gray-600, #4b5563);
  font-size: 0.85rem;
  font-weight: 500;
  cursor: pointer;
  text-align: left;
  transition: background 0.12s, color 0.12s;
}

.ayuda-cat-btn:hover {
  background: var(--td-gray-50, #f9fafb);
  color: var(--td-gray-800, #1f2937);
}

.ayuda-cat-btn--active {
  background: #FF8200;
  color: #fff;
  font-weight: 600;
}

.ayuda-cat-btn--active:hover {
  background: #e67300;
  color: #fff;
}

/* Botones de contacto en sidebar */
.ayuda-contact-btn {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 0.4rem;
  width: 100%;
  padding: 0.6rem 0.75rem;
  border-radius: 8px;
  border: none;
  color: #fff;
  font-size: 0.85rem;
  font-weight: 600;
  text-decoration: none;
  cursor: pointer;
  transition: opacity 0.15s;
  box-sizing: border-box;
}

.ayuda-contact-btn:hover {
  opacity: 0.88;
  color: #fff;
}

/* Botón volver */
.ayuda-back-btn {
  display: inline-flex;
  align-items: center;
  gap: 0.3rem;
  padding: 0.35rem 0.75rem;
  border-radius: 6px;
  border: 1px solid var(--td-gray-200, #e5e7eb);
  background: #fff;
  color: var(--td-gray-600, #4b5563);
  font-size: 0.82rem;
  font-weight: 500;
  cursor: pointer;
  transition: all 0.15s;
}

.ayuda-back-btn:hover {
  background: var(--td-gray-50, #f9fafb);
  border-color: #FF8200;
  color: #FF8200;
}

/* Badge de sección */
.ayuda-section-badge {
  display: inline-flex;
  align-items: center;
  gap: 0.3rem;
  padding: 0.25rem 0.65rem;
  border-radius: 999px;
  background: #fff3e8;
  color: #b85c00;
  font-size: 0.75rem;
  font-weight: 600;
  vertical-align: middle;
}

/* Contenido del artículo */
.ayuda-content {
  font-size: 0.9rem;
  line-height: 1.7;
  color: var(--td-gray-700, #374151);
}

.ayuda-content h3 {
  font-size: 0.97rem;
  font-weight: 700;
  color: #FF8200;
  margin: 1.5rem 0 0.5rem;
}

.ayuda-content h3:first-child {
  margin-top: 0;
}

.ayuda-content p {
  margin: 0 0 0.75rem;
}

.ayuda-content ul,
.ayuda-content ol {
  margin: 0 0 0.75rem 1.2rem;
  padding: 0;
}

.ayuda-content li {
  margin-bottom: 0.35rem;
}

.ayuda-content ul li::marker {
  color: #4814A0;
  content: "✓  ";
}

.ayuda-content strong {
  color: var(--td-gray-800, #1f2937);
}

.ayuda-content code {
  background: #f3f4f6;
  border: 1px solid #e5e7eb;
  border-radius: 4px;
  padding: 0.1em 0.4em;
  font-size: 0.85em;
  color: #4814A0;
  font-family: 'Courier New', monospace;
}

/* Steps numerados */
.ayuda-steps {
  counter-reset: ayuda-step;
  list-style: none;
  margin: 0 0 0.75rem 0;
  padding: 0;
}

.ayuda-steps li {
  counter-increment: ayuda-step;
  display: flex;
  align-items: flex-start;
  gap: 0.6rem;
  margin-bottom: 0.5rem;
}

.ayuda-steps li::before {
  content: counter(ayuda-step);
  display: flex;
  align-items: center;
  justify-content: center;
  min-width: 1.4rem;
  height: 1.4rem;
  border-radius: 50%;
  background: #4814A0;
  color: #fff;
  font-size: 0.72rem;
  font-weight: 700;
  flex-shrink: 0;
  margin-top: 0.1rem;
}

/* Bloque de tip/nota */
.ayuda-tip {
  background: #fffbeb;
  border-left: 3px solid #d4a200;
  border-radius: 6px;
  padding: 0.65rem 0.9rem;
  font-size: 0.85rem;
  color: #78350f;
  margin: 0.75rem 0;
  line-height: 1.55;
}

/* Responsive: sidebar debajo en pantallas angostas */
@media (max-width: 900px) {
  .ayuda-layout {
    flex-direction: column;
  }
  .ayuda-sidebar {
    width: 100%;
    position: static;
  }
  .ayuda-cats {
    flex-direction: row;
    flex-wrap: wrap;
  }
  .ayuda-cat-btn {
    width: auto;
  }
}

/* ── Brand images (logo / firma / sello) ─────────────── */
.brand-images-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 1rem;
  margin-top: .75rem;
}
@media (max-width: 700px) { .brand-images-grid { grid-template-columns: 1fr; } }

.brand-img-block { display: flex; flex-direction: column; gap: .4rem; }

.brand-img-drop {
  border: 2px dashed var(--td-gray-300);
  border-radius: var(--td-radius);
  min-height: 110px;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: .35rem;
  cursor: pointer;
  transition: border-color .15s, background .15s;
  padding: .75rem;
  text-align: center;
}
.brand-img-drop:hover,
.brand-img-drop--over   { border-color: var(--td-primary); background: color-mix(in srgb, var(--td-primary) 5%, transparent); }
.brand-img-drop--filled { border-style: solid; border-color: var(--td-gray-200); background: var(--td-gray-50); }

.brand-img-placeholder { font-size: 1.8rem; }
.brand-img-hint { font-size: .75rem; color: var(--td-gray-400); }
.brand-img-preview { max-height: 70px; max-width: 100%; object-fit: contain; }
.brand-img-preview--circle { border-radius: 50%; max-height: 70px; max-width: 70px; }
.brand-img-remove { color: var(--td-gray-400); font-size: .75rem; align-self: flex-start; padding: 0; }

/* Doc generator brand preview */
.docgen-brand-preview {
  display: flex;
  align-items: center;
  gap: 1.25rem;
  flex-wrap: wrap;
  padding: .75rem;
  background: var(--td-gray-50);
  border-radius: var(--td-radius-sm);
  margin-bottom: .5rem;
}
.docgen-brand-item { display: flex; flex-direction: column; align-items: center; gap: .25rem; font-size: .72rem; color: var(--td-success); }
.docgen-brand-thumb { max-height: 45px; max-width: 100px; object-fit: contain; }
.docgen-brand-thumb--circle { border-radius: 50%; max-width: 45px; max-height: 45px; }
.docgen-brand-missing { font-size: .75rem; color: var(--td-gray-400); }

/* form-hint inline */
.form-hint { font-size: .72rem; color: var(--td-gray-400); margin-left: .35rem; font-weight: 400; }

/* ── Doc dropzone ─────────────────────────────────────── */
.doc-dropzone {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: .35rem;
  border: 2px dashed var(--td-gray-300);
  border-radius: var(--td-radius);
  padding: 1.5rem 1rem;
  cursor: pointer;
  transition: border-color .15s, background .15s;
  text-align: center;
}
.doc-dropzone:hover,
.doc-dropzone--over {
  border-color: var(--td-primary);
  background: color-mix(in srgb, var(--td-primary) 5%, transparent);
}
.doc-dropzone--ready {
  border-color: var(--td-success);
  background: color-mix(in srgb, var(--td-success) 5%, transparent);
}
.doc-dropzone-icon { font-size: 1.8rem; }
.doc-dropzone-text { font-size: .83rem; color: var(--td-gray-500); }
.doc-dropzone-name { font-size: .82rem; color: var(--td-success); font-weight: 600; }

/* ── Doc visibility toggle ───────────────────────────── */
.doc-app-toggle { font-size: .9rem; transition: opacity .15s; }
.doc-app-on  { opacity: 1; }
.doc-app-off { opacity: .3; filter: grayscale(1); }

/* ── App client tab ──────────────────────────────────── */
.app-tab-wrap { display: flex; flex-direction: column; gap: 1.25rem; }

.app-section {
  background: var(--td-white);
  border: 1px solid var(--td-gray-200);
  border-radius: var(--td-radius);
  padding: 1rem;
}
.app-section-header {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: .75rem;
  margin-bottom: .85rem;
  flex-wrap: wrap;
}
.app-section-title { font-size: .92rem; font-weight: 700; color: var(--td-gray-800); margin: 0 0 .15rem; }
.app-section-sub   { font-size: .76rem; color: var(--td-gray-400); margin: 0; }

.app-doc-list { display: flex; flex-direction: column; gap: .35rem; }
.app-doc-row  { display: flex; align-items: center; gap: .5rem; font-size: .83rem; padding: .4rem .5rem; background: var(--td-gray-50); border-radius: var(--td-radius-sm); }
.app-doc-icon { font-size: 1rem; flex-shrink: 0; }
.app-doc-name { flex: 1; font-weight: 500; color: var(--td-gray-800); min-width: 0; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.app-doc-cat  { font-size: .74rem; color: var(--td-gray-400); white-space: nowrap; }

/* Reco admin blocks */
.recos-admin-list { display: flex; flex-direction: column; gap: .6rem; }
.reco-admin-block {
  border: 1px solid var(--td-gray-200);
  border-radius: var(--td-radius-sm);
  padding: .75rem;
  background: var(--td-gray-50);
}
.reco-admin-header {
  display: flex;
  align-items: center;
  gap: .5rem;
  margin-bottom: .5rem;
}
.reco-admin-titulo {
  flex: 1;
  font-weight: 700;
  font-size: .85rem;
}
.reco-admin-items { display: flex; flex-direction: column; gap: .35rem; }
.reco-admin-item  { display: flex; align-items: center; gap: .35rem; }
.reco-admin-item .form-control-sm { font-size: .81rem; }

/* ── Docs: drag&drop + used + sort ─────────────────────────── */
.doc-list { display: flex; flex-direction: column; gap: .35rem; }
.doc-item--used .doc-item-name { text-decoration: line-through; color: var(--td-gray-400); }
.doc-item--used { opacity: .65; }
.doc-row--dragging   { opacity: .4; }
.doc-row--drag-over  { border-top: 2px solid var(--td-primary); }
.doc-drag-handle:hover { color: var(--td-primary) !important; }
.doc-used-on  { color: #10b981 !important; }
.doc-used-off { color: var(--td-gray-400) !important; }
