/* :root tokens moved to tokens.css — single source of truth */
*{margin:0;padding:0;box-sizing:border-box;-webkit-tap-highlight-color:transparent}
body{font-family:-apple-system,BlinkMacSystemFont,'SF Pro Display','SF Pro Text','Segoe UI','Helvetica Neue',sans-serif;background:var(--bg);color:var(--t1);font-size:14px;overflow:hidden;height:100dvh;position:fixed;width:100%;letter-spacing:-.01em}
body::before{content:'';position:fixed;inset:0;background:radial-gradient(ellipse at 15% 0%,var(--primary-a6) 0%,transparent 55%),radial-gradient(ellipse at 85% 100%,var(--info-subtle) 0%,transparent 45%);pointer-events:none;z-index:0}
a{color:var(--acc2);text-decoration:none}
input,select,textarea,button{font-family:inherit;font-size:14px}
input,select,textarea{background:var(--glass2);border:1px solid var(--brd2);color:var(--t1);border-radius:12px;padding:10px 14px;width:100%;outline:none;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);transition:border-color .2s,box-shadow .2s}
input:focus,select:focus,textarea:focus{border-color:var(--primary-a40);box-shadow:0 0 0 3px var(--primary-a8)}
input::placeholder,textarea::placeholder{color:var(--t3)}
button{cursor:pointer;border:none;border-radius:12px;padding:10px 16px;transition:all .2s}

/* SVG Icons */
.i{display:inline-flex;width:18px;height:18px;align-items:center;justify-content:center;flex-shrink:0}
.i svg{width:18px;height:18px;stroke:currentColor;fill:none;stroke-width:1.8;stroke-linecap:round;stroke-linejoin:round}
.bnav .i svg{width:22px;height:22px;stroke-width:1.6}

/* Login */
#login-screen{position:fixed;inset:0;background:var(--bg);display:flex;align-items:center;justify-content:center;z-index:1000}
#login-screen::before{content:'';position:absolute;inset:0;background:radial-gradient(circle at 50% 30%,var(--primary-a12) 0%,transparent 50%),radial-gradient(circle at 50% 80%,var(--info-subtle) 0%,transparent 40%)}
.login-box{background:var(--glass);backdrop-filter:blur(40px);-webkit-backdrop-filter:blur(40px);border:1px solid var(--brd2);border-radius:var(--r3);padding:40px 28px;width:360px;max-width:92vw;text-align:center;box-shadow:var(--sh2);position:relative}
.login-box h1{font-size:26px;font-weight:700;margin-bottom:4px;background:linear-gradient(135deg,var(--acc2),var(--cyn));-webkit-background-clip:text;-webkit-text-fill-color:transparent;letter-spacing:-.03em}
.login-box p{color:var(--t3);margin-bottom:24px;font-size:12px;letter-spacing:.02em}
.login-box input[type="text"],.login-box input[type="password"],.login-box input[type="email"]{margin-bottom:12px;border-radius:14px;padding:14px 16px;width:100%;box-sizing:border-box}
.pw-field{position:relative;margin-bottom:12px}
.pw-field input{margin-bottom:0 !important;padding-right:48px !important}
.pw-toggle{position:absolute;right:8px;top:50%;transform:translateY(-50%);width:36px;height:36px;display:flex;align-items:center;justify-content:center;padding:0;background:none;border:none;border-radius:8px;color:var(--t3);font-size:18px;cursor:pointer;box-shadow:none;transition:background .15s}
.pw-toggle:hover{background:var(--border-hover)}
.login-check{display:flex;align-items:center;gap:8px;margin:8px 0 14px;cursor:pointer;font-size:12px;color:var(--t2);justify-content:flex-start}
.login-check input[type="checkbox"]{width:18px;height:18px;accent-color:var(--acc);margin:0;padding:0;flex-shrink:0}
.login-submit{width:100%;padding:16px;background:linear-gradient(135deg,var(--acc),var(--primary-active));color:var(--text-on-primary);font-weight:600;font-size:15px;border-radius:16px;box-shadow:var(--sh-acc);letter-spacing:.01em;border:none;cursor:pointer}
.login-submit:active{transform:scale(.98)}
.login-box .err{color:var(--red);font-size:12px;margin-top:8px}

/* App */
.app{display:none;height:100dvh;flex-direction:column;position:relative;z-index:1}.app.show{display:flex}
.topbar{background:var(--glass);backdrop-filter:blur(var(--blur));-webkit-backdrop-filter:blur(var(--blur));border-bottom:1px solid var(--brd);display:flex;align-items:center;justify-content:space-between;padding:0 20px;height:52px;flex-shrink:0;z-index:10}
.topbar h1{font-size:15px;font-weight:700;letter-spacing:-.02em;background:linear-gradient(135deg,var(--acc2),var(--cyn));-webkit-background-clip:text;-webkit-text-fill-color:transparent}
.topbar .ui{display:flex;align-items:center;gap:10px;font-size:12px;color:var(--t2)}
.topbar .ui button{background:var(--glass2);color:var(--t2);font-size:11px;padding:8px 14px;border-radius:10px;border:1px solid var(--brd);font-weight:500;backdrop-filter:blur(8px)}
.topbar .ui button:hover{background:var(--bg4);color:var(--t1)}
.sidebar{display:none;background:var(--glass);backdrop-filter:blur(var(--blur));-webkit-backdrop-filter:blur(var(--blur));border-right:1px solid var(--brd);padding:10px 8px;flex-direction:column;gap:1px;width:210px;flex-shrink:0;overflow-y:auto}
.content-area{display:flex;flex:1;overflow:hidden}
.main{flex:1;overflow-y:auto;padding:20px;padding-bottom:calc(76px + var(--safe-b));-webkit-overflow-scrolling:touch}
.pg{display:none}.pg.act{display:block}
.ph{margin-bottom:20px}.ph h2{font-size:22px;font-weight:700;letter-spacing:-.03em;margin-bottom:2px}.ph p{color:var(--t3);font-size:12px;font-weight:500}

/* Bottom nav */
.bnav{display:flex;background:var(--glass);backdrop-filter:blur(var(--blur));-webkit-backdrop-filter:blur(var(--blur));border-top:1px solid var(--brd);padding:4px 6px calc(4px + var(--safe-b));flex-shrink:0;z-index:10;gap:2px}
.bnav .bi{flex:1;display:flex;flex-direction:column;align-items:center;padding:6px 0 4px;color:var(--t3);font-size:9px;gap:2px;cursor:pointer;border-radius:12px;transition:all .2s;font-weight:500;letter-spacing:.02em}
.bnav .bi:active{transform:scale(.92)}
.bnav .bi.act{color:var(--acc2);background:var(--primary-a8)}
.bnav .bi .ico{font-size:20px;line-height:1}

/* Sidebar items */
.ni{display:flex;align-items:center;gap:10px;padding:10px 14px;border-radius:12px;color:var(--t2);cursor:pointer;font-size:13px;font-weight:500;transition:all .15s}
.ni:hover{background:var(--border-subtle);color:var(--t1)}
.ni.act{background:var(--primary-a12);color:var(--acc2)}
.ni .icon{font-size:16px;width:22px;text-align:center}
.sidebar .sep{height:1px;background:var(--brd);margin:6px 4px}

/* Cards grid */
.cg{display:grid;grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:14px;margin-bottom:18px}
.cs{background:var(--glass);backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);border:1px solid var(--brd2);border-radius:var(--r2);padding:18px;box-shadow:var(--sh);transition:transform .2s,box-shadow .2s}
.cs:hover{transform:translateY(-1px);box-shadow:var(--sh2)}
.cs h3{font-size:12px;color:var(--t3);margin-bottom:10px;font-weight:600;text-transform:uppercase;letter-spacing:.06em}
.stat-val{font-size:30px;font-weight:800;margin-bottom:2px;letter-spacing:-.04em}.stat-lbl{font-size:10px;color:var(--t3);text-transform:uppercase;letter-spacing:.06em;font-weight:600}

