/* ── VARIABLES Y TEMAS ── */
:root {
  --font-display:'Syne',sans-serif;
  --font-body:'DM Sans',sans-serif;
  --font-mono:'JetBrains Mono',monospace;
  --bg-base:#080a0f; --bg-surface:#0d0f17; --bg-card:#111420;
  --bg-elevated:#161928; --bg-hover:#1c2035; --bg-active:#1e2238;
  --border-subtle:rgba(255,255,255,0.04); --border-dim:rgba(255,255,255,0.08);
  --border-mid:rgba(255,255,255,0.13); --border-bright:rgba(255,255,255,0.22);
  --text-primary:#f0f2ff; --text-secondary:#8b90b0;
  --text-muted:#4a5070; --text-dim:#2a2f4a;
  --brand:#6366f1; --brand-light:#818cf8;
  --brand-dim:rgba(99,102,241,0.12); --brand-glow:rgba(99,102,241,0.28); --brand-hover:#4f46e5;
  --green:#10b981; --green-dim:rgba(16,185,129,0.12);
  --amber:#f59e0b; --amber-dim:rgba(245,158,11,0.12);
  --red:#ef4444; --red-dim:rgba(239,68,68,0.12);
  --blue:#3b82f6; --blue-dim:rgba(59,130,246,0.12);
  --purple:#a855f7; --purple-dim:rgba(168,85,247,0.12);
  --cyan:#06b6d4; --cyan-dim:rgba(6,182,212,0.12);
  --shadow-sm:0 2px 8px rgba(0,0,0,0.30); --shadow-md:0 4px 16px rgba(0,0,0,0.40);
  --shadow-lg:0 8px 32px rgba(0,0,0,0.50); --shadow-xl:0 16px 48px rgba(0,0,0,0.60);
  --shadow-brand:0 4px 20px rgba(99,102,241,0.30);
  --r-sm:6px; --r-md:10px; --r-lg:14px; --r-xl:20px; --r-2xl:28px; --r-full:9999px;
  --ease:cubic-bezier(0.22,1,0.36,1); --ease-spring:cubic-bezier(0.34,1.56,0.64,1);
}
[data-theme="wa-dark"]{
  --bg-base:#060d10;--bg-surface:#0b141a;--bg-card:#111b21;
  --bg-elevated:#182028;--bg-hover:#1e2832;--bg-active:#222e38;
  --brand:#25D366;--brand-light:#34d399;--brand-dim:rgba(37,211,102,0.10);
  --brand-glow:rgba(37,211,102,0.22);--brand-hover:#1db954;
  --border-subtle:rgba(255,255,255,0.03);--border-dim:rgba(255,255,255,0.07);
  --border-mid:rgba(255,255,255,0.12);--border-bright:rgba(255,255,255,0.20);
  --text-primary:#e9edef;--text-secondary:#8696a0;--text-muted:#4a5568;--text-dim:#2a3540;
  --shadow-sm:0 2px 8px rgba(0,0,0,0.40);--shadow-md:0 4px 16px rgba(0,0,0,0.50);
}

[data-theme="wa-light"]{
  --bg-base:#e5ddd5;--bg-surface:#ffffff;--bg-card:#f0f2f5;
  --bg-elevated:#e8eaf0;--bg-hover:#dde0e8;--bg-active:#d0d4dc;
  --brand:#128c7e;--brand-light:#075e54;--brand-dim:rgba(18,140,126,0.10);
  --brand-glow:rgba(18,140,126,0.20);--brand-hover:#075e54;
  --border-subtle:rgba(0,0,0,0.06);--border-dim:rgba(0,0,0,0.10);
  --border-mid:rgba(0,0,0,0.16);--border-bright:rgba(0,0,0,0.24);
  --text-primary:#0a1929;--text-secondary:#374151;--text-muted:#6b7280;--text-dim:#9ca3af;
  --green:#059669;--amber:#d97706;--red:#dc2626;--blue:#2563eb;--purple:#7c3aed;--cyan:#0891b2;
  --green-dim:rgba(5,150,105,0.10);--amber-dim:rgba(217,119,6,0.10);
  --red-dim:rgba(220,38,38,0.10);--blue-dim:rgba(37,99,235,0.10);
  --purple-dim:rgba(124,58,237,0.10);--cyan-dim:rgba(8,145,178,0.10);
  --shadow-sm:0 2px 8px rgba(0,0,0,0.08);--shadow-md:0 4px 16px rgba(0,0,0,0.12);
  --shadow-lg:0 8px 32px rgba(0,0,0,0.16);--shadow-xl:0 16px 48px rgba(0,0,0,0.20);
}

[data-theme="fb-dark"]{
  --bg-base:#0a0a0a;--bg-surface:#18191a;--bg-card:#242526;
  --bg-elevated:#2d2f31;--bg-hover:#3a3b3c;--bg-active:#444546;
  --brand:#0866ff;--brand-light:#2e81f4;--brand-dim:rgba(8,102,255,0.12);
  --brand-glow:rgba(8,102,255,0.22);--brand-hover:#0558e0;
  --border-subtle:rgba(255,255,255,0.04);--border-dim:rgba(255,255,255,0.08);
  --border-mid:rgba(255,255,255,0.13);--border-bright:rgba(255,255,255,0.22);
  --text-primary:#e4e6eb;--text-secondary:#b0b3b8;--text-muted:#6b6f7a;--text-dim:#3a3d4a;
  --shadow-sm:0 2px 8px rgba(0,0,0,0.40);--shadow-md:0 4px 16px rgba(0,0,0,0.50);
}

