/* Motiva CRM — interfaz definitiva (diseño "interfaz/" 2026-07).
   Tokens claro/oscuro · Manrope · riel de navegación · componentes del design system. */

* { box-sizing: border-box; }
html, body { margin: 0; padding: 0; height: 100%; }

:root, [data-theme="dark"] {
  --bg:#0B1018; --surface:#121A24; --surface-2:#18222F; --surface-3:#1E2A39;
  --border:#243343; --border-soft:#1B2734;
  --text:#EAF1F8; --dim:#97A6B8; --faint:#5E6E80;
  --primary:#19BDE8; --primary-press:#36C9EE; --on-primary:#04121A;
  --primary-soft:rgba(25,189,232,0.14); --primary-line:rgba(25,189,232,0.40);
  --ok:#1FC07A; --ok-soft:rgba(31,192,122,0.14);
  --warn:#F5A524; --warn-soft:rgba(245,165,36,0.14);
  --danger:#F0594E; --danger-soft:rgba(240,89,78,0.14);
  --note:#E3B341; --note-soft:rgba(227,179,65,0.10); --note-line:rgba(227,179,65,0.35);
  --shadow:0 10px 30px rgba(0,0,0,0.45);
  --wa:#25D366; --tg:#2AABEE; --ms:#0A7CFF; --ig:#E1306C;
  --d1:#3987e5; --d2:#199e70; --d3:#c98500; --d4:#9085e9;
  --r1:#86b6ef; --r2:#6ca3e3; --r3:#528fd6; --r4:#3a7bc7; --r5:#2a6bb8; --r6:#1c5cab;
  --grid-dot: rgba(151,166,184,0.13);
}
[data-theme="light"] {
  --bg:#EEF3F8; --surface:#FFFFFF; --surface-2:#F4F8FC; --surface-3:#ECF2F8;
  --border:#DEE7F0; --border-soft:#E9EFF5;
  --text:#0F1B2A; --dim:#5A6B82; --faint:#91A1B4;
  --primary:#0593BF; --primary-press:#0A82A8; --on-primary:#FFFFFF;
  --primary-soft:rgba(5,147,191,0.10); --primary-line:rgba(5,147,191,0.32);
  --ok:#109E66; --ok-soft:rgba(16,158,102,0.10);
  --warn:#C9821B; --warn-soft:rgba(201,130,27,0.12);
  --danger:#D6483D; --danger-soft:rgba(214,72,61,0.10);
  --note:#B5841A; --note-soft:rgba(181,132,26,0.08); --note-line:rgba(181,132,26,0.30);
  --shadow:0 8px 24px rgba(20,40,70,0.10);
  --wa:#1EB257; --tg:#229ED9; --ms:#0A7CFF; --ig:#D62A6F;
  --d1:#2a78d6; --d2:#1baf7a; --d3:#eda100; --d4:#4a3aa7;
  --grid-dot: rgba(15,27,42,0.10);
}

body {
  background: var(--bg); color: var(--text);
  font-family: Manrope, system-ui, sans-serif; font-size: 14px;
  -webkit-font-smoothing: antialiased; overflow: hidden;
}
::-webkit-scrollbar { width: 10px; height: 10px; }
::-webkit-scrollbar-thumb { background: var(--border); border-radius: 8px; border: 2px solid transparent; background-clip: padding-box; }
.oculto { display: none !important; }
a { color: var(--primary); }

@keyframes mtv-pulse { 0%,100% { opacity:.35; transform:translateY(0);} 50% { opacity:1; transform:translateY(-2px);} }
@keyframes mtv-skel { 0%,100% { opacity: .4; } 50% { opacity: 1; } }
@keyframes toast-in { from { opacity: 0; transform: translateY(10px); } to { opacity: 1; transform: none; } }