/* Pipeline */
.pipeline{display:flex;gap:5px;overflow-x:auto;padding:4px 0;margin-bottom:16px;-webkit-overflow-scrolling:touch}
.pipe-s{flex:0 0 auto;padding:8px 14px;background:var(--glass2);backdrop-filter:blur(8px);border-radius:12px;cursor:pointer;text-align:center;min-width:76px;border:1px solid var(--brd);transition:all .2s}
.pipe-s:hover{border-color:var(--primary-a30);background:var(--primary-a6)}.pipe-n{font-size:9px;color:var(--t3);white-space:nowrap;font-weight:500}.pipe-c{font-size:18px;font-weight:800}

/* Tables */
table{width:100%;border-collapse:collapse}
th{text-align:left;padding:10px 8px;font-size:10px;color:var(--t3);text-transform:uppercase;letter-spacing:.06em;border-bottom:1px solid var(--brd);position:sticky;top:0;background:var(--bg-base);font-weight:600;backdrop-filter:blur(8px)}
td{padding:10px 8px;border-bottom:1px solid var(--brd)}
tr{transition:background .15s}tr:hover{background:var(--border-subtle)}.nm{font-weight:600}.mt{color:var(--t2);font-size:12px}

/* Badges */
.bd{display:inline-block;padding:3px 10px;border-radius:20px;font-size:10px;font-weight:600;letter-spacing:.02em}
.bd-nuevo{background:var(--primary-a8);color:var(--acc2)}.bd-contactado{background:var(--info-subtle);color:var(--cyn)}.bd-respondido{background:var(--success-subtle);color:var(--grn)}.bd-interesado{background:var(--warning-subtle);color:var(--ylw)}.bd-reunion{background:var(--orange-subtle);color:var(--org)}.bd-propuesta{background:var(--pink-subtle);color:var(--pink)}.bd-negociacion{background:var(--primary-a8);color:var(--acc2)}.bd-pago_pendiente{background:var(--warning-subtle);color:var(--ylw)}.bd-cliente{background:var(--success-subtle);color:var(--grn)}.bd-proyecto{background:var(--info-subtle);color:var(--cyn)}.bd-completado{background:var(--success-subtle-strong);color:var(--grn)}.bd-descartado{background:var(--danger-subtle);color:var(--red)}.bd-no_responde{background:var(--muted-subtle);color:var(--t3)}

/* Buttons */
.btn{padding:10px 18px;border-radius:12px;font-weight:600;font-size:13px;transition:all .2s;display:inline-flex;align-items:center;gap:6px;letter-spacing:.01em}
.btn:active{transform:scale(.97)}
.btn-p{background:linear-gradient(135deg,var(--acc),var(--primary-active));color:var(--text-on-primary);box-shadow:0 2px 12px var(--primary-a25)}
.btn-p:hover{box-shadow:0 4px 20px var(--primary-a30);transform:translateY(-1px)}
.btn-g{background:linear-gradient(135deg,var(--grn),var(--success-bold));color:var(--text-on-warning);box-shadow:0 2px 12px var(--success-border)}
.btn-c{background:linear-gradient(135deg,var(--cyn),var(--info-bold));color:var(--text-on-warning);box-shadow:0 2px 12px var(--info-border)}
.btn-o{background:linear-gradient(135deg,var(--org),var(--orange-500));color:var(--text-on-primary);box-shadow:0 2px 12px var(--orange-border)}
.btn-sm{padding:7px 12px;font-size:11px;border-radius:10px}
.btn-gh{background:var(--glass2);color:var(--t2);border:1px solid var(--brd);backdrop-filter:blur(8px)}
.btn-gh:hover{background:var(--bg4);color:var(--t1);border-color:var(--brd2)}
.ab{background:var(--glass2);color:var(--t2);padding:7px 12px;border-radius:10px;font-size:13px;border:1px solid var(--brd);cursor:pointer;transition:all .2s;font-weight:500;backdrop-filter:blur(8px)}
.ab:hover{background:var(--bg4);color:var(--t1)}.ab:active{transform:scale(.96)}

/* Filters */
.filters{display:flex;gap:6px;flex-wrap:wrap;margin-bottom:14px}
.fb{background:var(--glass2);color:var(--t2);padding:7px 14px;border-radius:20px;cursor:pointer;font-size:11px;border:1px solid var(--brd);white-space:nowrap;transition:all .2s;font-weight:500;backdrop-filter:blur(8px)}
.fb.act{background:var(--primary-a18);color:var(--acc2);border-color:var(--primary-a30)}.fb:active{transform:scale(.96)}
.scb{display:flex;align-items:center;gap:6px}.scn{font-weight:700;font-size:14px;min-width:18px}
.sct{width:40px;height:5px;background:var(--bg);border-radius:3px;overflow:hidden}.scf{height:100%;border-radius:3px}

/* Drawers */
.drawer-ov{position:fixed;inset:0;background:var(--overlay-dim);backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px);z-index:100;display:none}.drawer-ov.show{display:block}
.drawer{position:fixed;right:-100%;top:0;bottom:0;width:100%;max-width:520px;background:var(--glass);backdrop-filter:blur(40px);-webkit-backdrop-filter:blur(40px);border-left:1px solid var(--brd);z-index:101;transition:.3s cubic-bezier(.16,1,.3,1);overflow-y:auto;padding:20px;-webkit-overflow-scrolling:touch}
.drawer.show{right:0}
.drawer .close{position:sticky;top:0;right:0;float:right;background:var(--glass2);border:1px solid var(--brd);color:var(--t2);width:34px;height:34px;border-radius:50%;cursor:pointer;font-size:15px;z-index:5;transition:all .2s;display:flex;align-items:center;justify-content:center}
.drawer .close:hover{background:var(--bg4);color:var(--t1)}
.d-header{margin-bottom:14px;padding-right:40px}.d-header h3{font-size:18px;margin-bottom:4px;font-weight:700;letter-spacing:-.02em}
.d-tabs{display:flex;gap:4px;margin-bottom:14px;overflow-x:auto;padding-bottom:8px;border-bottom:1px solid var(--brd);-webkit-overflow-scrolling:touch}
.d-tab{padding:8px 14px;border-radius:10px;cursor:pointer;font-size:12px;color:var(--t3);white-space:nowrap;flex-shrink:0;transition:all .2s;font-weight:500}
.d-tab:hover{color:var(--t2);background:var(--border-subtle)}
.d-tab.act{background:var(--primary-a12);color:var(--acc2)}
.d-tab-content{display:none}.d-tab-content.act{display:block}
.biz-section{margin-bottom:16px;border:1px solid var(--brd);border-radius:var(--r);padding:14px;background:var(--glass2);backdrop-filter:blur(8px)}
.biz-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px;cursor:pointer;font-size:13px;font-weight:700;color:var(--acc2)}
.biz-count{display:inline-block;background:var(--primary-a12);color:var(--acc2);padding:2px 8px;border-radius:12px;font-size:10px;margin-left:4px;font-weight:600}
.csb.act{background:var(--acc)!important;color:var(--text-on-primary)!important}
.tc-contact:hover{background:var(--border-subtle)}.tc-contact.act{background:var(--primary-a6)}
.inbox-fb.act{background:var(--primary-a18)!important;color:var(--acc2)!important;border-color:var(--primary-a30)!important}

