@import url('https://fonts.googleapis.com/css2?family=Inter:wght@400;450;500;600;700&display=swap');

:root{
  --bg:#ffffff; --panel:#fbfbfd; --topbar:#18181b;
  --ink:#1f2330; --muted:#656b78; --ink-3:#9aa0ad;
  --line:#ededf1; --line-2:#f4f4f7;
  --brand:#7c6cf0; --brand-600:#6a57e8; --brand-soft:#f2f0fe; --brand-100:#e7e3fd;
  --green:#10b981; --orange:#f59e0b; --red:#f43f5e; --pink:#ec4899; --wa:#25d366; --blue:#3b82f6; --teal:#0d9488; --gray:#94a3b8;
  --shadow-sm:0 1px 2px rgba(20,20,40,.05);
  --shadow:0 1px 2px rgba(20,20,40,.04),0 10px 30px rgba(20,20,40,.07);
}
body.dark{
  --bg:#16161c; --panel:#1b1b23; --topbar:#101015;
  --ink:#e9e9f0; --muted:#a5a7b4; --ink-3:#6f7180;
  --line:#2a2a35; --line-2:#21212a; --brand-soft:#241f3d; --brand-100:#2f2853;
  --shadow-sm:0 1px 2px rgba(0,0,0,.3);
  --shadow:0 1px 2px rgba(0,0,0,.3),0 10px 30px rgba(0,0,0,.45);
}

*{box-sizing:border-box;margin:0;padding:0}
html,body{height:100%}
body{font-family:'Inter',-apple-system,BlinkMacSystemFont,'Segoe UI',sans-serif;background:var(--bg);color:var(--ink);-webkit-font-smoothing:antialiased;font-size:14px;line-height:1.45}
.hidden{display:none !important}
.muted{color:var(--muted)}
.small{font-size:12.5px}