/* ===== Login ===== */
#pantalla-login {
  min-height: 100vh; display: grid; place-items: center; padding: 24px;
  background: radial-gradient(900px 500px at 70% -10%, rgba(25,189,232,0.13), transparent 60%),
              radial-gradient(700px 500px at 10% 110%, rgba(25,189,232,0.07), transparent 60%), var(--bg);
}
.login-caja { width: 400px; max-width: 94vw; }
.login-marca { display: flex; flex-direction: column; align-items: center; gap: 14px; margin-bottom: 26px; }
.login-logo { padding: 14px 22px; border-radius: 16px; background: linear-gradient(135deg,#0A2230,#0E3A52); border: 1px solid var(--border); }
.login-logo img { height: 26px; display: block; }
.login-titulo { font-size: 20px; font-weight: 800; letter-spacing: -.4px; text-align: center; }
.login-titulo .acento { color: var(--primary); }
.login-sub { font-size: 13px; color: var(--dim); margin-top: 3px; text-align: center; }
.login-form { background: var(--surface); border: 1px solid var(--border); border-radius: 18px; padding: 26px 24px 24px; box-shadow: 0 20px 50px rgba(0,0,0,0.5); }
.login-form label { display: block; font-size: 12px; font-weight: 800; color: var(--dim); margin-bottom: 6px; }
.login-form input[type=email], .login-form input[type=password] {
  width: 100%; height: 42px; padding: 0 13px; border-radius: 10px; border: 1px solid var(--border);
  background: var(--surface-2); color: var(--text); font-family: inherit; font-size: 14px; outline: none; margin-bottom: 15px;
}
.login-form input:focus { border-color: var(--primary-line); }
.campo-clave { position: relative; }
.campo-clave input[type=password], .campo-clave input[type=text] {
  width: 100%; height: 42px; padding: 0 42px 0 13px; border-radius: 10px; border: 1px solid var(--border);
  background: var(--surface-2); color: var(--text); font-family: inherit; font-size: 14px; outline: none; margin-bottom: 15px;
}
#btn-ver-clave {
  position: absolute; top: 0; right: 0; width: 42px; height: 42px; display: flex; align-items: center; justify-content: center;
  background: none; border: none; cursor: pointer; color: var(--dim); border-radius: 10px;
}
#btn-ver-clave:hover { color: var(--text); }
.login-alerta { display: flex; gap: 9px; align-items: center; padding: 10px 13px; border-radius: 10px; margin-bottom: 16px;
  font-size: 12.5px; font-weight: 700; }
.login-alerta.error { background: var(--danger-soft); border: 1px solid color-mix(in srgb, var(--danger) 40%, transparent); color: var(--danger); }
.login-alerta.bloqueo { background: var(--warn-soft); border: 1px solid color-mix(in srgb, var(--warn) 40%, transparent); color: var(--warn); }
.login-pie { text-align: center; margin-top: 18px; font-size: 11.5px; color: var(--faint); }

/* ===== Shell ===== */
#app { height: 100vh; display: flex; overflow: hidden; }
#nav {
  width: 78px; flex: 0 0 78px; display: flex; flex-direction: column; align-items: center; gap: 2px;
  padding: 12px 8px; background: var(--surface); border-right: 1px solid var(--border); overflow-y: auto;
}
.nav-logo { width: 44px; height: 44px; border-radius: 12px; background: linear-gradient(135deg,#0A2230,#0E3A52);
  border: 1px solid var(--border); display: grid; place-items: center; margin-bottom: 10px; }
.nav-logo img { width: 30px; height: 30px; object-fit: contain; }
#nav a.nav-item {
  width: 62px; padding: 8px 0 7px; display: flex; flex-direction: column; align-items: center; gap: 4px;
  border-radius: 11px; text-decoration: none; color: var(--dim); position: relative;
}
#nav a.nav-item:hover { background: var(--surface-2); color: var(--text); }
#nav a.nav-item.activa { color: var(--primary); background: var(--primary-soft); }
#nav a.nav-item span.eti { font-size: 10px; font-weight: 700; }
#nav a.nav-item.activa span.eti { font-weight: 800; }
.nav-badge { position: absolute; top: 4px; right: 7px; min-width: 16px; height: 16px; padding: 0 4px; border-radius: 9px;
  background: var(--danger); color: #fff; font-size: 9.5px; font-weight: 800; display: grid; place-items: center; }
.nav-punto { position: absolute; top: 6px; right: 10px; width: 8px; height: 8px; border-radius: 50%; background: var(--warn); border: 2px solid var(--surface); }

.principal { flex: 1; display: flex; flex-direction: column; min-width: 0; }
#header {
  height: 52px; flex: 0 0 52px; display: flex; align-items: center; gap: 12px; padding: 0 16px;
  background: var(--surface); border-bottom: 1px solid var(--border);
}
#header h1 { margin: 0; font-size: 16px; font-weight: 800; letter-spacing: -.3px; }
#header .sub { font-size: 12px; color: var(--dim); font-weight: 600; }
.pill-vivo { display: flex; align-items: center; gap: 6px; font-size: 11.5px; font-weight: 700; color: var(--ok);
  background: var(--ok-soft); padding: 4px 10px; border-radius: 20px; }