/* ═══ Messaging Module — Base CSS (patch v36.1) ═══ */
.msg-bar{display:flex;justify-content:space-between;align-items:center;padding:10px 0;margin-bottom:12px;gap:8px;flex-wrap:wrap}
.msg-seg{display:flex;gap:4px;background:var(--glass2);border-radius:12px;padding:3px;border:1px solid var(--brd)}
.msg-seg-btn{padding:8px 16px;border-radius:10px;font-size:12px;font-weight:600;color:var(--t3);background:transparent;border:none;cursor:pointer;transition:all .2s;font-family:inherit;display:flex;align-items:center;gap:6px;white-space:nowrap}
.msg-seg-btn:hover{color:var(--t2);background:var(--border-subtle)}
.msg-seg-btn.act{background:var(--primary-a15);color:var(--acc2);box-shadow:0 1px 4px rgba(var(--shadow-color),.15)}
.msg-seg-badge{font-size:9px;padding:1px 6px;border-radius:10px;font-weight:700;display:none}
.msg-seg-badge.inbox{background:var(--primary-a15);color:var(--acc2)}
.msg-seg-badge.team{background:var(--info-subtle);color:var(--cyn)}
.msg-panel{display:flex;gap:0;border:1px solid var(--brd);border-radius:var(--r);overflow:hidden;background:var(--glass)}
.ix-sidebar{width:340px;flex-shrink:0;display:flex;flex-direction:column;background:var(--glass);border-right:1px solid var(--brd);overflow:hidden}
.ix-sidebar-top{padding:10px;display:flex;flex-direction:column;gap:8px;border-bottom:1px solid var(--brd);flex-shrink:0}
.ix-filters{display:flex;gap:4px;flex-wrap:wrap}
.ix-filter{padding:5px 10px;border-radius:8px;font-size:10px;font-weight:600;color:var(--t3);background:transparent;border:1px solid var(--brd);cursor:pointer;transition:all .15s;font-family:inherit;white-space:nowrap}
.ix-filter:hover{color:var(--t2);border-color:var(--brd2)}
.ix-filter.act{background:var(--primary-a12);color:var(--acc2);border-color:var(--primary-a25)}
.ix-search-wrap{display:flex;align-items:center;gap:6px;padding:0 10px;background:var(--glass2);border-radius:8px;height:32px;border:1px solid var(--brd)}
.ix-search-wrap input{flex:1;background:transparent;border:none;padding:4px 0;font-size:12px;color:var(--t1);outline:none}
.ix-list{flex:1;overflow-y:auto;-webkit-overflow-scrolling:touch}
.ix-list::-webkit-scrollbar{width:3px}.ix-list::-webkit-scrollbar-thumb{background:var(--brd2);border-radius:3px}
.ix-thread{display:flex;align-items:center;gap:10px;padding:10px 12px;cursor:pointer;transition:all .15s;border-bottom:1px solid var(--border-subtle);position:relative}
.ix-thread:hover{background:var(--primary-a4)}
.ix-thread.act{background:var(--primary-a8);border-left:3px solid var(--acc)}
.ix-avatar{width:38px;height:38px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:700;flex-shrink:0;position:relative}
.ix-ch-dot{position:absolute;bottom:-1px;right:-1px;width:14px;height:14px;border-radius:50%;display:flex;align-items:center;justify-content:center;border:2px solid var(--bg)}
.ix-ch-dot svg{width:8px;height:8px;stroke:var(--text-on-primary);fill:none;stroke-width:3}
.ix-info{flex:1;min-width:0;overflow:hidden}
.ix-name{font-size:13px;font-weight:600;color:var(--t1);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.ix-preview{font-size:11px;color:var(--t3);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;margin-top:2px}
.ix-meta{display:flex;align-items:center;gap:6px;margin-top:3px}
.ix-badge{font-size:9px;padding:1px 6px;border-radius:6px;font-weight:600}
.ix-time{font-size:10px;color:var(--t3);text-align:right;flex-shrink:0;display:flex;flex-direction:column;align-items:flex-end;gap:4px}
.ix-unread{background:var(--acc);color:var(--text-on-primary);font-size:9px;padding:2px 6px;border-radius:10px;font-weight:700;min-width:18px;text-align:center}
.ix-detail{flex:1;display:flex;flex-direction:column;min-width:0;background:var(--bg)}
.ix-detail-header{display:flex;justify-content:space-between;align-items:center;padding:10px 16px;border-bottom:1px solid var(--brd);min-height:48px;flex-shrink:0;background:var(--glass);gap:8px}
.ix-detail-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;flex:1;padding:40px;text-align:center}
.ix-input-bar{display:flex;align-items:center;gap:6px;padding:8px 12px;border-top:1px solid var(--brd);background:var(--glass);flex-shrink:0}
.ix-send-btn{width:36px;height:36px;border-radius:50%;background:var(--acc);color:var(--text-on-primary);border:none;display:flex;align-items:center;justify-content:center;cursor:pointer;flex-shrink:0;transition:all .15s;box-shadow:0 2px 8px var(--primary-a25)}
.ix-send-btn:hover{background:var(--primary-active);transform:scale(1.05)}
.ix-send-btn:active{transform:scale(.95)}
.ix-send-btn svg{width:16px;height:16px;stroke:var(--text-on-primary);fill:none;stroke-width:2;stroke-linecap:round;stroke-linejoin:round}
.ix-icon-btn{width:32px;height:32px;border-radius:8px;display:flex;align-items:center;justify-content:center;background:var(--glass2);border:1px solid var(--brd);color:var(--t3);cursor:pointer;font-size:14px;transition:all .15s;flex-shrink:0}
.ix-icon-btn:hover{background:var(--bg4);color:var(--t1)}
.tc-sidebar{width:220px;flex-shrink:0;display:flex;flex-direction:column;background:var(--glass);border-right:1px solid var(--brd);overflow-y:auto}
.tc-sidebar-label{padding:10px 14px 4px;font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:var(--t3)}
.tc-list{display:flex;flex-direction:column}
.tc-item{padding:6px 14px;font-size:12px;color:var(--t2);cursor:pointer;transition:all .15s;border-radius:6px;margin:1px 6px;display:flex;align-items:center;gap:6px}
.tc-item:hover{background:var(--border-subtle);color:var(--t1)}
.tc-item.act{background:var(--primary-a8);color:var(--acc2)}
.tc-detail{flex:1;display:flex;flex-direction:column;min-width:0}
.tc-header{display:flex;justify-content:space-between;align-items:center;padding:10px 16px;border-bottom:1px solid var(--brd);flex-shrink:0}
.tc-title{font-size:14px;font-weight:700;color:var(--t1)}
.tc-subtitle{font-size:11px;color:var(--t3)}
/* ═══ End Messaging Module CSS ═══ */

.df-item{display:flex;justify-content:space-between;align-items:center;padding:10px 0;border-bottom:1px solid var(--brd);gap:8px}
.df-item label{font-size:11px;color:var(--t3);min-width:70px;flex-shrink:0;font-weight:500}
.df-item input{flex:1;padding:7px 10px;font-size:13px}
.df-item a,.df-item span{font-size:12px;color:var(--t2);text-align:right;flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}

/* Timeline */
.tl-item{display:flex;gap:10px;padding:10px 0;border-bottom:1px solid var(--brd)}
.tl-icon{width:32px;height:32px;border-radius:10px;display:flex;align-items:center;justify-content:center;font-size:14px;flex-shrink:0}
.tl-icon.estado{background:var(--primary-a8)}.tl-icon.nota{background:var(--warning-subtle)}.tl-icon.whatsapp{background:var(--success-subtle)}.tl-icon.reunion{background:var(--orange-subtle)}.tl-icon.otro{background:var(--muted-subtle)}
.tl-text{font-size:12px;color:var(--t2);flex:1}.tl-date{font-size:10px;color:var(--t3);margin-top:2px}

