/* ════════════════════════════════════════════════════════════════
   ORKIA ENTERPRISE DESIGN SYSTEM — v2.0
   Filosofia: B2B SaaS monocromático, Enterprise-grade
   Inspiração: Linear, Notion, CRMPilot
   ════════════════════════════════════════════════════════════════ */

/* ── Alias .dark → mesmo que base :root (dark-first) ─────────── */
.dark { /* já é o padrão — :root é dark */ }

/* ── Google Fonts — Inter ─────────────────────────────────────── */
@import url('https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700&display=swap');

/* ── DARK MODE (padrão) ────────────────────────────────────────── */
:root {
  /* Background layers */
  --bg:         hsl(220, 16%, 8%);
  --surface:    hsl(220, 16%, 11%);
  --surface-2:  hsl(220, 14%, 16%);
  --surface-3:  hsl(220, 14%, 20%);

  /* Bordas */
  --border:       hsl(220, 14%, 18%);
  --border-strong:hsl(220, 14%, 25%);

  /* Texto */
  --text:       hsl(220, 10%, 92%);
  --text-muted: hsl(220, 10%, 55%);
  --text-faint: hsl(220, 10%, 42%);

  /* Acento (azul sidebar ativo — Orkia brand) */
  --accent:        hsl(210, 80%, 60%);
  --accent-dim:    hsla(210, 80%, 60%, 0.10);
  --accent-border: hsla(210, 80%, 60%, 0.30);

  /* Semânticas funcionais */
  --green:     hsl(145, 63%, 48%);
  --green-dim: hsla(145, 63%, 48%, 0.12);
  --yellow:    hsl(45, 93%, 52%);
  --yellow-dim:hsla(45, 93%, 52%, 0.12);
  --red:       hsl(0, 72%, 58%);
  --red-dim:   hsla(0, 72%, 58%, 0.12);
  --blue:      hsl(210, 100%, 58%);
  --blue-dim:  hsla(210, 100%, 58%, 0.12);

  /* Tokens semânticos (shadcn/Radix compatíveis) */
  --background:            hsl(220, 16%, 8%);
  --foreground:            hsl(220, 10%, 92%);
  --card:                  hsl(220, 16%, 11%);
  --card-foreground:       hsl(220, 10%, 92%);
  --primary:               hsl(220, 10%, 92%);
  --primary-foreground:    hsl(220, 16%, 8%);
  --secondary:             hsl(220, 14%, 16%);
  --secondary-foreground:  hsl(220, 10%, 92%);
  --muted:                 hsl(220, 14%, 16%);
  --muted-foreground:      hsl(220, 10%, 55%);
  --popover:               hsl(220, 16%, 11%);
  --popover-foreground:    hsl(220, 10%, 92%);
  --ring:                  hsl(220, 10%, 80%);
  --input:                 hsl(220, 14%, 18%);
  --success:               hsl(145, 63%, 48%);
  --success-foreground:    hsl(0, 0%, 100%);
  --warning:               hsl(45, 93%, 52%);
  --warning-foreground:    hsl(0, 0%, 10%);
  --destructive:           hsl(0, 72%, 58%);
  --destructive-foreground:hsl(0, 0%, 100%);
  --info:                  hsl(210, 100%, 58%);
  --info-foreground:       hsl(0, 0%, 100%);

  /* Orkia custom tokens */
  --orkia-surface:         hsl(220, 16%, 11%);
  --orkia-surface-hover:   hsl(220, 14%, 14%);
  --orkia-text-primary:    hsl(220, 10%, 92%);
  --orkia-text-secondary:  hsl(220, 10%, 55%);
  --orkia-text-tertiary:   hsl(220, 10%, 42%);
  --orkia-border-subtle:   hsl(220, 14%, 18%);
  --orkia-border-strong:   hsl(220, 14%, 25%);
  --orkia-sidebar-active-bg: rgba(224, 242, 254, 0.08);
  --orkia-sidebar-active-fg: hsl(210, 80%, 65%);

  /* Sombras */
  --shadow:    0 1px 3px 0 hsl(220 20% 4% / 0.30), 0 1px 2px -1px hsl(220 20% 4% / 0.20);
  --shadow-md: 0 4px 6px -1px hsl(220 20% 4% / 0.25), 0 2px 4px -2px hsl(220 20% 4% / 0.20);
  --shadow-lg: 0 10px 40px hsl(220 20% 2% / 0.55);

  /* Sidebar tokens próprios (dark) */
  --sidebar-background:          hsl(220, 16%, 9%);
  --sidebar-foreground:          hsl(220, 10%, 65%);
  --sidebar-primary:             hsl(220, 10%, 92%);
  --sidebar-primary-foreground:  hsl(220, 16%, 8%);
  --sidebar-accent:              hsl(220, 14%, 16%);
  --sidebar-accent-foreground:   hsl(220, 10%, 92%);
  --sidebar-border:              hsl(220, 14%, 18%);
  --sidebar-ring:                hsl(220, 10%, 80%);

  /* Border radius derivados */
  --radius:    0.5rem;   /* 8px */
  --radius-sm: 0.25rem;  /* 4px */
  --radius-md: 0.375rem; /* 6px */
  --radius-lg: 0.75rem;  /* 12px */
  --radius-xl: 1rem;     /* 16px */
  --radius-full: 9999px;

  /* Sombras enterprise ultra-sutis (tint azul-frio) */
  --orkia-shadow:    0 1px 3px 0 hsl(220 20% 10% / 0.18), 0 1px 2px -1px hsl(220 20% 10% / 0.14);
  --orkia-shadow-md: 0 4px 6px -1px hsl(220 20% 10% / 0.22), 0 2px 4px -2px hsl(220 20% 10% / 0.16);

  /* Layout */
  --sidebar-w:           220px;
  --sidebar-collapsed-w: 52px;
  --font: 'Inter', -apple-system, BlinkMacSystemFont, 'Segoe UI', system-ui, sans-serif;
}