.pill-vivo .punto { width: 7px; height: 7px; border-radius: 50%; background: var(--ok); }
.usuario-zona { display: flex; align-items: center; gap: 9px; padding-left: 12px; border-left: 1px solid var(--border); }
.avatar-usuario { width: 30px; height: 30px; border-radius: 50%; background: linear-gradient(135deg,#7C5CFF,#B05CFF);
  display: grid; place-items: center; font-weight: 800; font-size: 11px; color: #fff; }
.usuario-nombre { line-height: 1.1; }
.usuario-nombre .n { font-weight: 700; font-size: 12px; }
.usuario-nombre .r { font-size: 10.5px; color: var(--dim); }

#contenido { flex: 1; overflow: hidden; min-height: 0; display: flex; flex-direction: column; }

/* ===== Botones / inputs / chips ===== */
.btn {
  height: 34px; padding: 0 13px; display: inline-flex; align-items: center; justify-content: center; gap: 6px;
  border-radius: 9px; border: 1px solid var(--border); background: var(--surface-2); color: var(--text);
  font-family: inherit; font-weight: 700; font-size: 12.5px; cursor: pointer; text-decoration: none;
}
.btn:hover { border-color: var(--faint); }
.btn-primario { border: none; background: var(--primary); color: var(--on-primary); font-weight: 800; }
.btn-primario:hover { background: var(--primary-press); }
.btn-suave { border: 1px solid var(--primary-line); background: var(--primary-soft); color: var(--primary); font-weight: 800; }
.btn-peligro { border: 1px solid color-mix(in srgb, var(--danger) 40%, transparent); background: var(--danger-soft); color: var(--danger); }
.btn-ok { border: none; background: var(--ok); color: #04140C; font-weight: 800; }
.btn-mini { height: 30px; padding: 0 10px; font-size: 12px; border-radius: 8px; }
.btn-icono { width: 34px; height: 34px; padding: 0; display: grid; place-items: center; color: var(--dim); }
.btn-icono:hover { color: var(--text); }

input, select, textarea {
  border-radius: 9px; border: 1px solid var(--border); background: var(--surface-2); color: var(--text);
  font-family: inherit; font-size: 13px; outline: none; padding: 8px 11px;
}
input:focus, select:focus, textarea:focus { border-color: var(--primary-line); }
textarea { resize: vertical; min-height: 64px; line-height: 1.5; }

.pill { display: inline-flex; align-items: center; gap: 4px; font-size: 10.5px; font-weight: 800; padding: 2px 9px; border-radius: 20px; width: fit-content; white-space: nowrap; }
.pill.ok { color: var(--ok); background: var(--ok-soft); }
.pill.warn { color: var(--warn); background: var(--warn-soft); }
.pill.danger { color: var(--danger); background: var(--danger-soft); }
.pill.info { color: var(--primary); background: var(--primary-soft); }
.pill.gris { color: var(--faint); background: var(--surface-2); }
.pill.d1 { color: var(--d1); background: color-mix(in srgb, var(--d1) 14%, transparent); }
.pill.d2 { color: var(--d2); background: color-mix(in srgb, var(--d2) 14%, transparent); }
.pill.d4 { color: var(--d4); background: color-mix(in srgb, var(--d4) 14%, transparent); }

.chip-filtro { display: inline-flex; align-items: center; gap: 5px; height: 27px; padding: 0 10px; border-radius: 8px; cursor: pointer;
  font-family: inherit; font-size: 11.5px; font-weight: 700; border: 1px solid var(--border); background: transparent; color: var(--dim); }
.chip-filtro.activa { border-color: var(--primary-line); background: var(--primary-soft); color: var(--primary); }
.chip-filtro .num { font-size: 10.5px; font-weight: 800; padding: 0 5px; border-radius: 20px; background: var(--surface-3); color: var(--faint); }
.chip-filtro.activa .num { background: var(--primary); color: var(--on-primary); }

.punto-canal { width: 17px; height: 17px; border-radius: 50%; display: inline-grid; place-items: center; color: #fff;
  font-size: 8px; font-weight: 800; flex: 0 0 auto; }
.tag { display: inline-flex; align-items: center; gap: 5px; font-size: 11px; font-weight: 700; padding: 3px 9px; border-radius: 7px; color: #fff; }

.avatar { width: 40px; height: 40px; min-width: 40px; border-radius: 50%; display: grid; place-items: center;
  font-weight: 800; font-size: 13px; color: #fff; }

/* ===== Layout de vista ===== */
.vista { flex: 1; overflow-y: auto; min-height: 0; padding: 16px; }
.vista-encabezado { display: flex; align-items: center; justify-content: space-between; gap: 12px; margin-bottom: 14px; flex-wrap: wrap; }
.vista-encabezado h1 { margin: 0; font-size: 16px; font-weight: 800; letter-spacing: -.3px; }
.sub { font-size: 12px; color: var(--dim); font-weight: 600; }
.suave { font-size: 11px; color: var(--faint); font-weight: 600; }
.rejilla { display: grid; gap: 11px; }
.rejilla-2 { grid-template-columns: repeat(auto-fit, minmax(340px, 1fr)); }
.rejilla-3 { grid-template-columns: repeat(auto-fill, minmax(300px, 1fr)); }
.rejilla-4 { grid-template-columns: repeat(auto-fit, minmax(200px, 1fr)); }
.tarjeta { border: 1px solid var(--border); border-radius: 13px; background: var(--surface); padding: 15px 17px; }
.tarjeta h2 { margin: 0 0 10px; font-size: 13px; font-weight: 800; }
.dato { display: flex; gap: 9px; padding: 4px 0; font-size: 12.5px; align-items: baseline; }
.dato span { color: var(--dim); width: 110px; flex: 0 0 auto; font-size: 11.5px; }
.dato b { font-weight: 700; min-width: 0; }

.vacio { display: flex; flex-direction: column; align-items: center; text-align: center; padding: 40px 22px; gap: 6px; color: var(--dim); }
.vacio .icono { width: 66px; height: 66px; border-radius: 50%; background: var(--surface-2); border: 1px dashed var(--border);
  display: grid; place-items: center; font-size: 26px; margin-bottom: 6px; }
.skeleton { height: 58px; border-radius: 11px; background: var(--surface-2); margin: 6px 8px; animation: mtv-skel 1.2s ease-in-out infinite; }

/* ===== Tablas ===== */
.tabla { width: 100%; border-collapse: collapse; font-size: 12.5px; }
.tabla th { text-align: left; padding: 9px 14px; background: var(--surface-2); border-bottom: 1px solid var(--border);
  font-size: 10.5px; font-weight: 800; color: var(--faint); text-transform: uppercase; letter-spacing: .4px; }
.tabla td { padding: 11px 14px; border-bottom: 1px solid var(--border-soft); vertical-align: middle; }
.tabla tr:hover td { background: var(--surface-2); }

/* ===== Inbox ===== */
.inbox { flex: 1; display: grid; grid-template-columns: 324px minmax(0,1fr) 324px; min-height: 0; overflow: hidden; }
.inbox-lista { display: flex; flex-direction: column; min-height: 0; background: var(--surface); border-right: 1px solid var(--border); }
.inbox-filtros { padding: 12px 12px 8px; display: flex; flex-direction: column; gap: 9px; }
.inbox-filtros input[type=text] { height: 34px; width: 100%; }
.fila-chips { display: flex; gap: 5px; flex-wrap: wrap; align-items: center; }
.chip-canal { width: 28px; height: 28px; border-radius: 8px; cursor: pointer; font-family: inherit; font-size: 11px; font-weight: 800;
  display: grid; place-items: center; color: #fff; border: 2px solid transparent; opacity: .5; }
.chip-canal.todos { color: var(--dim); background: var(--surface-2); }
.chip-canal.activa { border-color: var(--text); opacity: 1; }
.chip-canal.plena { opacity: 1; }
.inbox-items { flex: 1; overflow-y: auto; min-height: 0; padding: 2px 8px 12px; }
.conv-item { display: flex; gap: 10px; padding: 10px 9px; border-radius: 11px; cursor: pointer; margin-bottom: 2px; border: 1px solid transparent; }
.conv-item:hover { background: var(--surface-2); }
.conv-item.activa { border-color: var(--primary-line); background: var(--primary-soft); }
.conv-avatar { position: relative; flex: 0 0 auto; }
.conv-avatar .canal { position: absolute; right: -2px; bottom: -2px; width: 17px; height: 17px; border-radius: 50%;
  border: 2.5px solid var(--surface); display: grid; place-items: center; color: #fff; font-size: 8.5px; font-weight: 800; }
.conv-datos { flex: 1; min-width: 0; }
.conv-fila1 { display: flex; align-items: center; gap: 6px; }
.conv-nombre { font-size: 13px; font-weight: 700; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.conv-nombre.negrita { font-weight: 800; }
.conv-hora { margin-left: auto; font-size: 10.5px; color: var(--faint); font-weight: 600; flex: 0 0 auto; }
.conv-snippet { font-size: 12px; color: var(--dim); overflow: hidden; text-overflow: ellipsis; white-space: nowrap; display: block; margin-top: 2px; }
.conv-snippet.negrita { color: var(--text); font-weight: 600; }
.conv-metas { display: flex; align-items: center; gap: 5px; margin-top: 6px; flex-wrap: wrap; }
.badge-num { min-width: 18px; height: 18px; padding: 0 5px; border-radius: 10px; background: var(--primary); color: var(--on-primary);
  font-size: 10.5px; font-weight: 800; display: grid; place-items: center; margin-left: auto; }

.hilo { display: flex; flex-direction: column; min-height: 0; min-width: 0; background: var(--bg); }
.hilo-encabezado { flex: 0 0 auto; padding: 9px 16px; display: flex; align-items: center; gap: 11px;
  background: var(--surface); border-bottom: 1px solid var(--border); flex-wrap: wrap; }
.hilo-mensajes { flex: 1; overflow-y: auto; min-height: 0; padding: 16px 16px 8px; display: flex; flex-direction: column; gap: 3px; }
.burbuja { max-width: 70%; padding: 9px 13px; border-radius: 14px; font-size: 13.5px; line-height: 1.5; margin-top: 4px; position: relative; white-space: pre-wrap; }
.burbuja .meta { display: block; font-size: 10px; margin-top: 4px; text-align: right; color: var(--faint); }
.msg-entrante { align-self: flex-start; background: var(--surface-2); border: 1px solid var(--border-soft); border-bottom-left-radius: 5px; }
.msg-agente { align-self: flex-end; background: var(--primary); color: var(--on-primary); border-bottom-right-radius: 5px; }
.msg-agente .meta { color: color-mix(in srgb, var(--on-primary) 70%, transparent); }
.msg-bot { align-self: flex-end; background: var(--primary-soft); border: 1px solid var(--primary-line); border-bottom-right-radius: 5px; }
.msg-nota { align-self: center; max-width: 78%; background: var(--note-soft); border: 1px dashed var(--note-line); border-radius: 11px; }
.etiqueta-autor { font-size: 10.5px; font-weight: 800; color: var(--primary); }
.msg-nota .etiqueta-autor { color: var(--note); text-transform: uppercase; letter-spacing: .3px; }
.dia-separador { align-self: center; margin: 9px 0; font-size: 11px; font-weight: 700; color: var(--faint);
  background: var(--surface-2); padding: 3px 11px; border-radius: 20px; border: 1px solid var(--border-soft); }

.copiloto-panel { flex: 0 0 auto; margin: 0 16px 10px; border-radius: 13px; border: 1px solid var(--primary-line);
  background: var(--primary-soft); padding: 13px 15px; }
.copiloto-texto { font-size: 12.5px; line-height: 1.55; background: var(--surface); border: 1px solid var(--border);
  border-radius: 10px; padding: 10px 12px; white-space: pre-wrap; }

.compositor-zona { flex: 0 0 auto; padding: 0 16px 14px; }
.compositor { border-radius: 14px; border: 1px solid var(--border); background: var(--surface); box-shadow: var(--shadow); }
.compositor.modo-nota { border-color: var(--note-line); background: var(--note-soft); }
.compositor-tabs { display: flex; gap: 4px; padding: 6px 8px; border-bottom: 1px solid var(--border-soft); align-items: center; flex-wrap: wrap; }
.tab-comp { height: 27px; padding: 0 11px; border-radius: 7px; border: none; font-family: inherit; font-weight: 800; font-size: 12px;
  cursor: pointer; background: transparent; color: var(--dim); display: flex; align-items: center; gap: 5px; }
.tab-comp.activa { background: var(--primary-soft); color: var(--primary); }
.tab-comp.nota-activa { background: rgba(227,179,65,0.2); color: var(--note); }
.compositor textarea { width: 100%; min-height: 52px; max-height: 130px; border: none; background: transparent; padding: 11px 13px; font-size: 13.5px; }
.compositor-pie { display: flex; align-items: center; gap: 9px; padding: 7px 10px 9px; flex-wrap: wrap; }
.aviso-ventana { display: flex; align-items: center; gap: 10px; padding: 11px 14px; background: var(--danger-soft);
  border-bottom: 1px solid color-mix(in srgb, var(--danger) 30%, transparent); border-radius: 14px 14px 0 0; font-size: 12px; }
.compositor.vencida { border-color: color-mix(in srgb, var(--danger) 45%, transparent); }

.ficha { display: flex; flex-direction: column; min-height: 0; background: var(--surface); border-left: 1px solid var(--border);
  overflow-y: auto; }
.ficha-seccion { padding: 13px 16px; border-bottom: 1px solid var(--border-soft); }
.ficha-seccion h3 { margin: 0 0 9px; font-size: 10.5px; font-weight: 800; color: var(--faint); text-transform: uppercase; letter-spacing: .5px; }

/* ===== Kanban ===== */
.kanban { flex: 1; overflow-x: auto; overflow-y: hidden; min-height: 0; display: flex; gap: 12px; padding: 4px 2px 10px; }
.kanban-col { width: 236px; flex: 0 0 236px; display: flex; flex-direction: column; min-height: 0; border-radius: 13px;
  background: var(--surface); border: 1.5px solid var(--border); }
.kanban-col.sobre { border-color: var(--primary); box-shadow: 0 0 0 3px var(--primary-soft); }
.kanban-col-encabezado { display: flex; align-items: center; gap: 7px; padding: 10px 12px 8px; font-size: 12.5px; font-weight: 800; }
.kanban-col-encabezado .cubo { width: 8px; height: 8px; border-radius: 3px; }
.kanban-cuerpo { flex: 1; overflow-y: auto; min-height: 60px; padding: 2px 8px 10px; display: flex; flex-direction: column; gap: 7px; }
.kanban-tarjeta { padding: 10px 11px; border-radius: 11px; background: var(--surface-2); border: 1px solid var(--border-soft); cursor: grab; }
.kanban-tarjeta .monto { font-size: 13px; font-weight: 800; color: var(--ok); }

/* ===== Lienzo de flujos ===== */
.flujos-layout { flex: 1; display: grid; grid-template-columns: 252px minmax(0,1fr); gap: 0; min-height: 0;
  border: 1px solid var(--border); border-radius: 13px; overflow: hidden; background: var(--surface); }
.flujos-lista { overflow-y: auto; min-height: 0; padding: 10px 8px; border-right: 1px solid var(--border); }
.flujo-item { padding: 11px 12px; border-radius: 11px; cursor: pointer; margin-bottom: 4px; border: 1px solid transparent; }
.flujo-item:hover { background: var(--surface-2); }
.flujo-item.activa { border-color: var(--primary-line); background: var(--primary-soft); }
.flujo-zona { display: flex; flex-direction: column; min-width: 0; min-height: 0; }
.flujo-barra { flex: 0 0 auto; display: flex; align-items: center; gap: 7px; padding: 9px 14px; background: var(--surface);
  border-bottom: 1px solid var(--border); flex-wrap: wrap; }
.lienzo-envoltura { flex: 1; overflow: auto; min-height: 260px;
  background-image: radial-gradient(var(--grid-dot) 1.5px, transparent 1.5px); background-size: 22px 22px; background-color: var(--bg); }
.lienzo { position: relative; width: 1700px; height: 900px; }
.nodo { position: absolute; width: 190px; padding: 9px 10px; border-radius: 12px; background: var(--surface); cursor: pointer;
  box-shadow: var(--shadow); border: 1.5px solid var(--border); user-select: none; }
.nodo.seleccionado { border-color: var(--primary); box-shadow: 0 0 0 3px var(--primary-soft); }
.nodo .cab { display: flex; align-items: center; gap: 8px; }
.nodo .glifo { flex: 0 0 auto; min-width: 26px; height: 26px; padding: 0 5px; border-radius: 8px; color: #fff;
  display: grid; place-items: center; font-size: 10px; font-weight: 800; }
.nodo .titulo { font-size: 12px; font-weight: 800; line-height: 1.2; }
.nodo .detalle { font-size: 10.5px; color: var(--dim); margin-top: 2px; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.nodo .metricas { margin-top: 7px; font-size: 10px; font-weight: 700; color: var(--faint); background: var(--surface-2);
  border-radius: 6px; padding: 2px 7px; display: inline-block; }
.nodo .metricas:empty { display: none; }
#nodo-editor { flex: 0 0 auto; }

/* ===== Panel IA ===== */
.tabs-vista { flex: 0 0 auto; display: flex; gap: 3px; padding: 10px 16px 0; background: var(--surface); border-bottom: 1px solid var(--border); overflow-x: auto; }
.tab-vista { height: 36px; padding: 0 14px; border: none; border-bottom: 2.5px solid transparent; background: transparent;
  color: var(--dim); font-family: inherit; font-weight: 700; font-size: 12.5px; cursor: pointer; white-space: nowrap; }
.tab-vista.activa { border-bottom-color: var(--primary); color: var(--text); font-weight: 800; }
.kb-item { display: flex; gap: 12px; align-items: flex-start; padding: 12px 14px; border: 1px solid var(--border);
  border-radius: 12px; background: var(--surface); margin-bottom: 8px; }
.kb-fuente { flex: 0 0 auto; font-size: 10.5px; font-weight: 800; padding: 4px 10px; border-radius: 7px; white-space: nowrap; max-width: 180px; overflow: hidden; text-overflow: ellipsis; }

/* ===== Reportes ===== */
.kpi .titulo { display: block; font-size: 10.5px; font-weight: 800; color: var(--faint); text-transform: uppercase; letter-spacing: .4px; }
.kpi .valor { display: block; font-size: 22px; font-weight: 800; letter-spacing: -.5px; margin-top: 5px; }
.kpi .delta { display: block; font-size: 11px; font-weight: 800; color: var(--dim); margin-top: 4px; }
.barras { display: flex; flex-direction: column; gap: 9px; }
.barra-fila { display: grid; grid-template-columns: 130px 1fr 46px; gap: 9px; align-items: center; }
.barra-eti { font-size: 11.5px; font-weight: 700; color: var(--dim); text-align: right; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.barra-riel { height: 14px; border-radius: 5px; background: var(--surface-3); overflow: hidden; }
.barra-relleno { height: 100%; border-radius: 5px; }
.barra-val { font-size: 12px; font-weight: 800; }
.leyenda { display: flex; gap: 12px; font-size: 11px; font-weight: 700; color: var(--dim); margin-bottom: 8px; }
.leyenda .cuadro { display: inline-block; width: 9px; height: 9px; border-radius: 3px; margin-right: 5px; vertical-align: -1px; }
.mini-cols { display: flex; align-items: flex-end; gap: 10px; height: 150px; padding-top: 8px; }
.mini-col { flex: 1; display: flex; flex-direction: column; align-items: center; gap: 3px; height: 100%; justify-content: flex-end; }
.mini-col .pila { width: 100%; max-width: 38px; display: flex; flex-direction: column; gap: 2px; justify-content: flex-end; }
.mini-col .seg { border-radius: 3px; min-height: 3px; }
.mini-col .eje { font-size: 10px; font-weight: 700; color: var(--faint); }
.mini-col .tot { font-size: 10px; font-weight: 800; }

/* ===== Canales / eventos ===== */
.canal-banner { font-size: 11.5px; line-height: 1.5; padding: 9px 11px; border-radius: 9px; margin-top: 9px; }
.evento-fila { display: flex; gap: 12px; align-items: flex-start; padding: 11px 16px; border-bottom: 1px solid var(--border-soft); }
.evento-punto { flex: 0 0 auto; width: 10px; height: 10px; border-radius: 50%; margin-top: 4px; }

/* ===== Modal / toasts ===== */
.modal-fondo { position: fixed; inset: 0; background: rgba(4,10,18,0.62); display: grid; place-items: center; z-index: 50; }
.modal { width: 470px; max-width: 94vw; max-height: 90vh; overflow-y: auto; background: var(--surface);
  border: 1px solid var(--border); border-radius: 16px; box-shadow: var(--shadow); padding: 20px; }
.modal h2 { margin: 0 0 14px; font-size: 16px; font-weight: 800; }
.form-fila { margin-bottom: 12px; display: flex; flex-direction: column; gap: 5px; }
.form-fila label { font-size: 11.5px; font-weight: 800; color: var(--dim); }
.form-fila input, .form-fila select, .form-fila textarea { width: 100%; }
.form-acciones { display: flex; justify-content: flex-end; gap: 8px; margin-top: 16px; }

#toasts { position: fixed; right: 18px; bottom: 18px; display: flex; flex-direction: column; gap: 8px; z-index: 60; max-width: 340px; }
.toast { background: var(--surface); border: 1px solid var(--border); border-left: 3px solid var(--primary); border-radius: 12px;
  box-shadow: var(--shadow); padding: 11px 14px; font-size: 12.5px; font-weight: 700; animation: toast-in .3s ease both; }

/* ===== Móvil ===== */
.solo-movil { display: none; }
#tabbar { display: none; }
.mv-cab { display: none; }
.btn-texto-primario { border: none; background: transparent; color: var(--primary); font-family: inherit;
  font-weight: 800; font-size: 14px; cursor: pointer; padding: 0 4px; flex: 0 0 auto; }

/* Paneles móviles renderizados por JS (solo se generan bajo 720px) */
.mv-panel { flex: 1; display: flex; flex-direction: column; min-height: 0; }
.mv-cabecera { flex: 0 0 auto; padding: 14px 16px 10px; display: flex; flex-direction: column; gap: 10px;
  background: var(--surface); border-bottom: 1px solid var(--border); }
.mv-titulo { font-size: 21px; font-weight: 800; letter-spacing: -.4px; }
.mv-lista { flex: 1; overflow-y: auto; min-height: 0; padding: 4px 10px 8px; }
.mv-fila { display: flex; gap: 11px; padding: 12px 8px; border-bottom: 1px solid var(--border-soft); cursor: pointer; align-items: center; }
.mv-chips { display: flex; gap: 6px; overflow-x: auto; padding-bottom: 2px; flex-wrap: nowrap; }
.mv-chips .chip-filtro { flex: 0 0 auto; height: 30px; border-radius: 20px; padding: 0 13px; font-size: 12.5px; }
.mv-tarjetas { flex: 1; overflow-y: auto; min-height: 0; padding: 12px; display: flex; flex-direction: column; gap: 9px; }
.mv-tarjeta { padding: 12px 13px; border-radius: 13px; background: var(--surface); border: 1px solid var(--border); }
.mv-avatar { border: none; cursor: pointer; width: 30px; height: 30px; min-width: 30px; font-size: 11px; }
.mv-noleidos { font-size: 12px; font-weight: 800; color: var(--primary); }

.tab-item { flex: 1; display: flex; flex-direction: column; align-items: center; gap: 3px; position: relative;
  padding: 0; color: var(--faint); text-decoration: none; }
.tab-item .eti { font-size: 10px; font-weight: 800; }
.tab-item.activa { color: var(--primary); }
.tab-badge { position: absolute; top: -3px; right: 22%; min-width: 15px; height: 15px; padding: 0 4px; border-radius: 8px;
  background: var(--danger); color: #fff; font-size: 9px; font-weight: 800; display: grid; place-items: center; }
.tab-badge.oculto { display: none; }

@media (max-width: 900px) {
  .inbox { grid-template-columns: 1fr; }
  .inbox-lista, .ficha { display: none; }
  .inbox.movil-lista .inbox-lista { display: flex; }
  .inbox.movil-lista .hilo, .inbox.movil-lista .ficha { display: none; }
  .inbox.movil-ficha .ficha { display: flex; }
  .inbox.movil-ficha .hilo, .inbox.movil-ficha .inbox-lista { display: none; }
  .solo-movil { display: inline-flex; }
  #nav { width: 60px; flex-basis: 60px; }
  #nav a.nav-item { width: 48px; }
  #nav a.nav-item span.eti { display: none; }
  .rejilla-2, .rejilla-3, .rejilla-4 { grid-template-columns: 1fr; }
  .flujos-layout { grid-template-columns: 1fr; }
  .flujos-lista { display: none; }
}

/* Teléfono (maqueta "Inbox móvil"): sin riel ni header, tab bar inferior, vistas a pantalla completa */
@media (max-width: 720px) {
  #nav, #header { display: none; }
  body:not(.sin-tabbar) #contenido { padding-bottom: 62px; }
  #tabbar { display: flex; position: fixed; left: 0; right: 0; bottom: 0; z-index: 40;
    border-top: 1px solid var(--border); background: var(--surface);
    padding: 8px 6px calc(9px + env(safe-area-inset-bottom)); }
  body.sin-tabbar #tabbar { display: none; }

  .mv-cab { display: flex; align-items: center; gap: 9px; }
  .inbox-filtros { padding: 14px 16px 10px; gap: 10px; background: var(--surface); border-bottom: 1px solid var(--border); }
  .inbox-filtros input[type=text] { height: 36px; border-radius: 10px; }
  .inbox-filtros .fila-chips { flex-wrap: nowrap; overflow-x: auto; }
  .inbox-filtros .chip-filtro { flex: 0 0 auto; height: 30px; border-radius: 20px; padding: 0 13px; font-size: 12.5px; }
  .inbox-items { padding: 4px 10px 8px; }
  .conv-item { padding: 12px 8px; border-radius: 0; border: none; border-bottom: 1px solid var(--border-soft); margin: 0; }
  .conv-item.activa { border: none; border-bottom: 1px solid var(--border-soft); background: transparent; }
  .conv-avatar .avatar { width: 46px; height: 46px; min-width: 46px; font-size: 15px; }
  .conv-avatar .canal { width: 18px; height: 18px; font-size: 9px; }

  .hilo-encabezado { padding: 8px 10px; gap: 8px; }
  .hilo-encabezado #sel-asignar { display: none; }
  .hilo-mensajes { padding: 12px 10px 8px; }
  .burbuja { max-width: 84%; }
  .compositor-zona { padding: 0 10px 12px; }
  .compositor-pie > .suave { display: none; }
  .compositor textarea { min-height: 42px; }

  .vista { padding: 12px; }
  .rejilla-4 { grid-template-columns: 1fr 1fr !important; }
  .kpi .valor { font-size: 21px; }
  .mini-cols { gap: 6px; }
  .modal { width: 94vw; padding: 16px; }
  #toasts { left: 14px; right: 14px; bottom: 76px; max-width: none; }
}