/* Chat bubbles */
.wa-chat{display:flex;flex-direction:column;gap:6px;max-height:350px;overflow-y:auto;padding:10px;background:var(--surface-1);border-radius:var(--r)}
.wa-bub{max-width:78%;padding:10px 14px;border-radius:18px;font-size:13px;line-height:1.5;word-break:break-word}
.wa-bub.out{align-self:flex-end;background:var(--acc);color:var(--text-on-primary);border-bottom-right-radius:6px}
.wa-bub.in{align-self:flex-start;background:var(--glass2);color:var(--t1);border-bottom-left-radius:6px;border:1px solid var(--brd)}
.wa-bub .wa-time{font-size:9px;opacity:.55;margin-top:3px;text-align:right}
.con{background:var(--surface-elevated);border:1px solid var(--brd);border-radius:12px;padding:12px;font-family:'SF Mono',SFMono-Regular,Menlo,Consolas,monospace;font-size:12px;max-height:250px;overflow-y:auto;display:none}
.con .ln{padding:2px 0;color:var(--t2)}.con .ok{color:var(--grn)}.con .er{color:var(--red)}.con .in{color:var(--cyn)}
.chat-area{display:flex;flex-direction:column;height:calc(100dvh - 130px)}
.chat-msgs{flex:1;overflow-y:auto;padding:8px 0;-webkit-overflow-scrolling:touch}
.chat-msg{margin-bottom:10px;display:flex;gap:8px}.chat-msg.user{justify-content:flex-end}
.chat-bubble{max-width:78%;padding:12px 16px;border-radius:18px;font-size:13px;line-height:1.5}
.chat-msg.user .chat-bubble{background:var(--acc);color:var(--text-on-primary);border-bottom-right-radius:6px}
.chat-msg.ai .chat-bubble{background:var(--glass2);color:var(--t1);border-bottom-left-radius:6px;border:1px solid var(--brd)}
.chat-msg .exec{background:var(--grn);color:var(--text-on-warning);padding:3px 8px;border-radius:6px;font-size:11px;margin-top:4px;display:inline-block}
.chat-sug{display:flex;gap:6px;flex-wrap:wrap;margin:4px 0 8px 0}
.chat-sug .fb{background:var(--primary-a8);color:var(--acc2);border:1px solid var(--primary-a25);font-size:12px;padding:8px 14px}
.chat-input{display:flex;gap:8px;padding:8px 0}
.chat-input input{flex:1;padding:14px 16px;border-radius:16px}
.voice-btn{width:48px;height:48px;border-radius:50%;border:1px solid var(--brd);background:var(--glass2);color:var(--t2);font-size:20px;display:flex;align-items:center;justify-content:center;cursor:pointer;flex-shrink:0;transition:all .2s}
.voice-btn:hover{background:var(--bg4);color:var(--t1)}
.voice-btn.rec{background:var(--red);border-color:var(--red);color:var(--text-on-primary);animation:pulse 1.5s infinite}
@keyframes pulse{0%,100%{transform:scale(1);opacity:1}50%{transform:scale(1.06);opacity:.85}}

/* Forms */
.fg{margin-bottom:12px}.fg label{display:block;font-size:11px;color:var(--t3);margin-bottom:4px;text-transform:uppercase;letter-spacing:.06em;font-weight:600}
.row{display:grid;grid-template-columns:1fr 1fr;gap:12px}

/* Modals */
.modal-ov{position:fixed;inset:0;background:var(--overlay-dim);backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px);z-index:200;display:none;align-items:center;justify-content:center;padding:16px}
.modal-ov.show{display:flex}
.modal{background:var(--glass);backdrop-filter:blur(40px);-webkit-backdrop-filter:blur(40px);border:1px solid var(--brd2);border-radius:var(--r2);padding:24px;width:100%;max-width:460px;max-height:85vh;overflow-y:auto;box-shadow:var(--sh2)}
.modal h3{margin-bottom:16px;font-size:17px;font-weight:700;letter-spacing:-.02em}

/* Toast */
.toast{position:fixed;bottom:calc(76px + var(--safe-b) + 10px);left:50%;transform:translateX(-50%) translateY(100px);background:var(--glass);backdrop-filter:blur(24px);-webkit-backdrop-filter:blur(24px);color:var(--t1);padding:12px 22px;border-radius:16px;font-size:13px;z-index:999;opacity:0;transition:.3s cubic-bezier(.16,1,.3,1);white-space:nowrap;border:1px solid var(--brd2);box-shadow:var(--sh);font-weight:500}
.toast.show{transform:translateX(-50%) translateY(0);opacity:1}
.toast.ok{border-left:3px solid var(--grn)}.toast.er{border-left:3px solid var(--red)}
.empty{text-align:center;padding:36px;color:var(--t3);font-size:13px;font-weight:500}
.temp-hot{color:var(--temp-hot);font-weight:700}.temp-warm{color:var(--temp-warm)}.temp-cold{color:var(--temp-cold)}.temp-new{color:var(--t3)}
.alert-card{background:var(--danger-subtle);border:1px solid var(--danger-border);border-radius:12px;padding:12px 14px;margin-bottom:8px;font-size:12px;display:flex;justify-content:space-between;align-items:center}
.reminder-card{background:var(--warning-subtle);border:1px solid var(--warning-border);border-radius:12px;padding:12px 14px;margin-bottom:8px;font-size:12px;display:flex;justify-content:space-between;align-items:center}
.funnel-bar{display:flex;align-items:center;gap:8px;margin-bottom:6px}
.funnel-bar .fb-label{font-size:11px;min-width:80px;color:var(--t2);font-weight:500}
.funnel-bar .fb-bar{flex:1;height:26px;background:var(--surface-1);border-radius:8px;overflow:hidden;position:relative}
.funnel-bar .fb-fill{height:100%;border-radius:8px;display:flex;align-items:center;padding-left:8px;font-size:10px;color:var(--text-on-primary);font-weight:600;transition:.4s cubic-bezier(.16,1,.3,1)}
.rev-bar{display:flex;flex-direction:column;align-items:center;flex:1}
.rev-bar .rb-bar{width:100%;border-radius:6px 6px 0 0;min-height:4px;transition:.3s}
.rev-bar .rb-label{font-size:9px;color:var(--t3);margin-top:2px}.rev-bar .rb-val{font-size:10px;color:var(--t2);font-weight:600}

/* Kanban */
.kanban{display:flex;gap:10px;min-height:300px;padding-bottom:8px}
.kan-col{min-width:180px;max-width:200px;background:var(--glass);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border:1px solid var(--brd);border-radius:var(--r);flex-shrink:0;display:flex;flex-direction:column}
.kan-head{padding:10px 12px;font-size:11px;font-weight:700;border-bottom:1px solid var(--brd);display:flex;justify-content:space-between;align-items:center;letter-spacing:.02em}
.kan-body{flex:1;padding:8px;overflow-y:auto;min-height:80px}
.kan-card{background:var(--glass2);border:1px solid var(--brd);border-radius:12px;padding:10px 12px;margin-bottom:8px;cursor:pointer;font-size:12px;transition:all .2s}
.kan-card:hover{border-color:var(--primary-a30);transform:translateY(-2px);box-shadow:0 4px 16px rgba(var(--shadow-color),.2)}
.kan-card .kc-name{font-weight:600;margin-bottom:3px}
.kan-card .kc-meta{font-size:10px;color:var(--t3);display:flex;justify-content:space-between}
.p-card{background:var(--glass);backdrop-filter:blur(12px);border:1px solid var(--brd);border-radius:var(--r);padding:16px;cursor:pointer;transition:all .2s;box-shadow:0 2px 8px rgba(var(--shadow-color),.12)}
.p-card:hover{border-color:var(--primary-a25);transform:translateY(-2px);box-shadow:var(--sh)}
.p-card .pc-name{font-weight:600;font-size:14px;margin-bottom:4px}
.p-card .pc-meta{font-size:11px;color:var(--t3)}

