:root {
  --bg:#09090B;--surface:#18181B;--surface-2:#27272A;--surface-3:#3F3F46;
  --border:rgba(255,255,255,0.07);--border-strong:rgba(255,255,255,0.13);
  --text:#F4F4F5;--text-muted:#71717A;--text-faint:#52525B;
  --accent:#8B5CF6;--accent-dim:rgba(139,92,246,0.15);--accent-border:rgba(139,92,246,0.4);
  --green:#22C55E;--green-dim:rgba(34,197,94,0.12);
  --yellow:#EAB308;--yellow-dim:rgba(234,179,8,0.12);
  --red:#EF4444;--red-dim:rgba(239,68,68,0.12);
  --blue:#60A5FA;--blue-dim:rgba(96,165,250,0.12);
  --sidebar-w:220px;--radius:8px;--radius-lg:12px;
  --font:-apple-system,BlinkMacSystemFont,'Segoe UI',system-ui,sans-serif;
  --shadow:0 1px 3px rgba(0,0,0,0.4),0 1px 2px rgba(0,0,0,0.3);
  --shadow-lg:0 10px 40px rgba(0,0,0,0.5);
}
.theme-light {
  --bg:#FAFAFA;--surface:#FFFFFF;--surface-2:#F4F4F5;--surface-3:#E4E4E7;
  --border:rgba(0,0,0,0.07);--border-strong:rgba(0,0,0,0.13);
  --text:#18181B;--text-muted:#71717A;--text-faint:#A1A1AA;
  --accent:#7C3AED;--accent-dim:rgba(124,58,237,0.08);--accent-border:rgba(124,58,237,0.3);
  --shadow:0 1px 3px rgba(0,0,0,0.08),0 1px 2px rgba(0,0,0,0.05);
  --shadow-lg:0 10px 40px rgba(0,0,0,0.15);
}
*{box-sizing:border-box;margin:0;padding:0}
html,body{height:100%;font-family:var(--font);background:var(--bg);color:var(--text);font-size:14px;-webkit-font-smoothing:antialiased}
#app{height:100%}
a{color:var(--accent);text-decoration:none}
button{font-family:var(--font);cursor:pointer;border:none;outline:none}
input,select,textarea{font-family:var(--font);outline:none}

/* SPLASH */
.splash{position:fixed;inset:0;background:var(--bg);display:flex;flex-direction:column;align-items:center;justify-content:center;gap:24px;z-index:999}
.splash-logo{display:flex;align-items:center;gap:10px;font-size:24px;font-weight:700;letter-spacing:-0.5px}
.logo-hex{color:var(--accent);font-size:32px}
.logo-dot{color:var(--accent)}
.spinner{width:20px;height:20px;border:2px solid var(--border-strong);border-top-color:var(--accent);border-radius:50%;animation:spin .7s linear infinite}
@keyframes spin{to{transform:rotate(360deg)}}

/* LAYOUT */
.layout{display:flex;height:100vh;overflow:hidden}
.sidebar{width:var(--sidebar-w);background:var(--surface);border-right:1px solid var(--border);display:flex;flex-direction:column;flex-shrink:0;overflow:hidden;position:relative;z-index:150}
.main-content{flex:1;overflow:auto;background:var(--bg)}

/* SIDEBAR */
.sidebar-header{padding:16px 16px 8px;display:flex;align-items:center;gap:8px;border-bottom:1px solid var(--border)}
.brand{font-size:15px;font-weight:700;letter-spacing:-0.3px}
.brand-dot{color:var(--accent)}
.sidebar-nav{flex:1;padding:8px 0;overflow-y:auto}
.nav-item{display:flex;align-items:center;gap:10px;padding:8px 14px;color:var(--text-muted);border-radius:var(--radius);margin:1px 8px;cursor:pointer;transition:all .15s;font-size:13.5px;user-select:none}
.nav-item:hover{background:var(--surface-2);color:var(--text)}
.nav-item.active{background:var(--accent-dim);color:var(--accent)}
.nav-icon{width:18px;text-align:center;font-size:16px;flex-shrink:0}
.sidebar-footer{padding:10px 8px;border-top:1px solid var(--border)}
.user-pill{display:flex;align-items:center;gap:8px;padding:8px;border-radius:var(--radius);cursor:pointer}
.user-pill:hover{background:var(--surface-2)}
.user-avatar{width:28px;height:28px;border-radius:50%;background:var(--accent-dim);border:1px solid var(--accent-border);display:flex;align-items:center;justify-content:center;font-size:12px;color:var(--accent);font-weight:600;flex-shrink:0}
.user-info{flex:1;min-width:0}
.user-email{font-size:11.5px;color:var(--text-muted);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.user-role{font-size:10px;color:var(--text-faint);text-transform:uppercase;letter-spacing:.5px}

/* TOPBAR */
.topbar{height:52px;border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between;padding:0 24px;background:var(--surface)}
.topbar-title{font-size:15px;font-weight:600}
.topbar-actions{display:flex;align-items:center;gap:8px}
.btn-icon{width:32px;height:32px;border-radius:var(--radius);background:transparent;color:var(--text-muted);display:flex;align-items:center;justify-content:center;font-size:16px;transition:all .15s}
.btn-icon:hover{background:var(--surface-2);color:var(--text)}

/* PAGE */
.page{padding:24px;max-width:1400px}
.page-header{margin-bottom:24px}
.page-title{font-size:20px;font-weight:700;letter-spacing:-0.3px}
.page-sub{color:var(--text-muted);font-size:13px;margin-top:4px}

/* CARDS */
.card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:20px}
.card-sm{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:14px}
.card-title{font-size:12px;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.7px;margin-bottom:12px}

/* GRID */
.grid-2{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.grid-3{display:grid;grid-template-columns:1fr 1fr 1fr;gap:16px}
.grid-4{display:grid;grid-template-columns:repeat(4,1fr);gap:16px}
.grid-auto{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:16px}

/* STATUS BADGES */
.badge{display:inline-flex;align-items:center;gap:5px;padding:2px 8px;border-radius:20px;font-size:11.5px;font-weight:500}
.badge-idle{background:var(--surface-2);color:var(--text-muted)}
.badge-running{background:var(--accent-dim);color:var(--accent)}
.badge-done{background:var(--green-dim);color:var(--green)}
.badge-error{background:var(--red-dim);color:var(--red)}
.badge-waiting{background:var(--yellow-dim);color:var(--yellow)}
.badge-offline{background:var(--surface-2);color:var(--text-faint)}
.badge-active{background:var(--green-dim);color:var(--green)}
.badge-planned{background:var(--surface-2);color:var(--text-muted)}
.badge-not-ready{background:var(--yellow-dim);color:var(--yellow)}
.badge-inactive{background:var(--surface-2);color:var(--text-faint)}
.dot{width:6px;height:6px;border-radius:50%;background:currentColor;display:inline-block}
.dot-pulse{animation:pulse 2s ease infinite}
@keyframes pulse{0%,100%{opacity:1}50%{opacity:.4}}

/* STAT CARDS */
.stat-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:18px 20px}
.stat-label{font-size:12px;color:var(--text-muted);font-weight:500;margin-bottom:6px}
.stat-value{font-size:26px;font-weight:700;letter-spacing:-0.5px;line-height:1}
.stat-sub{font-size:12px;color:var(--text-muted);margin-top:6px}
.stat-accent{color:var(--accent)}

/* AGENT CARDS */
.agent-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:18px;cursor:pointer;transition:all .2s;position:relative;overflow:hidden}
.agent-card:hover{border-color:var(--accent-border);box-shadow:0 0 0 1px var(--accent-border),var(--shadow)}
.agent-card.running{border-color:var(--accent-border)}
.agent-card.running::before{content:'';position:absolute;top:0;left:0;right:0;height:2px;background:linear-gradient(90deg,var(--accent),transparent);animation:shimmer 2s ease infinite}
.task-running{position:relative;border-left:2px solid var(--accent)!important}.task-running::after{content:'';position:absolute;top:0;left:0;right:0;height:2px;background:linear-gradient(90deg,var(--accent),transparent);animation:shimmer 2s ease infinite}
@keyframes shimmer{0%{opacity:.5}50%{opacity:1}100%{opacity:.5}}
.agent-avatar{width:42px;height:42px;border-radius:12px;background:var(--accent-dim);border:1px solid var(--accent-border);display:flex;align-items:center;justify-content:center;font-size:20px;margin-bottom:12px}
.agent-name{font-size:14px;font-weight:700;margin-bottom:2px}
.agent-role{font-size:12px;color:var(--text-muted);margin-bottom:10px;line-height:1.4}
.agent-model{font-size:11px;color:var(--text-faint);display:flex;align-items:center;gap:4px}

