/* ============================================================
   PYM360 · MODULE — Jarvis (chat asistente IA)
   Capa 3 — específico de #pym-view-ask.
   ============================================================ */

#pym-view-ask{
  padding:var(--pym-space-6) var(--pym-space-8);
  max-width:var(--pym-content-max-w);
  margin:0 auto;
}
@media (max-width:980px){#pym-view-ask{padding:var(--pym-space-4)}}

/* ============================================================
   SHELL — sidebar + main chat
   ============================================================ */
.jarvis-shell{
  background:var(--pym-color-surface);
  border:1px solid var(--pym-color-border);
  border-radius:var(--pym-radius-xl);
  overflow:hidden;
  display:grid;
  grid-template-columns:240px 1fr;
  min-height:600px;
}
@media (max-width:780px){.jarvis-shell{grid-template-columns:1fr;min-height:auto}.jarvis-sidebar{display:none}}

/* ============================================================
   SIDEBAR — conversaciones
   ============================================================ */
.jarvis-sidebar{
  border-right:1px solid var(--pym-color-border);
  display:flex;
  flex-direction:column;
  background:var(--pym-color-bg);
  min-height:0;
}
.jarvis-sidebar-h{
  padding:var(--pym-space-3);
  border-bottom:1px solid var(--pym-color-border);
}
.jarvis-conv-list{
  flex:1;
  overflow-y:auto;
  padding:var(--pym-space-2);
  display:flex;
  flex-direction:column;
  gap:2px;
}
.jarvis-conv-row{
  padding:8px 10px;
  border-radius:var(--pym-radius-sm);
  cursor:pointer;
  font-size:var(--pym-fs-base);
  color:var(--pym-color-text-dim);
  border-left:2px solid transparent;
  transition:all var(--pym-trans-fast);
}
.jarvis-conv-row:hover{background:var(--pym-color-surface-2);color:var(--pym-color-text)}
.jarvis-conv-row--active{
  background:linear-gradient(90deg,var(--pym-color-accent-dim),rgba(73,124,251,.04));
  color:var(--pym-color-text);
  border-left-color:var(--pym-color-accent-2);
}
.jarvis-conv-title{
  font-weight:var(--pym-fw-medium);
  white-space:nowrap;
  overflow:hidden;
  text-overflow:ellipsis;
}
.jarvis-conv-row--active .jarvis-conv-title{font-weight:var(--pym-fw-semibold)}
.jarvis-conv-meta{
  font-size:var(--pym-fs-xs);
  color:var(--pym-color-text-muted);
  margin-top:2px;
}

.jarvis-sidebar-foot{
  padding:8px 10px;
  border-top:1px solid var(--pym-color-border);
  font-size:var(--pym-fs-xs);
  color:var(--pym-color-text-muted);
  text-align:center;
}
.jarvis-sidebar-foot kbd{
  background:var(--pym-color-surface-2);
  padding:1px 5px;
  border-radius:var(--pym-radius-xs);
  font-family:var(--pym-font-mono);
  font-size:var(--pym-fs-xs);
  color:var(--pym-color-text-dim);
  border:1px solid var(--pym-color-border);
}

.jarvis-conv-empty{
  padding:var(--pym-space-4) var(--pym-space-3);
  text-align:center;
  color:var(--pym-color-text-muted);
  font-size:var(--pym-fs-sm);
}

/* ============================================================
   MAIN — header + info + chat + input
   ============================================================ */
.jarvis-main{
  display:flex;
  flex-direction:column;
  min-width:0;
  min-height:0;
}

.jarvis-header{
  display:flex;
  justify-content:space-between;
  align-items:center;
  padding:var(--pym-space-3) var(--pym-space-4);
  border-bottom:1px solid var(--pym-color-border);
  gap:var(--pym-space-2);
  flex-shrink:0;
}
.jarvis-header-name{display:flex;align-items:center;gap:10px;min-width:0}
.jarvis-header-name b{
  font-weight:var(--pym-fw-semibold);
  color:var(--pym-color-text);
  font-size:var(--pym-fs-md);
}
.jarvis-conv-titulo{
  color:var(--pym-color-text-muted);
  font-size:var(--pym-fs-base);
  font-weight:var(--pym-fw-regular);
  overflow:hidden;
  text-overflow:ellipsis;
  white-space:nowrap;
}
.jarvis-header-actions{display:flex;gap:6px;flex-shrink:0}

/* Avatar — gradiente lila/azul. Se reusa en mensajes */
.jarvis-avatar{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  border-radius:50%;
  background:linear-gradient(135deg,var(--pym-color-accent),var(--pym-color-accent-2));
  color:#fff;
  flex-shrink:0;
  box-shadow:var(--pym-shadow-accent);
}
.jarvis-avatar--sm{width:30px;height:30px;font-size:16px}
.jarvis-avatar--md{width:38px;height:38px;font-size:20px}
.jarvis-avatar--lg{width:64px;height:64px;font-size:32px}

/* Banner informativo bajo el header */
.jarvis-info{
  padding:7px var(--pym-space-4);
  border-bottom:1px solid var(--pym-color-border);
  font-size:var(--pym-fs-sm);
  color:var(--pym-color-text-muted);
  background:rgba(73,124,251,.03);
  flex-shrink:0;
}
.jarvis-info b{color:var(--pym-color-text-dim)}

/* ============================================================
   CHAT — área scrollable de mensajes
   ============================================================ */
.jarvis-chat{
  flex:1;
  overflow-y:auto;
  padding:var(--pym-space-3) var(--pym-space-4);
  min-height:300px;
  position:relative;
}

/* Empty state con ejemplos */
.jarvis-empty{
  text-align:center;
  padding:var(--pym-space-7) var(--pym-space-3);
}
.jarvis-empty-title{
  color:var(--pym-color-text);
  font-size:var(--pym-fs-lg);
  margin-bottom:4px;
  margin-top:var(--pym-space-3);
}
.jarvis-empty-title b{font-weight:var(--pym-fw-semibold)}
.jarvis-empty-sub{
  color:var(--pym-color-text-muted);
  font-size:var(--pym-fs-base);
  margin-bottom:var(--pym-space-5);
}
.jarvis-empty-sub b{color:var(--pym-color-text-dim)}
.jarvis-ejemplos{
  display:flex;
  flex-wrap:wrap;
  gap:var(--pym-space-2);
  justify-content:center;
  max-width:640px;
  margin:0 auto;
}
.jarvis-ejemplo-btn{
  padding:8px 12px;
  background:var(--pym-color-surface-2);
  border:1px solid var(--pym-color-border);
  border-radius:var(--pym-radius-md);
  color:var(--pym-color-text-dim);
  text-align:left;
  max-width:300px;
  white-space:normal;
  line-height:1.35;
  font-size:var(--pym-fs-base);
  font-family:inherit;
  cursor:pointer;
  transition:all var(--pym-trans-fast);
}
.jarvis-ejemplo-btn:hover{
  background:var(--pym-color-surface-3);
  border-color:var(--pym-color-accent-2);
  color:var(--pym-color-text);
}

/* ============================================================
   MENSAJES — burbujas user/bot
   ============================================================ */
.jarvis-msg-user{
  margin-bottom:var(--pym-space-3);
  display:flex;
  justify-content:flex-end;
}
.jarvis-msg-user-bubble{
  background:linear-gradient(180deg,var(--pym-color-accent-2),var(--pym-color-accent));
  color:#fff;
  padding:9px 13px;
  border-radius:14px 14px 3px 14px;
  max-width:70%;
  font-size:var(--pym-fs-md);
  white-space:pre-wrap;
  box-shadow:var(--pym-shadow-sm);
  line-height:1.4;
}

.jarvis-msg-bot{
  margin-bottom:var(--pym-space-4);
  display:flex;
  justify-content:flex-start;
  gap:var(--pym-space-2);
}
.jarvis-msg-bot-content{
  flex:1;
  background:var(--pym-color-surface-2);
  border:1px solid var(--pym-color-border);
  padding:11px 13px;
  border-radius:3px 14px 14px 14px;
  font-size:var(--pym-fs-md);
  max-width:85%;
  min-width:0;
}
.jarvis-msg-bot-content .jarvis-md{line-height:1.55}

/* Drop overlay — cuando arrastras archivos */
.jarvis-drop-overlay{
  position:absolute;
  inset:0;
  background:var(--pym-color-accent-dim);
  border:3px dashed var(--pym-color-accent-2);
  border-radius:var(--pym-radius-lg);
  display:flex;
  align-items:center;
  justify-content:center;
  pointer-events:none;
  z-index:var(--pym-z-overlay);
  font-size:var(--pym-fs-lg);
  color:var(--pym-color-accent-2);
  font-weight:var(--pym-fw-semibold);
}

/* ============================================================
   INPUT — área de envío
   ============================================================ */
.jarvis-input-wrap{
  padding:var(--pym-space-3) var(--pym-space-4);
  border-top:1px solid var(--pym-color-border);
  display:flex;
  gap:var(--pym-space-2);
  align-items:flex-end;
  background:var(--pym-color-bg);
  flex-shrink:0;
}
.jarvis-input{
  flex:1;
  background:var(--pym-color-surface-2);
  border:1px solid var(--pym-color-border);
  border-radius:var(--pym-radius-md);
  padding:9px 12px;
  color:var(--pym-color-text);
  resize:vertical;
  font-family:inherit;
  font-size:var(--pym-fs-md);
  min-height:42px;
  transition:border-color var(--pym-trans-fast),box-shadow var(--pym-trans-fast);
}
.jarvis-input:focus{
  outline:none;
  border-color:var(--pym-color-accent);
  box-shadow:0 0 0 3px var(--pym-color-accent-dim);
}
.jarvis-input::placeholder{color:var(--pym-color-text-subtle)}

/* ============================================================
   ADJUNTOS — preview de archivos cargados (cards en chat)
   ============================================================ */
.jarvis-adjunto-card{
  background:var(--pym-color-surface);
  border:1px solid var(--pym-color-border);
  border-radius:var(--pym-radius-md);
  padding:var(--pym-space-2) var(--pym-space-3);
  margin-top:var(--pym-space-2);
  font-size:var(--pym-fs-sm);
  color:var(--pym-color-text-dim);
}

/* ============================================================
   PASOS (tool calls) — debajo del mensaje del bot
   ============================================================ */
.jarvis-pasos{
  margin-top:var(--pym-space-2);
  padding:var(--pym-space-2) var(--pym-space-3);
  background:var(--pym-color-bg);
  border:1px dashed var(--pym-color-border);
  border-radius:var(--pym-radius-sm);
  font-size:var(--pym-fs-xs);
  color:var(--pym-color-text-muted);
  font-family:var(--pym-font-mono);
}
