*{margin:0;padding:0;box-sizing:border-box}
body{font-family:-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,sans-serif;background:#f5f5f5;color:#333}
a{color:#667eea;text-decoration:none}
.container{max-width:1400px;margin:0 auto;padding:20px}

.navbar{background:#2c3e50;color:#fff;padding:15px 30px;display:flex;justify-content:space-between;align-items:center;box-shadow:0 2px 10px rgba(0,0,0,.1)}
.navbar-brand{font-size:20px;font-weight:700}
.navbar-user{display:flex;gap:12px;align-items:center;font-size:14px}

.logout-btn{background:#e74c3c;color:#fff;border:0;padding:8px 15px;border-radius:4px;cursor:pointer}
.logout-btn:hover{background:#c0392b}

.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:15px;margin-bottom:30px}
.stat-card{background:#fff;padding:20px;border-radius:8px;box-shadow:0 2px 8px rgba(0,0,0,.08)}
.stat-card h3{font-size:12px;color:#666;margin-bottom:10px;text-transform:uppercase}
.stat-card .number{font-size:32px;font-weight:800;color:#667eea}

.filters{background:#fff;padding:20px;border-radius:8px;margin-bottom:20px;box-shadow:0 2px 8px rgba(0,0,0,.08)}
.filter-row{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:15px;align-items:end}
.form-group{display:flex;flex-direction:column}
.form-group label{font-size:12px;color:#666;margin-bottom:6px;font-weight:600}
input[type="text"],input[type="email"],input[type="password"],select,textarea{
  padding:10px;border:1px solid #ddd;border-radius:4px;font-size:14px;background:#fff
}
textarea{resize:vertical}
input:focus,select:focus,textarea:focus{outline:none;border-color:#667eea;box-shadow:0 0 0 3px rgba(102,126,234,.12)}

.btn{padding:10px 18px;background:#667eea;color:#fff;border:0;border-radius:4px;cursor:pointer}
.btn:hover{background:#5568d3}
.btn-secondary{background:#95a5a6}
.btn-secondary:hover{background:#7f8c8d}

.table-container{background:#fff;border-radius:8px;box-shadow:0 2px 8px rgba(0,0,0,.08);overflow:hidden}
table{width:100%;border-collapse:collapse}
th{background:#34495e;color:#fff;padding:15px;text-align:left;font-weight:700;font-size:13px}
td{padding:12px 15px;border-bottom:1px solid #ecf0f1}
tbody tr:hover{background:#fafafa}

.estado-badge{display:inline-block;padding:4px 8px;border-radius:3px;font-size:11px;font-weight:800;text-transform:uppercase}
.estado-nuevo{background:#e3f2fd;color:#1976d2}
.estado-contactado{background:#fff3e0;color:#e65100}
.estado-seguimiento{background:#f3e5f5;color:#6a1b9a}
.estado-matriculado{background:#e8f5e9;color:#2e7d32}
.estado-descartado{background:#ffebee;color:#c62828}

.test-badge{font-size:11px;font-weight:800}
.test-si{background:#d4edda;color:#155724;padding:3px 6px;border-radius:2px}
.test-no{background:#f8d7da;color:#721c24;padding:3px 6px;border-radius:2px}

.actions{display:flex;gap:8px}
.action-btn{padding:6px 12px;font-size:12px;background:#667eea;color:#fff;border-radius:3px}
.action-btn:hover{background:#5568d3}

.pagination{display:flex;justify-content:center;gap:6px;margin-top:10px;padding:18px}
.pagination a,.pagination span{padding:8px 12px;border:1px solid #ddd;border-radius:4px}
.pagination .active{background:#667eea;color:#fff;border-color:#667eea}

.no-results{text-align:center;padding:30px;color:#666}
.small{font-size:12px;color:#444}
.muted{color:#777}

.login-body{display:flex;min-height:100vh;align-items:center;justify-content:center}
.login-card{width:380px;background:#fff;border-radius:10px;padding:24px;box-shadow:0 8px 25px rgba(0,0,0,.12)}
.login-card h1{margin-bottom:14px}
.alert{background:#ffebee;color:#c62828;padding:10px;border-radius:6px;margin:10px 0}

.lead-header{display:flex;justify-content:space-between;align-items:flex-start;margin:10px 0 18px}
.lead-sub{display:flex;gap:10px;align-items:center;margin-top:6px}
.pill{background:#eef2ff;color:#2c3e50;font-weight:700;font-size:12px;padding:4px 8px;border-radius:999px}

.grid-2{display:grid;grid-template-columns:1fr 1fr;gap:16px}
@media(max-width:1000px){.grid-2{grid-template-columns:1fr}}

.card{background:#fff;border-radius:10px;padding:16px;box-shadow:0 2px 8px rgba(0,0,0,.08)}
.card h2{font-size:16px;margin-bottom:10px}

.kv{display:grid;grid-template-columns:160px 1fr;gap:10px;padding:8px 0;border-bottom:1px solid #f0f0f0}
.kv:last-child{border-bottom:0}
.kv > div:first-child{color:#666;font-size:12px;font-weight:800;text-transform:uppercase}
.kv > div:last-child{font-size:14px}

.note{border:1px solid #eee;border-radius:8px;padding:10px;margin-top:10px;background:#fafafa}
.note-meta{display:flex;justify-content:space-between;font-size:12px;color:#666;margin-bottom:6px}

.conv{border:1px solid #eee;border-radius:10px;padding:12px;margin-top:12px;background:#fff}
.conv.in{border-left:6px solid #2ecc71}
.conv.out{border-left:6px solid #667eea}
.conv-meta{display:flex;gap:8px;align-items:center;margin-bottom:8px}
.conv-subject{font-weight:800;margin-bottom:6px}
.conv-body{white-space:pre-wrap;font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,monospace;font-size:12px;background:#fafafa;padding:10px;border-radius:8px}

.semaforo{display:inline-block;width:16px;height:16px;border-radius:50%;font-size:12px;text-align:center;line-height:16px;font-weight:900}
.semaforo-verde{background:#2ecc71;color:#fff}
.semaforo-rojo{background:#e74c3c;color:#fff}

/* 1) Forzar que las columnas del grid no se expandan por contenido largo */
.grid-2 > .card { min-width:0; }

/* 2) Forzar wrap de valores largos (URL / user agent / textos) */
.kv > div:last-child {
  min-width:0;
  overflow-wrap:anywhere;
  word-break:break-word;
}

/* 3) Asegurar que .small también rompe */
.small { overflow-wrap:anywhere; word-break:break-word; }

/* 4) Por si la URL llegara como <a> en algún caso */
.kv a { overflow-wrap:anywhere; word-break:break-word; }

/* =========================================================
   MEJORA PANEL "ACCIONES" (alineación + secciones + semáforo)
   ========================================================= */

/* Formularios inline (Estado + Guardar) */
.inline-form{
  display:flex;
  gap:10px;
  align-items:end;
  flex-wrap:wrap;
}
.inline-form label{
  font-size:12px;
  color:#666;
  font-weight:600;
  margin-right:4px;
}
.inline-form select{
  min-width:220px;
}

/* Secciones internas dentro de Acciones */
.actions-section{
  padding:14px 0;
  border-top:1px solid #e9e9e9;
}
.actions-section:first-of-type{
  padding-top:0;
  border-top:0;
}

.actions-grid-2{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:10px;
  align-items:end;
}
.actions-full{ grid-column:1 / -1; }

.form-label{
  display:block;
  font-size:12px;
  color:#666;
  font-weight:600;
  margin-bottom:6px;
}

/* Email manual con grid consistente */
.form-grid-2{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:10px;
  align-items:end;
}
@media(max-width:700px){
  .actions-grid-2,.form-grid-2{ grid-template-columns:1fr; }
}

/* Semáforo tipo “píldora” */
.control-toggle{
  display:inline-flex;
  align-items:center;
  gap:10px;
  user-select:none;
}

.traffic-pill{
  border:0;
  border-radius:999px;
  padding:10px 14px;
  color:#fff;
  font-weight:800;
  cursor:pointer;
  display:inline-flex;
  align-items:center;
  gap:8px;
  line-height:1;
}
.traffic-pill.ai{ background:#2ecc71; }
.traffic-pill.manual{ background:#e74c3c; }

.traffic-dot{
  width:10px;
  height:10px;
  border-radius:50%;
  background:rgba(255,255,255,.95);
}
.traffic-help{
  font-size:12px;
  color:#777;
}
/* CONTROL: Estado | Guardar | Semáforo en una misma fila */
.control-row{
  display:grid;
  grid-template-columns: 1fr auto; /* form a la izquierda, semáforo a la derecha */
  gap: 14px;
  align-items: start;
}

.control-form{
  display:grid;
  grid-template-columns: 1fr auto; /* select + guardar */
  gap: 10px;
  align-items: end;
  min-width: 0;
}

.control-estado select{ width: 100%; }

/* Semáforo alineado a la derecha */
.control-pill-wrap{
  justify-self: end;
  display:flex;
  flex-direction: column;
  align-items: flex-end;
  gap: 6px;
}

.traffic-help{
  font-size:12px;
  color:#777;
  text-align:right;
  max-width: 220px;
}

/* En móvil: que baje debajo */
@media (max-width: 800px){
  .control-row{ grid-template-columns: 1fr; }
  .control-pill-wrap{ justify-self: start; align-items: flex-start; }
  .traffic-help{ text-align:left; }
}
.form-grid-2 textarea{ width: 100%; }
.form-grid-2 input{ width: 100%; }
.actions-section textarea{ width:100%; }
@media (max-width: 768px){

  .lead-header{
    flex-direction: column;
    align-items: flex-start;
    gap: 10px;
  }

  .lead-header > div:last-child{
    align-self: flex-end; /* si quieres el botón a la derecha */
  }

}
/* LISTADO: móvil -> scroll horizontal y Acciones sticky */
.table-container{
  overflow-x: auto;
  -webkit-overflow-scrolling: touch;
}

.table-container table{
  min-width: 980px; /* ajusta si quieres, pero con 980 suele entrar todo */
}

@media (max-width: 768px){
  .table-container th:last-child,
  .table-container td:last-child{
    position: sticky;
    right: 0;
    background: #fff;
    z-index: 2;
  }

  .table-container thead th:last-child{
    background: #34495e; /* mismo color del thead */
    z-index: 3;
  }
}
.login-form{
  display: grid;
  grid-template-columns: 1fr;   /* SIEMPRE una columna */
  gap: 14px;
}

.login-field label{
  display:block;
  font-size:12px;
  color:#666;
  font-weight:600;
  margin-bottom:6px;
}

.login-field input{
  width:100%;
}

.login-form .btn{
  height: 42px; /* alinea con inputs */
  padding: 10px 18px;
}

@media (max-width: 650px){
  .login-form .btn{
    width:100%;
  }
}
/* Modal email: responsive en móvil */
@media (max-width: 768px){
  #emailModal .modal-dialog{
    width: calc(100vw - 20px);
    max-width: 100%;
    margin: 10px auto;
    border-radius: 12px;
  }

  #emailModal .modal-body{
    max-height: calc(100vh - 140px);
    overflow: auto;
    -webkit-overflow-scrolling: touch;
  }

  #emailModal .modal-frame,
  #emailModal .modal-pre{
    width: 100%;
    display: block;
  }

  /* si el iframe tiene altura fija en desktop, en móvil que sea más grande */
  #emailModal .modal-frame{
    min-height: 65vh;
  }
}

