/* ── Design tokens ───────────────────────────────────────── */
:root {
  --font-sans:  'DM Sans', system-ui, sans-serif;
  --font-mono:  'DM Mono', 'Fira Mono', monospace;
  --clr-bg:     #F5F5F7;
  --clr-surface:#FFFFFF;
  --clr-border: #E8E8EC;
  --clr-border2:#F0F0F4;
  --clr-text:   #0D1B2A;
  --clr-muted:  #6B7280;
  --clr-faint:  #9CA3AF;
  --clr-accent: #2B2BFF;
  --clr-accent-l:#EEF2FF;
  --radius-sm:  6px;
  --radius-md:  10px;
  --radius-lg:  14px;
  --shadow-sm:  0 1px 3px rgba(0,0,0,.06), 0 1px 2px rgba(0,0,0,.04);
  --shadow-md:  0 4px 12px rgba(0,0,0,.08), 0 1px 3px rgba(0,0,0,.05);
  --shadow-lg:  0 12px 32px rgba(0,0,0,.1), 0 2px 6px rgba(0,0,0,.06);
  --drw-shadow: -16px 0 40px rgba(0,0,0,.08), -1px 0 0 var(--clr-border);
  --easing-spring: cubic-bezier(.32,.72,0,1);
}

/* ── Reset ───────────────────────────────────────────────── */
*{margin:0;padding:0;box-sizing:border-box}
body{font-family:var(--font-sans);background:var(--clr-bg);color:var(--clr-text);display:flex;height:100vh;overflow:hidden;-webkit-font-smoothing:antialiased}

/* ── Drawer system ───────────────────────────────────────── */
@keyframes drwIn {
  from { transform: translateX(100%); }
  to   { transform: translateX(0); }
}
@keyframes drwOut {
  from { transform: translateX(0); opacity: 1; }
  to   { transform: translateX(100%); opacity: 0; }
}
@keyframes ovIn {
  from { opacity: 0; }
  to   { opacity: 1; }
}
@keyframes ovOut {
  from { opacity: 1; }
  to   { opacity: 0; }
}
.drw-overlay {
  position: fixed; top: 0; bottom: 0; left: 0; right: 56px; /* no tapa el chat bar */
  z-index: 580;
  background: rgba(10,15,28,.04);
  animation: ovIn .2s ease forwards;
}
.drw-panel {
  position: fixed; top: 0; right: 56px; height: 100vh; /* queda a la izquierda del chat bar */
  background: var(--clr-surface);
  display: flex; flex-direction: column;
  box-shadow: var(--drw-shadow);
  z-index: 600; /* por debajo del chat bar (900) */
  animation: drwIn .32s var(--easing-spring) forwards;
  transition: transform .28s var(--easing-spring);
  will-change: transform;
}
.drw-panel.drw-closing {
  animation: drwOut .22s ease forwards;
}
.drw-hd {
  padding: 18px 20px 16px;
  border-bottom: 1px solid var(--clr-border2);
  display: flex; align-items: center; gap: 10px;
  flex-shrink: 0;
}
.drw-title {
  font-size: 15px; font-weight: 700; color: var(--clr-text); flex: 1;
  letter-spacing: -.2px;
}
.drw-close {
  width: 28px; height: 28px; border-radius: var(--radius-sm);
  background: none; border: none; cursor: pointer;
  color: var(--clr-faint); display: flex; align-items: center; justify-content: center;
  transition: background .15s, color .15s;
}
.drw-close:hover { background: var(--clr-border2); color: var(--clr-text); }
.drw-body { flex: 1; overflow-y: auto; }
.drw-footer {
  padding: 14px 20px; border-top: 1px solid var(--clr-border2);
  display: flex; justify-content: flex-end; gap: 8px; flex-shrink: 0;
}

/* ── Legacy modal overlay (reemplazado pero mantenido por compat) */
.js-modal-overlay {
  animation: ovIn .18s ease forwards;
}
.js-modal-overlay > div {
  animation: drwIn .3s var(--easing-spring) forwards;
}

/* ── KPIs — fuente monoespaciada para números ── */
.kpi-val { font-family: var(--font-mono); }

/* ── Inputs mejorados ────────────────────────────────────── */
input, textarea, select {
  font-family: var(--font-sans);
}