/* KANBAN */
.kanban{display:flex;gap:14px;overflow-x:auto;padding-bottom:8px}
.kanban::-webkit-scrollbar{height:5px}
.kanban::-webkit-scrollbar-track{background:transparent}
.kanban::-webkit-scrollbar-thumb{background:var(--border-strong);border-radius:4px}
.kanban-col{min-width:230px;max-width:230px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);overflow:hidden;flex-shrink:0}
.kanban-col-header{padding:11px 14px;border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between}
.kanban-col-title{font-size:12px;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.6px}
.kanban-count{background:var(--surface-2);color:var(--text-muted);font-size:11px;padding:1px 7px;border-radius:20px}
.kanban-cards{padding:10px;display:flex;flex-direction:column;gap:8px;min-height:80px}
.task-card{background:var(--surface-2);border:1px solid var(--border);border-radius:var(--radius);padding:11px;cursor:pointer;transition:all .15s}
.task-card:hover{border-color:var(--border-strong);background:var(--surface-3)}
.task-title{font-size:12.5px;font-weight:500;margin-bottom:6px;line-height:1.4}
.task-meta{display:flex;align-items:center;gap:6px;font-size:11px;color:var(--text-faint)}
.task-agent{color:var(--accent);font-weight:500}
.empty-state{text-align:center;padding:32px 16px;color:var(--text-faint);font-size:12.5px}

/* TABLES */
.table{width:100%;border-collapse:collapse}
.table th{font-size:11px;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.6px;padding:10px 14px;text-align:left;border-bottom:1px solid var(--border)}
.table td{padding:12px 14px;border-bottom:1px solid var(--border);font-size:13px;vertical-align:middle}
.table tr:last-child td{border-bottom:none}
.table tr:hover td{background:var(--surface-2)}

/* SIDE PANEL */
.side-panel-overlay{position:fixed;inset:0;background:rgba(0,0,0,.4);z-index:100;display:flex;justify-content:flex-end;animation:fadeIn .15s ease}
.side-panel{width:420px;height:100%;background:var(--surface);border-left:1px solid var(--border);overflow-y:auto;animation:slideIn .2s ease;box-shadow:var(--shadow-lg)}
.side-panel.side-panel-wide{width:680px;display:flex;flex-direction:column;overflow:hidden}
@media(max-width:780px){.side-panel.side-panel-wide{width:100vw}}
@keyframes fadeIn{from{opacity:0}to{opacity:1}}
@keyframes slideIn{from{transform:translateX(20px)}to{transform:translateX(0)}}
.panel-header{padding:18px 20px;border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between;position:sticky;top:0;background:var(--surface)}
.panel-title{font-size:15px;font-weight:700}
.panel-close{background:var(--surface-2);border:none;width:28px;height:28px;border-radius:6px;color:var(--text-muted);cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:16px;transition:all .15s}
.panel-close:hover{color:var(--text)}
.panel-body{padding:20px}
.panel-section{margin-bottom:20px}
.panel-section-title{font-size:11px;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.7px;margin-bottom:10px}
.info-row{display:flex;justify-content:space-between;align-items:center;padding:7px 0;border-bottom:1px solid var(--border)}
.info-row:last-child{border-bottom:none}
.info-key{font-size:12px;color:var(--text-muted)}
.info-val{font-size:12.5px;font-weight:500;max-width:60%;text-align:right;word-break:break-all}
/* AGENT PANEL WIDE */
.ap-hero{padding:20px;border-bottom:1px solid var(--border);display:flex;align-items:flex-start;gap:16px;flex-shrink:0}
.ap-avatar-wrap{position:relative;flex-shrink:0}
.ap-avatar{width:64px;height:64px;border-radius:16px;background:var(--accent-dim);border:2px solid var(--accent-border);display:flex;align-items:center;justify-content:center;font-size:30px;cursor:pointer;transition:all .2s;user-select:none}
.ap-avatar:hover{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-dim)}
.ap-avatar-hint{position:absolute;bottom:-2px;right:-2px;background:var(--surface-3);border-radius:50%;width:18px;height:18px;display:flex;align-items:center;justify-content:center;font-size:11px;color:var(--text-muted);border:1px solid var(--border)}
.ap-info{flex:1;min-width:0}
.ap-name{font-size:18px;font-weight:800;letter-spacing:-0.3px;margin-bottom:2px}
.ap-bio{font-size:13px;color:var(--text-muted);line-height:1.5;margin-top:4px;cursor:pointer}
.ap-bio:hover{color:var(--text)}
.ap-bio-edit{width:100%;background:var(--bg);border:1px solid var(--accent-border);border-radius:var(--radius);color:var(--text);font-size:13px;padding:6px 10px;resize:none;font-family:var(--font);margin-top:4px}
.ap-bio-edit:focus{outline:none;border-color:var(--accent)}
.ap-emoji-picker{display:flex;flex-wrap:wrap;gap:6px;padding:12px;background:var(--surface-2);border:1px solid var(--border);border-radius:var(--radius-lg);position:absolute;top:70px;left:0;z-index:200;box-shadow:var(--shadow-lg);width:220px}
.ap-emoji-picker span{font-size:22px;cursor:pointer;padding:4px;border-radius:6px;transition:background .1s}
.ap-emoji-picker span:hover{background:var(--surface-3)}
.ap-tabs{display:flex;border-bottom:1px solid var(--border);flex-shrink:0;background:var(--surface)}
.ap-tab{flex:1;padding:10px;text-align:center;font-size:13px;font-weight:500;color:var(--text-muted);cursor:pointer;border-bottom:2px solid transparent;transition:all .15s;user-select:none}
.ap-tab:hover{color:var(--text);background:var(--surface-2)}
.ap-tab.active{color:var(--accent);border-bottom-color:var(--accent);background:transparent}
.ap-tab-body{flex:1;overflow:hidden;display:flex;flex-direction:column}
.ap-tab-pane{display:none;flex:1;overflow-y:auto;flex-direction:column}
.ap-tab-pane.active{display:flex}
/* Panel inline chat */
.panel-chat-layout{display:flex;flex-direction:column;flex:1;overflow:hidden}
.panel-chat-msgs{flex:1;overflow-y:auto;padding:14px 16px;display:flex;flex-direction:column;gap:10px}
.panel-chat-bar{border-top:1px solid var(--border);padding:10px 14px;display:flex;gap:8px;background:var(--surface);flex-shrink:0}
.panel-chat-input{flex:1;padding:8px 12px;background:var(--bg);border:1px solid var(--border-strong);border-radius:var(--radius);color:var(--text);font-size:13px;resize:none;height:38px;max-height:100px;overflow-y:auto;font-family:var(--font)}
.panel-chat-input:focus{border-color:var(--accent);outline:none}