/* Calendar */
.cal-cell{background:var(--glass2);border:1px solid var(--brd);min-height:72px;padding:6px;border-radius:12px;font-size:11px;position:relative;cursor:pointer;transition:all .2s}
.cal-cell:hover{border-color:var(--primary-a25)}.cal-cell.today{border-color:var(--primary-a40);background:var(--primary-a6)}
.cal-cell.other{opacity:.25}.cal-cell .cal-day{font-weight:700;margin-bottom:3px;font-size:12px}
.cal-cell .cal-ev{font-size:8px;padding:2px 5px;border-radius:6px;margin-bottom:2px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.cal-header{font-size:10px;font-weight:700;color:var(--t3);text-align:center;padding:8px 4px;letter-spacing:.06em;text-transform:uppercase}

/* Templates */
.tpl-card{background:var(--glass2);border:1px solid var(--brd);border-radius:var(--r);padding:14px;margin-bottom:10px;transition:all .2s}
.tpl-card:hover{border-color:var(--brd2)}
.tpl-card .tpl-name{font-weight:600;font-size:13px;margin-bottom:4px}
.tpl-card .tpl-msg{font-size:12px;color:var(--t2);margin-bottom:8px;white-space:pre-wrap;max-height:80px;overflow:hidden}
.tpl-card .tpl-meta{font-size:10px;color:var(--t3);display:flex;justify-content:space-between;align-items:center}
.st-item{display:flex;align-items:center;gap:8px;padding:10px 0;border-bottom:1px solid var(--brd)}
.st-item input[type=color]{width:32px;height:32px;border:none;background:none;cursor:pointer;padding:0}
.st-item input[type=text]{flex:1;padding:7px 10px}

/* Responsive */
@media(min-width:769px){.sidebar{display:flex}.bnav{display:none}.main{padding-bottom:24px}.drawer{max-width:540px}.chat-area{height:calc(100dvh - 100px)}.toast{bottom:24px}.install-banner{display:none!important}}
@media(max-width:768px){
.cg{grid-template-columns:1fr;gap:10px}
.row{grid-template-columns:1fr}
table .hm{display:none}
.drawer{border-radius:var(--r2) var(--r2) 0 0;padding:20px 16px}
.d-header h3{font-size:17px}
.d-header{margin-bottom:12px}
.d-tabs{gap:2px;margin-bottom:12px;padding-bottom:6px}
.d-tab{padding:9px 14px;font-size:12px;min-height:38px;display:flex;align-items:center}
.df-item{padding:10px 0}.df-item input{padding:12px 10px;font-size:14px}
.btn{padding:12px 18px;font-size:14px;min-height:44px}
.btn-sm{padding:8px 14px;font-size:12px;min-height:36px}
.ab{padding:10px 14px;font-size:14px;min-height:44px}
.fb{padding:9px 16px;font-size:12px;min-height:38px}
.wa-bub{font-size:14px;padding:12px 16px}
.chat-bubble{font-size:14px;padding:14px 18px}
.biz-section{padding:12px;margin-bottom:12px}
.biz-header{padding:4px 0;font-size:13px}
.biz-header .btn{min-height:32px;padding:4px 10px}
.fg{margin-bottom:14px}
.fg label{font-size:12px;margin-bottom:5px}
input,select,textarea{padding:12px 14px;font-size:15px;border-radius:12px}
.modal{padding:20px 16px;border-radius:var(--r2)}
.modal h3{font-size:18px}
.cs{padding:16px}
.stat-val{font-size:28px}
.pipe-s{min-width:80px;padding:10px 14px}
.tl-item{padding:12px 0;gap:12px}
.tl-icon{width:36px;height:36px;border-radius:12px;font-size:16px}
.ph{margin-bottom:16px}
.ph h2{font-size:20px}
.cal-cell{min-height:56px;padding:4px;border-radius:8px}
.cal-cell .cal-day{font-size:11px}
.cal-cell .cal-ev{font-size:7px;padding:1px 3px}
.cal-header{padding:6px 2px;font-size:9px}
#cal-grid{gap:2px!important}
#pg-mensajes .ix-sidebar{width:100%;max-height:35vh;border-right:none;border-bottom:1px solid var(--brd)}#pg-mensajes .ix-detail{flex:1;min-height:300px}#pg-mensajes .msg-panel{flex-direction:column;height:auto!important}#pg-mensajes .tc-sidebar{width:100%;max-height:150px;border-right:none;border-bottom:1px solid var(--brd);flex-direction:row;overflow-x:auto}#pg-mensajes .tc-sidebar .tc-sidebar-label{display:none}#pg-mensajes .tc-sidebar .tc-list{flex-direction:row;overflow-x:auto;flex:none}#pg-mensajes .tc-item{min-width:120px;white-space:nowrap}
.msg-bar{padding:8px 0;margin-bottom:8px;flex-wrap:wrap}
.msg-seg-btn{padding:7px 12px;font-size:11px}
.ix-thread{padding:8px 10px;gap:8px}
.ix-avatar{width:34px;height:34px;font-size:11px}
.ix-name{font-size:12px}
.ix-preview{font-size:10px}
.ix-detail-header{padding:8px 12px;min-height:44px}
.ix-input-bar{padding:6px 8px;padding-bottom:calc(6px + var(--safe-b))}
.ix-input-bar input{font-size:16px!important;-webkit-appearance:none}
#inbox-detail-msgs{-webkit-overflow-scrolling:touch;overscroll-behavior:contain}
}

/* PWA Install */
.install-banner{position:fixed;bottom:calc(64px + var(--safe-b));left:16px;right:16px;background:var(--glass);backdrop-filter:blur(24px);-webkit-backdrop-filter:blur(24px);border:1px solid var(--brd2);color:var(--text-on-primary);padding:16px 18px;border-radius:var(--r2);z-index:50;display:none;align-items:center;gap:14px;box-shadow:var(--sh2)}
.install-banner.show{display:flex}
.install-banner .ib-text{flex:1;font-size:13px;line-height:1.4}
.install-banner .ib-text b{display:block;font-size:14px;margin-bottom:2px}
.install-banner button{background:var(--acc);color:var(--text-on-primary);border:none;padding:10px 18px;border-radius:12px;font-weight:600;font-size:13px;white-space:nowrap}
.install-banner .ib-close{background:none;padding:8px;font-size:16px;opacity:.5}

/* Custom scrollbar */
::-webkit-scrollbar{width:5px;height:5px}
::-webkit-scrollbar-track{background:transparent}
::-webkit-scrollbar-thumb{background:var(--border-subtle);border-radius:3px}
::-webkit-scrollbar-thumb:hover{background:var(--border-hover)}

/* ═══════════════════════════════════════════════════════════
   COMPONENT SYSTEM v1.0 — 7 Components (additive only)
   ═══════════════════════════════════════════════════════════ */

/* C1: TOPBAR */
.c-topbar{height:56px;display:flex;align-items:center;padding:0 var(--space-lg);background:var(--glass-2);backdrop-filter:blur(var(--glass-2-blur)) saturate(var(--glass-2-sat));-webkit-backdrop-filter:blur(var(--glass-2-blur)) saturate(var(--glass-2-sat));border-bottom:.5px solid var(--glass-2-brd);gap:var(--space-base);position:relative;z-index:var(--z-topbar)}
.c-topbar-brand{font-size:var(--text-md);font-weight:700;letter-spacing:-.02em;display:flex;align-items:center;gap:var(--space-sm);color:var(--label-primary);margin-right:var(--space-lg)}
.c-topbar-brand span{font-size:18px}
.c-topbar-search{display:flex;align-items:center;gap:var(--space-sm);height:36px;padding:0 var(--space-md);background:var(--fill-tertiary);border:none;border-radius:var(--radius-sm);color:var(--label-tertiary);font-size:var(--text-sm);cursor:text;transition:background var(--duration-normal) var(--ease-default);flex-shrink:0;width:240px}
.c-topbar-search:hover{background:var(--fill-secondary)}
.c-topbar-search svg{width:14px;height:14px;stroke:currentColor;fill:none;stroke-width:2;stroke-linecap:round;flex-shrink:0}
.c-topbar-search kbd{margin-left:auto;font-family:var(--font);font-size:10px;font-weight:600;color:var(--label-quaternary);background:var(--border-subtle);padding:2px 6px;border-radius:4px}
.c-topbar-spacer{flex:1}
.c-topbar-icon{width:36px;height:36px;border-radius:50%;display:flex;align-items:center;justify-content:center;background:var(--fill-tertiary);border:none;color:var(--label-secondary);cursor:pointer;transition:all var(--duration-normal) var(--ease-default);position:relative;flex-shrink:0}
.c-topbar-icon:hover{background:var(--fill-secondary);color:var(--label-primary)}
.c-topbar-icon svg{width:16px;height:16px;stroke:currentColor;fill:none;stroke-width:1.8;stroke-linecap:round;stroke-linejoin:round}
.c-topbar-icon .dot{position:absolute;top:6px;right:6px;width:8px;height:8px;border-radius:50%;background:var(--error);border:2px solid var(--bg-primary)}
.c-topbar-sep{width:.5px;height:24px;background:var(--separator-thin);flex-shrink:0}
.c-topbar-user{display:flex;align-items:center;gap:var(--space-sm);padding:var(--space-xs) var(--space-sm);border-radius:var(--radius-sm);cursor:pointer;transition:background var(--duration-normal) var(--ease-default)}
.c-topbar-user:hover{background:var(--fill-tertiary)}
.c-topbar-avatar{width:32px;height:32px;border-radius:50%;background:linear-gradient(135deg,var(--accent),var(--primary-active));display:flex;align-items:center;justify-content:center;font-size:var(--text-sm);font-weight:700;color:var(--text-on-primary);flex-shrink:0}
.c-topbar-name{font-size:var(--text-sm);font-weight:600;color:var(--label-secondary)}
.c-topbar-version{font-size:10px;font-weight:600;color:var(--label-quaternary);background:var(--border-subtle);padding:2px 8px;border-radius:var(--radius-full);letter-spacing:.02em}

/* C2: SIDEBAR */
.c-nav-item{display:flex;align-items:center;gap:var(--space-md);padding:0 var(--space-md);height:44px;border-radius:var(--radius-md);color:var(--label-secondary);font-size:var(--text-base);font-weight:500;cursor:pointer;transition:all var(--duration-normal) var(--ease-default);letter-spacing:-.01em;position:relative;border:none;background:none;width:100%;text-align:left;font-family:var(--font)}
.c-nav-item:hover{background:var(--border-subtle);color:var(--label-primary)}
.c-nav-item.active{background:var(--accent-bg);color:var(--accent-light)}
.c-nav-item.active::before{content:'';position:absolute;left:0;top:10px;bottom:10px;width:3px;background:var(--accent);border-radius:0 2px 2px 0}
.c-nav-item svg{width:20px;height:20px;flex-shrink:0;stroke:currentColor;fill:none;stroke-width:1.5;stroke-linecap:round;stroke-linejoin:round}
.c-nav-badge{margin-left:auto;background:var(--error);color:var(--text-on-primary);font-size:10px;font-weight:700;padding:1px 6px;border-radius:var(--radius-full);min-width:18px;text-align:center;line-height:16px}
.c-nav-sep{height:.5px;background:var(--separator-thin);margin:var(--space-md)}
.c-nav-group-label{font-size:10px;font-weight:700;color:var(--label-quaternary);text-transform:uppercase;letter-spacing:.06em;padding:var(--space-base) var(--space-md) var(--space-xs)}

/* C3: TABLE */
.c-table-wrap{background:var(--glass-1);border:.5px solid var(--glass-1-brd);border-radius:var(--radius-lg);overflow:hidden}
.c-table-toolbar{display:flex;align-items:center;gap:var(--space-sm);padding:var(--space-md) var(--space-base);border-bottom:.5px solid var(--separator-thin)}
.c-table-toolbar-count{font-size:var(--text-sm);font-weight:600;color:var(--accent-light)}
.c-table-toolbar-spacer{flex:1}
.c-table-toolbar-btn{height:28px;padding:0 var(--space-md);border-radius:var(--radius-xs);font-size:var(--text-xs);font-weight:600;border:none;cursor:pointer;font-family:var(--font);transition:all var(--duration-normal) var(--ease-default)}
.c-table-toolbar-btn.ghost{background:var(--fill-tertiary);color:var(--label-secondary)}
.c-table-toolbar-btn.ghost:hover{background:var(--fill-secondary);color:var(--label-primary)}
.c-table-toolbar-btn.accent{background:var(--accent-bg-2);color:var(--accent-light)}
.c-table-toolbar-btn.danger{background:var(--error-bg);color:var(--error)}
.c-table{width:100%;border-collapse:collapse}
.c-table th{text-align:left;padding:var(--space-md) var(--space-base);font-size:var(--text-xs);font-weight:600;color:var(--label-tertiary);text-transform:uppercase;letter-spacing:.04em;border-bottom:.5px solid var(--separator);background:var(--bg-base);position:sticky;top:0;z-index:var(--z-sticky);height:44px}
.c-table td{padding:14px var(--space-base);border-bottom:.5px solid var(--border-subtle);font-size:var(--text-base);vertical-align:middle}
.c-table tr{transition:background var(--duration-fast) var(--ease-default)}
.c-table tbody tr:hover{background:var(--border-subtle)}
.c-table tbody tr.selected{background:var(--accent-bg)}
.c-table .td-name{font-weight:600;letter-spacing:-.01em}
.c-table .td-sub{font-size:var(--text-sm);color:var(--label-tertiary);margin-top:1px}
.c-table .td-mono{font-family:var(--font-mono);font-size:var(--text-sm);color:var(--label-secondary)}
.c-checkbox{width:18px;height:18px;border-radius:var(--radius-xs);appearance:none;-webkit-appearance:none;border:1.5px solid var(--separator);background:transparent;cursor:pointer;transition:all var(--duration-fast) var(--ease-default);display:grid;place-content:center}
.c-checkbox:hover{border-color:var(--label-tertiary)}
.c-checkbox:checked{background:var(--accent);border-color:var(--accent)}
.c-checkbox:checked::after{content:'';width:10px;height:10px;background:url("data:image/svg+xml,%3Csvg viewBox='0 0 14 14' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M11 4L5.5 9.5L3 7' stroke='white' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E") center/contain no-repeat}
.c-badge{display:inline-block;padding:3px 10px;border-radius:var(--radius-full);font-size:var(--text-xs);font-weight:600;line-height:1.4}

/* C4: ANALYTICS CARDS */
.c-card{background:var(--glass-1);border:.5px solid var(--glass-1-brd);border-radius:var(--radius-lg);padding:var(--space-lg);transition:background var(--duration-normal) var(--ease-default)}
.c-card:hover{background:var(--surface-2)}
.c-card-title{font-size:var(--text-sm);font-weight:700;color:var(--label-tertiary);text-transform:uppercase;letter-spacing:.04em;margin-bottom:var(--space-base)}
.c-kpi{text-align:center;padding:var(--space-lg) var(--space-base);min-height:100px;display:flex;flex-direction:column;align-items:center;justify-content:center}
.c-kpi-value{font-size:var(--text-3xl);font-weight:800;letter-spacing:-.04em;line-height:1;font-feature-settings:'tnum' 1}
.c-kpi-label{font-size:var(--text-xs);font-weight:600;color:var(--label-tertiary);margin-top:var(--space-sm);text-transform:uppercase;letter-spacing:.03em}
.c-kpi-delta{font-size:var(--text-xs);font-weight:600;margin-top:var(--space-xs);display:flex;align-items:center;gap:var(--space-2xs)}
.c-chart{height:200px;display:flex;align-items:flex-end;gap:3px;padding-top:var(--space-sm)}
.c-chart-bar{flex:1;border-radius:3px 3px 0 0;min-height:4px;transition:height .4s var(--ease-spring)}
.c-chart-bar:hover{opacity:.85}
.c-funnel-row{display:flex;align-items:center;gap:var(--space-md);margin-bottom:var(--space-sm)}
.c-funnel-label{font-size:var(--text-sm);color:var(--label-secondary);width:90px;flex-shrink:0;font-weight:500}
.c-funnel-bg{flex:1;height:28px;background:var(--border-subtle);border-radius:var(--radius-xs);overflow:hidden}
.c-funnel-fill{height:100%;border-radius:var(--radius-xs);display:flex;align-items:center;padding-left:10px;font-size:var(--text-xs);color:var(--text-on-primary);font-weight:600}
.c-funnel-val{font-size:13px;font-weight:700;width:36px;text-align:right;flex-shrink:0;font-feature-settings:'tnum' 1}

/* C5: CHAT LAYOUT */
.c-chat-layout{display:flex;border-radius:var(--radius-lg);overflow:hidden;border:.5px solid var(--glass-1-brd);height:480px}
.c-chat-threads{width:360px;flex-shrink:0;display:flex;flex-direction:column;background:var(--glass-1);border-right:.5px solid var(--separator-thin)}
.c-chat-threads-header{padding:var(--space-base) var(--space-base) var(--space-md)}
.c-chat-threads-title{font-size:var(--text-lg);font-weight:700;letter-spacing:-.025em}
.c-chat-filters{display:flex;gap:var(--space-xs);padding:0 var(--space-base) var(--space-md)}
.c-chat-filter{padding:var(--space-xs) var(--space-md);border-radius:var(--radius-full);font-size:var(--text-xs);font-weight:600;color:var(--label-tertiary);background:transparent;border:1px solid var(--separator-thin);cursor:pointer;transition:all var(--duration-normal) var(--ease-default);font-family:var(--font);white-space:nowrap}
.c-chat-filter:hover{color:var(--label-secondary);border-color:var(--separator)}
.c-chat-filter.active{color:var(--accent-light);background:var(--accent-bg-2);border-color:transparent}
.c-chat-search{display:flex;align-items:center;gap:var(--space-sm);margin:0 var(--space-base) var(--space-sm);padding:0 var(--space-md);background:var(--fill-tertiary);border-radius:var(--radius-sm);height:36px}
.c-chat-search svg{width:14px;height:14px;stroke:var(--label-tertiary);fill:none;stroke-width:2;stroke-linecap:round;flex-shrink:0}
.c-chat-list{flex:1;overflow-y:auto}.c-chat-list::-webkit-scrollbar{width:0}
.c-thread{display:flex;gap:var(--space-md);padding:14px var(--space-base);cursor:pointer;transition:background var(--duration-fast) var(--ease-default);border-bottom:.5px solid var(--border-subtle);position:relative}
.c-thread:hover{background:var(--border-subtle)}
.c-thread.active{background:var(--accent-bg)}
.c-thread.active::after{content:'';position:absolute;right:0;top:14px;bottom:14px;width:2px;background:var(--accent);border-radius:1px}
.c-thread-av{width:42px;height:42px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:var(--text-base);font-weight:700;flex-shrink:0}
.c-thread-info{flex:1;min-width:0}
.c-thread-name{font-size:var(--text-base);font-weight:600;letter-spacing:-.01em;display:flex;align-items:center;gap:var(--space-sm)}
.c-thread-ch{font-size:9px;font-weight:700;padding:1px 5px;border-radius:var(--radius-xs);text-transform:uppercase;letter-spacing:.03em;line-height:14px}
.c-thread-preview{font-size:var(--text-sm);color:var(--label-tertiary);margin-top:2px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.c-thread-meta{flex-shrink:0;text-align:right;display:flex;flex-direction:column;align-items:flex-end;gap:var(--space-xs)}
.c-thread-time{font-size:var(--text-xs);color:var(--label-tertiary)}
.c-thread-unread{background:var(--accent);color:var(--text-on-primary);font-size:10px;font-weight:700;width:20px;height:20px;border-radius:50%;display:flex;align-items:center;justify-content:center}
.c-chat-conv{flex:1;display:flex;flex-direction:column;background:var(--bg-primary)}
.c-chat-header{padding:var(--space-md) var(--space-lg);border-bottom:.5px solid var(--separator-thin);display:flex;align-items:center;gap:var(--space-md);height:60px;flex-shrink:0}
.c-chat-header-av{width:36px;height:36px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:var(--text-sm);font-weight:700;flex-shrink:0}
.c-chat-header-name{font-size:var(--text-md);font-weight:700;letter-spacing:-.01em}
.c-chat-header-sub{font-size:var(--text-sm);color:var(--label-tertiary)}
.c-chat-msgs{flex:1;overflow-y:auto;padding:var(--space-lg);display:flex;flex-direction:column;gap:2px}
.c-chat-gap{height:var(--space-md)}
.c-chat-date{align-self:center;font-size:var(--text-xs);font-weight:600;color:var(--label-quaternary);background:var(--fill-tertiary);padding:var(--space-xs) 14px;border-radius:var(--radius-full);margin:var(--space-sm) 0}
.c-bubble{max-width:65%;padding:10px var(--space-base);font-size:var(--text-base);line-height:1.5;word-break:break-word}
.c-bubble-in{align-self:flex-start;background:var(--bg-secondary);color:var(--label-primary);border-radius:18px;border-bottom-left-radius:var(--radius-xs);border:.5px solid var(--separator-thin)}
.c-bubble-out{align-self:flex-end;background:var(--accent);color:var(--text-on-primary);border-radius:18px;border-bottom-right-radius:var(--radius-xs)}
.c-bubble-time{font-size:10px;opacity:.5;margin-top:3px;text-align:right;display:flex;align-items:center;justify-content:flex-end;gap:var(--space-xs)}
.c-chat-input{padding:var(--space-md) var(--space-lg);border-top:.5px solid var(--separator-thin);display:flex;align-items:center;gap:var(--space-sm);flex-shrink:0}
.c-chat-input-btn{width:32px;height:32px;border-radius:var(--radius-sm);display:flex;align-items:center;justify-content:center;background:var(--fill-tertiary);border:none;color:var(--label-tertiary);cursor:pointer;transition:all var(--duration-fast);flex-shrink:0}
.c-chat-input-btn:hover{background:var(--fill-secondary);color:var(--label-secondary)}
.c-chat-input-btn.ai{background:var(--info-bg);color:var(--info)}
.c-chat-input-btn svg{width:14px;height:14px;stroke:currentColor;fill:none;stroke-width:2;stroke-linecap:round;stroke-linejoin:round}
.c-chat-input-field{flex:1;height:40px;border:none;background:var(--fill-tertiary);border-radius:var(--radius-full);padding:0 18px;font-size:var(--text-base);color:var(--label-primary);outline:none;font-family:var(--font);transition:background var(--duration-normal)}
.c-chat-input-field::placeholder{color:var(--label-tertiary)}
.c-chat-input-field:focus{background:var(--fill-secondary)}
.c-chat-send{width:38px;height:38px;border-radius:50%;background:var(--accent);border:none;display:flex;align-items:center;justify-content:center;cursor:pointer;flex-shrink:0;transition:all var(--duration-fast)}
.c-chat-send:hover{transform:scale(1.05)}
.c-chat-send svg{width:16px;height:16px;stroke:var(--text-on-primary);fill:none;stroke-width:2.5;stroke-linecap:round;stroke-linejoin:round}

/* C6: KANBAN */
.c-kanban{display:grid;grid-template-columns:repeat(var(--kan-cols,5),1fr);gap:var(--space-md)}
.c-kan-col{background:var(--glass-1);border:.5px solid var(--glass-1-brd);border-radius:var(--radius-lg);display:flex;flex-direction:column;min-height:360px}
.c-kan-header{padding:var(--space-base);border-bottom:.5px solid var(--separator-thin);display:flex;align-items:center;justify-content:space-between}
.c-kan-title{font-size:var(--text-sm);font-weight:700;letter-spacing:-.01em;display:flex;align-items:center;gap:var(--space-sm)}
.c-kan-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}
.c-kan-count{font-size:var(--text-xs);font-weight:600;color:var(--label-tertiary);background:var(--fill-tertiary);padding:2px 8px;border-radius:var(--radius-full)}
.c-kan-body{flex:1;padding:var(--space-sm);display:flex;flex-direction:column;gap:var(--space-sm);overflow-y:auto}
.c-kan-body::-webkit-scrollbar{width:0}
.c-kan-card{background:var(--bg-elevated);border:.5px solid var(--separator-thin);border-radius:var(--radius-md);padding:var(--space-md) var(--space-base);cursor:pointer;transition:all var(--duration-normal) var(--ease-default)}
.c-kan-card:hover{border-color:var(--separator);background:var(--surface-3)}
.c-kan-card-name{font-size:var(--text-sm);font-weight:600;letter-spacing:-.01em;margin-bottom:var(--space-xs)}
.c-kan-card-meta{font-size:var(--text-xs);color:var(--label-tertiary);display:flex;justify-content:space-between;align-items:center}
.c-kan-card-av{width:22px;height:22px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:9px;font-weight:700}
.c-kan-add{padding:var(--space-sm);text-align:center;font-size:var(--text-sm);color:var(--label-quaternary);cursor:pointer;border-radius:var(--radius-md);transition:all var(--duration-normal);border:1px dashed var(--separator-thin);margin:0 var(--space-sm) var(--space-sm)}
.c-kan-add:hover{color:var(--label-tertiary);border-color:var(--separator);background:var(--border-subtle)}

/* C7: MODAL */
.c-modal-overlay{position:fixed;inset:0;background:var(--overlay-dim);backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px);z-index:var(--z-overlay);display:flex;align-items:center;justify-content:center;padding:var(--space-xl)}
.c-modal{background:var(--glass-3);backdrop-filter:blur(var(--glass-3-blur)) saturate(var(--glass-3-sat));-webkit-backdrop-filter:blur(var(--glass-3-blur)) saturate(var(--glass-3-sat));border:.5px solid var(--glass-3-brd);border-radius:var(--radius-xl);padding:var(--space-lg);width:100%;max-width:480px;box-shadow:var(--shadow-lg);position:relative}
.c-modal-close{position:absolute;top:var(--space-base);right:var(--space-base);width:32px;height:32px;border-radius:50%;display:flex;align-items:center;justify-content:center;background:var(--fill-tertiary);border:none;color:var(--label-tertiary);cursor:pointer;transition:all var(--duration-fast);font-size:14px}
.c-modal-close:hover{background:var(--fill-secondary);color:var(--label-primary)}
.c-modal-title{font-size:var(--text-lg);font-weight:700;letter-spacing:-.025em;margin-bottom:var(--space-xs)}
.c-modal-desc{font-size:var(--text-sm);color:var(--label-tertiary);margin-bottom:var(--space-lg)}
.c-input-group{margin-bottom:var(--space-md)}
.c-input-label{display:block;font-size:var(--text-xs);font-weight:600;color:var(--label-tertiary);text-transform:uppercase;letter-spacing:.04em;margin-bottom:var(--space-xs)}
.c-input{width:100%;height:40px;background:var(--fill-tertiary);border:none;border-radius:var(--radius-md);padding:0 var(--space-md);font-size:var(--text-base);color:var(--label-primary);font-family:var(--font);outline:none;transition:all var(--duration-normal)}
.c-input:focus{background:var(--fill-secondary);box-shadow:0 0 0 3px var(--primary-a15)}
.c-input::placeholder{color:var(--label-tertiary)}
.c-textarea{width:100%;min-height:80px;background:var(--fill-tertiary);border:none;border-radius:var(--radius-md);padding:var(--space-md);font-size:var(--text-base);color:var(--label-primary);font-family:var(--font);outline:none;resize:vertical;line-height:1.5;transition:all var(--duration-normal)}
.c-textarea:focus{background:var(--fill-secondary);box-shadow:0 0 0 3px var(--primary-a15)}
.c-modal-actions{display:flex;gap:var(--space-sm);justify-content:flex-end;margin-top:var(--space-lg)}
.c-btn{height:40px;padding:0 var(--space-lg);border-radius:var(--radius-md);font-size:var(--text-base);font-weight:600;border:none;cursor:pointer;font-family:var(--font);transition:all var(--duration-normal) var(--ease-default);display:inline-flex;align-items:center;justify-content:center;gap:var(--space-sm);letter-spacing:-.01em}
.c-btn-primary{background:var(--accent);color:var(--text-on-primary)}
.c-btn-primary:hover{background:var(--accent-light)}
.c-btn-ghost{background:var(--fill-tertiary);color:var(--label-secondary)}
.c-btn-ghost:hover{background:var(--fill-secondary);color:var(--label-primary)}
.c-btn-danger{background:var(--error-bg);color:var(--error)}
.c-btn-sm{height:32px;padding:0 var(--space-base);font-size:var(--text-sm);border-radius:var(--radius-sm)}