/* ── LIGHT MODE ──────────────────────────────────────────────── */
.theme-light {
  --bg:         hsl(220, 14%, 97%);
  --surface:    hsl(0, 0%, 100%);
  --surface-2:  hsl(220, 10%, 94%);
  --surface-3:  hsl(220, 13%, 88%);

  --border:        hsl(220, 13%, 90%);
  --border-strong: hsl(220, 13%, 82%);

  --text:       hsl(220, 20%, 12%);
  --text-muted: hsl(220, 10%, 45%);
  --text-faint: hsl(220, 10%, 60%);

  --accent:        hsl(210, 80%, 46%);
  --accent-dim:    hsla(210, 80%, 46%, 0.08);
  --accent-border: hsla(210, 80%, 46%, 0.25);

  --green:     hsl(145, 63%, 42%);
  --green-dim: hsla(145, 63%, 42%, 0.10);
  --yellow:    hsl(45, 93%, 47%);
  --yellow-dim:hsla(45, 93%, 47%, 0.10);
  --red:       hsl(0, 72%, 51%);
  --red-dim:   hsla(0, 72%, 51%, 0.10);
  --blue:      hsl(210, 100%, 52%);
  --blue-dim:  hsla(210, 100%, 52%, 0.10);

  --background:            hsl(220, 14%, 97%);
  --foreground:            hsl(220, 20%, 12%);
  --card:                  hsl(0, 0%, 100%);
  --card-foreground:       hsl(220, 20%, 12%);
  --primary:               hsl(220, 20%, 14%);
  --primary-foreground:    hsl(0, 0%, 98%);
  --secondary:             hsl(220, 10%, 94%);
  --secondary-foreground:  hsl(220, 20%, 14%);
  --muted:                 hsl(220, 10%, 94%);
  --muted-foreground:      hsl(220, 10%, 45%);
  --popover:               hsl(0, 0%, 100%);
  --popover-foreground:    hsl(220, 20%, 12%);
  --ring:                  hsl(220, 20%, 14%);
  --input:                 hsl(220, 13%, 90%);
  --success:               hsl(145, 63%, 42%);
  --success-foreground:    hsl(0, 0%, 100%);
  --warning:               hsl(45, 93%, 47%);
  --warning-foreground:    hsl(0, 0%, 10%);
  --destructive:           hsl(0, 72%, 51%);
  --destructive-foreground:hsl(0, 0%, 100%);
  --info:                  hsl(210, 100%, 52%);
  --info-foreground:       hsl(0, 0%, 100%);

  --orkia-surface:         hsl(0, 0%, 100%);
  --orkia-surface-hover:   hsl(220, 10%, 96%);
  --orkia-text-primary:    hsl(220, 20%, 12%);
  --orkia-text-secondary:  hsl(220, 10%, 45%);
  --orkia-text-tertiary:   hsl(220, 10%, 60%);
  --orkia-border-subtle:   hsl(220, 13%, 92%);
  --orkia-border-strong:   hsl(220, 13%, 82%);
  --orkia-sidebar-active-bg: rgba(224, 242, 254, 0.70);
  --orkia-sidebar-active-fg: rgb(3, 105, 161);

  /* Sidebar tokens próprios (light) */
  --sidebar-background:          hsl(220, 14%, 95%);
  --sidebar-foreground:          hsl(220, 10%, 35%);
  --sidebar-primary:             hsl(220, 20%, 12%);
  --sidebar-primary-foreground:  hsl(0, 0%, 98%);
  --sidebar-accent:              hsl(220, 10%, 90%);
  --sidebar-accent-foreground:   hsl(220, 20%, 12%);
  --sidebar-border:              hsl(220, 13%, 88%);
  --sidebar-ring:                hsl(220, 20%, 14%);

  /* Sombras enterprise ultra-sutis light */
  --orkia-shadow:    0 1px 3px 0 hsl(220 20% 10% / 0.04), 0 1px 2px -1px hsl(220 20% 10% / 0.03);
  --orkia-shadow-md: 0 4px 6px -1px hsl(220 20% 10% / 0.06), 0 2px 4px -2px hsl(220 20% 10% / 0.04);

  --shadow:    var(--orkia-shadow);
  --shadow-md: var(--orkia-shadow-md);
  --shadow-lg: 0 10px 40px hsl(220 20% 10% / 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;line-height:1.6;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;text-rendering:optimizeLegibility;letter-spacing:-0.01em}
#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(--sidebar-background);border-right:1px solid var(--sidebar-border);display:flex;flex-direction:column;flex-shrink:0;overflow:hidden;position:relative;z-index:150;transition:width .22s cubic-bezier(.4,0,.2,1)}
.sidebar.collapsed{width:var(--sidebar-collapsed-w)}
.sidebar.collapsed .brand,.sidebar.collapsed .user-info,.sidebar.collapsed .nav-item span:not(.nav-icon){display:none}
.sidebar.collapsed .nav-item{justify-content:center;padding:9px 0;margin:1px 6px}
.sidebar.collapsed .sidebar-header{justify-content:center;padding:14px 0 8px}
.sidebar.collapsed .user-pill{justify-content:center;padding:8px 0}
.sidebar.collapsed .user-info{display:none}
.sidebar-toggle{background:none;border:none;color:var(--text-faint);cursor:pointer;font-size:15px;padding:2px 4px;border-radius:4px;line-height:1;margin-left:auto;flex-shrink:0;transition:color .15s}
.sidebar-toggle:hover{color:var(--text);background:var(--surface-2)}
.sidebar.collapsed .sidebar-toggle{margin-left:0}
.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 12px;color:var(--sidebar-foreground);border-radius:var(--radius);margin:1px 8px;cursor:pointer;transition:all .15s;font-size:13.5px;user-select:none;font-weight:400}
.nav-item:hover{background:var(--sidebar-accent);color:var(--sidebar-accent-foreground)}
.nav-item.active{background:var(--orkia-sidebar-active-bg);color:var(--orkia-sidebar-active-fg);font-weight:500}
.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:56px;border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between;padding:0 24px;background:var(--surface);backdrop-filter:blur(8px)}
.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:600;letter-spacing:-0.5px;color:var(--foreground);line-height:1.2}
.page-sub{color:var(--text-muted);font-size:13px;margin-top:4px}

/* CARDS */
.card{background:var(--card);border:1px solid var(--border);border-radius:var(--radius-lg);padding:20px;box-shadow:var(--orkia-shadow,var(--shadow))}
.card-sm{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:14px}
.card-title{font-size:11px;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.8px;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:hsl(220 14% 16% / 1);color:var(--muted-foreground)}
.badge-running{background:hsla(210,80%,60%,.10);color:var(--info)}
.badge-done{background:hsla(145,63%,48%,.10);color:var(--success)}
.badge-error{background:hsla(0,72%,58%,.10);color:var(--destructive)}
.badge-waiting{background:hsla(45,93%,52%,.10);color:var(--warning)}
.badge-offline{background:hsl(220 14% 16% / 1);color:var(--muted-foreground)}
.badge-active{background:hsla(145,63%,48%,.10);color:var(--success)}
.badge-planned{background:var(--surface-2);color:var(--text-muted)}
.badge-not-ready{background:hsla(45,93%,52%,.10);color:var(--warning)}
.badge-inactive{background:hsl(220 14% 16% / 1);color:var(--muted-foreground)}
.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(--card);border:1px solid var(--border);border-radius:var(--radius-lg);padding:18px 20px;box-shadow:var(--orkia-shadow,var(--shadow));transition:box-shadow .2s,border-color .2s}
.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-md)}
.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(--muted-foreground);text-transform:uppercase;letter-spacing:.7px;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:13.5px;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:14px;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;height:36px}
.btn:disabled,.btn[disabled]{opacity:0.5;cursor:not-allowed;pointer-events:none}
.btn-primary{background:var(--success);color:var(--success-foreground)}
.btn-primary:hover{filter:brightness(1.08)}
.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(--ring);outline:2px solid hsl(var(--ring) / 0.15);outline-offset:0}
.form-input:disabled{opacity:0.5;cursor:not-allowed}
.form-input::placeholder{color:var(--text-faint)}
.login-btn{width:100%;padding:10px;background:var(--success);color:var(--success-foreground);border:none;border-radius:var(--radius);font-size:14px;font-weight:600;cursor:pointer;transition:all .15s;margin-top:8px;box-shadow:0 1px 4px hsla(145,63%,48%,.3)}
.login-btn:hover{filter:brightness(1.08);box-shadow:0 2px 8px hsla(145,63%,48%,.4)}
.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(--success);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:14px;line-height:1.65}
.msg-user{background:hsl(210 80% 55%);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:11.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:12px;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(--orkia-border-strong);box-shadow:var(--shadow-md)}
.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:24px;margin-bottom:28px;padding:16px 0}

/* ══ ARC REACTOR PLANETÁRIO ══════════════════════════════════════
   Baseado em: ArchitJ6/iron-man-arc-reactor (Vite+React+CSS)
   Escala: 280px (página) → 64px (float)
   ══════════════════════════════════════════════════════════════ */

/* Wrapper — tamanho total do reactor */
.jarvis-orb-wrap{
  position:relative;
  width:280px;height:280px;
  display:flex;align-items:center;justify-content:center;
  cursor:pointer;
  filter:drop-shadow(0 0 32px rgba(105,241,241,.35));
  transition:filter .3s;
}
.jarvis-orb-wrap:hover{filter:drop-shadow(0 0 48px rgba(105,241,241,.6))}

/* Botão invisível por cima para capturar clique */
.jarvis-orb{
  position:absolute;inset:0;border-radius:50%;
  background:transparent;border:none;cursor:pointer;z-index:200;
}

/* ── component-1: anel externo girando com blur glow ─────────── */
.arc-c1{
  position:absolute;
  width:280px;height:280px;border-radius:50%;
  background:linear-gradient(rgba(105,241,241,.8),rgba(99,193,223,.8));
  animation:arc-cw 2s linear infinite;
}
.arc-c1::before{
  content:'';position:absolute;z-index:1;inset:14px;border-radius:50%;
  background:#020c14;
}
.arc-c1 .arc-inner{position:absolute;width:100%;height:100%;border-radius:50%;background:linear-gradient(rgba(105,241,241,.8),rgba(99,193,223,.8))}
.arc-c1 .arc-inner:nth-child(1){filter:blur(5px)}
.arc-c1 .arc-inner:nth-child(2){filter:blur(5px)}
.arc-c1 .arc-inner:nth-child(3){filter:blur(15px)}
.arc-c1 .arc-inner:nth-child(4){filter:blur(75px)}