#app-shell{display:flex;width:100%;height:100vh;overflow:hidden}
.sidebar{width:214px;min-width:214px;background:var(--clr-surface);border-right:1px solid var(--clr-border);display:flex;flex-direction:column;height:100vh;overflow-y:auto}
.logo-area{padding:16px 14px 12px;border-bottom:1px solid #F3F4F6}
.logo-text{font-size:20px;font-weight:800;color:#2B2BFF;letter-spacing:-.5px}
.logo-badge{font-size:9px;font-weight:700;background:#2B2BFF;color:#fff;padding:2px 5px;border-radius:4px;margin-left:4px;vertical-align:middle}
.nav-section{padding:6px 0}
.nav-label{font-size:10px;font-weight:700;color:#9CA3AF;text-transform:uppercase;letter-spacing:.7px;padding:8px 14px 3px}
.ni{display:flex;align-items:center;gap:9px;padding:7px 12px;cursor:pointer;border-radius:7px;color:var(--clr-muted);font-size:13px;font-weight:500;transition:all .15s;margin:1px 6px;border-left:2px solid transparent}
.ni:hover{background:var(--clr-bg);color:var(--clr-text)}
.ni.active{background:var(--clr-accent-l);color:var(--clr-accent);border-left-color:var(--clr-accent);font-weight:600}
.ni-icon{width:18px;height:18px;flex-shrink:0;display:flex;align-items:center;justify-content:center}
.ni-icon svg{width:16px;height:16px;stroke-width:1.75}
.pinned-area{padding:8px 14px;border-top:1px solid #F3F4F6}
.pinned-label{font-size:10px;font-weight:700;color:#9CA3AF;text-transform:uppercase;letter-spacing:.7px;margin-bottom:6px}
.pinned-item{display:flex;align-items:center;gap:8px;padding:5px 0;font-size:12px;color:#6B7280;cursor:pointer}
.pinned-item:hover{color:#0D1B2A}
.p-dot{width:8px;height:8px;border-radius:50%}
.sidebar-user{padding:10px 14px;border-top:1px solid #F3F4F6;display:flex;align-items:center;gap:9px;cursor:pointer;margin-top:auto}
.u-av{width:30px;height:30px;border-radius:50%;background:linear-gradient(135deg,#667eea,#764ba2);display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:700;color:#fff;flex-shrink:0}
.u-name{font-size:12px;font-weight:600;color:#0D1B2A}
.u-handle{font-size:10px;color:#9CA3AF}
.main{flex:1;overflow:hidden;display:flex;flex-direction:column}
.view{display:none;height:100%;overflow-y:auto;padding:24px 28px}
.view.active{display:block}
.view-full{display:none;height:100%;overflow:hidden}
.view-full.active{display:flex;flex-direction:column}
.vh{display:flex;align-items:center;justify-content:space-between;margin-bottom:18px}
.vt{font-size:21px;font-weight:700;color:#0D1B2A}
.btn{display:inline-flex;align-items:center;gap:5px;padding:7px 14px;border-radius:var(--radius-sm);font-size:12px;font-weight:600;cursor:pointer;border:none;transition:all .15s;font-family:var(--font-sans);letter-spacing:-.1px}
.btn-primary{background:var(--clr-accent);color:#fff;box-shadow:0 1px 4px rgba(43,43,255,.25)}.btn-primary:hover{background:#1a1aee;box-shadow:0 2px 8px rgba(43,43,255,.35);transform:translateY(-1px)}
.btn-outline{background:var(--clr-surface);color:#374151;border:1px solid var(--clr-border)}.btn-outline:hover{background:var(--clr-bg);border-color:#C9C9D4}
.btn-auto{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff}
.btn-ghost{background:none;border:none;color:var(--clr-muted);cursor:pointer;font-size:12px;font-family:var(--font-sans)}
/* Feed styles */
.feed-post{background:#fff;border-radius:10px;border:1px solid #F3F4F6;box-shadow:0 1px 4px rgba(0,0,0,.05);padding:16px;margin-bottom:12px}
.feed-hd{display:flex;align-items:center;gap:10px;margin-bottom:10px}
.feed-actions{display:flex;gap:0;margin-top:10px;border-top:1px solid #F3F4F6;padding-top:8px}
.feed-action{flex:1;text-align:center;font-size:12px;color:#6B7280;cursor:pointer;padding:6px;border-radius:6px;transition:background .1s}
.feed-action:hover{background:#F3F4F6}
/* Improved badge colors */
.badge.b-red{background:#FEE2E2;color:#EF4444}
.badge.b-orange{background:#FEF3C7;color:#D97706}
/* Proj card hover */
.proj-card{background:#fff;border-radius:12px;padding:16px;border:1px solid #F3F4F6;cursor:pointer;transition:box-shadow .15s,transform .15s;box-shadow:0 1px 4px rgba(0,0,0,.05)}
.proj-card:hover{box-shadow:0 8px 24px rgba(0,0,0,.1);transform:translateY(-2px)}
.card{background:var(--clr-surface);border-radius:var(--radius-md);box-shadow:var(--shadow-sm);border:1px solid var(--clr-border2)}
.card-hd{padding:12px 16px;border-bottom:1px solid #F3F4F6;display:flex;align-items:center;justify-content:space-between}
.card-title{font-size:13px;font-weight:700;color:#0D1B2A}
.card-body{padding:14px 16px}
.kpi-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:12px;margin-bottom:18px}
.kpi{background:#fff;border-radius:10px;padding:14px 16px;border:1px solid #F3F4F6;box-shadow:0 1px 4px rgba(0,0,0,.04)}
.kpi-label{font-size:10px;font-weight:700;color:#9CA3AF;text-transform:uppercase;letter-spacing:.5px;margin-bottom:5px}
.kpi-val{font-size:24px;font-weight:800;color:#0D1B2A;line-height:1}
.kpi-sub{font-size:11px;color:#10B981;font-weight:500;margin-top:4px}
.kpi-sub.down{color:#EF4444}
.badge{display:inline-flex;align-items:center;gap:3px;padding:2px 7px;border-radius:10px;font-size:11px;font-weight:600}
.b-blue{background:#EEF2FF;color:#2B2BFF}.b-green{background:#D1FAE5;color:#065F46}
.b-orange{background:#FEF3C7;color:#92400E}.b-red{background:#FEE2E2;color:#991B1B}
.b-purple{background:#EDE9FE;color:#5B21B6}.b-gray{background:#F3F4F6;color:#374151}
.b-wa{background:#D1FAE5;color:#065F46}.b-ig{background:#FDF2F8;color:#9D174D}
.b-li{background:#EFF6FF;color:#1E40AF}.b-meta{background:#FEF3C7;color:#92400E}
.src-map{}
.tbl{width:100%;border-collapse:collapse}
.tbl th{padding:9px 13px;text-align:left;font-size:11px;font-weight:700;color:#6B7280;text-transform:uppercase;letter-spacing:.4px;border-bottom:1px solid #F3F4F6;background:#FAFAFA}
.tbl td{padding:10px 13px;font-size:13px;border-bottom:1px solid #F9FAFB;color:#374151}
.tbl tr:hover td{background:#FAFAFA}
.av{display:inline-flex;align-items:center;justify-content:center;border-radius:50%;font-weight:700;color:#fff;flex-shrink:0}
.av-sm{width:24px;height:24px;font-size:10px}
.av-md{width:32px;height:32px;font-size:13px}
.av-lg{width:40px;height:40px;font-size:16px}
.vtabs{display:flex;gap:2px;background:#F3F4F6;padding:3px;border-radius:8px}
.vtab{padding:5px 11px;border-radius:6px;font-size:12px;font-weight:500;cursor:pointer;color:#6B7280;transition:all .15s}
.vtab.active{background:#fff;color:#0D1B2A;font-weight:600;box-shadow:0 1px 3px rgba(0,0,0,.1)}
.pill{display:inline-flex;align-items:center;gap:4px;padding:3px 9px;border-radius:6px;font-size:11px;font-weight:500;background:#fff;border:1px solid #E5E7EB;color:#374151;cursor:pointer}
.pill span{background:#2B2BFF;color:#fff;border-radius:10px;padding:0 5px;font-size:10px}
.kanban-board{display:flex;gap:12px;overflow-x:auto;padding-bottom:8px}
.kol{flex-shrink:0;width:215px;display:flex;flex-direction:column;max-height:100%}
.kol-hd{background:#fff;border-radius:8px 8px 0 0;overflow:hidden;margin-bottom:8px;box-shadow:0 1px 3px rgba(0,0,0,.05)}
.kol-bar{height:3px}
.kol-info{padding:9px 11px;display:flex;align-items:center;justify-content:space-between}
.kol-name{font-size:12px;font-weight:700;color:#0D1B2A}
.kol-cnt{font-size:10px;font-weight:700;background:#F3F4F6;color:#6B7280;padding:1px 6px;border-radius:10px;margin-left:4px}
.kol-amt{font-size:11px;color:#9CA3AF}
.kol-cards{flex:1;overflow-y:auto;display:flex;flex-direction:column;gap:6px}
.deal{background:#fff;border-radius:7px;padding:8px 9px 7px 11px;border:1px solid #F3F4F6;cursor:pointer;border-left:3px solid #E5E7EB;box-shadow:0 1px 3px rgba(0,0,0,.04);transition:all .15s}
.deal:hover{box-shadow:0 3px 8px rgba(0,0,0,.1);transform:translateY(-1px)}
.deal-top{display:flex;align-items:center;gap:7px;margin-bottom:4px}
.deal-name{font-size:12px;font-weight:600;color:#0D1B2A;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.deal-co{font-size:10px;color:#9CA3AF;padding-left:29px;margin-bottom:4px}
.deal-row{display:flex;align-items:center;justify-content:space-between;gap:4px}
.deal-val{font-size:12px;font-weight:700;color:#0D1B2A}
.deal-time{font-size:10px;color:#9CA3AF}
.qadd{display:flex;align-items:center;justify-content:center;gap:5px;padding:8px;border:1.5px dashed #D1D5DB;border-radius:7px;color:#9CA3AF;font-size:12px;cursor:pointer;background:none;width:100%;transition:all .15s;font-family:'Inter',sans-serif}
.qadd:hover{border-color:#2B2BFF;color:#2B2BFF;background:#EEF2FF}
.comms-wrap{display:flex;flex:1;overflow:hidden}
.thread-col{width:300px;min-width:300px;border-right:1px solid #F3F4F6;display:flex;flex-direction:column;background:#fff}
.thread-search{padding:10px;border-bottom:1px solid #F3F4F6}
.tsearch{width:100%;padding:7px 10px;border:1px solid #E5E7EB;border-radius:7px;font-size:12px;outline:none;font-family:'Inter',sans-serif}
.tsearch:focus{border-color:#2B2BFF}
.thread-filters{display:flex;gap:3px;overflow-x:auto;padding:7px 10px;border-bottom:1px solid #F3F4F6}
.tf{padding:3px 9px;border-radius:6px;font-size:11px;font-weight:500;cursor:pointer;color:#6B7280;white-space:nowrap}
.tf.active{background:#EEF2FF;color:#2B2BFF;font-weight:600}
.thread-list{flex:1;overflow-y:auto}
.thread{padding:9px 10px;border-bottom:1px solid #F9FAFB;cursor:pointer;display:flex;gap:8px;align-items:flex-start}
.thread:hover{background:#F9FAFB}
.thread.sel{background:#EEF2FF}
.t-av-wrap{position:relative;flex-shrink:0}
.t-src{position:absolute;bottom:-2px;right:-2px;width:14px;height:14px;border-radius:50%;background:#fff;display:flex;align-items:center;justify-content:center;font-size:9px;border:1.5px solid #fff}
.t-info{flex:1;overflow:hidden}
.t-name{font-size:12px;font-weight:600;color:#0D1B2A}
.t-co{font-size:10px;color:#9CA3AF}
.t-preview{font-size:11px;color:#6B7280;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;margin-top:2px}
.t-meta{display:flex;flex-direction:column;align-items:flex-end;gap:3px}
.t-time{font-size:10px;color:#9CA3AF}
.t-unread{width:16px;height:16px;background:#2B2BFF;color:#fff;border-radius:50%;font-size:9px;font-weight:700;display:flex;align-items:center;justify-content:center}
.chat-col{flex:1;display:flex;flex-direction:column;background:#FAFAFA}
.chat-hd{padding:11px 14px;border-bottom:1px solid #F3F4F6;display:flex;align-items:center;justify-content:space-between;background:#fff}
.chat-msgs{flex:1;overflow-y:auto;padding:14px;display:flex;flex-direction:column;gap:9px}
.msg{display:flex;flex-direction:column;max-width:68%}
.msg.in{align-self:flex-start}.msg.out{align-self:flex-end;align-items:flex-end}.msg.sys{align-self:center}
.msg-bbl{padding:8px 11px;border-radius:9px;font-size:12.5px;line-height:1.5}
.msg.in .msg-bbl{background:#fff;border:1px solid #F3F4F6;border-radius:3px 9px 9px 9px;color:#0D1B2A}
.msg.out .msg-bbl{background:#2B2BFF;color:#fff;border-radius:9px 3px 9px 9px}
.msg.sys .msg-bbl{background:#F3F4F6;color:#6B7280;font-size:11px;border-radius:6px}
.msg-time{font-size:10px;color:#9CA3AF;margin-top:2px}
.chat-reply{padding:10px 12px;border-top:1px solid #F3F4F6;display:flex;gap:8px;background:#fff}
.reply-inp{flex:1;padding:8px 11px;border:1px solid #E5E7EB;border-radius:8px;font-size:12px;outline:none;font-family:'Inter',sans-serif;resize:none}
.reply-inp:focus{border-color:#2B2BFF}
.pipe-topbar{display:flex;align-items:center;gap:8px;margin-bottom:14px;flex-wrap:wrap}
.kanban-wrap{overflow-x:auto;padding-bottom:10px}
.tbl-wrap{background:#fff;border-radius:10px;border:1px solid #F3F4F6;overflow:hidden;box-shadow:0 1px 4px rgba(0,0,0,.04)}
.task-item{background:#fff;border-radius:8px;padding:10px 13px;border:1px solid #F3F4F6;display:flex;align-items:center;gap:9px;margin-bottom:6px;box-shadow:0 1px 2px rgba(0,0,0,.03)}
.tchk{width:16px;height:16px;border-radius:50%;border:2px solid #D1D5DB;cursor:pointer;flex-shrink:0;transition:all .15s}
.tchk:hover{border-color:#2B2BFF}
.tchk.done{background:#10B981;border-color:#10B981}
.p-alta{background:#FEE2E2;color:#DC2626}.p-media{background:#FEF3C7;color:#D97706}.p-baja{background:#D1FAE5;color:#059669}
.proj-card{background:#fff;border-radius:10px;padding:16px;border:1px solid #F3F4F6;box-shadow:0 1px 4px rgba(0,0,0,.05);cursor:pointer;transition:all .15s}
.proj-card:hover{box-shadow:0 4px 12px rgba(0,0,0,.1);transform:translateY(-2px)}
.proj-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:14px;margin-bottom:20px}
.pbar-wrap{background:#F3F4F6;border-radius:4px;height:6px;overflow:hidden;margin:8px 0}
.pbar{height:100%;border-radius:4px;transition:width .3s}
.feed-post{background:#fff;border-radius:10px;padding:14px 16px;border:1px solid #F3F4F6;margin-bottom:12px;box-shadow:0 1px 3px rgba(0,0,0,.04)}
.feed-hd{display:flex;align-items:center;gap:10px;margin-bottom:10px}
.feed-actions{display:flex;gap:14px;padding-top:10px;border-top:1px solid #F9FAFB;margin-top:10px}
.feed-action{display:flex;align-items:center;gap:5px;font-size:12px;color:#6B7280;cursor:pointer;transition:color .15s}
.feed-action:hover{color:#2B2BFF}
.ai-layout{display:flex;flex:1;overflow:hidden}
.team-chat{display:flex;flex-direction:column;flex:1;border-right:1px solid #F3F4F6}
.tc-hd{padding:11px 14px;border-bottom:1px solid #F3F4F6;display:flex;align-items:center;gap:9px;background:#fff}
.av-stack{display:flex}
.av-stacked{margin-left:-6px;border:2px solid #fff}.av-stacked:first-child{margin-left:0}
.tc-msgs{flex:1;overflow-y:auto;padding:14px;display:flex;flex-direction:column;gap:11px;background:#FAFAFA}
.tm-row{display:flex;gap:8px;align-items:flex-start}
.tm-row.out{flex-direction:row-reverse}
.tm-content{max-width:76%}
.tm-name{font-size:10px;color:#9CA3AF;margin-bottom:2px;font-weight:500}
.tm-row.out .tm-name{text-align:right}
.tm-bbl{padding:8px 11px;border-radius:9px;font-size:12.5px;line-height:1.55}
.tm-row.out .tm-bbl{background:#2B2BFF;color:#fff;border-radius:9px 3px 9px 9px}
.tm-row.in-j .tm-bbl{background:#fff;border:1px solid #F3F4F6;border-radius:3px 9px 9px 9px;color:#0D1B2A}
.tm-row.in-ai .tm-bbl{background:linear-gradient(135deg,#f0f4ff,#f5f0ff);border:1px solid #DDD6FE;border-radius:3px 9px 9px 9px;color:#0D1B2A}
.tm-time{font-size:10px;color:#9CA3AF;margin-top:2px}
.tc-input-row{padding:10px 12px;border-top:1px solid #F3F4F6;display:flex;gap:8px;background:#fff}
.tc-inp{flex:1;padding:8px 11px;border:1px solid #E5E7EB;border-radius:8px;font-size:12px;outline:none;font-family:'Inter',sans-serif}
.tc-inp:focus{border-color:#2B2BFF}
.ai-panel{width:270px;min-width:270px;padding:14px;overflow-y:auto;background:#fff;border-left:1px solid #F3F4F6}
.ai-stat{background:#F9FAFB;border-radius:7px;padding:8px 10px;font-size:11px;color:#374151;margin-bottom:6px}
.ai-stat span{font-weight:700;color:#0D1B2A}
.prompt-chip{display:block;width:100%;text-align:left;background:#F9FAFB;border:1px solid #E5E7EB;border-radius:7px;padding:7px 9px;font-size:12px;color:#374151;cursor:pointer;margin-bottom:5px;transition:all .15s;font-family:'Inter',sans-serif}
.prompt-chip:hover{background:#EEF2FF;color:#2B2BFF;border-color:#C7D2FE}
.dif-card{background:#fff;border-radius:10px;padding:13px 15px;border:1px solid #F3F4F6;margin-bottom:9px;box-shadow:0 1px 3px rgba(0,0,0,.04)}
.chart-card{background:#fff;border-radius:10px;padding:15px;border:1px solid #F3F4F6;box-shadow:0 1px 4px rgba(0,0,0,.04)}
.chart-title{font-size:13px;font-weight:700;color:#0D1B2A;margin-bottom:12px}
.donut{width:90px;height:90px;border-radius:50%;background:conic-gradient(#2B2BFF 0% 40%,#EC4899 40% 68%,#F59E0B 68% 86%,#10B981 86% 100%);flex-shrink:0}
.bar-col{display:flex;flex-direction:column;align-items:center;gap:3px;flex:1}
.bar-fill{width:100%;background:#2B2BFF;border-radius:4px 4px 0 0;opacity:.85}
.funnel-row{display:flex;align-items:center;gap:8px;margin-bottom:7px;font-size:11px}
.funnel-bar-wrap{flex:1;background:#F3F4F6;border-radius:4px;height:18px;overflow:hidden}
.funnel-bar{height:100%;border-radius:4px;display:flex;align-items:center;justify-content:flex-end;padding-right:6px;font-size:10px;font-weight:700;color:#fff}
.sett-section{background:#fff;border-radius:10px;border:1px solid #F3F4F6;margin-bottom:14px;overflow:hidden;box-shadow:0 1px 3px rgba(0,0,0,.04)}
.sett-title{padding:11px 15px;font-size:13px;font-weight:700;border-bottom:1px solid #F3F4F6;background:#FAFAFA}
.sett-row{padding:11px 15px;display:flex;align-items:center;justify-content:space-between;border-bottom:1px solid #F9FAFB;font-size:13px}
.sett-row:last-child{border-bottom:none}
.toggle{width:34px;height:18px;background:#D1D5DB;border-radius:9px;cursor:pointer;position:relative;transition:background .2s;flex-shrink:0}
.toggle.on{background:#2B2BFF}
.toggle::after{content:'';position:absolute;width:12px;height:12px;background:#fff;border-radius:50%;top:3px;left:3px;transition:left .2s;box-shadow:0 1px 3px rgba(0,0,0,.2)}
.toggle.on::after{left:19px}
.qr-box{width:140px;height:140px;border:2px solid #E5E7EB;border-radius:10px;padding:8px;background:#fff;flex-shrink:0}
.qr-inner{width:100%;height:100%;background:repeating-conic-gradient(#000 0% 25%,#fff 0% 50%) 0 0/8px 8px;border-radius:4px}
.panel-overlay{position:fixed;inset:0;background:rgba(0,0,0,.25);z-index:400;display:none}
.panel-overlay.open{display:block}
.lead-panel{position:fixed;top:0;right:-430px;width:410px;height:100vh;background:#fff;border-left:1px solid #E5E7EB;z-index:500;transition:right .25s cubic-bezier(.4,0,.2,1);display:flex;flex-direction:column;box-shadow:-4px 0 20px rgba(0,0,0,.12)}
.lead-panel.open{right:0}
.lp-hd{padding:13px 15px 11px;border-bottom:1px solid #F3F4F6;display:flex;align-items:center;gap:11px}
.lp-close{margin-left:auto;background:none;border:none;color:#9CA3AF;cursor:pointer;font-size:18px;padding:4px}
.lp-close:hover{color:#374151}
.lp-actions{display:flex;gap:5px;padding:9px 15px;border-bottom:1px solid #F3F4F6}
.lp-btn{flex:1;display:flex;flex-direction:column;align-items:center;gap:2px;padding:7px 3px;border-radius:8px;border:1px solid #E5E7EB;background:#fff;cursor:pointer;font-size:10px;font-weight:600;color:#374151;transition:all .15s;font-family:'Inter',sans-serif}
.lp-btn:hover{background:#EEF2FF;border-color:#C7D2FE;color:#2B2BFF}
.lp-info{display:flex;gap:9px;padding:9px 15px;border-bottom:1px solid #F3F4F6;flex-wrap:wrap;font-size:11px;color:#374151}
.lp-tabs{display:flex;border-bottom:1px solid #F3F4F6}
.lp-tab{flex:1;padding:8px;text-align:center;font-size:12px;font-weight:500;color:#6B7280;cursor:pointer;border-bottom:2px solid transparent}
.lp-tab.active{color:#2B2BFF;border-bottom-color:#2B2BFF;font-weight:600}
.lp-msgs{flex:1;overflow-y:auto;padding:12px;display:flex;flex-direction:column;gap:7px;background:#FAFAFA}
.lm{display:flex;flex-direction:column;max-width:80%}
.lm.in{align-self:flex-start}.lm.out{align-self:flex-end;align-items:flex-end}.lm.sys{align-self:center}
.lm-bbl{padding:7px 10px;border-radius:8px;font-size:12px;line-height:1.5}
.lm.in .lm-bbl{background:#fff;border:1px solid #F3F4F6;border-radius:3px 8px 8px 8px;color:#0D1B2A}
.lm.out .lm-bbl{background:#2B2BFF;color:#fff;border-radius:8px 3px 8px 8px}
.lm.sys .lm-bbl{background:#F3F4F6;color:#6B7280;font-size:11px;border-radius:6px}
.lm-time{font-size:10px;color:#9CA3AF;margin-top:2px}
.lp-reply{padding:9px 12px;border-top:1px solid #F3F4F6;display:flex;gap:7px;background:#fff}
.lp-rep-inp{flex:1;padding:7px 10px;border:1px solid #E5E7EB;border-radius:7px;font-size:12px;outline:none;font-family:'Inter',sans-serif}
.lp-rep-inp:focus{border-color:#2B2BFF}
.copilot-float{position:fixed;bottom:22px;right:22px;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;border-radius:50px;padding:10px 16px;font-size:13px;font-weight:700;cursor:pointer;box-shadow:0 4px 14px rgba(102,126,234,.45);display:flex;align-items:center;gap:6px;z-index:300;transition:all .2s;font-family:'Inter',sans-serif}
.copilot-float:hover{transform:translateY(-2px);box-shadow:0 6px 20px rgba(102,126,234,.6)}
.section-lbl{font-size:11px;font-weight:700;color:#9CA3AF;text-transform:uppercase;letter-spacing:.6px;margin-bottom:8px;margin-top:4px}
.integ-row{padding:11px 15px;display:flex;align-items:center;justify-content:space-between;border-bottom:1px solid #F9FAFB;font-size:13px}
.integ-row:last-child{border-bottom:none}
.conn{font-size:11px;font-weight:600;color:#059669;background:#D1FAE5;padding:2px 8px;border-radius:10px}
.not-conn{font-size:11px;font-weight:600;color:#9CA3AF;background:#F3F4F6;padding:2px 8px;border-radius:10px}
.bot-card{background:#fff;border-radius:10px;padding:14px 16px;border:1px solid #F3F4F6;margin-bottom:10px;box-shadow:0 1px 3px rgba(0,0,0,.04)}
.bot-status-dot{width:8px;height:8px;border-radius:50%;display:inline-block;margin-right:5px}

/* === FASE 3/5 — Chat right bar layout compensation ===
   .main recibe padding-right:56px (colapsada) o 190px (expandida) vía JS.
   Este valor base es el estado inicial antes de que JS llame _applyMainPadding(). */
.main { padding-right: 56px; box-sizing: border-box; }

/* === FASE 5 — Chat barra fija derecha ===
   scrollbar oculto cuando la barra está colapsada */
#chat-right-bar { scrollbar-width: none; }
#chat-right-bar::-webkit-scrollbar { display: none; }

/* === RESPONSIVE — Móvil (≤768px) ===
   En móvil: la barra fija desaparece y el padding se elimina.
   El chat es accesible vía la vista completa #view-chatequipo
   (que se carga con showView si se necesita). */
@media (max-width: 768px) {
  /* Ocultar barra fija y ventanas flotantes */
  #chat-right-bar          { display: none !important; }
  #chat-windows-container  { display: none !important; }

  /* Eliminar el padding derecho reservado para la barra */
  .main { padding-right: 0 !important; }

  /* Sidebar colapsa a barra de íconos en móvil */
  .sidebar {
    width: 48px;
    min-width: 48px;
    overflow: hidden;
  }
  .sidebar .logo-text,
  .sidebar .logo-badge,
  .sidebar .nav-label,
  .sidebar .ni span:not(.ni-icon),
  .sidebar .pinned-area,
  .sidebar .u-name,
  .sidebar .u-handle {
    display: none;
  }
  .sidebar .ni {
    padding: 10px 0;
    justify-content: center;
    border-left: none;
  }
  .sidebar .ni-icon { width: 24px; height: 24px; }
  .sidebar .ni-icon svg { width: 20px; height: 20px; }
  .sidebar .logo-area { padding: 12px 0; text-align: center; }
  .sidebar .sidebar-user { justify-content: center; padding: 8px 0; }
  .sidebar .u-av { margin: 0; }

  /* En móvil el modal de nuevo canal usa todo el ancho menos márgenes */
  #crb-channel-modal > div { width: 100% !important; }
}

/* === MODAL CHAT — Animación de entrada === */
@keyframes crbFadeIn {
  from { opacity: 0; transform: scale(.96); }
  to   { opacity: 1; transform: scale(1);   }
}

/* ── Notificación de mensaje entrante (card estilo WhatsApp) ── */
.notif-msg-card {
  background: #fff;
  border-radius: 12px;
  box-shadow: 0 4px 24px rgba(0,0,0,.14), 0 1px 4px rgba(0,0,0,.08);
  overflow: hidden;
  width: 300px;
  transition: opacity .3s, transform .3s;
  animation: notifSlideIn .25s ease;
}
@keyframes notifSlideIn {
  from { opacity: 0; transform: translateX(-16px); }
  to   { opacity: 1; transform: translateX(0); }
}
.notif-card-bar {
  height: 3px;
  width: 100%;
}
.notif-card-body {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 10px 12px 6px;
}
.notif-card-av {
  width: 36px;
  height: 36px;
  border-radius: 50%;
  flex-shrink: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 15px;
  font-weight: 700;
  color: #fff;
}
.notif-card-content {
  flex: 1;
  min-width: 0;
}
.notif-card-name {
  font-size: 13px;
  font-weight: 700;
  color: #0D1B2A;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.notif-card-ch { font-size: 11px; }
.notif-card-preview {
  font-size: 12px;
  color: #6B7280;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  margin-top: 1px;
}
.notif-card-close {
  background: none;
  border: none;
  cursor: pointer;
  color: #9CA3AF;
  font-size: 11px;
  flex-shrink: 0;
  padding: 2px 4px;
  line-height: 1;
}
.notif-card-close:hover { color: #374151; }
.notif-card-action {
  display: block;
  width: 100%;
  border: none;
  background: none;
  border-top: 1px solid #F3F4F6;
  padding: 7px 12px;
  font-size: 12px;
  font-weight: 600;
  color: #2B2BFF;
  cursor: pointer;
  text-align: left;
  transition: background .12s;
}
.notif-card-action:hover { background: #F8F9FF; }