/* GRID UTILITIES */
.grid-12{display:grid;grid-template-columns:repeat(12,1fr);gap:var(--grid-gutter)}
.span-3{grid-column:span 3}.span-4{grid-column:span 4}.span-6{grid-column:span 6}.span-8{grid-column:span 8}.span-12{grid-column:span 12}
@media(max-width:1023px){.grid-12{grid-template-columns:repeat(6,1fr)}.span-3{grid-column:span 3}.span-4{grid-column:span 3}.span-6{grid-column:span 6}.span-8{grid-column:span 6}.span-12{grid-column:1/-1}}
/* ═══════════════════════════════════════════════════════════════
   COMPONENT CLASSES — migrated from utilities.css audit
   These are multi-concern (layout+typo+visual) and belong
   here alongside other component definitions, not in utilities.
   ═══════════════════════════════════════════════════════════════ */

/* ── Badge component ──────────────────────────────────────────── */
.badge{display:inline-flex;align-items:center;padding:2px 8px;border-radius:var(--radius-full);font-size:var(--text-xs);font-weight:600;line-height:1.4;white-space:nowrap;gap:4px}
.badge-sm{padding:1px 6px;font-size:var(--text-2xs);border-radius:var(--radius-xs)}
.badge-count{display:inline-flex;align-items:center;justify-content:center;min-width:18px;padding:2px 6px;border-radius:var(--radius-full);font-size:var(--text-2xs);font-weight:700;text-align:center;background:var(--primary);color:var(--text-on-primary)}
.badge-count-danger{background:var(--danger);color:var(--text-on-primary)}