/* ── component-2: anel segmentado girando (anti) ─────────────── */
.arc-c2{
  position:absolute;
  width:calc(280px - 56px);height:calc(280px - 56px);
  border-radius:50%;
  border:10px solid #69f1f1;
  box-shadow:0 0 30px 20px rgba(105,241,241,.15);
  z-index:9;
  animation:arc-ccw 4s linear infinite;
}
.arc-c2 .arc-inner{
  position:absolute;top:50%;left:50%;
  transform:translate(-50%,-50%);
  width:calc(100% + 20px);height:10px;
  background:#020c14;
}
.arc-c2 .arc-inner:nth-child(1){transform:translate(-50%,-50%) rotate(90deg)}
.arc-c2 .arc-inner:nth-child(2){transform:translate(-50%,-50%) rotate(45deg)}
.arc-c2 .arc-inner:nth-child(3){transform:translate(-50%,-50%) rotate(-45deg)}
.arc-c2 .arc-inner:nth-child(4){transform:translate(-50%,-50%) rotate(30deg)}
.arc-c2 .arc-inner:nth-child(5){transform:translate(-50%,-50%) rotate(-30deg)}
.arc-c2 .arc-inner:nth-child(6){transform:translate(-50%,-50%) rotate(0deg)}
.arc-c2 .arc-inner:nth-child(7){transform:translate(-50%,-50%) rotate(55deg);height:5px}
.arc-c2 .arc-inner:nth-child(8){transform:translate(-50%,-50%) rotate(125deg);height:5px}

/* ── component-3: anel pontilhado lento ──────────────────────── */
.arc-c3{
  position:absolute;
  z-index:99;
  border-radius:50%;
  box-shadow:0 0 10px 10px rgba(105,241,241,.12);
}
.arc-c3::after{
  content:'';display:block;
  width:160px;height:160px;border-radius:50%;
  border:3px dotted rgba(105,241,241,.7);
  animation:arc-cw 10s linear infinite;
}

/* ── component-4: arcos internos girando ─────────────────────── */
.arc-c4{
  position:absolute;
  z-index:99;
  width:140px;height:140px;border-radius:50%;
  box-shadow:0 0 10px 10px rgba(105,241,241,.08);
  animation:arc-complex 20s infinite ease-in;
}
.arc-c4 .arc-inner{
  position:absolute;top:50%;left:50%;
  transform:translate(-50%,-50%);
  width:100%;height:100%;border-radius:50%;
  border:3px solid;border-color:#69f1f1 transparent transparent;
}
.arc-c4 .arc-inner:nth-child(1){transform:translate(-50%,-50%) rotate(45deg)}
.arc-c4 .arc-inner:nth-child(2){transform:translate(-50%,-50%) rotate(-75deg)}
.arc-c4 .arc-inner:nth-child(3){transform:translate(-50%,-50%) rotate(165deg)}

/* ── component-5: anel médio + glow ─────────────────────────── */
.arc-c5{
  position:absolute;z-index:99;
  width:90px;height:90px;border-radius:50%;
  animation:arc-complex 10s infinite ease-in;
  background:rgba(105,241,241,.15);
  box-shadow:0 0 20px 20px rgba(105,241,241,.15);
}
.arc-c5 .arc-inner{
  position:absolute;inset:0;z-index:99;
  width:80px;height:80px;border-radius:50%;
  border:5px solid;border-color:#69f1f1 transparent transparent;
}
.arc-c5 .arc-inner:nth-child(1){transform:rotate(0deg)}
.arc-c5 .arc-inner:nth-child(2){transform:rotate(120deg)}
.arc-c5 .arc-inner:nth-child(3){transform:rotate(240deg)}

/* ── component-6: anel tracejado central ────────────────────── */
.arc-c6{position:absolute;z-index:99}
.arc-c6::after{
  content:'';display:block;
  width:55px;height:55px;border-radius:50%;
  border:3px dashed #69f1f1;
  animation:arc-ccw 5s infinite ease-in;
}

/* ── component-7: núcleo brilhante ──────────────────────────── */
.arc-c7{position:absolute;z-index:99}
.arc-c7::after{
  content:'';display:block;
  width:38px;height:38px;border-radius:50%;
  background:#69f1f1;
  animation:arc-ccw 5s infinite ease-in;
  box-shadow:0 0 12px 8px rgba(105,241,241,.5),0 0 24px 12px rgba(105,241,241,.25);
}

/* ── component-8: mini arcos centrais ───────────────────────── */
.arc-c8{
  position:absolute;z-index:99;
  width:20px;height:20px;border-radius:50%;
  animation:arc-complex 5s infinite ease-in;
}
.arc-c8 .arc-inner{
  position:absolute;inset:0;z-index:99;
  width:18px;height:18px;border-radius:50%;
  border:1px solid;border-color:#020c14 transparent transparent;
}
.arc-c8 .arc-inner:nth-child(1){transform:rotate(120deg)}
.arc-c8 .arc-inner:nth-child(2){transform:rotate(240deg)}

/* ── Triângulo central (Stark Reactor symbol) ────────────────── */
.arc-triangle{
  position:absolute;top:66%;left:50%;
  transform:translate(-50%,-50%);
  z-index:150;
  width:120px;height:120px; /* escalonado para 280px */
  aspect-ratio:1;
  background:#69f1f1;
  clip-path:polygon(50% 88%,0 0,100% 0);
  pointer-events:none;
}
.arc-triangle::after{
  content:'';display:block;
  position:absolute;top:45%;left:50%;
  z-index:160;
  width:92px;height:92px;
  transform:translate(-50%,-50%);
  background:#020c14;
  clip-path:polygon(50% 90%,0 0,100% 0);
}

/* ── Keyframes arc reactor ───────────────────────────────────── */
@keyframes arc-cw  {from{transform:rotate(0)}to{transform:rotate(360deg)}}
@keyframes arc-ccw {from{transform:rotate(360deg)}to{transform:rotate(0)}}
@keyframes arc-complex{
  0%  {transform:translate(-50%,-50%) rotate(0)}
  30% {transform:translate(-50%,-50%) rotate(360deg)}
  50% {transform:translate(-50%,-50%) rotate(0)}
  100%{transform:translate(-50%,-50%) rotate(360deg)}
}