/* Botones */
button{font-family:inherit;cursor:pointer;border:none;border-radius:10px;font-size:14px;font-weight:600;background:var(--brand);color:#fff;padding:10px 16px;transition:background .15s ease,transform .04s ease}
button:hover{background:var(--brand-600)}
button:active{transform:translateY(1px)}
button.mini{padding:7px 12px;font-size:13px;border-radius:9px}
.btn-primary{background:var(--brand);color:#fff}
.ghost{background:transparent;color:var(--ink)}
.ghost:hover{background:var(--line-2)}
.icon{padding:0;width:38px;height:38px;display:inline-flex;align-items:center;justify-content:center;border-radius:10px}

/* Inputs */
input:not([type=checkbox]):not([type=radio]),textarea{font-family:inherit;font-size:14px;color:var(--ink);background:var(--bg);border:1px solid var(--line);border-radius:10px;padding:10px 12px;width:100%;outline:none;transition:border-color .15s ease,box-shadow .15s ease}
input:focus,textarea:focus{border-color:var(--brand);box-shadow:0 0 0 3px var(--brand-soft)}

/* Login */
.login-wrap{min-height:100dvh;display:flex;align-items:center;justify-content:center;padding:24px;background:var(--panel)}
.login-box{width:100%;max-width:360px;background:var(--bg);border:1px solid var(--line);border-radius:18px;padding:32px 28px;display:flex;flex-direction:column;gap:13px;box-shadow:var(--shadow)}
.login-logo{width:56px;height:56px;border-radius:16px;background:linear-gradient(160deg,#8c78f0,#6e5ce0);display:flex;align-items:center;justify-content:center}
.login-logo .dot{width:16px;height:16px;border-radius:50%;background:var(--brand)}
.login-box h1{font-size:22px;font-weight:700;letter-spacing:-.01em}
.login-err{color:var(--red);font-size:13px;min-height:16px}

/* Topbar */
.topbar{height:56px;flex-shrink:0;background:var(--bg);border-bottom:1px solid var(--line);display:flex;align-items:center;gap:14px;padding:0 16px}
.brand{display:flex;align-items:center;gap:9px;color:var(--ink);flex-shrink:0}
.brand-mark{width:30px;height:30px;border-radius:9px;background:linear-gradient(160deg,#8c78f0,#6e5ce0);display:flex;align-items:center;justify-content:center;flex:0 0 auto}
.brand-name{font-weight:700;font-size:16px;letter-spacing:-.01em;color:var(--ink)}
.brand-tld{font-size:.6em;font-weight:700;color:var(--ink-3);margin-left:1px;vertical-align:super;letter-spacing:.03em}
.topdiv{width:1px;height:20px;background:var(--line)}
.client-pill{display:flex;align-items:center;gap:7px;font-size:13px;font-weight:500;color:var(--muted);background:var(--line-2);padding:5px 11px;border-radius:8px}
.client-pill .cdot{width:7px;height:7px;border-radius:50%;background:var(--green)}
.searchwrap{flex:1;max-width:460px;margin:0 auto;position:relative}
.searchwrap .search-ico{position:absolute;left:13px;top:50%;transform:translateY(-50%);color:var(--ink-3);pointer-events:none}
.topbar .searchwrap input{width:100%;height:38px;border:1px solid transparent;border-radius:10px;background:var(--line-2);color:var(--ink);padding:0 14px 0 40px;font-size:13px}
.topbar .searchwrap input::placeholder{color:var(--ink-3)}
.topbar .searchwrap input:focus{background:var(--bg);border-color:var(--brand);box-shadow:0 0 0 3px var(--brand-soft)}
.topbar-right{margin-left:auto;display:flex;align-items:center;gap:7px}
.ticon{width:36px;height:36px;padding:0;border-radius:10px;background:transparent;color:var(--muted);display:inline-flex;align-items:center;justify-content:center}
.ticon:hover{background:var(--line-2);color:var(--ink)}
.avatar-top{width:30px;height:30px;border-radius:50%;background:linear-gradient(135deg,#f59e0b,#ef4444);display:flex;align-items:center;justify-content:center;font-weight:600;font-size:12px;color:#fff;flex:0 0 auto}
.avatar-exit{width:32px;height:32px;border-radius:50%;background:var(--red);color:#fff;display:inline-flex;align-items:center;justify-content:center;padding:0;flex:0 0 auto}
.avatar-exit:hover{background:#e11d48}
.update-btn{background:var(--brand);color:#fff;border-radius:9px;font-size:.8rem;font-weight:600;padding:7px 12px;display:inline-flex;align-items:center;gap:5px;animation:dodoPulse 2.2s infinite}
.update-btn:hover{background:var(--brand-600);animation:none}
@keyframes dodoPulse{0%{box-shadow:0 0 0 0 rgba(124,108,240,.5)}70%{box-shadow:0 0 0 8px rgba(124,108,240,0)}100%{box-shadow:0 0 0 0 rgba(124,108,240,0)}}

/* Layout */
#app{display:flex;flex-direction:column;height:100dvh}
.layout{flex:1;display:flex;min-height:0}

/* Rail */
.rail{width:232px;flex:0 0 232px;border-right:1px solid var(--line);padding:16px 12px;display:flex;flex-direction:column;gap:4px;background:var(--bg);transition:width .18s ease,flex-basis .18s ease}
.rail.collapsed{width:66px;flex:0 0 66px;padding:14px 8px}
.rail-label{font-size:11px;font-weight:600;letter-spacing:.05em;text-transform:uppercase;color:var(--ink-3);padding:10px 10px 6px}
.rail.collapsed .rail-label{display:none}
.rail-item{display:flex;align-items:center;gap:11px;padding:8px 10px;border-radius:10px;cursor:pointer;color:var(--muted);font-weight:500;font-size:13.5px;position:relative}
.rail-item:hover{background:var(--line-2)}
.rail-item.active{background:var(--brand-soft);color:var(--ink)}
.rail-item.active::before{content:"";position:absolute;left:-12px;top:7px;bottom:7px;width:3px;border-radius:0 3px 3px 0;background:var(--brand)}
#railUnread.active::before{background:var(--pink)}
#railAsesor.active::before{background:var(--red)}
.rail.collapsed .rail-item{justify-content:center;padding:9px 0;gap:0;font-size:0}
.rail.collapsed .rail-item.active::before{left:-8px}
.rail.collapsed .rail-count{display:none}
.tile{width:26px;height:26px;border-radius:7px;display:flex;align-items:center;justify-content:center;flex:0 0 auto;color:#fff}
.tile svg{width:15px;height:15px}
.t-purple{background:var(--brand)} .t-pink{background:var(--pink)} .t-red{background:var(--red)}
.t-orange{background:var(--orange)} .t-blue{background:var(--blue)} .t-teal{background:var(--teal)} .t-gray{background:var(--gray)} .t-gold{background:#eab308} .t-green{background:#16a34a}
.t-toggle{background:var(--line-2);color:var(--muted)}
.rail-toggle{margin-top:auto}
.rail-toggle:hover .t-toggle{background:var(--brand);color:#fff}
.rail-count{margin-left:auto;font-size:11px;font-weight:700;color:#fff;min-width:18px;height:18px;border-radius:6px;display:flex;align-items:center;justify-content:center;padding:0 5px}
.c-pink{background:var(--pink)} .c-red{background:var(--red)}
.rail-sep{height:1px;background:var(--line);margin:10px 8px}
.rail:not(.collapsed) .rail-item[data-tip]:hover::after,.rail:not(.collapsed) .rail-item[data-tip]:hover::before{content:none}
.rail.collapsed .rail-item[data-tip]:hover::after{content:attr(data-tip);position:absolute;top:50%;left:calc(100% + 12px);transform:translateY(-50%);background:#26262f;color:#fff;font-size:11.5px;font-weight:500;white-space:nowrap;padding:5px 9px;border-radius:7px;z-index:60;pointer-events:none;box-shadow:0 6px 18px rgba(0,0,0,.22)}
.rail.collapsed .rail-item[data-tip]:hover::before{content:"";position:absolute;top:50%;left:calc(100% + 7px);transform:translateY(-50%);border:5px solid transparent;border-right-color:#26262f;z-index:60;pointer-events:none}

/* Sidebar / lista */
.sidebar{width:340px;flex:0 0 340px;display:flex;flex-direction:column;background:var(--bg);border-right:1px solid var(--line);min-height:0}
.list-head{display:flex;align-items:center;justify-content:space-between;gap:10px;padding:18px 16px 12px}
.list-title{font-weight:700;font-size:16px;letter-spacing:-.01em}
.count-pill{font-size:12px;font-weight:600;color:var(--muted);background:var(--line-2);padding:2px 9px;border-radius:7px}
.chips{display:flex;gap:7px;padding:0 16px 12px}
.chip{font-size:12.5px;font-weight:600;color:var(--muted);background:var(--line-2);padding:6px 11px;border-radius:8px}
.chip:hover{background:var(--line)}
.chip.on{background:var(--brand);color:#fff}
.chip-n{margin-left:5px;font-weight:700;opacity:.9}

/* Contactos */
.contacts{list-style:none;padding:2px 8px 24px;display:flex;flex-direction:column;gap:4px;flex:1;overflow-y:auto;min-height:0}
.contacts .empty{padding:24px 12px;color:var(--muted);text-align:center}
.contact{display:flex;gap:12px;padding:11px 10px;border-radius:12px;cursor:pointer;position:relative;align-items:center}
.contact:hover{background:var(--line-2)}
.contact.active{background:var(--brand-soft)}
.contact.active::before{content:"";position:absolute;left:-4px;top:10px;bottom:10px;width:3px;border-radius:3px;background:var(--brand)}
.av{width:42px;height:42px;border-radius:13px;flex:0 0 auto;display:flex;align-items:center;justify-content:center;font-weight:600;font-size:14px;color:#fff;position:relative}
.ch{position:absolute;right:-4px;bottom:-4px;width:19px;height:19px;border-radius:50%;border:2px solid var(--bg);display:flex;align-items:center;justify-content:center}
.ch svg{width:11px;height:11px}
.contact.active .ch{border-color:var(--brand-soft)}
.ch.wa{background:var(--wa)}
.ch.ig{background:linear-gradient(135deg,#feda75,#fa7e1e,#d62976,#962fbf,#4f5bd5)}
.ch.ms{background:linear-gradient(135deg,#00b2ff,#006aff)}
.cmid{flex:1;min-width:0}
.crow{display:flex;align-items:center;gap:8px}
.cname{font-weight:600;font-size:14px;color:var(--ink);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.contact.unread .cname{font-weight:700}
.ctime{margin-left:auto;font-size:11.5px;color:var(--ink-3);flex:0 0 auto}
.cprev{font-size:13px;color:var(--muted);margin-top:2px;display:flex;align-items:center;gap:6px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.cnum{overflow:hidden;text-overflow:ellipsis}
.pill{font-size:11px;font-weight:600;padding:2px 8px;border-radius:6px;flex:0 0 auto}
.pill.asesor{background:#fff0f1;color:#e11d48}
.pill.cotiz{background:#fff0f1;color:#e11d48}
.pill.ia{background:#e9fbf3;color:#059669}
body.dark .pill.asesor{background:rgba(244,63,94,.16);color:#fb7185}
body.dark .pill.cotiz{background:rgba(244,63,94,.16);color:#fb7185}
body.dark .pill.ia{background:rgba(16,185,129,.16);color:#34d399}
.unread-dot{margin-left:auto;width:9px;height:9px;border-radius:50%;background:var(--pink);flex:0 0 auto}

/* Chat */
.chat-pane{flex:1;display:flex;min-width:0;background:var(--panel)}
.chat-empty{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:12px;color:var(--muted);background:var(--panel);padding:24px;text-align:center}
.chat-box{flex:1;width:100%;min-width:0;display:flex;flex-direction:column;overflow:hidden}
.chat-head{display:flex;align-items:center;gap:11px;padding:11px 16px;border-bottom:1px solid var(--line);background:var(--bg)}
.chat-av{width:40px;height:40px;border-radius:12px;background:linear-gradient(135deg,#fb7185,#ef4444);display:flex;align-items:center;justify-content:center;color:#fff;font-weight:600;font-size:14px;flex:0 0 auto}
.chat-title{flex:1;display:flex;flex-direction:column;gap:1px;overflow:hidden}
#chatName{font-weight:600;font-size:15px;color:var(--ink)}
.chat-head-right{display:flex;align-items:center;gap:8px;flex-shrink:0}
.state-pill{font-size:12px;font-weight:600;padding:5px 10px;border-radius:8px}
.state-pill.ok{background:#e9fbf3;color:#059669}
.state-pill.alert{background:#fff0f1;color:#e11d48}
body.dark .state-pill.ok{background:rgba(16,185,129,.16);color:#34d399}
body.dark .state-pill.alert{background:rgba(244,63,94,.16);color:#fb7185}
.chat-messages{flex:1;overflow-y:auto;padding:20px 18px;display:flex;flex-direction:column;gap:10px;background:var(--panel)}
.chat-messages .empty{margin:auto;color:var(--muted)}
.msg{max-width:74%;padding:9px 13px;border-radius:14px;font-size:14px;line-height:1.5;display:flex;flex-direction:column;gap:3px;box-shadow:var(--shadow-sm)}
.msg.in{align-self:flex-start;background:var(--bg);border:1px solid var(--line);border-bottom-left-radius:5px;color:var(--ink)}
.msg.out{align-self:flex-end;background:var(--brand);color:#fff;border-bottom-right-radius:5px}
.msg-by{font-size:10.5px;font-weight:700}
.msg.in .msg-by{color:var(--brand)}
.msg.out .msg-by{color:#ece9ff}
.msg-text{white-space:pre-wrap;word-break:break-word}
.msg-ts{font-size:10px;align-self:flex-end}
.msg.in .msg-ts{color:var(--ink-3)}
.msg.out .msg-ts{color:#ece9ff;opacity:.85}
.chat-input{display:flex;gap:10px;padding:14px;border-top:1px solid var(--line);align-items:center;background:var(--bg)}
.chat-input #chatText{flex:1}
.send-btn{width:46px;height:46px;padding:0;border-radius:50%;background:var(--brand);color:#fff;display:inline-flex;align-items:center;justify-content:center;flex-shrink:0}
.send-btn:hover{background:var(--brand-600)}

/* Modales */
.modal{position:fixed;inset:0;background:rgba(10,12,20,.45);display:flex;align-items:flex-start;justify-content:center;padding:5vh 16px;z-index:70;overflow-y:auto}
.modal-box{background:var(--bg);border-radius:18px;padding:24px;width:100%;max-width:440px;display:flex;flex-direction:column;gap:13px;box-shadow:var(--shadow);max-height:90vh;overflow-y:auto}
.modal-head{display:flex;align-items:center;justify-content:space-between;position:sticky;top:0;background:var(--bg);padding-bottom:2px}
.modal-head span{font-weight:700;font-size:16px}
.section-label{font-size:11px;font-weight:700;letter-spacing:.05em;text-transform:uppercase;color:var(--ink-3);margin-top:2px}
.sep{border:none;border-top:1px solid var(--line);margin:4px 0}
.row-end{display:flex;justify-content:flex-end}
.radio{display:flex;align-items:center;gap:9px;font-size:14px;cursor:pointer}
.list-add{display:flex;gap:8px}
.list-add input{flex:1}
.num-list{display:flex;flex-wrap:wrap;gap:8px}
.num-chip{display:inline-flex;align-items:center;gap:7px;background:var(--line-2);border-radius:9px;padding:6px 10px;font-size:13px}
.num-x{background:transparent;color:var(--muted);padding:0;width:18px;height:18px;border-radius:50%;font-size:16px;line-height:1;display:inline-flex;align-items:center;justify-content:center}
.num-x:hover{background:var(--red);color:#fff}
.switch{display:flex;align-items:center;gap:9px;font-size:14px;font-weight:600;cursor:pointer}
.preset-row{display:flex;flex-wrap:wrap;gap:8px}
.sched-days{display:flex;flex-direction:column;gap:8px}
.sched-row{display:flex;align-items:center;justify-content:space-between;gap:10px;flex-wrap:wrap}
.sched-day{display:flex;align-items:center;gap:8px;font-size:14px;min-width:130px}
.sched-times{display:flex;align-items:center;gap:6px}
.sched-times input[type=time]{width:auto}

/* Toast / menú contextual */
.toast{position:fixed;bottom:22px;left:50%;transform:translateX(-50%);background:#26262f;color:#fff;padding:10px 16px;border-radius:10px;font-size:13.5px;z-index:80;box-shadow:var(--shadow)}
.ctx-menu{position:fixed;background:var(--bg);border:1px solid var(--line);border-radius:10px;box-shadow:var(--shadow);padding:5px;z-index:90}
.ctx-menu button{display:block;width:100%;text-align:left;background:transparent;color:var(--ink);padding:8px 12px;border-radius:7px;font-weight:500}
.ctx-menu button:hover{background:var(--line-2)}

/* Responsive */
@media (max-width:900px){.searchwrap{display:none}}
@media (max-width:760px){
  .rail{display:none}
  .sidebar{width:100%;flex:1;border-right:none}
  .layout{position:relative;overflow:hidden}
  .chat-pane{position:absolute;inset:0;transform:translateX(100%);transition:transform .22s ease;z-index:5}
  body.chat-open .chat-pane{transform:translateX(0)}
}
@media (min-width:761px){#chatBack{display:none}}

/* Encuesta de satisfacción (CSAT) */
.survey-stats{display:flex;flex-direction:column;gap:8px;margin-top:4px}
.srv-head{display:flex;align-items:baseline;gap:8px;margin-bottom:8px}
.srv-avg{font-size:34px;font-weight:700;line-height:1;color:var(--brand)}
.srv-row{display:flex;align-items:center;gap:10px}
.srv-star{width:28px;font-size:13px;color:var(--muted);text-align:right;flex:0 0 auto}
.srv-bar{flex:1;height:9px;border-radius:5px;background:var(--line-2);overflow:hidden}
.srv-fill{display:block;height:100%;background:var(--brand);border-radius:5px}
.srv-n{width:24px;text-align:right;font-size:13px;color:var(--ink);flex:0 0 auto}

/* Cotizador · editor de lista de precios */
.pl-rows{display:flex;flex-direction:column;gap:8px;margin:10px 0}
.pl-row{display:flex;align-items:center;gap:8px}
.pl-name{flex:1;min-width:0;padding:9px 11px;border:1px solid var(--line);border-radius:9px;background:var(--bg);color:var(--ink);font-size:14px}
.pl-price{display:flex;align-items:center;gap:4px;border:1px solid var(--line);border-radius:9px;background:var(--bg);padding:0 10px;width:120px;flex:0 0 auto}
.pl-sign{color:var(--muted);font-size:14px}
.pl-amount{width:100%;border:none;background:transparent;color:var(--ink);font-size:14px;padding:9px 0;outline:none}
.pl-del{flex:0 0 auto;width:30px;height:30px;border:none;border-radius:8px;background:var(--line-2);color:var(--muted);cursor:pointer;font-size:14px}
.pl-del:hover{background:var(--red);color:#fff}
.pl-actions{display:flex;align-items:center;gap:12px;margin-top:12px}

/* Cotizador · datos de la empresa */
.ql-label{font-size:13px;font-weight:600;color:var(--ink);margin:2px 0 2px}
.ql-sep{height:1px;background:var(--line);margin:16px 0}
.biz-grid{display:grid;grid-template-columns:1fr 1fr;gap:8px;margin:8px 0 2px}
.biz-in{padding:9px 11px;border:1px solid var(--line);border-radius:9px;background:var(--bg);color:var(--ink);font-size:14px;width:100%;box-sizing:border-box}
.biz-in:focus{outline:none;border-color:var(--brand)}
.biz-wide{grid-column:1 / -1}
@media(max-width:520px){.biz-grid{grid-template-columns:1fr}}

/* Cotizador · lista de solicitudes + editor */
.quotes-box{max-width:560px}
.qhead-actions{display:flex;gap:8px;align-items:center}
.q-list{display:flex;flex-direction:column;gap:6px;margin-top:8px;max-height:62vh;overflow:auto}
.q-row{display:flex;align-items:center;justify-content:space-between;gap:10px;padding:11px 12px;border:1px solid var(--line);border-radius:11px;cursor:pointer;background:var(--bg)}
.q-row:hover{background:var(--line-2)}
.q-row-main{display:flex;flex-direction:column;gap:2px;min-width:0}
.q-num{font-size:12px;color:var(--muted);font-weight:600}
.q-who{font-size:14px;color:var(--ink);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:330px}
.q-badge{font-size:11px;font-weight:600;padding:3px 9px;border-radius:999px;flex:0 0 auto}
.qs-pending{background:#fee2e2;color:#b91c1c}
.qs-draft{background:var(--line-2);color:var(--muted)}
.qs-sent{background:#dcfce7;color:#15803d}
.qs-rej{background:#f3f4f6;color:#9ca3af}
.q-items-head{display:grid;grid-template-columns:1fr 56px 92px 84px 30px;gap:6px;font-size:11px;color:var(--muted);margin:6px 0 4px;padding:0 2px}
.q-items{display:flex;flex-direction:column;gap:6px}
.q-item{display:grid;grid-template-columns:1fr 56px 92px 84px 30px;gap:6px;align-items:center}
.qi-desc,.qi-qty,.qi-price{padding:8px 9px;border:1px solid var(--line);border-radius:8px;background:var(--bg);color:var(--ink);font-size:14px;width:100%;box-sizing:border-box}
.qi-desc:focus,.qi-qty:focus,.qi-price:focus{outline:none;border-color:var(--brand)}
.qi-qty,.qi-price{text-align:right}
.qi-tot{font-size:13px;text-align:right;color:var(--ink)}
.q-totals{margin:14px 0 2px;display:flex;flex-direction:column;gap:4px;align-items:flex-end}
.q-trow{display:flex;gap:14px;font-size:14px;color:var(--muted)}
.q-trow b{color:var(--ink);min-width:96px;text-align:right}
.q-total{font-size:17px;font-weight:700;margin-top:4px}
.q-total span,.q-total b{color:var(--ink)}
.q-actions{display:flex;align-items:center;gap:10px;margin-top:16px;flex-wrap:wrap}
.q-actions .primary{margin-left:auto}
.ghost.danger{color:#dc2626;border-color:#f1c0c0}
.ghost.danger:hover{background:#fee2e2}
#qReqNote{margin-top:6px}

/* Cotizador · subir logo */
.logo-row{display:flex;align-items:center;gap:14px;margin:8px 0 2px}
.logo-prev{width:120px;height:64px;border:1px dashed var(--line);border-radius:10px;display:flex;align-items:center;justify-content:center;background:var(--line-2);overflow:hidden;flex:0 0 auto}
.logo-prev img{max-width:100%;max-height:100%;object-fit:contain}
.logo-btns{display:flex;flex-direction:column;gap:6px;align-items:flex-start}

/* Cotizador · filtros de la lista */
.q-filters{display:flex;gap:7px;margin:10px 0 4px}
.q-chip{font-size:12px;padding:5px 12px;border-radius:999px;border:1px solid var(--line);background:var(--bg);color:var(--muted);cursor:pointer}
.q-chip.on{background:var(--brand);border-color:var(--brand);color:#fff}

/* Señales visuales en la lista de conversaciones */
.contact.unread:not(.alert):not(.quote) .av{box-shadow:0 0 0 3px var(--brand-100),0 0 11px rgba(124,108,240,.45)}
.contact.quote .av{animation:asesorPulse 1.7s ease-in-out infinite}
.contact.alert .av{animation:asesorPulse 1.7s ease-in-out infinite}
@keyframes asesorPulse{
  0%,100%{box-shadow:0 0 0 3px rgba(239,68,68,.22),0 0 0 0 rgba(239,68,68,.5)}
  50%{box-shadow:0 0 0 3px rgba(239,68,68,.22),0 0 0 7px rgba(239,68,68,0)}
}

/* Puntito rojo de cotizaciones: visible aun con la barra colapsada */
#quotesCount{position:absolute;top:2px;right:6px;margin:0;min-width:17px;height:17px;font-size:10px;border:2px solid var(--panel);z-index:2}
.rail.collapsed #quotesCount{display:flex;top:2px;right:2px}
.rail.collapsed #quotesCount.hidden{display:none}

/* Píldora verde: cotización enviada */
.pill.qsent{background:#e7f7ee;color:#15803d}
body.dark .pill.qsent{background:rgba(34,197,94,.16);color:#4ade80}

/* Toggle enviar automáticamente (config cotización) */
.auto-send-row{display:flex;gap:10px;align-items:flex-start;margin:4px 0 12px;cursor:pointer}
.auto-send-row input{margin-top:3px;width:16px;height:16px;flex:0 0 auto;cursor:pointer}

/* Selector de fuente de la lista de precios (manual / archivo) */
.pl-source{display:flex;gap:6px;margin:6px 0 10px}
.pl-seg{flex:1;padding:8px;border:1px solid var(--line,#e5e7eb);background:transparent;border-radius:8px;cursor:pointer;font-size:13px;color:var(--muted,#6b7280)}
.pl-seg.active{background:var(--brand-100,#ede9fe);border-color:var(--brand,#7c6cf0);color:var(--brand,#7c6cf0);font-weight:600}
#plFileBox input[type=file]{margin-top:4px;font-size:13px}

/* Paleta para editar color de los iconos del rail */
.color-pop{position:fixed;z-index:9999;background:var(--panel,#fff);border:1px solid var(--line,#e5e7eb);border-radius:12px;padding:10px;box-shadow:0 12px 32px rgba(0,0,0,.18);width:168px}
.color-pop-title{font-size:12px;color:var(--muted,#6b7280);margin-bottom:8px;font-weight:600}
.color-pop-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:8px}
.color-sw{width:24px;height:24px;border-radius:50%;border:2px solid #fff;box-shadow:0 0 0 1px rgba(0,0,0,.12);cursor:pointer;padding:0;transition:transform .1s}
.color-sw:hover{transform:scale(1.15)}
.color-reset{margin-top:10px;width:100%;font-size:12px;color:var(--muted,#6b7280);background:transparent;border:1px solid var(--line,#e5e7eb);border-radius:8px;padding:6px;cursor:pointer}
.color-reset:hover{background:rgba(0,0,0,.05)}