/* ── Button base component ────────────────────────────────────── */
.btn-base{display:inline-flex;align-items:center;justify-content:center;gap:6px;border:none;border-radius:var(--radius-md);font-weight:600;font-family:inherit;cursor:pointer;transition:all .2s;white-space:nowrap}
.btn-base:active{transform:scale(.97)}

/* ── Data row component ───────────────────────────────────────── */
.data-row{display:flex;justify-content:space-between;align-items:center;padding:6px 0;border-bottom:1px solid var(--border-subtle);font-size:var(--text-base)}

/* ── Surface section component ────────────────────────────────── */
.surface-section{background:var(--surface-2);border:1px solid var(--border-subtle);border-radius:var(--radius-md);padding:14px;backdrop-filter:blur(var(--glass-blur-sm));-webkit-backdrop-filter:blur(var(--glass-blur-sm))}

/* ── Surface components (glass patterns) ──────────────────────── */
.surface-card{background:var(--surface-1);backdrop-filter:blur(var(--glass-blur-md));-webkit-backdrop-filter:blur(var(--glass-blur-md));border:1pxsolidvar(--border-default);border-radius:var(--radius-xl);box-shadow:var(--shadow-md);}
.surface-panel{background:var(--surface-2);border:1pxsolidvar(--border-subtle);border-radius:var(--radius-md);backdrop-filter:blur(var(--glass-blur-sm));-webkit-backdrop-filter:blur(var(--glass-blur-sm));}
.surface-elevated{background:var(--surface-elevated);backdrop-filter:blur(var(--glass-blur-lg));-webkit-backdrop-filter:blur(var(--glass-blur-lg));border:1pxsolidvar(--border-default);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);}
.surface-overlay{position:fixed;inset:0;background:var(--overlay-dim);backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px);}