[data-theme="fb-light"]{
  --bg-base:#e9ebee;--bg-surface:#ffffff;--bg-card:#f0f2f5;
  --bg-elevated:#f8f9fb;--bg-hover:#e4e6eb;--bg-active:#d8dadf;
  --brand:#0866ff;--brand-light:#0558e0;--brand-dim:rgba(8,102,255,0.08);
  --brand-glow:rgba(8,102,255,0.18);--brand-hover:#0558e0;
  --border-subtle:rgba(0,0,0,0.06);--border-dim:rgba(0,0,0,0.10);
  --border-mid:rgba(0,0,0,0.16);--border-bright:rgba(0,0,0,0.24);
  --text-primary:#050505;--text-secondary:#374151;--text-muted:#65676b;--text-dim:#9ca3af;
  --green:#059669;--amber:#d97706;--red:#dc2626;--blue:#2563eb;--purple:#7c3aed;--cyan:#0891b2;
  --green-dim:rgba(5,150,105,0.10);--amber-dim:rgba(217,119,6,0.10);
  --red-dim:rgba(220,38,38,0.10);--blue-dim:rgba(37,99,235,0.10);
  --purple-dim:rgba(124,58,237,0.10);--cyan-dim:rgba(8,145,178,0.10);
  --shadow-sm:0 2px 8px rgba(0,0,0,0.08);--shadow-md:0 4px 16px rgba(0,0,0,0.12);
  --shadow-lg:0 8px 32px rgba(0,0,0,0.16);--shadow-xl:0 16px 48px rgba(0,0,0,0.20);
}
/* ── ESTILOS GLOBALES BASE ── */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0;}
html,body{height:100%;overflow:hidden;background:var(--bg-base);color:var(--text-primary);font-family:var(--font-body);font-size:13px;line-height:1.5;-webkit-font-smoothing:antialiased;}
input,select,textarea,button{font-family:var(--font-body);outline:none;}
a{text-decoration:none;color:inherit;}
input,select,textarea{background:var(--bg-elevated);color:var(--text-primary);border:1px solid var(--border-dim);border-radius:var(--r-md);transition:border-color .2s var(--ease),box-shadow .2s var(--ease),background .2s;}
input:focus,select:focus,textarea:focus{border-color:var(--brand);box-shadow:0 0 0 3px var(--brand-dim);background:var(--bg-active);}
input::placeholder,textarea::placeholder{color:var(--text-muted);}
[data-theme*="light"] input,[data-theme*="light"] select,[data-theme*="light"] textarea{background:#fff;color:#0a1929;border-color:rgba(0,0,0,0.13);}
::-webkit-scrollbar{width:4px;height:4px;}
::-webkit-scrollbar-track{background:transparent;}
::-webkit-scrollbar-thumb{background:var(--border-mid);border-radius:var(--r-full);}
::-webkit-scrollbar-thumb:hover{background:var(--text-muted);}

/* ── ANIMACIONES ── */
@keyframes fadeUp{from{opacity:0;transform:translateY(8px);}to{opacity:1;transform:translateY(0);}}
@keyframes fadeIn{from{opacity:0;}to{opacity:1;}}
@keyframes scaleIn{from{opacity:0;transform:scale(.94);}to{opacity:1;transform:scale(1);}}
@keyframes pulse{0%,100%{opacity:1;}50%{opacity:.4;}}
@keyframes shimmer{from{background-position:-200% 0;}to{background-position:200% 0;}}
@keyframes glowPulse{0%,100%{box-shadow:0 0 8px var(--brand-glow);}50%{box-shadow:0 0 24px var(--brand-glow),0 0 48px var(--brand-dim);}}
@keyframes recPulse{0%,100%{opacity:1;box-shadow:0 0 0 0 rgba(239,68,68,.4);}50%{opacity:.6;box-shadow:0 0 0 6px rgba(239,68,68,0);}}
@keyframes bounceIn{0%{transform:scale(0.3);opacity:0;}60%{transform:scale(1.08);}80%{transform:scale(0.96);}100%{transform:scale(1);opacity:1;}}

/* ── LAYOUT ── */
#app{display:flex;height:100vh;overflow:hidden;background:var(--bg-base);}
.view{display:none;flex:1;overflow:hidden;flex-direction:column;min-height:0;}
.view.active{display:flex;}

/* ── MOBILE HEADER ── */
.mobile-header{display:none;position:fixed;top:0;left:0;right:0;z-index:200;height:58px;background:rgba(13,15,23,0.94);backdrop-filter:blur(20px);border-bottom:1px solid var(--border-dim);padding:0 16px;align-items:center;justify-content:space-between;}
@media(max-width:768px){.mobile-header{display:flex;}body{padding-top:58px;}#app{height:calc(100vh - 58px);}}

/* ── SIDEBAR ── */
#sidebar{width:200px;background:var(--bg-surface);border-right:1px solid var(--border-subtle);display:flex;flex-direction:column;flex-shrink:0;z-index:150;transition:transform .3s var(--ease);position:relative;overflow:hidden;}
#sidebar::before{content:'';position:absolute;top:0;left:0;right:0;height:1px;background:linear-gradient(90deg,transparent,var(--brand-light),transparent);opacity:.25;}
.brand-zone{padding:20px 14px 16px;border-bottom:1px solid var(--border-subtle);display:flex;align-items:center;gap:10px;cursor:pointer;transition:background .2s;}
.brand-zone:hover{background:var(--bg-card);}
.brand-logo{width:34px;height:34px;border-radius:10px;background:linear-gradient(135deg,var(--brand) 0%,var(--purple) 100%);display:flex;align-items:center;justify-content:center;font-family:var(--font-display);font-size:16px;font-weight:800;color:#fff;flex-shrink:0;box-shadow:0 4px 12px var(--brand-glow),inset 0 1px 0 rgba(255,255,255,0.15);position:relative;}
.brand-logo::after{content:'';position:absolute;inset:0;border-radius:10px;background:linear-gradient(135deg,rgba(255,255,255,0.14) 0%,transparent 55%);}
.brand-text-main{font-family:var(--font-display);font-size:13px;font-weight:700;color:var(--text-primary);line-height:1.1;}
.brand-text-sub{font-size:9px;color:var(--text-muted);font-weight:500;letter-spacing:.05em;margin-top:1px;}
.nav-body{flex:1;overflow-y:auto;overflow-x:hidden;padding:10px 8px;}
.nav-section-label{font-size:9px;font-weight:700;text-transform:uppercase;letter-spacing:.1em;color:var(--text-dim);padding:0 10px;margin:14px 0 5px;}
.nav-section-label:first-child{margin-top:4px;}
.nav-item{display:flex;align-items:center;gap:10px;padding:8px 10px;border-radius:var(--r-md);cursor:pointer;color:var(--text-secondary);margin-bottom:1px;transition:all .2s var(--ease);border:1px solid transparent;background:transparent;width:100%;text-align:left;font-family:var(--font-body);position:relative;overflow:hidden;}
.nav-item::before{content:'';position:absolute;inset:0;background:linear-gradient(90deg,var(--brand-dim),transparent);opacity:0;transition:opacity .2s;border-radius:var(--r-md);}
.nav-item:hover{color:var(--text-primary);background:var(--bg-hover);}
.nav-item.active{color:var(--brand-light);background:var(--brand-dim);border-color:rgba(99,102,241,0.15);}
.nav-item.active::before{opacity:1;}
.nav-icon{width:30px;height:30px;display:flex;align-items:center;justify-content:center;border-radius:var(--r-sm);flex-shrink:0;transition:all .2s var(--ease-spring);color:inherit;}
.nav-item.active .nav-icon{background:var(--brand);color:#fff;box-shadow:0 2px 8px var(--brand-glow);transform:scale(1.06);}
.nav-item:hover:not(.active) .nav-icon{background:var(--bg-active);}
.nav-label{font-size:12px;font-weight:500;flex:1;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
.nav-badge{min-width:17px;height:17px;background:var(--red);color:#fff;font-size:9px;font-weight:700;border-radius:var(--r-full);display:none;align-items:center;justify-content:center;padding:0 4px;box-shadow:0 2px 6px rgba(239,68,68,.4);animation:bounceIn .3s var(--ease-spring);}
.nav-divider{height:1px;background:var(--border-subtle);margin:6px 10px;}
.agent-footer{padding:12px;border-top:1px solid var(--border-subtle);display:flex;align-items:center;gap:10px;cursor:pointer;transition:background .2s;margin-top:auto;}
.agent-footer:hover{background:var(--bg-hover);}
.agent-av{width:34px;height:34px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:700;color:#fff;flex-shrink:0;background:linear-gradient(135deg,var(--green) 0%,var(--cyan) 100%);position:relative;}
.agent-av::after{content:'';position:absolute;bottom:0;right:0;width:9px;height:9px;background:var(--green);border-radius:50%;border:2px solid var(--bg-surface);}
.agent-name{font-size:12px;font-weight:600;color:var(--text-primary);line-height:1.2;}
.agent-hint{font-size:9px;color:var(--red);opacity:.7;margin-top:1px;}

/* ── CONTACTS PANEL ── */
#contacts-panel{width:286px;min-width:286px;background:var(--bg-surface);border-right:1px solid var(--border-subtle);display:flex;flex-direction:column;flex-shrink:0;z-index:40;}
.cp-header{padding:20px 14px 13px;border-bottom:1px solid var(--border-subtle);}
.cp-title{font-family:var(--font-display);font-size:18px;font-weight:700;color:var(--text-primary);margin-bottom:13px;letter-spacing:-.3px;}
.metrics-row{display:flex;gap:7px;margin-bottom:12px;}
.metric-chip{flex:1;background:var(--bg-card);border:1px solid var(--border-subtle);border-radius:var(--r-lg);padding:9px 7px;text-align:center;cursor:default;transition:all .25s var(--ease);position:relative;overflow:hidden;}
.metric-chip::before{content:'';position:absolute;top:0;left:0;right:0;height:2px;border-radius:var(--r-full);}
.metric-chip:nth-child(1)::before{background:var(--amber);}
.metric-chip:nth-child(2)::before{background:var(--green);}
.metric-chip:nth-child(3)::before{background:var(--blue);}
.metric-chip:hover{border-color:var(--border-mid);transform:translateY(-1px);}
.metric-val{font-family:var(--font-display);font-size:20px;font-weight:700;line-height:1;}
.metric-val.amber{color:var(--amber);}.metric-val.green{color:var(--green);}.metric-val.blue{color:var(--blue);}
.metric-lbl{font-size:9px;color:var(--text-muted);margin-top:3px;font-weight:600;text-transform:uppercase;letter-spacing:.05em;}
.search-box{display:flex;align-items:center;gap:8px;background:var(--bg-card);border:1px solid var(--border-dim);border-radius:var(--r-lg);padding:9px 13px;transition:all .2s;}
.search-box:focus-within{border-color:var(--brand);box-shadow:0 0 0 3px var(--brand-dim);background:var(--bg-elevated);}
.search-box svg{width:15px;height:15px;color:var(--text-muted);flex-shrink:0;}
.search-box input{background:none;border:none;box-shadow:none;padding:0;border-radius:0;color:var(--text-primary);font-size:13px;flex:1;width:100%;}
.cp-tabs{display:flex;gap:4px;padding:9px 13px;border-bottom:1px solid var(--border-subtle);}
.cp-tab{flex:1;padding:6px 8px;border-radius:var(--r-md);font-size:11px;font-weight:600;cursor:pointer;color:var(--text-muted);transition:all .2s;border:1px solid transparent;background:transparent;text-align:center;}
.cp-tab:hover{color:var(--text-primary);background:var(--bg-hover);}
.cp-tab.active{background:var(--brand-dim);border-color:rgba(99,102,241,0.20);color:var(--brand-light);}
#contact-list{flex:1;overflow-y:auto;padding:7px;display:flex;flex-direction:column;gap:2px;}
.contact-item{display:flex;align-items:flex-start;gap:10px;padding:10px 11px;border-radius:var(--r-lg);cursor:pointer;transition:all .2s var(--ease);border:1px solid transparent;position:relative;overflow:hidden;}
.contact-item::before{content:'';position:absolute;left:0;top:50%;transform:translateY(-50%);width:3px;height:0;border-radius:0 var(--r-full) var(--r-full) 0;background:var(--brand);transition:height .25s var(--ease-spring);}
.contact-item:hover{background:var(--bg-card);}
.contact-item:hover::before{height:55%;}
.contact-item.active{background:var(--bg-elevated);border-color:var(--border-dim);box-shadow:var(--shadow-sm);}
.contact-item.active::before{height:68%;background:var(--brand-light);}
.ci-av{width:42px;height:42px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:14px;color:#fff;flex-shrink:0;position:relative;box-shadow:0 2px 8px rgba(0,0,0,.3);}
.ci-channel-badge{position:absolute;bottom:-2px;right:-2px;width:16px;height:16px;border-radius:50%;border:2px solid var(--bg-surface);display:flex;align-items:center;justify-content:center;}
.ci-info{flex:1;min-width:0;}
.ci-row1{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:1px;}
.ci-name{font-size:13px;font-weight:600;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:130px;}
.ci-time{font-size:10px;color:var(--text-muted);font-weight:500;flex-shrink:0;}
.ci-phone{font-size:10px;color:var(--text-dim);font-family:var(--font-mono);letter-spacing:.02em;margin-bottom:2px;}
.ci-preview{font-size:11.5px;color:var(--text-secondary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;margin-bottom:5px;}
.ci-footer{display:flex;justify-content:space-between;align-items:center;}
.status-dot{display:inline-flex;align-items:center;gap:4px;font-size:9px;font-weight:700;padding:2px 7px;border-radius:var(--r-full);letter-spacing:.03em;}
.sd-pending{background:var(--amber-dim);color:var(--amber);}
.sd-open{background:var(--green-dim);color:var(--green);}
.sd-bot{background:var(--purple-dim);color:var(--purple);}
.sd-resolved{background:var(--border-dim);color:var(--text-muted);}
.ci-unread{min-width:18px;height:18px;background:var(--brand);color:#fff;font-size:9px;font-weight:700;border-radius:var(--r-full);display:flex;align-items:center;justify-content:center;padding:0 5px;box-shadow:0 2px 8px var(--brand-glow);}

/* ── CHAT MAIN ── */
#chat-main{
  flex:1;
  display:flex;
  flex-direction:column;
  min-width:0;
  min-height:0;
  overflow:hidden;
  background:var(--bg-base);
  position:relative;
  z-index:10;
}
.chat-topbar{padding:11px 18px;border-bottom:1px solid var(--border-subtle);display:flex;align-items:center;gap:11px;background:rgba(13,15,23,0.80);backdrop-filter:blur(20px);z-index:50;min-height:60px;flex-shrink:0;}
.hdr-av{width:38px;height:38px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:13px;font-weight:700;color:#fff;flex-shrink:0;position:relative;}
.hdr-info{flex:1;min-width:0;cursor:pointer;}
.hdr-name{font-size:14px;font-weight:700;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;font-family:var(--font-display);}
.hdr-meta{display:flex;align-items:center;gap:6px;margin-top:2px;}
.hdr-actions{display:flex;align-items:center;gap:6px;}
.btn-ghost{display:inline-flex;align-items:center;gap:6px;padding:6px 11px;border-radius:var(--r-md);font-size:12px;font-weight:600;cursor:pointer;border:1px solid var(--border-dim);background:transparent;color:var(--text-secondary);transition:all .2s var(--ease);white-space:nowrap;font-family:var(--font-body);}
.btn-ghost:hover{color:var(--text-primary);background:var(--bg-hover);border-color:var(--border-mid);}
.btn-resolve{background:var(--green-dim);border-color:rgba(16,185,129,.25);color:var(--green);}
.btn-resolve:hover{background:var(--green);color:#fff;border-color:transparent;}

/* MESSAGES BOX */
#messages-box{
  flex:1;
  overflow-y:auto;
  overflow-x:hidden;
  padding:22px 26px;
  display:flex;
  flex-direction:column;
  gap:3px;
  background:var(--bg-base);
  background-image:radial-gradient(ellipse 60% 50% at 50% 0%,rgba(99,102,241,0.04) 0%,transparent 70%);
  min-height:0;
}

.sys-separator{display:flex;align-items:center;justify-content:center;margin:12px 0 8px;width:100%;}
.sys-separator span{background:var(--bg-elevated);color:var(--text-muted);font-size:10px;font-weight:600;padding:3px 12px;border-radius:var(--r-full);border:1px solid var(--border-subtle);text-transform:uppercase;letter-spacing:.05em;white-space:nowrap;}
.msg-row{display:flex;gap:8px;width:100%;margin-bottom:2px;}
.msg-row.out{flex-direction:row-reverse;}
.bubble-wrap{display:flex;flex-direction:column;max-width:62%;}
.bubble{padding:10px 14px;font-size:13.5px;line-height:1.55;word-break:break-word;position:relative;}
.msg-row.in .bubble{background:var(--bg-elevated);border:1px solid var(--border-dim);border-radius:2px var(--r-xl) var(--r-xl) var(--r-xl);color:var(--text-primary);}
.msg-row.out .bubble{background:linear-gradient(135deg,var(--brand) 0%,var(--brand-hover) 100%);border:1px solid rgba(255,255,255,.08);border-radius:var(--r-xl) 2px var(--r-xl) var(--r-xl);color:#fff;box-shadow:0 2px 12px var(--brand-glow);}
.bubble-meta{display:flex;align-items:center;gap:5px;margin-top:3px;padding:0 2px;}
.msg-row.out .bubble-meta{flex-direction:row-reverse;}
.bubble-time{font-size:10px;color:var(--text-muted);font-weight:500;}
.msg-row.out .bubble-time{color:rgba(255,255,255,.45);}
.ai-chip{display:inline-flex;align-items:center;gap:3px;background:var(--purple-dim);color:var(--purple);font-size:9px;font-weight:700;padding:2px 6px;border-radius:var(--r-full);border:1px solid rgba(168,85,247,.2);margin-bottom:4px;width:fit-content;}
#typing-indicator{display:none;padding:5px 26px;font-size:11.5px;font-weight:600;color:var(--brand-light);background:rgba(99,102,241,0.04);border-bottom:1px solid var(--border-subtle);flex-shrink:0;}

/* INPUT ZONE */
#chat-input-zone{
  padding:11px 18px;
  border-top:1px solid var(--border-subtle);
  background:rgba(13,15,23,0.80);
  backdrop-filter:blur(20px);
  flex-shrink:0;
  position:relative;
}
.input-toolbar{display:flex;align-items:center;gap:5px;margin-bottom:9px;}
.toolbar-btn{display:inline-flex;align-items:center;gap:5px;padding:5px 10px;border-radius:var(--r-md);font-size:11px;font-weight:600;cursor:pointer;border:1px solid var(--border-dim);background:var(--bg-card);color:var(--text-secondary);transition:all .2s;font-family:var(--font-body);}
.toolbar-btn:hover{color:var(--text-primary);border-color:var(--border-mid);background:var(--bg-elevated);}
.toolbar-btn.ai-btn{background:var(--purple-dim);border-color:rgba(168,85,247,.25);color:var(--purple);margin-left:auto;}
.toolbar-btn.ai-btn:hover{background:var(--purple);color:#fff;border-color:transparent;}
.input-row{display:flex;align-items:flex-end;gap:9px;}
.input-shell{flex:1;background:var(--bg-card);border:1px solid var(--border-dim);border-radius:16px;display:flex;align-items:flex-end;padding:3px 8px;min-height:48px;transition:all .2s;}
.input-shell:focus-within{border-color:var(--brand);box-shadow:0 0 0 3px var(--brand-dim);background:var(--bg-elevated);}
#chat-textarea{flex:1;background:transparent;border:none;box-shadow:none;color:var(--text-primary);padding:10px 8px;max-height:120px;font-size:14px;line-height:1.45;resize:none;overflow-y:auto;border-radius:0;}
.clip-btn{color:var(--text-muted);padding:10px 8px;cursor:pointer;transition:color .2s;}
.clip-btn:hover{color:var(--brand-light);}
#btn-mic{width:46px;height:46px;border-radius:50%;background:linear-gradient(135deg,var(--brand) 0%,var(--brand-hover) 100%);color:#fff;display:flex;align-items:center;justify-content:center;flex-shrink:0;border:none;cursor:pointer;transition:all .25s var(--ease-spring);box-shadow:0 4px 14px var(--brand-glow);}
#btn-mic:hover{transform:scale(1.08);box-shadow:0 6px 20px var(--brand-glow);}
#btn-mic:active{transform:scale(.94);}
#btn-mic.recording{background:linear-gradient(135deg,var(--red) 0%,#c0392b 100%);box-shadow:0 4px 14px rgba(239,68,68,.4);animation:glowPulse 1.5s infinite;}
#qr-dropdown{display:none;position:absolute;bottom:100%;left:0;right:0;background:var(--bg-elevated);border:1px solid var(--border-mid);border-radius:var(--r-lg) var(--r-lg) 0 0;max-height:220px;overflow-y:auto;z-index:50;box-shadow:var(--shadow-lg);}
.qr-item{display:flex;align-items:center;gap:10px;padding:10px 14px;cursor:pointer;transition:background .15s;border-bottom:1px solid var(--border-subtle);}
.qr-item:hover{background:var(--bg-hover);}
.qr-shortcut{font-family:var(--font-mono);font-size:11px;color:var(--brand-light);background:var(--brand-dim);padding:2px 8px;border-radius:var(--r-md);flex-shrink:0;}
.qr-content{font-size:12px;color:var(--text-secondary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
#recording-indicator{display:none;align-items:center;gap:10px;padding:8px 13px;margin-bottom:8px;background:var(--red-dim);border:1px solid rgba(239,68,68,.25);border-radius:var(--r-lg);}
#recording-indicator.show{display:flex;animation:fadeUp .2s var(--ease);}
.rec-dot{width:9px;height:9px;border-radius:50%;background:var(--red);animation:recPulse 1s infinite;}
.rec-timer{font-family:var(--font-mono);font-size:13px;font-weight:600;color:var(--red);}
.rec-cancel{margin-left:auto;padding:3px 10px;border-radius:var(--r-md);background:transparent;border:1px solid var(--red);color:var(--red);font-size:11px;cursor:pointer;transition:all .2s;font-family:var(--font-body);}
.rec-cancel:hover{background:var(--red);color:#fff;}
#camera-preview-wrap{display:none;flex-direction:column;gap:8px;margin-bottom:10px;padding:12px;background:var(--bg-card);border-radius:var(--r-lg);border:1px solid var(--border-dim);}
#camera-preview-wrap.show{display:flex;}
#camera-video{width:50%;max-height:280px;border-radius:var(--r-md);background:#000;object-fit:cover;}
.media-preview{display:none;align-items:center;gap:10px;padding:8px 13px;margin-bottom:8px;background:var(--bg-card);border:1px solid var(--border-dim);border-radius:var(--r-lg);}
.media-preview.show{display:flex;}
.media-preview-name{font-size:12px;font-weight:500;color:var(--text-primary);flex:1;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
.media-preview-remove{width:26px;height:26px;border-radius:var(--r-md);background:var(--red-dim);border:1px solid rgba(239,68,68,.2);color:var(--red);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s;font-size:13px;}
.media-preview-remove:hover{background:var(--red);color:#fff;}

/* ── RIGHT PANEL ── */
#right-panel{width:266px;min-width:266px;background:var(--bg-surface);border-left:1px solid var(--border-subtle);display:flex;flex-direction:column;overflow-y:auto;z-index:20;}
.rp-profile{display:flex;flex-direction:column;align-items:center;padding:22px 14px 16px;border-bottom:1px solid var(--border-subtle);background:linear-gradient(180deg,var(--bg-card) 0%,transparent 100%);}
.rp-av{width:56px;height:56px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-family:var(--font-display);font-weight:700;font-size:22px;color:#fff;margin-bottom:11px;box-shadow:var(--shadow-md);border:2px solid var(--bg-surface);}
.rp-name{font-family:var(--font-display);font-weight:700;font-size:15px;color:var(--text-primary);text-align:center;line-height:1.2;}
.rp-phone{font-size:11px;color:var(--text-muted);margin-top:3px;font-family:var(--font-mono);letter-spacing:.03em;}
.rp-section{padding:13px 14px;border-bottom:1px solid var(--border-subtle);}
.rp-label{font-size:9px;font-weight:700;text-transform:uppercase;letter-spacing:.1em;color:var(--text-dim);margin-bottom:10px;}
.rp-select{width:100%;background:var(--bg-card);border:1px solid var(--border-dim);border-radius:var(--r-md);padding:8px 11px;color:var(--text-primary);font-size:12px;font-weight:500;cursor:pointer;margin-bottom:7px;transition:all .2s;}
.rp-select:focus{border-color:var(--brand);box-shadow:0 0 0 2px var(--brand-dim);background:var(--bg-elevated);}
.crm-progress{display:flex;gap:4px;margin-top:10px;}
.crm-step{flex:1;height:3px;border-radius:var(--r-full);background:var(--border-dim);transition:all .35s var(--ease);}
.crm-step.done{background:var(--brand);}
.crm-step.now{background:var(--amber);box-shadow:0 0 6px rgba(245,158,11,.4);}
.note-textarea{width:100%;background:var(--bg-card);border:1px solid var(--border-dim);border-radius:var(--r-lg);padding:11px;color:var(--text-primary);font-size:12.5px;resize:none;min-height:150px;line-height:1.55;transition:all .2s;}
.note-textarea:focus{border-color:var(--brand);background:var(--bg-elevated);box-shadow:0 0 0 3px var(--brand-dim);}
.btn-save{width:100%;padding:12px;background:linear-gradient(135deg,var(--brand) 0%,var(--brand-hover) 100%);border:none;border-radius:var(--r-lg);color:#fff;font-size:12px;font-weight:700;cursor:pointer;margin-top:10px;transition:all .25s var(--ease);box-shadow:0 4px 12px var(--brand-glow);font-family:var(--font-body);letter-spacing:.03em;}
.btn-save:hover{transform:translateY(-2px);box-shadow:0 6px 20px var(--brand-glow);}

/* ── PILLS ── */
.pill{display:inline-flex;align-items:center;gap:4px;padding:3px 9px;border-radius:var(--r-full);font-size:10px;font-weight:700;letter-spacing:.02em;}
.pill-green{background:var(--green-dim);color:var(--green);border:1px solid rgba(16,185,129,.2);}
.pill-amber{background:var(--amber-dim);color:var(--amber);border:1px solid rgba(245,158,11,.2);}
.pill-red{background:var(--red-dim);color:var(--red);border:1px solid rgba(239,68,68,.2);}
.pill-blue{background:var(--blue-dim);color:var(--blue);border:1px solid rgba(59,130,246,.2);}
.pill-purple{background:var(--purple-dim);color:var(--purple);border:1px solid rgba(168,85,247,.2);}
.pill-brand{background:var(--brand-dim);color:var(--brand-light);border:1px solid rgba(99,102,241,.2);}
.pill-gray{background:var(--border-dim);color:var(--text-muted);border:1px solid var(--border-subtle);}

/* ── BUTTONS ── */
.v-btn{display:inline-flex;align-items:center;justify-content:center;gap:6px;padding:7px 13px;border-radius:var(--r-md);font-size:12px;font-weight:600;cursor:pointer;border:1px solid var(--border-dim);background:var(--bg-card);color:var(--text-secondary);transition:all .2s var(--ease);white-space:nowrap;font-family:var(--font-body);}
.v-btn:hover{background:var(--bg-elevated);border-color:var(--border-mid);color:var(--text-primary);}
.v-btn.primary{background:linear-gradient(135deg,var(--brand) 0%,var(--brand-hover) 100%);border-color:transparent;color:#fff;box-shadow:0 2px 10px var(--brand-glow);}
.v-btn.primary:hover{transform:translateY(-1px);box-shadow:0 4px 16px var(--brand-glow);}
.v-btn.danger{background:var(--red-dim);border-color:rgba(239,68,68,.25);color:var(--red);}
.v-btn.danger:hover{background:var(--red);color:#fff;border-color:transparent;}
.v-btn.success{background:var(--green-dim);border-color:rgba(16,185,129,.25);color:var(--green);}
.v-btn.success:hover{background:var(--green);color:#fff;border-color:transparent;}

/* ── VIEWS ── */
.view-body{flex:1;overflow-y:auto;padding:30px 34px;background:var(--bg-base);}
.view-header{display:flex;align-items:flex-end;justify-content:space-between;margin-bottom:26px;flex-wrap:wrap;gap:14px;}
.view-title{font-family:var(--font-display);font-size:22px;font-weight:800;color:var(--text-primary);letter-spacing:-.5px;}
.view-sub{font-size:13px;color:var(--text-secondary);margin-top:4px;}
.view-actions{display:flex;gap:8px;align-items:center;flex-wrap:wrap;}
.kpi-row{display:grid;grid-template-columns:repeat(auto-fit,minmax(185px,1fr));gap:13px;margin-bottom:20px;}
.kpi-card{background:var(--bg-surface);border:1px solid var(--border-subtle);border-radius:var(--r-xl);padding:22px;position:relative;overflow:hidden;transition:all .25s var(--ease);}
.kpi-card::after{content:'';position:absolute;top:0;left:0;right:0;height:3px;}
.kpi-card:nth-child(1)::after{background:linear-gradient(90deg,var(--brand),var(--brand-light));}
.kpi-card:nth-child(2)::after{background:linear-gradient(90deg,var(--green),var(--cyan));}
.kpi-card:nth-child(3)::after{background:linear-gradient(90deg,var(--amber),#fb923c);}
.kpi-card:nth-child(4)::after{background:linear-gradient(90deg,var(--purple),var(--brand));}
.kpi-card:hover{transform:translateY(-3px);box-shadow:var(--shadow-md);border-color:var(--border-dim);}
.kpi-label{font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:var(--text-muted);margin-bottom:11px;}
.kpi-value{font-family:var(--font-display);font-size:34px;font-weight:800;color:var(--text-primary);line-height:1;}
.charts-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(370px,1fr));gap:16px;margin-bottom:20px;}
.chart-card{background:var(--bg-surface);border:1px solid var(--border-subtle);border-radius:var(--r-xl);padding:22px;}
.chart-title{font-family:var(--font-display);font-weight:700;font-size:15px;color:var(--text-primary);margin-bottom:3px;}
.chart-sub{font-size:12px;color:var(--text-secondary);margin-bottom:18px;}
.chart-wrap{height:220px;position:relative;}
.table-card{background:var(--bg-surface);border:1px solid var(--border-subtle);border-radius:var(--r-xl);overflow-x:auto;}
.t-head th{padding:13px 18px;font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.07em;color:var(--text-muted);text-align:left;background:var(--bg-card);border-bottom:1px solid var(--border-subtle);white-space:nowrap;}
.t-body tr{transition:background .15s;}
.t-body tr:hover{background:var(--bg-hover);}
.t-body td{padding:13px 18px;font-size:13px;color:var(--text-secondary);border-bottom:1px solid var(--border-subtle);white-space:nowrap;}
.t-body td:first-child{color:var(--text-primary);font-weight:600;}
.t-body tr:last-child td{border-bottom:none;}
.field-label{font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.07em;color:var(--text-muted);display:block;margin-bottom:7px;}
.field-input,.field-textarea{width:100%;background:var(--bg-card);border:1px solid var(--border-dim);border-radius:var(--r-lg);padding:10px 13px;color:var(--text-primary);font-size:13px;transition:all .2s;}
.field-input:focus,.field-textarea:focus{border-color:var(--brand);box-shadow:0 0 0 3px var(--brand-dim);background:var(--bg-elevated);}
.settings-card{max-width:680px;background:var(--bg-surface);border:1px solid var(--border-subtle);border-radius:var(--r-2xl);padding:30px;}
.toggle-switch{width:42px;height:23px;border-radius:var(--r-full);background:var(--bg-active);border:1px solid var(--border-mid);cursor:pointer;position:relative;transition:all .3s var(--ease);flex-shrink:0;}
.toggle-switch.on{background:var(--green);border-color:var(--green);}
.toggle-switch::after{content:'';position:absolute;width:17px;height:17px;border-radius:50%;background:#fff;top:2px;left:2px;transition:transform .3s var(--ease-spring);box-shadow:0 1px 4px rgba(0,0,0,.3);}
.toggle-switch.on::after{transform:translateX(19px);}
.item-card{background:var(--bg-surface);border:1px solid var(--border-subtle);border-radius:var(--r-xl);padding:20px;transition:all .25s var(--ease);}
.item-card:hover{border-color:rgba(99,102,241,0.20);transform:translateY(-3px);box-shadow:var(--shadow-md);}
.pipeline-col{background:var(--bg-surface);border:1px solid var(--border-subtle);border-radius:var(--r-xl);padding:14px;display:flex;flex-direction:column;gap:9px;min-height:370px;}
.pipeline-col-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:5px;}
.pipeline-col-title{font-family:var(--font-display);font-weight:700;font-size:13px;}
.pipeline-count{background:var(--bg-active);color:var(--text-secondary);font-size:11px;font-weight:700;padding:2px 8px;border-radius:var(--r-full);}
.crm-card{background:var(--bg-card);border:1px solid var(--border-dim);border-radius:var(--r-lg);padding:13px;cursor:grab;transition:all .2s var(--ease);}
.crm-card:hover{border-color:rgba(99,102,241,0.2);background:var(--bg-elevated);transform:translateY(-2px);box-shadow:var(--shadow-sm);}
.crm-card-name{font-size:13px;font-weight:600;color:var(--text-primary);margin-bottom:3px;}
.crm-card-meta{font-size:11px;color:var(--text-muted);}
.crm-card-value{font-family:var(--font-mono);font-size:12px;color:var(--green);margin-top:5px;font-weight:600;}
.media-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:13px;}
.media-card{background:var(--bg-surface);border:1px solid var(--border-subtle);border-radius:var(--r-xl);overflow:hidden;transition:all .25s var(--ease);cursor:pointer;}
.media-card:hover{border-color:rgba(99,102,241,0.2);transform:translateY(-4px);box-shadow:var(--shadow-md);}
.media-thumb{width:100%;height:145px;object-fit:cover;background:var(--bg-card);display:block;border-bottom:1px solid var(--border-subtle);}
.media-info{padding:9px 11px;display:flex;justify-content:space-between;align-items:center;}
.media-name{font-size:11px;font-weight:500;color:var(--text-primary);flex:1;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
.media-del{color:var(--red);background:var(--red-dim);border:1px solid rgba(239,68,68,.2);border-radius:var(--r-md);width:24px;height:24px;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .2s;flex-shrink:0;margin-left:5px;font-size:11px;}
.media-del:hover{background:var(--red);color:#fff;}
.builder-sidebar{width:215px;flex-shrink:0;background:var(--bg-surface);border-right:1px solid var(--border-subtle);padding:18px 13px;overflow-y:auto;display:flex;flex-direction:column;gap:7px;}
.drag-item{display:flex;align-items:center;gap:8px;padding:9px 11px;background:var(--bg-card);border:1px solid var(--border-dim);border-radius:var(--r-md);cursor:grab;font-size:12px;font-weight:500;color:var(--text-secondary);transition:all .2s;user-select:none;}
.drag-item:hover{border-color:var(--brand-dim);color:var(--text-primary);background:var(--bg-elevated);transform:translateX(2px);}
.routing-rule-row{background:var(--bg-card);border:1px solid var(--border-dim);border-radius:var(--r-lg);padding:13px;margin-bottom:9px;}
.form-group{margin-bottom:17px;}

/* ── MODAL ── */
#modal-overlay{position:fixed;inset:0;background:rgba(0,0,0,.76);z-index:300;display:none;align-items:center;justify-content:center;backdrop-filter:blur(8px);}
#modal-overlay.open{display:flex;animation:fadeIn .2s var(--ease);}
.modal-box{background:var(--bg-surface);border:1px solid var(--border-mid);border-radius:var(--r-2xl);padding:30px;width:500px;max-width:95vw;max-height:88vh;overflow-y:auto;box-shadow:var(--shadow-xl);animation:scaleIn .25s var(--ease-spring);}
.modal-title{font-family:var(--font-display);font-weight:700;font-size:18px;color:var(--text-primary);margin-bottom:22px;letter-spacing:-.3px;}
.modal-footer{display:flex;gap:10px;justify-content:flex-end;margin-top:26px;padding-top:18px;border-top:1px solid var(--border-subtle);}

/* ── NOTIF PANEL ── */
#notif-panel{position:fixed;top:60px;right:20px;width:336px;max-height:470px;background:var(--bg-elevated);border:1px solid var(--border-mid);border-radius:var(--r-xl);box-shadow:var(--shadow-xl);z-index:250;display:none;flex-direction:column;overflow:hidden;}
#notif-panel.open{display:flex;animation:scaleIn .2s var(--ease-spring);}
.notif-header{padding:13px 15px;border-bottom:1px solid var(--border-subtle);display:flex;justify-content:space-between;align-items:center;}
.notif-title{font-family:var(--font-display);font-size:14px;font-weight:700;color:var(--text-primary);}
#notif-list{overflow-y:auto;flex:1;}
.notif-item{display:flex;gap:11px;padding:11px 15px;cursor:pointer;transition:background .15s;border-bottom:1px solid var(--border-subtle);}
.notif-item:hover{background:var(--bg-hover);}
.notif-item.unread{background:var(--brand-dim);}
.notif-msg{font-size:12.5px;color:var(--text-primary);font-weight:500;line-height:1.4;}
.notif-time{font-size:10px;color:var(--text-muted);margin-top:3px;}
#notif-count{display:none;position:absolute;top:-5px;right:-5px;min-width:18px;height:18px;background:var(--red);color:#fff;font-size:9px;font-weight:700;border-radius:var(--r-full);align-items:center;justify-content:center;padding:0 4px;}
.skeleton{background:linear-gradient(90deg,var(--bg-card) 0%,var(--bg-elevated) 50%,var(--bg-card) 100%);background-size:200% 100%;animation:shimmer 1.5s infinite;border-radius:var(--r-md);}

/* ── AVATARES ── */
.av-1{background:#6366f1;}.av-2{background:#10b981;}.av-3{background:#f59e0b;}
.av-4{background:#ef4444;}.av-5{background:#a855f7;}.av-6{background:#06b6d4;}
.av-c1{background:linear-gradient(135deg,#6366f1,#a855f7);}
.av-c2{background:linear-gradient(135deg,#10b981,#06b6d4);}
.av-c3{background:linear-gradient(135deg,#f59e0b,#ef4444);}

/* ── MOBILE MEDIA QUERIES ── */
@media(max-width:768px){
  #sidebar{position:fixed;left:0;top:0;bottom:0;height:100%;transform:translateX(-100%);box-shadow:4px 0 24px rgba(0,0,0,.6);}
  #sidebar.open{transform:translateX(0);}
  #mobile-overlay{display:none;position:fixed;inset:0;background:rgba(0,0,0,.65);z-index:140;backdrop-filter:blur(3px);}
  #mobile-overlay.show{display:block;}
  #v-chats{position:relative;overflow:hidden;flex-direction:row !important;height:100%;}
  #contacts-panel{width:100%;min-width:100%;transition:transform .3s var(--ease);}
  #chat-main{width:100%;min-width:100%;position:absolute;top:0;left:100%;height:100%;transition:transform .3s var(--ease);z-index:10;}
  #right-panel{width:100%;min-width:100%;position:absolute;top:0;left:200%;height:100%;transition:transform .3s var(--ease);z-index:20;}
  #v-chats.mobile-chat-view #contacts-panel{transform:translateX(-100%);}
  #v-chats.mobile-chat-view #chat-main{transform:translateX(-100%);}
  #v-chats.mobile-info-view #contacts-panel{transform:translateX(-200%);}
  #v-chats.mobile-info-view #chat-main{transform:translateX(-200%);}
  #v-chats.mobile-info-view #right-panel{transform:translateX(-200%);}
  .mobile-back-btn{display:flex !important;}
  .view-body{padding:18px 14px;}
  .charts-grid{grid-template-columns:1fr;}
  .hdr-actions{display:none;}
}
@media(min-width:769px){.mobile-back-btn{display:none !important;}}
/* ══ FIX CONTRASTE TEMAS CLAROS — CHAT ══ */

/* Topbar del chat */
[data-theme*="light"] .chat-topbar {
  background: var(--bg-surface) !important;
  border-bottom: 1px solid var(--border-dim) !important;
  backdrop-filter: none !important;
}

/* Zona de input inferior */
[data-theme*="light"] #chat-input-zone {
  background: var(--bg-surface) !important;
  border-top: 1px solid var(--border-dim) !important;
  backdrop-filter: none !important;
}

/* Botones de toolbar (Plantillas, Respuesta IA) */
[data-theme*="light"] .toolbar-btn {
  background: var(--bg-card) !important;
  border-color: var(--border-mid) !important;
  color: var(--text-secondary) !important;
}
[data-theme*="light"] .toolbar-btn:hover {
  background: var(--bg-hover) !important;
  color: var(--text-primary) !important;
}
[data-theme*="light"] .toolbar-btn.ai-btn {
  background: var(--purple-dim) !important;
  color: var(--purple) !important;
  border-color: rgba(124,58,237,0.2) !important;
}
[data-theme*="light"] .toolbar-btn.ai-btn:hover {
  background: var(--purple) !important;
  color: #fff !important;
}

/* Input shell (caja de texto) */
[data-theme*="light"] .input-shell {
  background: var(--bg-card) !important;
  border-color: var(--border-mid) !important;
}
[data-theme*="light"] .input-shell:focus-within {
  border-color: var(--brand) !important;
  box-shadow: 0 0 0 3px var(--brand-dim) !important;
  background: #ffffff !important;
}
[data-theme*="light"] #chat-textarea {
  color: var(--text-primary) !important;
}
[data-theme*="light"] #chat-textarea::placeholder {
  color: var(--text-muted) !important;
}

/* Botón clip adjuntar */
[data-theme*="light"] .clip-btn {
  color: var(--text-muted) !important;
}
[data-theme*="light"] .clip-btn:hover {
  color: var(--brand) !important;
}

/* Botón micrófono/enviar */
[data-theme*="light"] #btn-mic {
  background: linear-gradient(135deg, var(--brand) 0%, var(--brand-hover) 100%) !important;
  color: #fff !important;
  box-shadow: 0 4px 14px var(--brand-glow) !important;
}

/* Burbujas de mensajes entrantes */
[data-theme*="light"] .msg-row.in .bubble {
  background: #ffffff !important;
  border-color: var(--border-mid) !important;
  color: var(--text-primary) !important;
}

/* Burbujas de mensajes salientes */
[data-theme*="light"] .msg-row.out .bubble {
  color: #ffffff !important;
}
[data-theme*="light"] .msg-row.out .bubble-time {
  color: rgba(255,255,255,0.65) !important;
}

/* Separadores de fecha */
[data-theme*="light"] .sys-separator span {
  background: var(--bg-card) !important;
  color: var(--text-muted) !important;
  border-color: var(--border-mid) !important;
}

/* Dropdown respuestas rápidas */
[data-theme*="light"] #qr-dropdown {
  background: #ffffff !important;
  border-color: var(--border-mid) !important;
}
[data-theme*="light"] .qr-item:hover {
  background: var(--bg-hover) !important;
}
[data-theme*="light"] .qr-content {
  color: var(--text-secondary) !important;
}

/* Indicador de escritura */
[data-theme*="light"] #typing-indicator {
  background: var(--brand-dim) !important;
  color: var(--brand) !important;
  border-bottom-color: var(--border-dim) !important;
}

/* Botones Transferir y Finalizar en topbar */
[data-theme*="light"] .btn-ghost {
  background: var(--bg-card) !important;
  border-color: var(--border-mid) !important;
  color: var(--text-secondary) !important;
}
[data-theme*="light"] .btn-ghost:hover {
  background: var(--bg-hover) !important;
  color: var(--text-primary) !important;
}
[data-theme*="light"] .btn-resolve {
  background: var(--green-dim) !important;
  border-color: rgba(5,150,105,0.25) !important;
  color: var(--green) !important;
}
[data-theme*="light"] .btn-resolve:hover {
  background: var(--green) !important;
  color: #fff !important;
}

/* ── PHOSPHOR ICONS DUOTONE — INTEGRACIÓN NAV ── */
.nav-item .ph-duotone {
  font-size: 18px;
  line-height: 1;
  color: inherit;
  transition: color .2s var(--ease);
}

.nav-item.active .ph-duotone {
  color: #fff;
}

/* Efecto duotone secundario más visible */
.nav-item .ph-duotone::after {
  opacity: 0.3;
}

.nav-item.active .ph-duotone::after {
  opacity: 0.6;
}