/* ── Estados do reactor na página Jarvis ─────────────────────── */
/* idle: velocidade normal */
.arc-state-listening .arc-c1{animation-duration:.8s}
.arc-state-listening .arc-c2{animation-duration:1.5s}
.arc-state-listening .arc-c7::after{
  box-shadow:0 0 20px 14px rgba(105,241,241,.9),0 0 40px 20px rgba(105,241,241,.5);
  animation:arc-pulse-core .6s ease-in-out infinite;
}
.arc-state-processing .arc-c1{animation-duration:.4s}
.arc-state-processing .arc-c2{animation-duration:.8s}
.arc-state-processing .arc-c7::after{animation:arc-charge .4s ease-in-out infinite alternate}
.arc-state-speaking .arc-c1{animation-duration:1.2s}
.arc-state-speaking .arc-c7::after{
  background:#fff;
  box-shadow:0 0 24px 16px rgba(255,255,255,.7),0 0 48px 24px rgba(105,241,241,.4);
  animation:arc-pulse-core 1.2s ease-in-out infinite;
}
.arc-state-error .arc-c1{background:linear-gradient(rgba(239,68,68,.8),rgba(185,28,28,.8))}
.arc-state-error .arc-c2{border-color:#ef4444;box-shadow:0 0 20px 10px rgba(239,68,68,.2)}
.arc-state-error .arc-c7::after{background:#ef4444;box-shadow:0 0 12px 8px rgba(239,68,68,.6)}
@keyframes arc-pulse-core{0%,100%{transform:scale(1)}50%{transform:scale(1.2)}}
@keyframes arc-charge{from{box-shadow:0 0 6px 4px rgba(105,241,241,.4)}to{box-shadow:0 0 24px 16px rgba(105,241,241,1),0 0 40px 24px rgba(105,241,241,.6)}}

/* ── Legenda / status text ───────────────────────────────────── */
.jarvis-orb-icon{display:none} /* substituído pelo reactor */

.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 — SimCity-inspired grid */
.off-scene{
  position:relative;height:540px;
  background:var(--bg);
  background-image:
    linear-gradient(rgba(255,255,255,.04) 1px,transparent 1px),
    linear-gradient(90deg,rgba(255,255,255,.04) 1px,transparent 1px),
    linear-gradient(rgba(255,255,255,.012) 1px,transparent 1px),
    linear-gradient(90deg,rgba(255,255,255,.012) 1px,transparent 1px);
  background-size:72px 72px,72px 72px,24px 24px,24px 24px;
  border:1px solid var(--border);border-radius:var(--radius-lg);
  overflow:hidden;box-shadow:inset 0 0 60px rgba(0,0,0,.25);
}

/* Rooms — SimCity block style */
.off-room{
  position:absolute;
  border:2px solid var(--border-strong);border-radius:6px;
  overflow:hidden;cursor:default;
  transition:border-color .2s,box-shadow .2s;
  box-shadow:2px 2px 0 rgba(0,0,0,.35),inset 0 1px 0 rgba(255,255,255,.04);
}
.off-room:hover{border-color:rgba(255,255,255,.2);box-shadow:2px 2px 0 rgba(0,0,0,.5),inset 0 1px 0 rgba(255,255,255,.07)}
.off-room-mike{
  background:
    repeating-linear-gradient(45deg,rgba(139,92,246,.03) 0px,rgba(139,92,246,.03) 2px,transparent 2px,transparent 14px),
    var(--surface);
  border-color:rgba(139,92,246,.5);
  box-shadow:2px 2px 0 rgba(0,0,0,.4),0 0 20px rgba(139,92,246,.08) inset;
}
.off-room-mike:hover{border-color:var(--accent);box-shadow:2px 2px 0 rgba(0,0,0,.5),0 0 30px rgba(139,92,246,.15) inset}
.off-room-meeting{
  background:
    repeating-linear-gradient(-45deg,rgba(96,165,250,.025) 0px,rgba(96,165,250,.025) 2px,transparent 2px,transparent 16px),
    var(--surface);
}
.off-room-ops{
  background:
    repeating-linear-gradient(0deg,rgba(34,197,94,.02) 0px,rgba(34,197,94,.02) 1px,transparent 1px,transparent 18px),
    var(--surface);
}
.off-room-lounge{
  background:linear-gradient(180deg,var(--surface-2) 0%,var(--surface) 100%);
}
.off-room-label{
  position:absolute;top:6px;left:9px;
  font-size:9px;font-weight:800;color:var(--text-faint);
  text-transform:uppercase;letter-spacing:1.1px;user-select:none;
  text-shadow:0 1px 0 rgba(0,0,0,.5);
}
.off-label-accent{color:var(--accent);opacity:.9}

/* 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}

/* ── SimCity speech bubble ── */
.oa-speech{
  position:absolute;
  bottom:calc(100% + 10px);
  left:50%;transform:translateX(-50%);
  background:#fff;color:#1a1a1a;
  font-size:9.5px;font-weight:500;line-height:1.35;
  padding:5px 8px;border-radius:8px;
  max-width:110px;min-width:60px;
  text-align:center;word-break:break-word;
  white-space:normal;
  box-shadow:0 2px 0 #bbb,0 3px 8px rgba(0,0,0,.4);
  border:1.5px solid #ddd;
  pointer-events:none;z-index:20;
  animation:oa-bubble-in .18s ease-out;
}
.oa-speech::after{
  content:'';position:absolute;
  top:100%;left:50%;transform:translateX(-50%);
  border:5px solid transparent;
  border-top-color:#fff;
  filter:drop-shadow(0 2px 0 #bbb);
}
.oa-speech::before{
  content:'';position:absolute;
  top:100%;left:50%;transform:translateX(-50%);
  border:6px solid transparent;
  border-top-color:#ddd;margin-top:0;
}
@keyframes oa-bubble-in{
  from{opacity:0;transform:translateX(-50%) scale(.85)}
  to{opacity:1;transform:translateX(-50%) scale(1)}
}
@keyframes oa-bubble-out{
  from{opacity:1}
  to{opacity:0;transform:translateX(-50%) scale(.85)}
}
.oa-speech.fading{animation:oa-bubble-out .3s ease-in forwards}

/* ── 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:hsla(145,63%,48%,.12);color:var(--success);border:1px solid hsla(145,63%,48%,.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:11.5px;color:var(--text-muted);font-weight:500}
.off-chat-token-hint{font-size:11px;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:13px;color:var(--text-faint);line-height:1.7}

/* Mensagens estilo chat ao vivo */
.off-chat-msg{padding:6px 9px;border-radius:7px;font-size:13.5px;line-height:1.65;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:12px;font-weight:600;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:12px;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 — Arc Reactor (Iron Man) ───────────────────── */
#jarvis-float{
  position:fixed;bottom:28px;right:28px;z-index:9000;
  display:none;flex-direction:column;align-items:flex-end;gap:10px;
  animation:jf-levitate 4s ease-in-out infinite;
}
#jarvis-float.visible{display:flex}
@keyframes jf-levitate{
  0%,100%{transform:translateY(0px)}
  50%{transform:translateY(-8px)}
}
/* Ações (stop / open) */
.jf-actions{display:flex;gap:6px;align-items:center;justify-content:flex-end}
.jf-stop{
  width:24px;height:24px;border-radius:50%;
  background:rgba(239,68,68,.15);border:1px solid rgba(239,68,68,.6);
  display:flex;align-items:center;justify-content:center;
  cursor:pointer;font-size:10px;color:rgba(239,68,68,.9);
  transition:all .2s;box-shadow:0 0 6px rgba(239,68,68,.3);
}
.jf-stop:hover{background:rgba(239,68,68,.35);color:#fff;transform:scale(1.12);box-shadow:0 0 12px rgba(239,68,68,.6)}
.jf-open{
  width:24px;height:24px;border-radius:50%;
  background:rgba(0,212,255,.08);border:1px solid rgba(0,212,255,.4);
  display:flex;align-items:center;justify-content:center;
  cursor:pointer;font-size:11px;color:rgba(0,212,255,.8);
  transition:all .2s;box-shadow:0 0 6px rgba(0,212,255,.2);
}
.jf-open:hover{background:rgba(0,212,255,.18);color:#00d4ff;transform:scale(1.12);box-shadow:0 0 12px rgba(0,212,255,.5)}
/* Mini transcript panel */
.jf-transcript-panel{
  background:rgba(4,12,18,.88);border:1px solid rgba(0,212,255,.25);
  border-radius:8px;padding:7px 10px;font-size:11px;color:#7ee8f8;
  max-width:220px;line-height:1.4;backdrop-filter:blur(6px);
  box-shadow:0 0 14px rgba(0,212,255,.15);
  display:none;
}
.jf-transcript-panel.active{display:block}
/* ── Reactor container ──────────────────────────────────────── */
.jf-ball{
  width:64px;height:64px;border-radius:50%;
  background:radial-gradient(circle at 40% 35%,#0a1e2e 0%,#020c14 100%);
  border:2px solid rgba(0,212,255,.5);
  display:flex;align-items:center;justify-content:center;
  cursor:pointer;transition:border-color .3s,box-shadow .3s;
  box-shadow:0 0 18px rgba(0,212,255,.35),0 0 6px rgba(0,212,255,.2) inset;
  position:relative;overflow:visible;
}
.jf-ball:hover{border-color:rgba(0,212,255,.9);box-shadow:0 0 28px rgba(0,212,255,.6),0 0 10px rgba(0,212,255,.3) inset}
/* Coils girando */
.jf-coils{
  position:absolute;width:100%;height:100%;border-radius:50%;
  animation:jf-spin 3s linear infinite;
}
.jf-coil{
  position:absolute;width:8px;height:5px;border-radius:2px;
  background:#073c4b;box-shadow:0 0 4px #00d4ff inset,0 0 3px rgba(0,212,255,.4);
  top:calc(50% - 26px);left:calc(50% - 4px);
  transform-origin:4px 26px;
}
.jf-coil:nth-child(1){transform:rotate(0deg)}
.jf-coil:nth-child(2){transform:rotate(45deg)}
.jf-coil:nth-child(3){transform:rotate(90deg)}
.jf-coil:nth-child(4){transform:rotate(135deg)}
.jf-coil:nth-child(5){transform:rotate(180deg)}
.jf-coil:nth-child(6){transform:rotate(225deg)}
.jf-coil:nth-child(7){transform:rotate(270deg)}
.jf-coil:nth-child(8){transform:rotate(315deg)}
@keyframes jf-spin{from{transform:rotate(0deg)}to{transform:rotate(360deg)}}
/* Anel externo */
.jf-ring{
  position:absolute;width:54px;height:54px;border-radius:50%;
  border:1px solid rgba(0,212,255,.3);
  box-shadow:0 0 6px rgba(0,212,255,.15);
}
/* Núcleo */
.jf-core{
  width:26px;height:26px;border-radius:50%;
  background:radial-gradient(circle,#cceeff 0%,#52fefe 30%,#00d4ff 60%,#073c4b 100%);
  box-shadow:0 0 12px 4px rgba(82,254,254,.7),0 0 20px 6px rgba(0,212,255,.4),0 0 4px 2px #52fefe inset;
  transition:box-shadow .3s;
  z-index:2;
}
/* Estados */
.jf-ball.jf-listening .jf-coils{animation-duration:1.2s}
.jf-ball.jf-listening .jf-core{
  box-shadow:0 0 18px 7px rgba(82,254,254,.9),0 0 28px 10px rgba(0,212,255,.6),0 0 6px 3px #52fefe inset;
  animation:jf-core-pulse 0.8s ease-in-out infinite;
}
.jf-ball.jf-processing .jf-coils{animation-duration:0.6s}
.jf-ball.jf-processing .jf-core{animation:jf-core-charge 0.5s ease-in-out infinite alternate}
.jf-ball.jf-speaking .jf-core{
  background:radial-gradient(circle,#fff 0%,#a0f8ff 30%,#00d4ff 60%,#073c4b 100%);
  animation:jf-core-speak 1.5s ease-in-out infinite;
}
.jf-ball.jf-error{border-color:rgba(239,68,68,.7)}
.jf-ball.jf-error .jf-core{background:radial-gradient(circle,#fca5a5 0%,#ef4444 60%,#1a0000 100%);box-shadow:0 0 14px 5px rgba(239,68,68,.7)}
.jf-ball.jf-paused{opacity:.5;filter:saturate(.3)}
.jf-ball.jf-paused .jf-coils{animation-play-state:paused}
@keyframes jf-core-pulse{0%,100%{transform:scale(1)}50%{transform:scale(1.15)}}
@keyframes jf-core-charge{from{box-shadow:0 0 8px 3px rgba(82,254,254,.5)}to{box-shadow:0 0 22px 9px rgba(82,254,254,1),0 0 32px 12px rgba(0,212,255,.7)}}
@keyframes jf-core-speak{0%,100%{transform:scale(1)}30%{transform:scale(1.08)}60%{transform:scale(.96)}}
/* Tooltip */
.jf-tooltip{
  position:absolute;right:72px;top:50%;transform:translateY(-50%);
  background:rgba(4,12,18,.9);border:1px solid rgba(0,212,255,.25);
  border-radius:6px;padding:4px 10px;font-size:11px;
  color:#7ee8f8;white-space:nowrap;pointer-events:none;
  opacity:0;transition:opacity .2s;box-shadow:0 0 10px rgba(0,212,255,.2);
  font-family:monospace;letter-spacing:.03em;
}
.jf-ball:hover .jf-tooltip{opacity:1}

/* ══ ORKIA ENTERPRISE — Utility Classes ════════════════════════ */

/* Animações */
.orkia-fade-in{animation:orkia-fade .3s ease-out both}
.orkia-slide-up{animation:orkia-slide .4s ease-out both}
@keyframes orkia-fade{from{opacity:0}to{opacity:1}}
@keyframes orkia-slide{from{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}

/* Accordion (Radix-compatible) */
@keyframes accordion-down{from{height:0}to{height:var(--radix-accordion-content-height)}}
@keyframes accordion-up{from{height:var(--radix-accordion-content-height)}to{height:0}}
.accordion-down{animation:accordion-down .2s ease-out}
.accordion-up{animation:accordion-up .2s ease-out}

/* Tipografia semântica */
.orkia-section-title{font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.8px;color:var(--muted-foreground)}
.orkia-divider{height:1px;background:var(--border);margin:16px 0}

/* Cards enterprise */
.orkia-card{background:var(--card);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow)}
.orkia-card-hover{background:var(--card);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow);transition:box-shadow .2s,border-color .2s}
.orkia-card-hover:hover{box-shadow:var(--shadow-md);border-color:var(--orkia-border-strong)}

/* Inputs enterprise */
.orkia-input-sm{height:36px;padding:0 12px;border-radius:calc(var(--radius) - 2px);border:1px solid var(--input);background:var(--background);color:var(--foreground);font-size:13px;font-family:var(--font);transition:border-color .15s,outline .15s}
.orkia-input-md{height:44px;padding:0 16px;border-radius:var(--radius-lg);border:1px solid var(--input);background:var(--background);color:var(--foreground);font-size:14px;font-family:var(--font);transition:border-color .15s,outline .15s}
.orkia-input-lg{height:48px;padding:0 16px;border-radius:var(--radius-lg);border:1px solid var(--input);background:var(--background);color:var(--foreground);font-size:14px;font-family:var(--font);transition:border-color .15s,outline .15s}
.orkia-input-sm:focus,.orkia-input-md:focus,.orkia-input-lg:focus{outline:2px solid hsla(210,80%,60%,.2);outline-offset:0;border-color:var(--ring)}

/* Botões enterprise */
.orkia-button-primary{background:var(--success);color:var(--success-foreground);padding:8px 24px;border-radius:var(--radius-lg);font-size:14px;font-weight:600;border:none;cursor:pointer;transition:all .15s;box-shadow:0 1px 4px hsla(145,63%,48%,.3)}
.orkia-button-primary:hover{filter:brightness(1.08);box-shadow:0 2px 8px hsla(145,63%,48%,.4)}
.orkia-button-secondary{background:var(--secondary);color:var(--secondary-foreground);padding:8px 24px;border-radius:var(--radius-lg);font-size:14px;font-weight:500;border:1px solid var(--border);cursor:pointer;transition:all .15s}
.orkia-button-secondary:hover{background:var(--accent);border-color:var(--border-strong)}
.orkia-button-ghost{background:transparent;color:var(--muted-foreground);padding:8px 12px;border-radius:var(--radius-lg);font-size:14px;font-weight:500;border:none;cursor:pointer;transition:all .15s}
.orkia-button-ghost:hover{background:var(--accent);color:var(--foreground)}

/* Nav enterprise */
.orkia-nav-item{padding:7px 12px;border-radius:var(--radius);font-size:14px;color:var(--muted-foreground);cursor:pointer;transition:all .15s;display:flex;align-items:center;gap:10px}
.orkia-nav-item:hover{background:var(--accent);color:var(--foreground)}
.orkia-nav-item-active{background:var(--orkia-sidebar-active-bg)!important;color:var(--orkia-sidebar-active-fg)!important;font-weight:500}

/* Status — usando semântica enterprise */
.status-active{background:hsla(145,63%,48%,.12);color:var(--success);border:1px solid hsla(145,63%,48%,.25)}
.status-warning{background:hsla(45,93%,52%,.12);color:var(--warning);border:1px solid hsla(45,93%,52%,.25)}
.status-error{background:hsla(0,72%,58%,.12);color:var(--destructive);border:1px solid hsla(0,72%,58%,.25)}
.status-info{background:hsla(210,100%,58%,.10);color:var(--info);border:1px solid hsla(210,100%,58%,.25)}

/* CTA inline (ex: "+ Adicionar") */
.btn-cta-add{background:hsla(145,63%,48%,.10);color:var(--success);border:1px solid hsla(145,63%,48%,.25);padding:5px 12px;border-radius:var(--radius);font-size:12.5px;font-weight:600;cursor:pointer;transition:all .15s;display:inline-flex;align-items:center;gap:5px}
.btn-cta-add:hover{background:hsla(145,63%,48%,.18);border-color:hsla(145,63%,48%,.4)}


/* ══ ORKIA ENTERPRISE — Complemento Design System v2.1 ═════════ */

/* ── Tipografia hierárquica ────────────────────────────────────── */
h1,h2,h3,h4,h5,h6{font-family:var(--font);font-weight:600;letter-spacing:-0.4px;line-height:1.25;color:var(--foreground)}
h1{font-size:24px}
h2{font-size:20px}
h3{font-size:18px}
h4{font-size:16px}
h5,h6{font-size:14px}
.text-display{font-size:36px;font-weight:700;letter-spacing:-0.6px;line-height:1.1}
.text-caption{font-size:12px;color:var(--muted-foreground)}
.text-section-label{font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.8px;color:var(--muted-foreground)}

/* ── Focus ring global (Radix-compatible) ─────────────────────── */
:focus-visible{outline:2px solid var(--ring);outline-offset:2px}
button:focus-visible,input:focus-visible,textarea:focus-visible,select:focus-visible{
  outline:2px solid var(--ring);outline-offset:2px;
}

/* ── Ícone container semântico (Orkia pattern) ────────────────── */
.icon-container{width:40px;height:40px;border-radius:var(--radius);display:flex;align-items:center;justify-content:center;flex-shrink:0}
.icon-container-sm{width:32px;height:32px;border-radius:var(--radius-md);display:flex;align-items:center;justify-content:center;flex-shrink:0}
/* Variantes cromáticas */
.icon-primary{background:hsla(220,20%,14%,.08);color:var(--primary)}
.icon-success{background:hsla(145,63%,48%,.10);color:var(--success)}
.icon-warning{background:hsla(45,93%,52%,.10);color:var(--warning)}
.icon-destructive{background:hsla(0,72%,58%,.10);color:var(--destructive)}
.icon-info{background:hsla(210,100%,58%,.10);color:var(--info)}
.icon-muted{background:var(--muted);color:var(--muted-foreground)}

/* ── Banner de insight (horizontal) ──────────────────────────── */
.insight-banner{display:flex;align-items:center;gap:12px;padding:12px 16px;border-radius:var(--radius);border:1px solid;margin-bottom:16px;font-size:13px;line-height:1.5}
.insight-banner-success{background:hsla(145,63%,48%,.05);border-color:hsla(145,63%,48%,.20);color:var(--foreground)}
.insight-banner-warning{background:hsla(45,93%,52%,.05);border-color:hsla(45,93%,52%,.20);color:var(--foreground)}
.insight-banner-error{background:hsla(0,72%,58%,.05);border-color:hsla(0,72%,58%,.20);color:var(--foreground)}
.insight-banner-info{background:hsla(210,100%,58%,.05);border-color:hsla(210,100%,58%,.20);color:var(--foreground)}
.insight-banner-cta{margin-left:auto;flex-shrink:0;font-size:12px;font-weight:500;cursor:pointer;opacity:.7;transition:opacity .15s}
.insight-banner-cta:hover{opacity:1}

/* ── Sidebar brand + footer refinado ─────────────────────────── */
.sidebar-header{padding:16px 16px 8px;display:flex;align-items:center;gap:8px;border-bottom:1px solid var(--sidebar-border)}
.sidebar-footer{padding:10px 8px;border-top:1px solid var(--sidebar-border)}
.sidebar-nav{flex:1;padding:8px 0;overflow-y:auto}

/* ── PageHeader enterprise (h-16 = 64px) ─────────────────────── */
.page-header{height:56px;border-bottom:1px solid var(--border);display:flex;align-items:center;padding:0 24px;gap:12px;margin-bottom:0;background:var(--card)}
.page-header-icon{width:36px;height:36px;border-radius:var(--radius);display:flex;align-items:center;justify-content:center;font-size:18px;background:var(--muted);color:var(--muted-foreground);flex-shrink:0}
.page-header-title{font-size:18px;font-weight:600;letter-spacing:-0.3px;color:var(--foreground)}
.page-header-actions{margin-left:auto;display:flex;align-items:center;gap:8px}
/* Manter compatibilidade com .page-header sem altura (usado inline) */
.page-header-inline{margin-bottom:24px}
.page-header-inline .page-title{font-size:20px;font-weight:600;letter-spacing:-0.5px}
.page-header-inline .page-sub{color:var(--muted-foreground);font-size:13px;margin-top:4px}

/* ── Beta tag sidebar ─────────────────────────────────────────── */
.tag-beta{font-size:10px;font-weight:600;padding:1px 6px;border-radius:var(--radius-md);border:1px solid hsla(210,100%,58%,.40);color:var(--info);letter-spacing:.3px;vertical-align:super;margin-left:4px}

/* ── Chip / pill padrão enterprise ───────────────────────────── */
.chip{display:inline-flex;align-items:center;gap:5px;padding:3px 10px;border-radius:var(--radius-full);font-size:12px;font-weight:500;background:var(--secondary);color:var(--muted-foreground);border:1px solid var(--border);cursor:default;transition:all .15s}
.chip:hover{border-color:var(--orkia-border-strong);color:var(--foreground)}
.chip-active{background:hsla(145,63%,48%,.10);color:var(--success);border-color:hsla(145,63%,48%,.25)}
.chip-info{background:hsla(210,100%,58%,.10);color:var(--info);border-color:hsla(210,100%,58%,.25)}
.chip-warning{background:hsla(45,93%,52%,.10);color:var(--warning);border-color:hsla(45,93%,52%,.25)}

/* ── Scrollbar enterprise (minimalista) ──────────────────────── */
::-webkit-scrollbar{width:4px;height:4px}
::-webkit-scrollbar-track{background:transparent}
::-webkit-scrollbar-thumb{background:var(--border-strong);border-radius:var(--radius-full)}
::-webkit-scrollbar-thumb:hover{background:var(--muted-foreground)}

/* ── Table enterprise refinada ───────────────────────────────── */
.table th{font-size:11px;font-weight:600;color:var(--muted-foreground);text-transform:uppercase;letter-spacing:.7px;padding:10px 14px;text-align:left;border-bottom:1px solid var(--border)}
.table td{padding:11px 14px;border-bottom:1px solid var(--border);font-size:13.5px;vertical-align:middle;color:var(--foreground)}
.table tr:last-child td{border-bottom:none}
.table tr:hover td{background:var(--muted)}

/* ── Input base refinado ──────────────────────────────────────── */
.form-input,.chat-input,.panel-chat-input,.off-chat-input{
  font-size:13.5px;letter-spacing:-0.01em;
}
.form-input::placeholder,.chat-input::placeholder{color:var(--muted-foreground);opacity:.7}

/* ── Side panel upgrade ───────────────────────────────────────── */
.panel-header{padding:16px 20px;border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between;position:sticky;top:0;background:var(--card);backdrop-filter:blur(8px)}
.panel-title{font-size:15px;font-weight:600;letter-spacing:-0.2px;color:var(--foreground)}

/* ── Drawer upgrade ───────────────────────────────────────────── */
.crm-drawer{background:var(--card)}
.crm-drawer-header{background:var(--card)}
.crm-drawer-tabs{background:var(--card)}

/* ── Empty state ──────────────────────────────────────────────── */
.empty-state{text-align:center;padding:40px 16px;color:var(--muted-foreground);font-size:13px;line-height:1.6}
.empty-state-icon{font-size:28px;margin-bottom:10px;opacity:.4}
.empty-state-title{font-size:14px;font-weight:500;color:var(--foreground);margin-bottom:4px}

/* ── Transições enterprise (200ms ease-out) ───────────────────── */
.card,.stat-card,.agent-card,.task-card,.integ-card,.crm-card{transition:box-shadow .2s ease-out,border-color .2s ease-out}
.card:hover,.stat-card:hover{box-shadow:var(--orkia-shadow-md);border-color:var(--orkia-border-strong)}
.agent-card:hover{box-shadow:var(--orkia-shadow-md)}

/* ── Dark mode sombras mais densas ───────────────────────────── */
:root {
  --shadow:    var(--orkia-shadow);
  --shadow-md: var(--orkia-shadow-md);
}


/* ── JARVIS SIDE PANEL (Glass) ─────────────────────────────── */
.jarvis-main-layout{display:flex;gap:32px;align-items:flex-start;position:relative;min-height:320px}
.jarvis-orb-section{display:flex;flex-direction:column;align-items:center;gap:20px;padding:16px 0;flex-shrink:0}
.jarvis-side-panel{
  position:fixed;right:24px;top:110px;
  width:420px;min-width:280px;
  background:rgba(8,12,26,0.84);
  backdrop-filter:blur(18px);-webkit-backdrop-filter:blur(18px);
  border:1px solid rgba(105,241,241,0.18);
  border-radius:16px;
  box-shadow:0 8px 40px rgba(0,0,0,0.45),0 0 0 1px rgba(105,241,241,0.06),inset 0 1px 0 rgba(105,241,241,0.08);
  z-index:200;display:flex;flex-direction:column;overflow:hidden;
  transition:box-shadow .2s;
}
.jarvis-side-panel:hover{box-shadow:0 12px 48px rgba(0,0,0,0.5),0 0 0 1px rgba(105,241,241,0.14),inset 0 1px 0 rgba(105,241,241,0.1)}
.jsp-header{
  display:flex;align-items:center;justify-content:space-between;
  padding:10px 14px;
  background:rgba(105,241,241,0.05);
  border-bottom:1px solid rgba(105,241,241,0.1);
  cursor:grab;border-radius:16px 16px 0 0;
  user-select:none;
}
.jsp-header:active{cursor:grabbing}
.jsp-title{font-size:10px;font-weight:800;letter-spacing:3.5px;color:rgba(105,241,241,0.85);text-transform:uppercase}
.jsp-header-actions{display:flex;gap:4px;align-items:center}
.jsp-header-actions button{
  background:rgba(105,241,241,0.07);border:1px solid rgba(105,241,241,0.15);
  border-radius:6px;color:rgba(105,241,241,0.75);padding:3px 9px;
  font-size:12px;cursor:pointer;transition:all .15s;font-family:inherit;line-height:1.4
}
.jsp-header-actions button:hover{background:rgba(105,241,241,0.18);color:#69f1f1;border-color:rgba(105,241,241,0.4)}
.jsp-header-actions button.jsp-btn-active{border-color:#69f1f1;color:#69f1f1;background:rgba(105,241,241,0.15)}
.jsp-body{
  flex:1;overflow-y:auto;padding:14px;
  display:flex;flex-direction:column;gap:12px;
}
.jsp-body::-webkit-scrollbar{width:3px}
.jsp-body::-webkit-scrollbar-track{background:transparent}
.jsp-body::-webkit-scrollbar-thumb{background:rgba(105,241,241,0.2);border-radius:4px}
.jsp-section{display:flex;flex-direction:column;gap:7px}
.jsp-label{font-size:9.5px;font-weight:700;letter-spacing:2.5px;color:rgba(105,241,241,0.45);text-transform:uppercase}
.jsp-divider{height:1px;background:rgba(105,241,241,0.08);margin:2px 0;flex-shrink:0}
.jsp-textarea{
  width:100%;min-height:56px;
  background:rgba(255,255,255,0.03);
  border:1px solid rgba(105,241,241,0.12);
  border-radius:8px;
  color:rgba(220,238,255,0.9);
  font-size:13px;line-height:1.55;
  padding:8px 10px;resize:vertical;
  font-family:inherit;transition:border-color .2s,background .2s;
  box-sizing:border-box;
}
.jsp-textarea:focus{outline:none;border-color:rgba(105,241,241,0.42);background:rgba(255,255,255,0.05)}
.jsp-controls{display:flex;gap:5px;flex-wrap:wrap;align-items:center}
.jsp-btn{
  padding:4px 12px;border-radius:6px;font-size:11.5px;cursor:pointer;
  border:1px solid rgba(105,241,241,0.2);background:rgba(105,241,241,0.06);
  color:rgba(105,241,241,0.8);transition:all .15s;font-family:inherit;line-height:1.5
}
.jsp-btn:hover{background:rgba(105,241,241,0.16);color:#69f1f1;border-color:rgba(105,241,241,0.38)}
.jsp-btn-primary{background:rgba(105,241,241,0.16);border-color:rgba(105,241,241,0.45);color:#69f1f1;font-weight:700}
.jsp-btn-primary:hover{background:rgba(105,241,241,0.26)}
.jsp-btn-active{border-color:#69f1f1;color:#69f1f1;background:rgba(105,241,241,0.13)}
.jsp-btn-danger{border-color:rgba(239,68,68,0.45);color:rgba(239,68,68,0.9);background:rgba(239,68,68,0.06)}
.jsp-btn-danger:hover{background:rgba(239,68,68,0.14);border-color:rgba(239,68,68,0.7)}
.jsp-toggle-label{display:flex;align-items:center;gap:5px;font-size:11px;color:rgba(105,241,241,0.55);cursor:pointer}
.jsp-toggle-label input{accent-color:#69f1f1}
.jsp-response{
  background:rgba(255,255,255,0.025);
  border:1px solid rgba(105,241,241,0.08);
  border-radius:8px;padding:10px 12px;
  min-height:72px;max-height:340px;overflow-y:auto;
  font-size:13px;line-height:1.65;color:rgba(215,235,255,0.88);
  word-break:break-word;
}
.jsp-response::-webkit-scrollbar{width:3px}
.jsp-response::-webkit-scrollbar-thumb{background:rgba(105,241,241,0.18);border-radius:4px}
.jarvis-response-text{line-height:1.65}
.jsp-resize-handle{
  position:absolute;bottom:0;right:0;
  width:22px;height:22px;cursor:nwse-resize;
  background:linear-gradient(135deg,transparent 55%,rgba(105,241,241,0.28) 55%);
  border-radius:0 0 16px 0;z-index:10;
}
/* history inside jsp-body */
#jarvis-history .msg{padding:6px 9px;border-radius:7px;font-size:12px;line-height:1.5}
#jarvis-history .msg-user{background:rgba(105,241,241,0.07);color:rgba(220,238,255,0.85);align-self:flex-end}
#jarvis-history .msg-agent{background:rgba(255,255,255,0.04);color:rgba(215,235,255,0.8)}
#jarvis-history .msg-time{font-size:10px;color:rgba(105,241,241,0.35);margin-top:2px}

/* ── JARVIS PAGE LAYOUT FIXES ──────────────────────────────────── */
.jarvis-page { padding: 12px 24px 40px; }
.jarvis-title-bar { display:inline-flex;align-items:center;gap:12px;margin-bottom:4px; }
.jarvis-header { text-align:center;margin-bottom:20px; }
/* force panel fixed right */
.jarvis-side-panel { position:fixed !important; }
/* Piper voice mode button */
.jarvis-voice-mode-btn.active { border-color:#69f1f1;color:#69f1f1;background:rgba(105,241,241,.13); }

/* ── JARVIS LAYOUT: centralizar orb (panel é fixed, fora do flow) ── */
.jarvis-main-layout {
  display: flex;
  justify-content: center;
  align-items: flex-start;
  position: relative;
  min-height: 360px;
  padding-bottom: 40px;
}
.jarvis-orb-section {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 20px;
  padding: 16px 0;
}

/* Float dormant: baixa opacidade, sem animação */
#jarvis-float .jf-ball.jf-dormant {
  opacity: 0.38;
  filter: grayscale(0.5);
}
#jarvis-float .jf-ball.jf-dormant .jf-coil {
  animation-play-state: paused;
}
#jarvis-float .jf-ball.jf-dormant .jf-ring {
  animation-play-state: paused;
}

/* ── GLOBAL PROVIDER BANNER ────────────────────────────────────── */
#global-provider-banner { position: sticky; top: 0; z-index: 500; }
#global-provider-banner .prov-banner {
  display: flex; align-items: center; gap: 12px; flex-wrap: wrap;
  padding: 9px 20px;
  font-size: 13px; font-weight: 500;
}
#global-provider-banner .prov-banner-crit {
  background: rgba(239,68,68,0.12);
  border-bottom: 1px solid rgba(239,68,68,0.35);
  color: rgb(252,165,165);
}
#global-provider-banner .prov-banner-warn {
  background: rgba(234,179,8,0.1);
  border-bottom: 1px solid rgba(234,179,8,0.3);
  color: rgb(253,224,71);
}
#global-provider-banner .prov-banner-btns {
  display: flex; gap: 6px; margin-left: auto;
}
#global-provider-banner .btn-sm {
  padding: 3px 10px; font-size: 11px; border-radius: 5px;
  background: rgba(255,255,255,0.08); border: 1px solid rgba(255,255,255,0.2);
  color: inherit; cursor: pointer; text-decoration: none; display: inline-block;
}
#global-provider-banner .btn-sm:hover { background: rgba(255,255,255,0.15); }

/* ════════════════════════════════════════════════════════════════
   JARVIS TABS + BRAIN
   ════════════════════════════════════════════════════════════════ */

.jarvis-tabs-bar {
  display: flex;
  gap: 4px;
  padding: 0 0 16px 0;
  border-bottom: 1px solid var(--border);
  margin-bottom: 0;
}
.jarvis-tab-btn {
  display: flex;
  align-items: center;
  gap: 6px;
  padding: 6px 16px;
  border-radius: 6px;
  border: 1px solid var(--border);
  background: transparent;
  color: var(--text-muted);
  font-size: 13px;
  font-weight: 500;
  cursor: pointer;
  transition: all 0.15s;
  font-family: var(--font);
  letter-spacing: 0.3px;
}
.jarvis-tab-btn:hover { background: var(--surface-2); color: var(--text); }
.jarvis-tab-btn.active {
  background: var(--accent-dim);
  border-color: var(--accent-border);
  color: var(--accent);
}

/* ── Brain Page ────────────────────────────────────────────────── */
.brain-page {
  display: flex;
  flex-direction: column;
  height: 100%;
  gap: 0;
  padding: 20px 24px 0;
  overflow: hidden;
}
.brain-topbar {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 14px 0 14px;
}
.brain-title {
  font-size: 18px;
  font-weight: 700;
  color: var(--text);
  letter-spacing: 0.5px;
}
.brain-subtitle {
  font-size: 12px;
  color: var(--text-faint);
  margin-top: 2px;
}
.brain-status-pill {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 5px 14px;
  border-radius: 99px;
  border: 1px solid rgba(105,241,241,0.25);
  background: rgba(105,241,241,0.06);
  color: #69f1f1;
  font-size: 12px;
  font-weight: 500;
}
.brain-status-dot {
  width: 7px; height: 7px;
  border-radius: 50%;
  background: #69f1f1;
  animation: brainPulse 2s ease-in-out infinite;
}
@keyframes brainPulse {
  0%,100% { opacity:1; box-shadow: 0 0 0 0 rgba(105,241,241,0.5); }
  50%      { opacity:0.8; box-shadow: 0 0 0 5px rgba(105,241,241,0); }
}

.brain-body {
  display: flex;
  flex: 1;
  gap: 12px;
  overflow: hidden;
  padding-bottom: 20px;
  min-height: 0;
}

/* ── Sidebar esquerda ── */
.brain-sidebar {
  width: 180px;
  flex-shrink: 0;
  display: flex;
  flex-direction: column;
  gap: 0;
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: 10px;
  padding: 14px 12px;
  overflow: hidden;
}
.brain-sidebar-section { display: flex; flex-direction: column; gap: 6px; margin-bottom: 14px; }
.brain-sidebar-label {
  font-size: 10px;
  font-weight: 600;
  color: var(--text-faint);
  text-transform: uppercase;
  letter-spacing: 1px;
}
.brain-filter-group { display: flex; flex-direction: column; gap: 3px; }
.brain-filter-btn {
  display: flex; align-items: center; gap: 6px;
  padding: 5px 8px; border-radius: 5px; border: none;
  background: transparent; color: var(--text-muted);
  font-size: 12px; cursor: pointer; transition: all 0.12s;
  text-align: left; font-family: var(--font);
}
.brain-filter-btn:hover { background: var(--surface-2); color: var(--text); }
.brain-filter-btn.active {
  background: var(--surface-2);
  color: var(--fc, var(--accent));
  font-weight: 600;
}
.brain-agent-row {
  display: flex; align-items: center; gap: 7px;
  padding: 5px 6px; border-radius: 5px; cursor: pointer;
  transition: background 0.12s;
}
.brain-agent-row:hover { background: var(--surface-2); }
.brain-agent-dot { width: 6px; height: 6px; border-radius: 50%; flex-shrink: 0; }
.brain-agent-name { font-size: 12px; color: var(--text); flex: 1; }
.brain-agent-status { font-size: 10px; color: var(--text-faint); }
.brain-reset-btn {
  width: 100%; padding: 7px; border-radius: 6px;
  border: 1px solid var(--border); background: transparent;
  color: var(--text-muted); font-size: 12px; cursor: pointer;
  transition: all 0.12s; font-family: var(--font);
}
.brain-reset-btn:hover { background: var(--surface-2); color: var(--text); border-color: var(--border-strong); }

/* ── Canvas central ── */
.brain-canvas-wrap {
  flex: 1;
  position: relative;
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: 10px;
  overflow: hidden;
  min-width: 0;
}
#brain-canvas {
  display: block;
  width: 100%; height: 100%;
}
.brain-legend {
  position: absolute; bottom: 12px; left: 12px;
  display: flex; flex-wrap: wrap; gap: 8px;
  pointer-events: none;
}
.brain-legend-item {
  display: flex; align-items: center; gap: 4px;
  font-size: 10px; color: var(--text-faint);
}
.brain-legend-dot {
  width: 7px; height: 7px; border-radius: 50%; opacity: 0.85;
}

/* ── Painel direito ── */
.brain-detail-wrap {
  width: 210px;
  flex-shrink: 0;
  display: flex;
  flex-direction: column;
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: 10px;
  padding: 14px 12px;
  overflow-y: auto;
}
.brain-detail-panel { flex: 1; }
.brain-detail-empty {
  font-size: 12px; color: var(--text-faint);
  line-height: 1.6; padding: 8px 0;
}
.brain-detail-name { font-size: 15px; font-weight: 700; color: var(--text); }
.brain-detail-type { font-size: 11px; }
.brain-detail-desc {
  font-size: 12px; color: var(--text-muted); line-height: 1.6;
  margin-bottom: 12px;
}
.brain-detail-section {
  font-size: 10px; font-weight: 600; color: var(--text-faint);
  text-transform: uppercase; letter-spacing: 1px;
  margin-bottom: 8px;
}
.brain-detail-conns { display: flex; flex-direction: column; gap: 5px; }
.brain-detail-conn {
  font-size: 12px; color: var(--text-muted);
  display: flex; align-items: center; gap: 4px; flex-wrap: wrap;
}
.brain-detail-conn-lbl {
  font-size: 10px; color: var(--text-faint);
  background: var(--surface-2); border-radius: 3px; padding: 1px 5px;
}

/* ── Stats grid ── */
.brain-stats-grid {
  display: grid; grid-template-columns: 1fr 1fr; gap: 6px;
}
.brain-stat-card {
  background: var(--surface-2); border: 1px solid var(--border);
  border-radius: 7px; padding: 10px 10px 8px;
  text-align: center;
}
.brain-stat-val { font-size: 18px; font-weight: 700; line-height: 1.2; }
.brain-stat-lbl { font-size: 10px; color: var(--text-faint); margin-top: 3px; line-height: 1.3; }

/* ── Responsivo ── */
@media (max-width: 900px) {
  .brain-sidebar { display: none; }
  .brain-detail-wrap { width: 170px; }
}
@media (max-width: 640px) {
  .brain-body { flex-direction: column; }
  .brain-detail-wrap { width: 100%; height: 200px; }
  .brain-canvas-wrap { min-height: 260px; }
}

/* Garantir que a jarvis-page com tabs não quebre o layout */
.jarvis-page .jarvis-tabs-bar { margin-top: 0; }

/* ── Brain collapse panels ── */
.brain-sidebar, .brain-detail-wrap {
  transition: width 0.22s ease, padding 0.22s ease, opacity 0.18s ease;
  overflow: hidden;
}
.brain-sidebar.brain-collapsed {
  width: 32px !important;
  padding: 10px 4px !important;
  opacity: 0.7;
}
.brain-detail-wrap.brain-collapsed {
  width: 32px !important;
  padding: 10px 4px !important;
  opacity: 0.7;
}
.brain-sidebar.brain-collapsed > *:not(.brain-collapse-btn),
.brain-detail-wrap.brain-collapsed > *:not(.brain-collapse-btn) {
  display: none !important;
}
.brain-collapse-btn {
  display: flex; align-items: center; justify-content: center;
  width: 24px; height: 24px; border-radius: 5px;
  border: 1px solid var(--border); background: transparent;
  color: var(--text-muted); font-size: 12px; cursor: pointer;
  transition: all 0.12s; flex-shrink: 0;
  font-family: var(--font); line-height: 1;
}
.brain-collapse-btn:hover { background: var(--surface-2); color: var(--text); }
.brain-sidebar .brain-collapse-btn { margin-bottom: 8px; }
.brain-detail-wrap .brain-collapse-btn { margin-bottom: 8px; }