/* BUTTONS */
.btn{display:inline-flex;align-items:center;gap:6px;padding:7px 14px;border-radius:var(--radius);font-size:13px;font-weight:500;cursor:pointer;transition:all .15s;border:none}
.btn-primary{background:var(--accent);color:#fff}
.btn-primary:hover{opacity:.9}
.btn-secondary{background:var(--surface-2);color:var(--text);border:1px solid var(--border)}
.btn-secondary:hover{background:var(--surface-3)}
.btn-ghost{background:transparent;color:var(--text-muted)}
.btn-ghost:hover{color:var(--text);background:var(--surface-2)}
.btn-danger{background:var(--red-dim);color:var(--red)}
.btn-danger:hover{opacity:.9}

/* LOGIN */
.login-page{min-height:100vh;display:flex;align-items:center;justify-content:center;background:var(--bg)}
.login-box{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:36px 40px;width:100%;max-width:380px;box-shadow:var(--shadow-lg)}
.login-logo{text-align:center;margin-bottom:28px}
.login-logo-icon{font-size:36px;color:var(--accent)}
.login-logo-name{font-size:22px;font-weight:800;letter-spacing:-0.5px;margin-top:6px}
.login-logo-dot{color:var(--accent)}
.form-group{margin-bottom:16px}
.form-label{display:block;font-size:12px;font-weight:600;color:var(--text-muted);margin-bottom:6px}
.form-input{width:100%;padding:9px 12px;background:var(--bg);border:1px solid var(--border-strong);border-radius:var(--radius);color:var(--text);font-size:14px;transition:border .15s}
.form-input:focus{border-color:var(--accent)}
.form-input::placeholder{color:var(--text-faint)}
.login-btn{width:100%;padding:10px;background:var(--accent);color:#fff;border:none;border-radius:var(--radius);font-size:14px;font-weight:600;cursor:pointer;transition:opacity .15s;margin-top:8px}
.login-btn:hover{opacity:.9}
.login-error{background:var(--red-dim);border:1px solid rgba(239,68,68,.3);border-radius:var(--radius);padding:10px 12px;font-size:13px;color:var(--red);margin-top:12px;display:none}

/* CHARTS */
.bar-chart{display:flex;align-items:flex-end;gap:4px;height:80px}
.bar{flex:1;background:var(--accent-dim);border-radius:3px 3px 0 0;transition:height .3s ease;min-height:2px;position:relative;cursor:default}
.bar:hover{background:var(--accent)}
.bar-label{font-size:10px;color:var(--text-faint);text-align:center;margin-top:4px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}

/* USAGE PAGE */
.usage-filter-bar{display:flex;gap:6px;margin-bottom:20px}
.filter-btn{padding:5px 12px;border-radius:20px;font-size:12.5px;background:var(--surface);border:1px solid var(--border);color:var(--text-muted);cursor:pointer;transition:all .15s}
.filter-btn:hover{border-color:var(--border-strong);color:var(--text)}
.filter-btn.active{background:var(--accent-dim);border-color:var(--accent-border);color:var(--accent)}

/* DIVIDER */
.divider{height:1px;background:var(--border);margin:16px 0}

/* PROGRESS */
.progress-bar-wrap{background:var(--surface-2);border-radius:4px;height:5px;overflow:hidden}
.progress-bar{height:100%;background:var(--accent);border-radius:4px;transition:width .4s ease}

/* TAG */
.tag{display:inline-flex;align-items:center;gap:4px;padding:2px 7px;background:var(--surface-2);border:1px solid var(--border);border-radius:4px;font-size:11px;color:var(--text-muted);font-family:monospace}

/* CHAT */
.chat-layout{display:flex;height:calc(100vh - 52px)}
.chat-messages{flex:1;overflow-y:auto;padding:20px;display:flex;flex-direction:column;gap:12px}
.chat-input-bar{border-top:1px solid var(--border);padding:14px 20px;display:flex;gap:10px;background:var(--surface)}
.chat-input{flex:1;padding:10px 14px;background:var(--bg);border:1px solid var(--border-strong);border-radius:var(--radius);color:var(--text);font-size:14px;resize:none;height:42px;max-height:120px;overflow-y:auto}
.chat-input:focus{border-color:var(--accent)}
.msg{max-width:70%;padding:10px 14px;border-radius:var(--radius-lg);font-size:13.5px;line-height:1.5}
.msg-user{background:var(--accent);color:#fff;margin-left:auto;border-bottom-right-radius:4px}
.msg-agent{background:var(--surface-2);border:1px solid var(--border);margin-right:auto;border-bottom-left-radius:4px}
.msg-time{font-size:10.5px;color:var(--text-faint);margin-top:4px}
/* Mensagens técnicas internas — badge colapsável */
.msg-tech{display:flex;align-items:center;gap:6px;padding:4px 10px;border-radius:6px;font-size:11px;color:var(--text-faint);background:var(--surface-2);border:1px solid var(--border);margin:2px 0;max-width:100%;flex-wrap:wrap}
.msg-tech-icon{opacity:.5;flex-shrink:0}
.msg-tech-label{color:var(--text-faint);font-style:italic;flex:1}
.msg-tech-btn{background:none;border:none;color:var(--text-faint);cursor:pointer;font-size:10px;padding:0 3px;flex-shrink:0}
.msg-tech-btn:hover{color:var(--text-muted)}
.msg-tech-body{display:none;width:100%;margin:4px 0 0;font-size:10px;color:var(--text-muted);white-space:pre-wrap;word-break:break-word;background:var(--surface);border-radius:4px;padding:6px 8px;max-height:120px;overflow-y:auto;border:1px solid var(--border)}
.voice-btn{padding:10px 16px;background:var(--surface-2);border:1px solid var(--border);border-radius:var(--radius);color:var(--text-muted);cursor:pointer;font-size:18px;transition:all .15s}
.voice-btn:hover{border-color:var(--accent-border);color:var(--accent)}

/* RISK */
.risk-read{background:var(--green-dim);color:var(--green)}
.risk-write{background:var(--yellow-dim);color:var(--yellow)}
.risk-destructive{background:var(--red-dim);color:var(--red)}

/* SCROLLBAR */
::-webkit-scrollbar{width:5px}
::-webkit-scrollbar-track{background:transparent}
::-webkit-scrollbar-thumb{background:var(--border-strong);border-radius:4px}
::-webkit-scrollbar-thumb:hover{background:var(--text-faint)}

/* MISC */
.truncate{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.flex{display:flex}.flex-1{flex:1}.min-w-0{min-width:0}.items-center{align-items:center}.justify-between{justify-content:space-between}.gap-2{gap:8px}.gap-3{gap:12px}.mb-1{margin-bottom:4px}.mb-2{margin-bottom:8px}.mb-3{margin-bottom:12px}.mb-4{margin-bottom:20px}.mt-1{margin-top:4px}.mt-2{margin-top:8px}.mt-3{margin-top:12px}.text-sm{font-size:12.5px}.text-xs{font-size:11.5px}.text-muted{color:var(--text-muted)}.text-accent{color:var(--accent)}.font-bold{font-weight:700}.font-medium{font-weight:500}
.phase2-tag{background:var(--surface-2);border:1px dashed var(--border-strong);border-radius:4px;padding:1px 7px;font-size:10.5px;color:var(--text-faint)}

/* INTEGRATIONS */
.integ-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:16px;transition:border-color .15s}
.integ-card:hover{border-color:var(--border-strong)}
.integ-card-header{display:flex;align-items:flex-start;gap:12px;margin-bottom:4px}
.integ-icon{width:40px;height:40px;border-radius:10px;border:1px solid;display:flex;align-items:center;justify-content:center;font-size:20px;flex-shrink:0}

/* SKILLS PAGE */
.skills-layout{display:flex;gap:0;height:calc(100vh - 180px);border:1px solid var(--border);border-radius:var(--radius-lg);overflow:hidden;background:var(--surface)}
.skills-sidebar{width:240px;border-right:1px solid var(--border);overflow-y:auto;flex-shrink:0;background:var(--surface-2)}
.skills-editor{flex:1;overflow:hidden;display:flex;flex-direction:column}
.skill-agent-group{border-bottom:1px solid var(--border);padding-bottom:8px;margin-bottom:0}
.skill-agent-label{padding:10px 12px 4px;font-size:10px;font-weight:700;color:var(--accent);text-transform:uppercase;letter-spacing:.8px}
.skill-group-name{padding:4px 12px 2px;font-size:10px;color:var(--text-faint);text-transform:uppercase;letter-spacing:.5px}
.skill-file-item{display:flex;align-items:center;gap:6px;padding:5px 12px 5px 20px;cursor:pointer;font-size:12.5px;color:var(--text-muted);transition:all .1s;border-radius:0}
.skill-file-item:hover{background:var(--surface-3);color:var(--text)}
.skill-file-item.active{background:var(--accent-dim);color:var(--accent)}
.skill-file-icon{font-size:12px;flex-shrink:0}
.skill-file-name{flex:1;min-width:0}
.skills-editor-inner{display:flex;flex-direction:column;height:100%}
.skills-editor-topbar{padding:10px 16px;border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between;flex-shrink:0;background:var(--surface)}
.skill-editor-ta{flex:1;width:100%;background:var(--bg);color:var(--text);border:none;outline:none;padding:16px 20px;font-family:'JetBrains Mono',monospace,var(--font);font-size:13px;line-height:1.6;resize:none;tab-size:2}
.skill-editor-ta:focus{outline:none}

/* ── JARVIS / VOICE COMMAND ─────────────────────────────────── */
.jarvis-page{padding-top:12px;padding-bottom:40px}

.jarvis-header{text-align:center;margin-bottom:28px}
.jarvis-wordmark{display:inline-flex;align-items:center;gap:10px;font-size:22px;font-weight:800;letter-spacing:-.5px}
.jarvis-logo-icon{color:var(--accent);font-size:26px}
.jarvis-tag{font-size:10px;font-weight:600;letter-spacing:1.2px;text-transform:uppercase;color:var(--text-faint);background:var(--surface-2);border:1px solid var(--border);border-radius:4px;padding:2px 8px;align-self:center}

/* Agent selector */
.jarvis-agent-bar{display:flex;flex-direction:column;align-items:center;gap:10px;margin-bottom:28px}
.jarvis-agent-chips{display:flex;gap:8px;flex-wrap:wrap;justify-content:center}
.jarvis-agent-chip{display:inline-flex;align-items:center;gap:6px;padding:6px 14px;border-radius:20px;font-size:13px;font-weight:500;background:var(--surface);border:1px solid var(--border);color:var(--text-muted);cursor:pointer;transition:all .15s}
.jarvis-agent-chip:hover{border-color:var(--accent-border);color:var(--text)}
.jarvis-agent-chip.active{background:var(--accent-dim);border-color:var(--accent-border);color:var(--accent)}
.jarvis-chip-sub{font-size:10px;color:var(--text-faint);background:var(--surface-2);padding:1px 6px;border-radius:3px}
.jarvis-agent-label{font-size:12px;color:var(--text-muted);font-style:italic}

/* Orb */
.jarvis-orb-section{display:flex;flex-direction:column;align-items:center;gap:16px;margin-bottom:28px;padding:8px 0}
.jarvis-orb-wrap{position:relative;width:160px;height:160px;display:flex;align-items:center;justify-content:center}
.jarvis-orb{width:96px;height:96px;border-radius:50%;background:var(--surface);border:2px solid var(--border-strong);display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .25s;position:relative;z-index:2;box-shadow:0 4px 24px rgba(0,0,0,.3)}
.jarvis-orb:hover{border-color:var(--accent-border);box-shadow:0 0 0 10px var(--accent-dim),0 4px 24px rgba(0,0,0,.3)}
.jarvis-orb-icon{font-size:30px;color:var(--text-muted);transition:all .2s;user-select:none}

.jarvis-orb-listening{background:var(--accent-dim);border-color:var(--accent);animation:orb-pulse 1.4s ease infinite}
.jarvis-orb-listening .jarvis-orb-icon{color:var(--accent)}
.jarvis-orb-processing .jarvis-orb-icon{animation:spin .7s linear infinite;color:var(--accent)}
.jarvis-orb-processing{border-color:var(--accent-border)}
.jarvis-orb-speaking{border-color:var(--accent-border);background:var(--accent-dim)}
.jarvis-orb-speaking .jarvis-orb-icon{color:var(--accent)}
.jarvis-orb-error{border-color:var(--red);background:var(--red-dim)}
.jarvis-orb-error .jarvis-orb-icon{color:var(--red)}

@keyframes orb-pulse{0%,100%{box-shadow:0 0 0 0 rgba(139,92,246,0),0 4px 24px rgba(0,0,0,.3)}50%{box-shadow:0 0 0 18px rgba(139,92,246,0),0 4px 24px rgba(0,0,0,.3)}}

.jarvis-orb-ring{position:absolute;border-radius:50%;border:1px solid transparent;transition:all .35s;opacity:0}
.jarvis-ring-1{width:118px;height:118px;border-color:rgba(139,92,246,.3)}
.jarvis-ring-2{width:138px;height:138px;border-color:rgba(139,92,246,.2)}
.jarvis-ring-3{width:158px;height:158px;border-color:rgba(139,92,246,.1)}
.ring-active{opacity:1;animation:ring-breathe 2s ease infinite}
.jarvis-ring-2.ring-active{animation-delay:.15s}
.jarvis-ring-3.ring-active{animation-delay:.3s}
@keyframes ring-breathe{0%,100%{opacity:.5;transform:scale(1)}50%{opacity:1;transform:scale(1.02)}}

.jarvis-status-text{font-size:13.5px;color:var(--text-muted);text-align:center;min-height:22px;transition:color .2s;letter-spacing:.01em}
.jarvis-compat-warn{font-size:12px;color:var(--yellow);background:rgba(234,179,8,.08);border:1px solid rgba(234,179,8,.25);border-radius:var(--radius);padding:8px 14px;text-align:center;max-width:400px}

/* Panels */
.jarvis-panel{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:16px;margin-bottom:12px}
.jarvis-panel-label{font-size:10.5px;font-weight:700;color:var(--text-muted);text-transform:uppercase;letter-spacing:.8px;margin-bottom:10px}
.jarvis-transcript-ta{width:100%;background:var(--bg);border:1px solid var(--border);border-radius:var(--radius);color:var(--text);padding:10px 12px;font-size:14px;resize:vertical;font-family:var(--font);line-height:1.5;min-height:60px}
.jarvis-transcript-ta:focus{border-color:var(--accent);outline:none}
.jarvis-panel-controls{display:flex;align-items:center;justify-content:space-between;margin-top:10px;flex-wrap:wrap;gap:8px}
.jarvis-toggle-label{display:flex;align-items:center;gap:6px;font-size:12px;color:var(--text-muted);cursor:pointer;user-select:none}
.jarvis-toggle-label input{accent-color:var(--accent)}
.jarvis-response-area{min-height:52px;padding:12px;background:var(--bg);border:1px solid var(--border);border-radius:var(--radius);font-size:14px;line-height:1.65;color:var(--text);word-break:break-word}
.jarvis-response-text{line-height:1.65}

/* ── VIRTUAL OFFICE ──────────────────────────────────────────── */
.off-page{padding-bottom:24px}
.off-topbar{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:16px;flex-wrap:wrap;gap:12px}
.off-pills{display:flex;gap:6px;flex-wrap:wrap}
.off-pill{font-size:11px;font-weight:500;padding:3px 9px;border-radius:12px;border:1px solid transparent;white-space:nowrap}

/* Scene */
.off-scene{
  position:relative;height:520px;
  background:var(--bg);
  background-image:
    linear-gradient(rgba(255,255,255,.015) 1px,transparent 1px),
    linear-gradient(90deg,rgba(255,255,255,.015) 1px,transparent 1px);
  background-size:36px 36px;
  border:1px solid var(--border);border-radius:var(--radius-lg);
  overflow:hidden;
}

/* Rooms */
.off-room{
  position:absolute;
  border:1px solid var(--border);border-radius:7px;
  overflow:hidden;cursor:default;
  transition:border-color .2s;
}
.off-room:hover{border-color:var(--border-strong)}
.off-room-mike{
  background:var(--surface);
  border-color:var(--accent-border);
  box-shadow:0 0 0 1px var(--accent-dim) inset,0 2px 12px rgba(139,92,246,.06);
}
.off-room-mike:hover{border-color:var(--accent)}
.off-room-meeting{background:linear-gradient(135deg,var(--surface) 0%,rgba(96,165,250,.03) 100%)}
.off-room-ops{background:var(--surface)}
.off-room-lounge{background:linear-gradient(180deg,var(--surface-2) 0%,var(--surface) 100%)}
.off-room-label{
  position:absolute;top:7px;left:10px;
  font-size:9.5px;font-weight:700;color:var(--text-faint);
  text-transform:uppercase;letter-spacing:.9px;user-select:none;
}
.off-label-accent{color:var(--accent);opacity:.85}

/* Director desk */
.off-desk-director{
  position:absolute;left:50%;top:48%;transform:translate(-50%,-50%);
  width:58px;height:34px;
  background:var(--accent-dim);border:1px solid var(--accent-border);border-radius:5px;
}
.off-monitor{
  position:absolute;top:-14px;left:50%;transform:translateX(-50%);
  width:22px;height:14px;
  background:var(--surface-3);border:1px solid var(--border-strong);border-radius:2px;
}
.off-monitor::after{
  content:'';position:absolute;bottom:-4px;left:50%;transform:translateX(-50%);
  width:8px;height:4px;background:var(--surface-3);border-radius:0 0 2px 2px;
}

/* Room decorations */
.off-room-deco{position:absolute}
.off-deco-plant{
  right:8px;bottom:8px;width:13px;height:20px;
  background:radial-gradient(ellipse at 50% 100%,#15803d 55%,transparent 100%);
  border-radius:50% 50% 20% 20%;opacity:.5;
}

/* Ops desks row */
.off-desks-row{
  display:flex;gap:3%;
  position:absolute;bottom:16%;left:8%;width:84%;
  justify-content:space-between;
}
.off-desk-ops{
  flex:1;height:28px;max-width:100px;position:relative;
  background:var(--surface-2);border:1px solid var(--border);border-radius:4px;
}
.off-monitor-sm{
  position:absolute;top:-11px;left:50%;transform:translateX(-50%);
  width:16px;height:11px;
  background:var(--surface-3);border:1px solid var(--border);border-radius:2px;
}
.off-monitor-sm::after{
  content:'';position:absolute;bottom:-3px;left:50%;transform:translateX(-50%);
  width:6px;height:3px;background:var(--surface-3);border-radius:0 0 2px 2px;
}

/* Meeting table */
.off-meeting-table{
  position:absolute;left:50%;top:55%;transform:translate(-50%,-50%);
  width:55%;height:45%;min-width:80px;max-width:240px;
  background:var(--surface-3);border:1px solid var(--border);border-radius:8px;
}
.off-meeting-chairs{
  position:absolute;inset:-8px;
  border:6px solid transparent;
  border-radius:12px;
  background:
    radial-gradient(circle 4px at 10% 50%,var(--surface-2) 100%,transparent 0),
    radial-gradient(circle 4px at 90% 50%,var(--surface-2) 100%,transparent 0),
    radial-gradient(circle 4px at 30% 0%,var(--surface-2) 100%,transparent 0),
    radial-gradient(circle 4px at 70% 0%,var(--surface-2) 100%,transparent 0),
    radial-gradient(circle 4px at 30% 100%,var(--surface-2) 100%,transparent 0),
    radial-gradient(circle 4px at 70% 100%,var(--surface-2) 100%,transparent 0);
}

/* Lounge furniture */
.off-lounge-furniture{
  display:flex;align-items:center;gap:24px;
  position:absolute;bottom:18%;left:50%;transform:translateX(-50%);
}
.off-sofa{
  width:54px;height:22px;
  background:var(--surface-3);border:1px solid var(--border);
  border-radius:6px 6px 4px 4px;position:relative;flex-shrink:0;
}
.off-sofa::before{
  content:'';position:absolute;top:-4px;left:2px;right:2px;height:6px;
  background:var(--surface-3);border:1px solid var(--border);border-radius:4px 4px 0 0;
}
.off-coffee-table{
  width:32px;height:20px;flex-shrink:0;
  background:var(--surface-2);border:1px solid var(--border);border-radius:4px;
}

/* ── Agents layer ── */
#off-agents-layer{position:absolute;inset:0;pointer-events:none}
#off-agents-layer.off-animated .off-agent{
  transition:left 1.5s cubic-bezier(.4,0,.2,1),top 1.5s cubic-bezier(.4,0,.2,1);
}
.off-agent{
  position:absolute;display:flex;flex-direction:column;align-items:center;gap:2px;
  transform:translate(-50%,-50%);pointer-events:all;cursor:pointer;z-index:10;user-select:none;
}
.off-agent-dim{opacity:.34;filter:grayscale(1)}

/* ── Avatar structure ── */
.oa-wrap{position:relative;display:flex;align-items:center;justify-content:center}
.oa-figure-wrap{position:relative;display:flex;flex-direction:column;align-items:center}
.oa-figure{display:block}

/* Hover + Mike glow */
.off-agent:hover .oa-figure-wrap{filter:brightness(1.12) drop-shadow(0 0 6px rgba(139,92,246,.22))}
.off-agent-mike .oa-figure-wrap{filter:drop-shadow(0 0 8px rgba(139,92,246,.32))}
.off-agent-mike:hover .oa-figure-wrap{filter:brightness(1.12) drop-shadow(0 0 11px rgba(139,92,246,.48))}
.off-agent-mike .oa-name{color:var(--accent);font-weight:700}

/* ── Body animations ── */
@keyframes av-breathe{
  0%,100%{transform:translateY(0) scale(1)}
  50%{transform:translateY(-2px) scale(1.012)}
}
@keyframes av-work{
  0%,100%{transform:translateY(0) rotate(0deg)}
  25%{transform:translateY(-3px) rotate(-1.5deg)}
  75%{transform:translateY(-1px) rotate(1.5deg)}
}
@keyframes av-meet{
  0%,100%{transform:rotate(-1.5deg)}
  50%{transform:rotate(1.5deg)}
}
@keyframes av-wait{
  0%,100%{transform:translateY(0)}
  50%{transform:translateY(-2px)}
}
.av-idle{animation:av-breathe 2.8s ease-in-out infinite}
.av-running{animation:av-work 1.3s ease-in-out infinite}
.av-meeting{animation:av-meet 2.6s ease-in-out infinite}
.av-waiting{animation:av-wait 3.4s ease-in-out infinite}

/* ── Arm typing animation (running state) ── */
@keyframes av-type-l{
  0%,100%{transform:rotate(0deg)}
  25%{transform:rotate(-10deg)}
  75%{transform:rotate(5deg)}
}
@keyframes av-type-r{
  0%,100%{transform:rotate(0deg)}
  25%{transform:rotate(8deg)}
  75%{transform:rotate(-4deg)}
}
.av-running .oa-arm-g-l{
  transform-box:fill-box;transform-origin:50% 0%;
  animation:av-type-l .75s ease-in-out infinite;
}
.av-running .oa-arm-g-r{
  transform-box:fill-box;transform-origin:50% 0%;
  animation:av-type-r .75s ease-in-out .18s infinite;
}

/* ── Activity dot (running) ── */
.oa-act-dot{
  position:absolute;top:-11px;left:50%;transform:translateX(-50%);
  width:8px;height:8px;border-radius:50%;
  background:var(--accent);z-index:1;
}
@keyframes av-dot-pulse{
  0%,100%{transform:translateX(-50%) scale(1);opacity:1}
  50%{transform:translateX(-50%) scale(1.65);opacity:.38}
}
.av-running .oa-act-dot{animation:av-dot-pulse .9s ease-in-out infinite}

/* ── Waiting/meeting bubble ── */
.oa-bubble{
  position:absolute;top:-17px;left:50%;transform:translateX(-50%);
  font-size:11px;color:var(--yellow);letter-spacing:2px;
  user-select:none;white-space:nowrap;z-index:1;
}
@keyframes av-dots{
  0%,20%{opacity:1}
  50%{opacity:.18}
  80%,100%{opacity:1}
}
.av-meeting .oa-bubble,.av-waiting .oa-bubble{animation:av-dots 1.6s ease-in-out infinite}

/* ── Running ring ── */
.oa-ring{
  position:absolute;
  width:56px;height:56px;border-radius:50%;
  border:2px solid var(--accent);
  left:50%;top:40%;transform:translate(-50%,-50%);
  animation:oa-ring 2s ease-out infinite;pointer-events:none;
}
@keyframes oa-ring{
  0%{opacity:.8;transform:translate(-50%,-50%) scale(1)}
  100%{opacity:0;transform:translate(-50%,-50%) scale(1.55)}
}

/* ── Mike crown ── */
.oa-crown{
  position:absolute;top:-6px;left:50%;transform:translateX(-50%);
  font-size:11px;color:var(--accent);line-height:1;z-index:2;
}

/* ── Badge & labels ── */
.oa-badge{
  font-size:9px;font-weight:600;padding:1px 6px;border-radius:10px;
  white-space:nowrap;letter-spacing:.2px;
}
.off-bdg-running{background:var(--accent-dim);color:var(--accent);border:1px solid var(--accent-border)}
.off-bdg-meeting{background:rgba(167,139,250,.12);color:#a78bfa;border:1px solid rgba(167,139,250,.28)}
.off-bdg-waiting{background:var(--yellow-dim);color:var(--yellow);border:1px solid rgba(234,179,8,.3)}
.off-bdg-idle{background:var(--surface-2);color:var(--text-faint);border:1px solid var(--border)}
.off-bdg-error{background:var(--red-dim);color:var(--red);border:1px solid rgba(239,68,68,.3)}
.off-bdg-offline{background:var(--surface-2);color:var(--text-faint);border:1px solid var(--border)}
.oa-name{font-size:10px;font-weight:600;color:var(--text-muted);white-space:nowrap;text-shadow:0 1px 3px var(--bg)}
.oa-sub{font-size:9px;color:var(--accent);opacity:.7;white-space:nowrap;text-shadow:0 1px 2px var(--bg)}
.oa-task{font-size:9px;color:var(--text-faint);max-width:88px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;text-shadow:0 1px 2px var(--bg)}

/* ── Legend ── */
.off-legend{display:flex;align-items:center;gap:14px;margin-top:10px;padding:9px 14px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);flex-wrap:wrap}
.off-leg-item{display:flex;align-items:center;gap:5px;font-size:11px;color:var(--text-muted)}
.off-leg-dot{width:8px;height:8px;border-radius:50%;display:inline-block;flex-shrink:0}
/* ══ CRM AI-FIRST ══════════════════════════════════════════════ */
.crm-page{display:flex;flex-direction:column;gap:0;padding:0;height:100%;overflow:hidden}
.crm-header{display:flex;align-items:center;justify-content:space-between;padding:16px 20px 0}
.crm-title{font-size:18px;font-weight:700;color:var(--text);margin:0}
.crm-tabs{display:flex;gap:2px;padding:12px 20px 0;border-bottom:1px solid var(--border)}
.crm-tab{background:none;border:none;color:var(--text-muted);padding:8px 14px;cursor:pointer;font-size:13px;font-weight:500;border-radius:6px 6px 0 0;border-bottom:2px solid transparent;margin-bottom:-1px;transition:color .15s,border-color .15s}
.crm-tab:hover{color:var(--text)}
.crm-tab.active{color:var(--accent);border-bottom-color:var(--accent)}
.crm-body{flex:1;overflow:auto;padding:16px 20px}

/* Kanban */
.crm-kanban{display:flex;gap:10px;overflow-x:auto;min-height:calc(100vh - 220px);padding-bottom:20px}
.crm-col{min-width:200px;max-width:220px;flex-shrink:0;display:flex;flex-direction:column;gap:0}
.crm-col-header{display:flex;align-items:center;justify-content:space-between;padding:8px 10px;background:var(--surface);border-radius:8px 8px 0 0;border:1px solid var(--border);border-bottom:none}
.crm-col-name{font-size:11px;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.4px}
.crm-col-cnt{font-size:11px;font-weight:700;color:var(--text-dim);background:var(--surface-2);border-radius:10px;padding:1px 7px}
.crm-col-body{flex:1;background:var(--surface-2);border:1px solid var(--border);border-top:none;border-radius:0 0 8px 8px;padding:8px;display:flex;flex-direction:column;gap:7px;min-height:80px}
.crm-add-card{background:none;border:1px dashed var(--border);border-radius:6px;color:var(--text-faint);padding:6px;cursor:pointer;font-size:11px;width:100%;text-align:center;transition:border-color .15s,color .15s}
.crm-add-card:hover{border-color:var(--accent);color:var(--accent)}

/* Lead card */
.crm-card{background:var(--surface);border:1px solid var(--border);border-radius:7px;padding:9px 10px;cursor:pointer;transition:border-color .15s,box-shadow .15s;position:relative}
.crm-card:hover{border-color:var(--accent);box-shadow:0 2px 8px rgba(139,92,246,.12)}
.crm-card-del{position:absolute;top:4px;right:4px;width:18px;height:18px;border-radius:50%;background:transparent;color:var(--text-faint);border:none;cursor:pointer;font-size:14px;line-height:1;display:flex;align-items:center;justify-content:center;opacity:0;transition:opacity .15s,background .1s;padding:0;z-index:1}
.crm-card:hover .crm-card-del{opacity:1}
.crm-card-del:hover{background:var(--red-dim,rgba(239,68,68,.15));color:var(--red)}
.crm-card-top{display:flex;align-items:flex-start;justify-content:space-between;gap:6px}
.crm-card-name{font-size:12px;font-weight:600;color:var(--text);line-height:1.3}
.crm-temp{font-size:14px;flex-shrink:0}
.crm-card-co{font-size:11px;color:var(--text-muted);margin-top:2px}
.crm-card-scores{display:flex;flex-direction:column;gap:3px;margin:7px 0 4px}
.crm-score-bar{display:block;background:var(--surface-2);border-radius:3px;height:4px;overflow:hidden;position:relative}
.crm-score-bar span{display:block;height:100%;background:var(--accent);border-radius:3px;transition:width .3s}
.crm-card-nba{font-size:10px;color:var(--accent);margin-top:4px;line-height:1.3}
.crm-card-agent{font-size:10px;color:var(--text-faint);margin-top:4px;text-align:right}

/* Leads table */
.crm-leads-wrap{display:flex;flex-direction:column;gap:12px}
.crm-leads-toolbar{display:flex;gap:10px}
.crm-table{width:100%;border-collapse:collapse;font-size:12px}
.crm-table th{text-align:left;padding:8px 10px;border-bottom:2px solid var(--border);color:var(--text-dim);font-weight:600;font-size:11px;text-transform:uppercase;letter-spacing:.4px;white-space:nowrap}
.crm-tr{cursor:pointer;transition:background .1s}
.crm-tr:hover{background:var(--surface)}
.crm-tr td{padding:8px 10px;border-bottom:1px solid var(--border);color:var(--text);vertical-align:middle}
.crm-td-name{font-weight:600}
.crm-stage-pill{font-size:10px;font-weight:600;padding:2px 8px;border-radius:10px;white-space:nowrap}
.crm-score-num{font-size:11px;font-weight:700;color:var(--text-muted)}

/* Activities */
.crm-activities{display:flex;flex-direction:column;gap:10px;max-width:700px}
.crm-act-item{display:flex;gap:12px;padding:10px 14px;background:var(--surface);border:1px solid var(--border);border-radius:8px}
.crm-act-icon{font-size:18px;flex-shrink:0;margin-top:2px}
.crm-act-body{flex:1;min-width:0}
.crm-act-lead{font-size:12px;font-weight:600;color:var(--text);margin-bottom:2px}
.crm-act-co{color:var(--text-muted);font-weight:400}
.crm-act-content{font-size:13px;color:var(--text-muted);word-break:break-word}
.crm-act-meta{font-size:11px;color:var(--text-faint);margin-top:4px}

/* Approvals */
.crm-approvals{display:flex;flex-direction:column;gap:14px;max-width:700px}
.crm-section-title{font-size:15px;font-weight:600;color:var(--text);margin:0 0 8px;display:flex;align-items:center;gap:8px}
.badge-count{background:var(--accent);color:#fff;font-size:11px;font-weight:700;border-radius:10px;padding:1px 8px}
.crm-approval-card{background:var(--surface);border:1px solid var(--border);border-radius:8px;padding:14px 16px;display:flex;flex-direction:column;gap:6px}
.crm-approval-top{display:flex;align-items:center;gap:8px;flex-wrap:wrap}
.crm-approval-lead{font-weight:700;font-size:13px;color:var(--text)}
.crm-approval-action{font-size:14px;color:var(--text)}
.crm-approval-details{font-size:12px;color:var(--text-muted)}
.crm-approval-meta{font-size:11px;color:var(--text-faint)}
.crm-approval-btns{display:flex;gap:8px;margin-top:6px}
.btn-success{background:rgba(34,197,94,.15);color:#22c55e;border:1px solid rgba(34,197,94,.3)}
.btn-success:hover{background:rgba(34,197,94,.25)}
.btn-danger{background:rgba(239,68,68,.12);color:#ef4444;border:1px solid rgba(239,68,68,.25)}
.btn-danger:hover{background:rgba(239,68,68,.22)}

/* Settings */
.crm-settings{display:flex;flex-direction:column;gap:20px;max-width:580px}
.crm-stage-row{display:flex;align-items:center;gap:8px;padding:8px 0;border-bottom:1px solid var(--border)}
.crm-stage-dot{width:12px;height:12px;border-radius:50%;flex-shrink:0}
.crm-stage-name-inp{flex:1}
.crm-color-inp{width:36px;height:32px;border:1px solid var(--border);border-radius:6px;cursor:pointer;padding:2px;background:var(--surface)}
.crm-stage-add{display:flex;align-items:center;gap:8px;margin-top:12px;padding-top:12px;border-top:1px solid var(--border)}

/* Drawer */
.crm-drawer-overlay{position:fixed;inset:0;background:rgba(0,0,0,.45);z-index:200}
.crm-drawer{position:fixed;top:0;right:0;bottom:0;width:480px;max-width:96vw;background:var(--bg);border-left:1px solid var(--border);z-index:201;display:flex;flex-direction:column;overflow:hidden;box-shadow:-4px 0 24px rgba(0,0,0,.3)}
.crm-drawer-loading{display:flex;align-items:center;justify-content:center;flex:1}
.crm-drawer-header{padding:16px 18px 12px;border-bottom:1px solid var(--border);background:var(--surface);flex-shrink:0}
.crm-drawer-close{position:absolute;top:12px;right:14px;background:none;border:none;color:var(--text-faint);font-size:18px;cursor:pointer;padding:4px 8px;border-radius:4px}
.crm-drawer-close:hover{color:var(--text);background:var(--surface-2)}
.crm-drawer-name{font-size:18px;font-weight:700;color:var(--text);padding-right:32px;line-height:1.2}
.crm-drawer-meta{display:flex;align-items:center;gap:8px;flex-wrap:wrap;margin-top:6px}
.crm-temp-badge{font-size:12px;font-weight:600;padding:2px 8px;border-radius:10px;background:var(--surface-2)}
.crm-temp-hot{color:#f97316;background:rgba(249,115,22,.12)}
.crm-temp-warm{color:#eab308;background:rgba(234,179,8,.12)}
.crm-temp-cold{color:#06b6d4;background:rgba(6,182,212,.12)}
.crm-dnc-badge{font-size:11px;color:#ef4444;background:rgba(239,68,68,.12);border-radius:10px;padding:2px 8px}
.crm-optin-badge{font-size:11px;color:#22c55e;background:rgba(34,197,94,.12);border-radius:10px;padding:2px 8px}
.crm-drawer-scores{display:flex;gap:16px;margin-top:10px}
.crm-dscore{display:flex;align-items:center;gap:6px;font-size:11px;color:var(--text-muted)}
.crm-dscore label{width:36px;font-weight:600;flex-shrink:0}
.crm-score-track{width:80px;height:6px;background:var(--surface-2);border-radius:3px;overflow:hidden}
.crm-score-fill{height:100%;border-radius:3px;transition:width .3s}
.crm-dscore span{font-size:11px;font-weight:700;color:var(--text-dim);width:36px}
.crm-drawer-nba{margin-top:8px;font-size:12px;color:var(--accent);background:rgba(139,92,246,.08);border-radius:6px;padding:6px 10px;border-left:3px solid var(--accent)}
.crm-drawer-tabs{display:flex;gap:2px;padding:8px 14px 0;border-bottom:1px solid var(--border);background:var(--surface);flex-shrink:0}
.crm-drawer-tab{background:none;border:none;color:var(--text-muted);padding:6px 10px;cursor:pointer;font-size:12px;font-weight:500;border-bottom:2px solid transparent;margin-bottom:-1px;transition:color .15s,border-color .15s}
.crm-drawer-tab:hover{color:var(--text)}
.crm-drawer-tab.active{color:var(--accent);border-bottom-color:var(--accent)}
.crm-drawer-body{flex:1;overflow-y:auto;padding:16px 18px}
.crm-drawer-info,.crm-drawer-dossier,.crm-drawer-decisions,.crm-drawer-commitments,.crm-drawer-timeline{display:flex;flex-direction:column;gap:12px}
.crm-field-group{display:flex;flex-direction:column;gap:4px}
.crm-field-group label{font-size:11px;font-weight:600;color:var(--text-dim);text-transform:uppercase;letter-spacing:.4px}
.crm-field-row{display:flex;gap:10px}
.crm-field-row .crm-field-group{flex:1}
.crm-check-label{display:flex;align-items:center;gap:6px;font-size:12px;color:var(--text-muted);cursor:pointer}
.crm-textarea{resize:vertical;font-family:inherit;line-height:1.5}
.crm-dossier-ta{font-family:monospace;font-size:12px}
.crm-drawer-actions{display:flex;gap:8px;margin-top:4px;padding-top:12px;border-top:1px solid var(--border)}

/* Timeline */
.crm-tl-add{display:flex;gap:8px;align-items:center;margin-bottom:12px}
.crm-tl-add .input{flex:1}
.crm-tl-add select{flex-shrink:0;width:auto}
.crm-tl-feed{display:flex;flex-direction:column;gap:10px}
.crm-tl-item{display:flex;gap:10px;padding:10px;background:var(--surface);border:1px solid var(--border);border-radius:7px}
.crm-tl-icon{font-size:16px;flex-shrink:0;margin-top:1px}
.crm-tl-body{flex:1;min-width:0}
.crm-tl-content{font-size:13px;color:var(--text);word-break:break-word}
.crm-tl-meta{font-size:11px;color:var(--text-faint);margin-top:3px}

/* Decisions */
.crm-decision-item{padding:10px 12px;background:var(--surface);border:1px solid var(--border);border-radius:7px}
.crm-decision-text{font-size:13px;color:var(--text);font-weight:600}
.crm-decision-rationale{font-size:12px;color:var(--text-muted);margin-top:4px;font-style:italic}

/* Commitments */
.crm-commitment-item{display:flex;align-items:center;gap:8px;padding:8px 10px;background:var(--surface);border:1px solid var(--border);border-radius:7px}
.crm-commitment-item input[type=checkbox]{cursor:pointer;accent-color:var(--accent);width:15px;height:15px}
.crm-commitment-item span{flex:1;font-size:13px;color:var(--text)}
.crm-commitment-done span{text-decoration:line-through;color:var(--text-faint)}

/* ══ PROVIDER HEALTH BANNER ════════════════════════════════════ */
.prov-banner{display:flex;flex-wrap:wrap;align-items:center;gap:10px;padding:10px 16px;border-radius:var(--radius);margin-bottom:14px;font-size:13px;line-height:1.4}
.prov-banner-crit{background:rgba(239,68,68,.1);border:1px solid rgba(239,68,68,.35);color:var(--text)}
.prov-banner-warn{background:rgba(234,179,8,.1);border:1px solid rgba(234,179,8,.35);color:var(--text)}
.prov-banner-err{font-size:11px;color:var(--text-muted);font-family:monospace;background:var(--surface-2);border-radius:4px;padding:2px 6px;max-width:340px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.prov-banner-meta{font-size:11px;color:var(--text-faint)}
.prov-banner-btns{display:flex;gap:6px;margin-left:auto;flex-shrink:0}

/* ══ USAGE ALERTS ═══════════════════════════════════════════════ */
.usage-alert{padding:8px 14px;border-radius:6px;font-size:13px;margin-bottom:8px}
.usage-alert-crit{background:rgba(239,68,68,.1);border:1px solid rgba(239,68,68,.3);color:var(--text)}
.usage-alert-warn{background:rgba(234,179,8,.1);border:1px solid rgba(234,179,8,.3);color:var(--text)}

/* ══ JARVIS DIAGNOSTICS ═════════════════════════════════════════ */
.jarvis-diag-panel{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:24px;margin-top:20px;display:flex;flex-direction:column;gap:16px}
.jarvis-diag-title{font-size:17px;font-weight:700;color:var(--text)}
.jarvis-diag-desc{font-size:13px;color:var(--text-muted);line-height:1.6;margin:0}
.jarvis-diag-checks{display:flex;flex-direction:column;gap:8px}
.jarvis-diag-row{display:flex;align-items:center;gap:10px;padding:8px 12px;border-radius:6px;font-size:13px;background:var(--surface-2)}
.jarvis-diag-row.ok{border-left:3px solid var(--green)}
.jarvis-diag-row.fail{border-left:3px solid var(--red)}
.jarvis-diag-dot{width:8px;height:8px;border-radius:50%;background:currentColor;flex-shrink:0}
.jarvis-diag-row.ok .jarvis-diag-dot{color:var(--green)}
.jarvis-diag-row.fail .jarvis-diag-dot{color:var(--red)}
.jarvis-diag-fix{background:var(--surface-2);border-radius:8px;padding:16px;border-left:3px solid var(--accent)}
.jarvis-diag-fix-title{font-size:13px;font-weight:600;color:var(--text);margin-bottom:4px}

/* ══ OFFICE MAIN WRAP + CHAT PANEL ═════════════════════════════ */
.off-main-wrap{display:flex;gap:12px;align-items:flex-start}
.off-scene-col{flex:1;min-width:0;display:flex;flex-direction:column;gap:12px}

/* Painel lateral de chat */
.off-activity-panel{
  width:290px;flex-shrink:0;background:var(--surface);border:1px solid var(--border);
  border-radius:var(--radius-lg);display:flex;flex-direction:column;
  height:580px;overflow:hidden;transition:width .22s,opacity .22s,border-color .22s;
}
.off-activity-panel.closed{width:0;opacity:0;overflow:hidden;border-color:transparent}
.off-act-close{background:none;border:none;color:var(--text-faint);cursor:pointer;font-size:15px;padding:2px 6px;flex-shrink:0;line-height:1}
.off-act-close:hover{color:var(--text)}

/* Cabeçalho com abas de agente */
.off-chat-header{display:flex;align-items:center;gap:6px;padding:8px 10px 8px 8px;border-bottom:1px solid var(--border);flex-shrink:0;background:var(--surface-2)}
.off-agent-tabs{display:flex;gap:4px;flex:1;overflow-x:auto;scrollbar-width:none}
.off-agent-tabs::-webkit-scrollbar{display:none}
.off-agent-tab{
  background:none;border:1px solid transparent;border-radius:6px;cursor:pointer;
  font-size:16px;width:32px;height:32px;display:flex;align-items:center;justify-content:center;
  color:var(--text-muted);transition:background .15s,border-color .15s;flex-shrink:0;
}
.off-agent-tab:hover{background:var(--surface);border-color:var(--border)}
.off-agent-tab.active{background:var(--accent-dim);border-color:var(--accent-border);color:var(--accent)}
.off-chat-no-agents{font-size:11px;color:var(--text-faint);padding:4px 6px}

/* Barra de status */
.off-chat-statusbar{
  display:flex;align-items:center;justify-content:space-between;
  padding:4px 10px;border-bottom:1px solid var(--border);flex-shrink:0;
  background:var(--surface);min-height:24px;
}
.off-chat-status{font-size:10px;color:var(--text-muted);font-weight:500}
.off-chat-token-hint{font-size:9px;color:var(--text-faint);opacity:.7;cursor:help}

/* Feed de mensagens */
.off-chat-feed{
  flex:1;overflow-y:auto;padding:10px 8px;
  display:flex;flex-direction:column;gap:0;
}
.off-chat-feed::-webkit-scrollbar{width:4px}
.off-chat-feed::-webkit-scrollbar-thumb{background:var(--border);border-radius:2px}
.off-chat-empty{padding:30px 16px;text-align:center;font-size:12px;color:var(--text-faint);line-height:1.7}

/* Mensagens estilo chat ao vivo */
.off-chat-msg{padding:5px 8px;border-radius:7px;font-size:12.5px;line-height:1.5;margin-bottom:3px;max-width:100%}
.off-chat-msg:hover{background:var(--surface-2)}
.off-chat-msg-user{background:var(--accent-dim)}
.off-chat-msg-user:hover{background:var(--accent-dim)}
.off-chat-msg-meta{display:flex;align-items:baseline;gap:5px;margin-bottom:3px}
.off-chat-avatar{font-size:13px;flex-shrink:0}
.off-chat-name{font-size:11px;font-weight:700;color:var(--text-muted)}
.off-chat-msg-user .off-chat-name{color:var(--accent)}
.off-chat-time{font-size:9.5px;color:var(--text-faint);margin-left:auto;white-space:nowrap}
.off-chat-text{color:var(--text);word-break:break-word;line-height:1.55}
.off-chat-text p{margin:0 0 4px}
.off-chat-text p:last-child{margin:0}
.off-chat-text code{font-size:11px;background:var(--surface-2);padding:1px 4px;border-radius:3px}
.off-chat-text pre{font-size:10.5px;background:var(--surface-2);border-radius:5px;padding:6px 8px;overflow-x:auto;margin:4px 0}
.off-chat-msg-system{font-size:11px;color:var(--red);padding:4px 8px;text-align:center;opacity:.8}

/* Indicador de digitação */
.off-chat-typing{
  display:flex;align-items:center;gap:6px;padding:5px 8px;
  font-size:12px;color:var(--text-faint);min-height:28px;
}
.off-chat-dots{display:flex;gap:3px;align-items:center}
.off-chat-dots span{
  width:6px;height:6px;border-radius:50%;background:var(--text-faint);
  animation:off-dot-bounce .9s infinite;display:inline-block;
}
.off-chat-dots span:nth-child(2){animation-delay:.18s}
.off-chat-dots span:nth-child(3){animation-delay:.36s}
@keyframes off-dot-bounce{0%,80%,100%{transform:translateY(0)}40%{transform:translateY(-5px)}}

/* Input de mensagem */
.off-chat-input-row{
  display:flex;align-items:flex-end;gap:6px;padding:8px;
  border-top:1px solid var(--border);flex-shrink:0;background:var(--surface-2);
}
.off-chat-input{
  flex:1;background:var(--surface);border:1px solid var(--border);border-radius:8px;
  color:var(--text);font-size:12.5px;font-family:inherit;line-height:1.5;
  padding:7px 10px;resize:none;min-height:34px;max-height:90px;overflow-y:auto;
  outline:none;transition:border-color .15s;
}
.off-chat-input:focus{border-color:var(--accent)}
.off-chat-input::placeholder{color:var(--text-faint)}
.off-chat-send{
  background:var(--accent);border:none;border-radius:7px;color:#fff;
  cursor:pointer;width:32px;height:32px;flex-shrink:0;
  display:flex;align-items:center;justify-content:center;
  transition:background .15s,transform .1s;
}
.off-chat-send:hover{background:var(--accent-hover,#7c3aed)}
.off-chat-send:active{transform:scale(.93)}

/* ── JARVIS FLOAT BALL ─────────────────────────────────────────── */
#jarvis-float{
  position:fixed;bottom:24px;right:24px;z-index:9000;
  display:none;flex-direction:column;align-items:flex-end;gap:8px;
}
#jarvis-float.visible{display:flex}
.jf-actions{display:flex;gap:6px;align-items:center;justify-content:flex-end}
.jf-ball{
  width:56px;height:56px;border-radius:50%;
  background:var(--surface);border:2px solid var(--border-strong);
  display:flex;align-items:center;justify-content:center;
  cursor:pointer;transition:all .25s;
  box-shadow:0 4px 20px rgba(0,0,0,.4);
  position:relative;
}
.jf-ball:hover{transform:scale(1.07);border-color:var(--accent)}
.jf-ball.jf-ready{border-color:var(--accent);box-shadow:0 4px 16px rgba(124,58,237,.25)}
.jf-ball.jf-listening{background:var(--accent-dim);border-color:var(--accent);animation:orb-pulse 1.4s ease infinite}
.jf-ball.jf-processing{border-color:var(--accent-border)}
.jf-ball.jf-speaking{background:var(--accent-dim);border-color:var(--accent-border)}
.jf-ball.jf-error{border-color:var(--red);background:var(--red-dim)}
.jf-ball.jf-paused{opacity:.6}
.jf-icon{font-size:22px;color:var(--text-muted);transition:color .2s}
.jf-ball.jf-ready .jf-icon{color:var(--accent)}
.jf-ball.jf-listening .jf-icon,.jf-ball.jf-speaking .jf-icon{color:var(--accent)}
.jf-ball.jf-processing .jf-icon{color:var(--accent);animation:spin .7s linear infinite}
.jf-ball.jf-error .jf-icon{color:var(--red)}
.jf-stop{
  width:26px;height:26px;border-radius:50%;
  background:var(--red-dim);border:1px solid var(--red);
  display:flex;align-items:center;justify-content:center;
  cursor:pointer;font-size:11px;color:var(--red);
  transition:all .2s;box-shadow:0 2px 8px rgba(0,0,0,.3);
}
.jf-stop:hover{background:var(--red);color:#fff;transform:scale(1.1)}
.jf-open{
  width:26px;height:26px;border-radius:50%;
  background:var(--surface);border:1px solid var(--border);
  display:flex;align-items:center;justify-content:center;
  cursor:pointer;font-size:12px;color:var(--text-muted);
  transition:all .2s;box-shadow:0 2px 8px rgba(0,0,0,.2);
}
.jf-open:hover{background:var(--surface-2);color:var(--accent);transform:scale(1.1)}
.jf-tooltip{
  position:absolute;right:64px;top:50%;transform:translateY(-50%);
  background:var(--surface);border:1px solid var(--border);
  border-radius:6px;padding:4px 10px;font-size:11px;
  color:var(--text-muted);white-space:nowrap;pointer-events:none;
  opacity:0;transition:opacity .2s;box-shadow:0 2px 8px rgba(0,0,0,.3);
}
.jf-ball:hover .jf-tooltip{opacity:1}
