/* imo — Kanagawa Wave v12 — warm light mode */
:root {
  --bg: #f3efe6;
  --bg2: #eae5d9;
  --surface: rgba(59,107,158,0.06);
  --surface-hover: rgba(59,107,158,0.10);
  --card: rgba(255,255,255,0.72);
  --border: rgba(59,107,158,0.12);
  --border-light: rgba(59,107,158,0.06);
  --text: #1a1b2e;
  --text2: #3c3d52;
  --text3: #8b8a96;
  --accent: #3b6b9e;
  --accent-glow: rgba(59,107,158,0.10);
  --accent-hover: #2d5580;
  --green: #4a8b8c;
  --green-glow: rgba(74,139,140,0.10);
  --red: #8b3a3a;
  --red-glow: rgba(139,58,58,0.08);
  --orange: #b07d4f;
  --purple: #7a6b9e;
  --radius: 14px;
  --radius-sm: 10px;
  --font-display: 'Playfair Display', Georgia, serif;
  --font: 'DM Sans', -apple-system, BlinkMacSystemFont, system-ui, sans-serif;
  --font-mono: 'JetBrains Mono', ui-monospace, monospace;
  --shadow: 0 1px 4px rgba(26,27,46,0.06);
  --shadow-lg: 0 8px 24px rgba(26,27,46,0.10);
  --sidebar-w: 240px;
  --tabh: 84px;
  --touch-min: 44px;
  --safe-top: env(safe-area-inset-top, 0px);
  --safe-bottom: env(safe-area-inset-bottom, 0px);
  --keyboard-inset: 0px;
  --vvh: 1vh;
}

*{box-sizing:border-box;margin:0;padding:0;-webkit-tap-highlight-color:transparent}
html,body{height:100%;overflow:hidden}
html{font-size:16px;touch-action:manipulation}
body{background:var(--bg);color:var(--text);font-family:var(--font);-webkit-font-smoothing:antialiased;-webkit-text-size-adjust:100%;text-size-adjust:100%;touch-action:manipulation}
input,textarea,select{font-size:1rem}

:where(button, [role="button"], a, input, textarea, select, .nav-item, .tab, .btn, .btn-icon, .filter-pill, .cl-pill, .brain-tab, .sr-tab, .task-act, .task-check, .archive-back, .push-dismiss, .drop-zone, .file-card){
  -webkit-tap-highlight-color:transparent;
  touch-action:manipulation;
}

/* Grain texture overlay — subtle woodblock feel */
body::after{
  content:'';position:fixed;inset:0;z-index:9998;pointer-events:none;
  opacity:0.022;
  filter:url(#grain);
  width:100%;height:100%;
}

#app{display:flex;height:100dvh;height:calc(var(--vvh, 1vh) * 100)}

/* ===== SIDEBAR (desktop) ===== */
#sidebar{
  width:var(--sidebar-w);min-width:var(--sidebar-w);
  background:var(--bg2);
  border-right:1px solid var(--border);
  display:flex;flex-direction:column;z-index:10;
  position:relative;overflow:hidden;overflow-y:auto;-webkit-overflow-scrolling:touch;
}
/* Wave watermark on sidebar */
#sidebar::after{
  content:'';position:absolute;bottom:0;left:0;right:0;height:120px;
  background:linear-gradient(0deg, rgba(59,107,158,0.04) 0%, transparent 100%);
  pointer-events:none;
}
.sidebar-header{padding:24px 20px 20px;display:flex;align-items:center;justify-content:space-between;padding-top:max(24px, var(--safe-top))}
.logo{display:flex;align-items:center;gap:12px}
.logo h1{font-family:var(--font-display);font-size:1.3rem;font-weight:800;letter-spacing:-0.02em;color:var(--accent);line-height:1.1}
.logo .subtitle{font-family:var(--font-mono);font-size:.6rem;color:var(--text3);text-transform:uppercase;letter-spacing:.14em;font-weight:500}
.nav-items{list-style:none;flex:1;padding:0 10px;display:flex;flex-direction:column;gap:2px}
.nav-item{display:flex;align-items:center;gap:12px;padding:12px 14px;min-height:var(--touch-min);border-radius:var(--radius-sm);cursor:pointer;font-size:.86rem;font-weight:500;color:var(--text2);transition:all .15s;position:relative}
.nav-item:hover{background:var(--surface-hover);color:var(--text)}
.nav-item.active{background:var(--accent-glow);color:var(--accent)}
.nav-item.active::before{content:'';position:absolute;left:0;top:50%;transform:translateY(-50%);width:3px;height:20px;background:var(--accent);border-radius:0 3px 3px 0}
.sidebar-footer{display:flex;align-items:center;gap:8px;padding:16px 20px;border-top:1px solid var(--border);font-family:var(--font-mono);font-size:.68rem;color:var(--text3);font-weight:500;position:relative;z-index:1}
.status-dot{width:7px;height:7px;border-radius:50%;background:var(--orange);transition:all .3s;box-shadow:0 0 4px rgba(176,125,79,0.3)}
.status-dot.connected{background:var(--green);box-shadow:0 0 4px rgba(74,139,140,0.3)}
.status-dot.offline{background:var(--red);box-shadow:0 0 4px rgba(139,58,58,0.3);animation:pulse-offline 2s infinite}
@keyframes pulse-offline{0%,100%{opacity:1}50%{opacity:.4}}
.sync-badge{display:inline-block;margin-left:6px;padding:1px 7px;font-size:.66rem;font-weight:600;background:var(--orange);color:#fff;border-radius:8px;vertical-align:middle}

/* ===== MAIN ===== */
#main{
  flex:1;overflow:hidden;position:relative;
  background:var(--bg);
  /* Subtle wave pattern */
  background-image:
    radial-gradient(ellipse at 20% 80%, rgba(59,107,158,0.04) 0%, transparent 50%),
    radial-gradient(ellipse at 80% 20%, rgba(176,125,79,0.03) 0%, transparent 50%);
}

.view{
  position:absolute;inset:0;overflow-y:auto;overflow-x:hidden;-webkit-overflow-scrolling:touch;
  padding:16px 16px calc(24px + var(--keyboard-inset));
  padding-top:max(16px, var(--safe-top));
  scroll-padding-bottom:calc(24px + var(--keyboard-inset));
  opacity:0;pointer-events:none;transition:opacity .15s ease;will-change:opacity
}
.view.active{opacity:1;pointer-events:auto;z-index:1}

/* ===== STAGGER CASCADE ANIMATION ===== */
@keyframes cascadeIn{
  from{opacity:0;transform:translateY(12px)}
  to{opacity:1;transform:translateY(0)}
}
.stagger-in > *{
  animation:cascadeIn .35s cubic-bezier(.16,1,.3,1) both;
}
.stagger-in > *:nth-child(1){animation-delay:0s}
.stagger-in > *:nth-child(2){animation-delay:.05s}
.stagger-in > *:nth-child(3){animation-delay:.1s}
.stagger-in > *:nth-child(4){animation-delay:.15s}
.stagger-in > *:nth-child(5){animation-delay:.2s}
.stagger-in > *:nth-child(6){animation-delay:.25s}
.stagger-in > *:nth-child(7){animation-delay:.3s}
.stagger-in > *:nth-child(8){animation-delay:.35s}
.stagger-in > *:nth-child(9){animation-delay:.4s}
.stagger-in > *:nth-child(10){animation-delay:.45s}

/* ===== VIEW HEADER ===== */
.view-header{margin-bottom:20px;padding-top:4px}
.view-header h2{font-family:var(--font-display);font-size:1.8rem;font-weight:800;letter-spacing:-.02em;color:var(--text)}
.view-header p{font-family:var(--font-mono);color:var(--text3);font-size:.72rem;margin-top:2px;letter-spacing:.03em}

/* ===== CARDS ===== */
.card{
  background:var(--card);
  border-radius:var(--radius);
  padding:16px;
  box-shadow:var(--shadow);
  backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);
  border:1px solid var(--border);
}
.card-title{font-family:var(--font-mono);font-size:.65rem;color:var(--text3);text-transform:uppercase;letter-spacing:.1em;font-weight:500;margin-bottom:10px}

/* ===== STAT CARDS ===== */
.stats-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:10px;margin-bottom:16px}
.stat-card{
  background:var(--card);border-radius:var(--radius);padding:14px;
  box-shadow:var(--shadow);
  backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);
  border:1px solid var(--border);
}
.stat-card .value{font-family:var(--font-display);font-size:1.6rem;font-weight:700;letter-spacing:-.02em;line-height:1;color:var(--text)}
.stat-card .label{font-family:var(--font-mono);font-size:.6rem;color:var(--text3);margin-top:4px;text-transform:uppercase;letter-spacing:.08em;font-weight:500}
.stat-card.accent .value{color:var(--accent)}
.stat-card.green .value{color:var(--green)}

/* ===== BUTTONS ===== */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:6px;padding:10px 18px;border-radius:var(--radius-sm);border:none;font-size:.84rem;font-family:var(--font);font-weight:600;cursor:pointer;transition:all .12s;white-space:nowrap}
.btn:active{transform:scale(.96)}
.btn-primary{background:var(--accent);color:#fff}
.btn-ghost{background:var(--surface);color:var(--accent)}
.btn-danger{background:var(--red-glow);color:var(--red)}
.btn-sm{padding:7px 12px;font-size:.76rem;border-radius:8px}
.btn-icon{width:36px;height:36px;padding:0;border-radius:50%;background:var(--surface);color:var(--text2);display:flex;align-items:center;justify-content:center}

/* ===== DROP ZONE ===== */
.drop-zone{border:2px dashed var(--border);border-radius:var(--radius);padding:32px 20px;text-align:center;cursor:pointer;transition:all .2s;color:var(--text3);margin-bottom:12px;background:var(--card);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px)}
.drop-zone.over{border-color:var(--orange);color:var(--orange);background:rgba(176,125,79,0.06)}
.drop-zone p{font-size:.86rem;font-weight:500}
.drop-zone .hint{font-family:var(--font-mono);font-size:.65rem;color:var(--text3);margin-top:3px}
.drop-zone input{display:none}
.upload-progress{margin-bottom:8px}
.prog-item{background:var(--card);border-radius:var(--radius-sm);padding:10px 14px;margin-bottom:6px;box-shadow:var(--shadow);border:1px solid var(--border)}
.prog-item .name{font-size:.78rem;font-weight:500;margin-bottom:6px;word-break:break-all}
.prog-bar{height:3px;background:rgba(59,107,158,0.08);border-radius:2px;overflow:hidden}
.prog-fill{height:100%;background:linear-gradient(90deg,var(--accent),var(--green));width:0;transition:width .15s;border-radius:2px}
.prog-fill.done{background:var(--green)}
.prog-fill.error{background:var(--red)}

/* ===== FILE GRID ===== */
.file-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(100px,1fr));gap:10px;margin-bottom:16px}
.file-card{
  background:var(--card);border-radius:12px;overflow:hidden;
  box-shadow:var(--shadow);cursor:pointer;
  transition:transform .12s, box-shadow .2s, border-color .2s;
  position:relative;
  border:1px solid var(--border);
}
.file-card:hover{transform:translateY(-2px);box-shadow:0 6px 20px rgba(59,107,158,0.12);border-color:var(--accent)}
.file-card:active{transform:scale(.96)}
.file-card.selected{outline:3px solid var(--orange);outline-offset:-3px}
.file-card.selected::after{content:'\2713';position:absolute;top:6px;right:6px;width:22px;height:22px;background:var(--orange);color:#fff;border-radius:50%;font-size:.7rem;display:flex;align-items:center;justify-content:center;font-weight:700}
.file-thumb{width:100%;aspect-ratio:1;background:rgba(59,107,158,0.05);display:flex;align-items:center;justify-content:center;overflow:hidden}
.file-thumb img{width:100%;height:100%;object-fit:cover}
.file-thumb .file-icon{color:var(--text3)}
.file-info{padding:8px;overflow:hidden}
.file-info .fname{font-size:.68rem;font-weight:500;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;display:block}
.file-info .fsize{font-family:var(--font-mono);font-size:.58rem;color:var(--text3);margin-top:1px}

/* File selection bar */
.select-bar{position:sticky;top:0;z-index:10;background:var(--accent);color:#fff;border-radius:var(--radius);padding:12px 16px;margin-bottom:12px;display:flex;align-items:center;justify-content:space-between;box-shadow:var(--shadow-lg)}
.select-bar .count{font-weight:600;font-size:.88rem}
.select-bar .actions{display:flex;gap:8px}
.select-bar .btn{background:rgba(255,255,255,.2);color:#fff;padding:7px 14px}

/* ===== PREVIEW MODAL ===== */
.preview-overlay{position:fixed;inset:0;background:rgba(26,27,46,.94);z-index:200;display:flex;flex-direction:column;opacity:0;pointer-events:none;transition:opacity .2s}
.preview-overlay.open{opacity:1;pointer-events:auto}
.preview-header{display:flex;align-items:center;justify-content:space-between;padding:12px 16px;padding-top:max(12px,env(safe-area-inset-top));color:#f3efe6;flex-shrink:0}
.preview-header .title{font-size:.84rem;font-weight:600;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;flex:1;margin:0 12px}
.preview-header button{background:none;border:none;color:#f3efe6;cursor:pointer;padding:8px;font-size:1rem;font-weight:600}
.preview-body{flex:1;display:flex;align-items:center;justify-content:center;overflow:auto;padding:8px;-webkit-overflow-scrolling:touch}
.preview-body img{max-width:100%;max-height:100%;object-fit:contain;border-radius:4px}
.preview-footer{display:flex;justify-content:center;gap:20px;padding:16px;padding-bottom:max(16px,env(safe-area-inset-bottom));flex-shrink:0}
.preview-footer button{background:none;border:none;color:#f3efe6;display:flex;flex-direction:column;align-items:center;gap:4px;font-size:.64rem;font-family:var(--font);cursor:pointer;opacity:.7}
.preview-footer button:active{opacity:1}

/* ===== CHAT ===== */
.chat-view-wrap{padding:12px;overflow:hidden}
.chat-view{
  display:flex;flex-direction:column;height:100%;
  border-radius:var(--radius);background:var(--card);
  box-shadow:var(--shadow-lg);border:1px solid var(--border);
  overflow:hidden;
}
.chat-header{
  display:flex;align-items:center;justify-content:space-between;
  padding:16px 18px;
  background:linear-gradient(120deg,rgba(59,107,158,0.10),rgba(255,255,255,0.6));
  border-bottom:1px solid var(--border);
}
.chat-header h2{font-family:var(--font-display);font-size:1.4rem;font-weight:800;letter-spacing:-.02em;color:var(--text)}
.chat-header p{font-family:var(--font-mono);font-size:.7rem;color:var(--text3);margin-top:2px}
.chat-conn{display:flex;align-items:center;gap:6px;font-family:var(--font-mono);font-size:.65rem;color:var(--text3)}
.chat-conn .conn-dot{width:8px;height:8px;border-radius:50%;background:var(--orange);box-shadow:0 0 6px rgba(176,125,79,0.35)}
.chat-conn.online .conn-dot{background:var(--green);box-shadow:0 0 6px rgba(74,139,140,0.35)}

.chat-body{position:relative;flex:1;background:var(--bg)}
.chat-messages{
  position:relative;height:100%;
  overflow-y:auto;overflow-x:hidden;
  padding:18px;display:flex;flex-direction:column;gap:12px;
  -webkit-overflow-scrolling:touch;
}
.chat-sentinel{height:1px}
.chat-empty{
  position:absolute;inset:0;display:flex;flex-direction:column;
  align-items:center;justify-content:center;gap:10px;text-align:center;
  color:var(--text3);pointer-events:none;
}
.chat-empty.hidden{display:none}
.chat-empty .empty-title{font-family:var(--font-display);font-size:1.4rem;color:var(--text)}
.chat-empty .empty-sub{font-family:var(--font-mono);font-size:.7rem}
.chat-empty .empty-prompts{display:flex;flex-wrap:wrap;gap:8px;justify-content:center;pointer-events:auto}
.chat-empty .chat-prompt{
  background:var(--surface);border:1px solid var(--border);color:var(--text2);
  padding:8px 12px;border-radius:999px;font-size:.75rem;cursor:pointer;
}
.chat-empty .chat-prompt:hover{background:var(--surface-hover);color:var(--text)}

.chat-msg{display:flex;flex-direction:column;gap:4px;max-width:80%;animation:foamUp .3s cubic-bezier(.16,1,.3,1)}
@keyframes foamUp{from{opacity:0;transform:translateY(8px) scale(.97)}to{opacity:1;transform:translateY(0) scale(1)}}
.chat-msg.user{align-self:flex-end}
.chat-msg.assistant{align-self:flex-start}
.chat-msg.system{align-self:center;max-width:70%}
.chat-bubble{
  padding:12px 14px;border-radius:16px;font-size:.9rem;line-height:1.5;
  word-wrap:break-word;overflow-wrap:break-word;box-shadow:var(--shadow);
  border:1px solid transparent;
}
.chat-msg.user .chat-bubble{background:#23364d;color:#f5f7fb;border-bottom-right-radius:8px}
.chat-msg.assistant .chat-bubble{background:rgba(255,255,255,0.9);color:var(--text);border:1px solid var(--border);border-bottom-left-radius:8px}
.chat-msg.system .chat-bubble{background:rgba(59,107,158,0.10);color:var(--text2);border:1px dashed var(--border);border-radius:14px;font-size:.82rem}

.chat-bubble pre{
  margin:8px 0 0;padding:10px;border-radius:10px;
  background:rgba(26,27,46,0.08);overflow:auto;
  font-family:var(--font-mono);font-size:.78rem;
}
.chat-msg.user pre{background:rgba(255,255,255,0.15);color:#fff}
.chat-bubble code{
  background:rgba(26,27,46,0.08);padding:1px 4px;border-radius:6px;
  font-family:var(--font-mono);font-size:.8rem;
}
.chat-msg.user code{background:rgba(255,255,255,0.16);color:#fff}

.chat-meta{display:flex;align-items:center;gap:10px;font-family:var(--font-mono);font-size:.6rem;color:var(--text3);padding:0 6px}
.chat-meta .timestamp{opacity:0;transition:opacity .12s}
.chat-msg:hover .chat-meta .timestamp{opacity:1}
.chat-meta .status{text-transform:uppercase;letter-spacing:.08em}

.chat-actions{display:flex;gap:6px;padding:0 6px;opacity:0;transition:opacity .12s}
.chat-msg:hover .chat-actions{opacity:1}
.chat-action{
  width:26px;height:26px;border-radius:50%;
  border:1px solid var(--border);background:var(--surface);color:var(--text2);
  display:flex;align-items:center;justify-content:center;cursor:pointer;
}
.chat-action:hover{background:var(--surface-hover);color:var(--text)}

.chat-msg.typing .chat-bubble{background:rgba(255,255,255,0.85);border:1px solid var(--border)}
.typing-dots{display:flex;gap:4px}
.typing-dots span{
  width:6px;height:6px;border-radius:50%;background:var(--text3);
  animation:typingBlink 1.2s infinite;
}
.typing-dots span:nth-child(2){animation-delay:.2s}
.typing-dots span:nth-child(3){animation-delay:.4s}
@keyframes typingBlink{0%,80%,100%{opacity:.4}40%{opacity:1}}

.chat-composer{border-top:1px solid var(--border);padding:12px 16px;background:var(--bg2)}
.composer-wrap{display:flex;gap:10px;align-items:flex-end}
#chat-input{
  flex:1;background:rgba(255,255,255,0.85);border:1px solid var(--border);
  border-radius:16px;padding:10px 12px;color:var(--text);font-size:.86rem;
  font-family:var(--font);outline:none;resize:none;max-height:180px;
}
#chat-input::placeholder{color:var(--text3)}
#chat-input:focus{border-color:var(--accent);box-shadow:0 0 0 2px var(--accent-glow)}
#chat-send{border-radius:50%;width:40px;height:40px;padding:0;flex-shrink:0}
.composer-hint{font-family:var(--font-mono);font-size:.6rem;color:var(--text3);margin-top:6px}

/* ===== TASKS ===== */
.task-sections{display:flex;flex-direction:column;gap:16px}
.task-section-title{font-family:var(--font-mono);font-size:.65rem;font-weight:500;text-transform:uppercase;letter-spacing:.08em;color:var(--text3);margin-bottom:6px;padding-left:4px}
.task-list{display:flex;flex-direction:column}
.task-item{display:flex;align-items:center;gap:12px;background:var(--card);padding:13px 14px;border-bottom:.5px solid var(--border-light);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px)}
.task-item:first-child{border-radius:var(--radius) var(--radius) 0 0}
.task-item:last-child{border-radius:0 0 var(--radius) var(--radius);border-bottom:none}
.task-item:only-child{border-radius:var(--radius)}
.task-icon{flex-shrink:0;width:24px;height:24px;display:flex;align-items:center;justify-content:center}
.task-in_progress .task-icon{color:var(--accent)}
.task-done .task-icon,.task-completed .task-icon{color:var(--green)}

/* Wave-spin spinner */
.spinner{
  width:18px;height:18px;
  border:2px solid rgba(59,107,158,0.15);
  border-top-color:var(--accent);
  border-right-color:var(--orange);
  border-radius:50%;
  animation:waveSpin 1s ease-in-out infinite;
}
@keyframes waveSpin{
  0%{transform:rotate(0deg)}
  100%{transform:rotate(360deg)}
}

.task-dot{width:20px;height:20px;border-radius:50%;border:2px solid var(--text3)}
.task-body{flex:1;min-width:0}
.task-title{font-weight:600;font-size:.86rem}
.task-detail{font-size:.78rem;color:var(--text2);margin-top:1px;line-height:1.3}
.task-active-form{font-size:.76rem;color:var(--accent);font-weight:500;margin-top:2px;font-style:italic}
.task-meta{font-family:var(--font-mono);font-size:.6rem;color:var(--text3);margin-top:3px}
.task-badge{flex-shrink:0;font-family:var(--font-mono);font-size:.58rem;font-weight:500;text-transform:uppercase;letter-spacing:.06em;padding:3px 8px;border-radius:5px}
.badge-in_progress{background:var(--accent-glow);color:var(--accent)}
.badge-done{background:var(--green-glow);color:var(--green)}
.badge-pending{background:var(--surface);color:var(--text3)}

/* Task toolbar & filters */
.task-toolbar{display:flex;align-items:center;justify-content:space-between;gap:10px;margin-bottom:12px;flex-wrap:wrap}
.filter-pills{display:flex;gap:6px}
.filter-pill{background:var(--surface);border:1px solid var(--border);border-radius:20px;padding:5px 14px;font-size:.76rem;font-weight:500;color:var(--text2);cursor:pointer;transition:all .2s}
.filter-pill.active{background:var(--accent);color:#fff;border-color:var(--accent)}
.filter-pill:hover:not(.active){background:var(--surface-hover)}
.filter-count{font-family:var(--font-mono);font-size:.65rem;opacity:.7;margin-left:2px}
.btn-create-task{background:var(--accent);color:#fff;border:none;border-radius:var(--radius);padding:7px 16px;font-size:.8rem;font-weight:600;cursor:pointer;transition:background .2s}
.btn-create-task:hover{background:var(--accent-hover)}

/* Task create/edit forms */
.task-create-form,.task-edit-form{background:var(--card);border:1px solid var(--border);border-radius:var(--radius);padding:14px;margin-bottom:12px;display:flex;flex-direction:column;gap:8px;backdrop-filter:blur(12px)}
.task-create-title,.task-edit-title{font-size:1rem;font-weight:600;padding:8px 10px;border:1px solid var(--border);border-radius:6px;background:var(--bg);color:var(--text);outline:none}
.task-create-title:focus,.task-edit-title:focus{border-color:var(--accent)}
.task-create-desc,.task-edit-desc{font-size:1rem;padding:8px 10px;border:1px solid var(--border);border-radius:6px;background:var(--bg);color:var(--text);outline:none;resize:vertical;font-family:var(--font-sans)}
.task-create-desc:focus,.task-edit-desc:focus{border-color:var(--accent)}
.task-edit-row{display:flex;gap:8px;align-items:center;flex-wrap:wrap}
.task-edit-row select{font-size:1rem;padding:6px 8px;border:1px solid var(--border);border-radius:6px;background:var(--bg);color:var(--text);outline:none}
.btn-save{background:var(--accent);color:#fff;border:none;border-radius:6px;padding:6px 16px;font-size:.78rem;font-weight:600;cursor:pointer}
.btn-save:hover{background:var(--accent-hover)}
.btn-cancel{background:var(--surface);color:var(--text2);border:1px solid var(--border);border-radius:6px;padding:6px 14px;font-size:.78rem;cursor:pointer}

/* Task action buttons */
.task-actions{display:flex;gap:4px;opacity:0;transition:opacity .15s;flex-shrink:0;align-items:center}
.task-item:hover .task-actions{opacity:1}
@media(max-width:768px){.task-actions{opacity:1}}
.task-act{background:none;border:1px solid var(--border);border-radius:8px;padding:0;cursor:pointer;color:var(--text3);display:flex;align-items:center;justify-content:center;transition:all .15s;width:var(--touch-min);height:var(--touch-min)}
.task-act:hover{background:var(--surface);color:var(--accent);border-color:var(--accent)}
.task-act-del:hover{color:var(--red);border-color:var(--red)}

/* Task check button (complete/uncomplete) */
.task-check{width:var(--touch-min);height:var(--touch-min);border-radius:50%;border:2px solid var(--text3);background:none;cursor:pointer;display:flex;align-items:center;justify-content:center;padding:0;transition:all .15s}
.task-check:hover{border-color:var(--green);background:var(--green-glow)}
.task-check.checked{border:none;color:var(--green);background:none;cursor:pointer;padding:0}
.task-check.checked:hover{opacity:.7}

/* Truncated detail */
.task-detail-trunc{overflow:hidden;text-overflow:ellipsis;white-space:nowrap;max-width:300px}

/* Priority indicators */
.task-high{border-left:3px solid var(--orange)}
.task-urgent{border-left:3px solid var(--red)}
.prio-tag{font-weight:600;font-size:.58rem;text-transform:uppercase;letter-spacing:.04em}
.prio-1{color:var(--orange)}
.prio-2{color:var(--red)}

/* Editing state */
.task-editing{padding:0!important}

/* Expand cursor */
.task-body{cursor:pointer}

/* ===== PUSH BANNER ===== */
.push-banner{margin:12px 16px;cursor:pointer;animation:fadeSlide .4s ease}
.push-banner-inner{
  display:flex;align-items:center;gap:10px;
  background:linear-gradient(135deg, var(--accent), rgba(176,125,79,0.7));
  color:#fff;padding:12px 16px;border-radius:var(--radius);
  font-size:.84rem;font-weight:600;
  box-shadow:var(--shadow-lg);
}
.push-banner svg{flex-shrink:0;stroke:#fff}
.push-banner span{flex:1}
.push-dismiss{background:none;border:none;color:rgba(255,255,255,.6);font-size:1.2rem;padding:0 4px;cursor:pointer;line-height:1}
@keyframes fadeSlide{from{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}

/* ===== BRAIN ===== */
.brain-tabs{display:flex;background:var(--surface);border-radius:10px;padding:2px;margin-bottom:14px;border:1px solid var(--border)}
.brain-tab{flex:1;padding:8px;text-align:center;font-size:.8rem;font-weight:600;border-radius:8px;cursor:pointer;color:var(--text3);transition:all .15s;border:none;background:none;font-family:var(--font)}
.brain-tab.active{background:var(--card);color:var(--text);box-shadow:var(--shadow)}
.search-bar{display:flex;gap:8px;margin-bottom:12px}
.search-bar input{flex:1;background:var(--card);border:1px solid var(--border);border-radius:var(--radius-sm);padding:10px 14px;color:var(--text);font-size:.86rem;font-family:var(--font);outline:none;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px)}
.search-bar input::placeholder{color:var(--text3)}
.search-bar input:focus{border-color:var(--accent)}
.memory-item{padding:12px 0;border-bottom:1px solid var(--border-light)}
.memory-item:last-child{border-bottom:none}
.memory-item .key{font-weight:600;font-size:.86rem}
.memory-item .val{font-size:.78rem;color:var(--text2);line-height:1.4;margin-top:2px}
.memory-item .cat{display:inline-block;font-family:var(--font-mono);font-size:.56rem;font-weight:500;text-transform:uppercase;letter-spacing:.06em;color:#fff;padding:2px 7px;border-radius:5px;margin-right:5px;background:var(--accent)}
.cat-preference{background:var(--purple)!important}
.cat-tool{background:var(--orange)!important}
.cat-pattern{background:var(--green)!important}
.cat-correction{background:var(--red)!important}
.cat-project{background:var(--purple)!important}
.tag{display:inline-block;background:var(--surface);color:var(--text3);font-family:var(--font-mono);font-size:.58rem;font-weight:500;padding:2px 7px;border-radius:5px;margin-top:5px;margin-right:3px;border:1px solid var(--border)}

/* Brain graph */
#brain-canvas{width:100%;border-radius:var(--radius);background:var(--card);box-shadow:var(--shadow);touch-action:none;border:1px solid var(--border)}

/* New knowledge graph */
.brain-graph-page{display:flex;flex-direction:column;gap:12px;min-height:calc(100vh - 180px)}
.brain-stats-bar{
  display:grid;grid-template-columns:repeat(auto-fit,minmax(140px,1fr));gap:10px;
  background:var(--card);border-radius:var(--radius);padding:12px;border:1px solid var(--border);
  box-shadow:var(--shadow);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);
}
.stat-pill{display:flex;flex-direction:column;gap:4px}
.stat-pill span{font-family:var(--font-mono);font-size:.6rem;color:var(--text3);text-transform:uppercase;letter-spacing:.08em;font-weight:500}
.stat-pill strong{font-size:1.15rem;font-weight:700;color:var(--text)}

.brain-graph-shell{position:relative;flex:1;min-height:480px}
.brain-graph-canvas-wrap{
  position:relative;height:min(72vh,720px);min-height:420px;
  background:var(--card);border:1px solid var(--border);border-radius:var(--radius);
  overflow:hidden;box-shadow:var(--shadow-lg);
}
#brain-graph-canvas{
  width:100%;height:100%;display:block;
  background:
    radial-gradient(circle at 20% 20%, rgba(59,107,158,0.06), transparent 45%),
    radial-gradient(circle at 80% 80%, rgba(176,125,79,0.05), transparent 45%),
    linear-gradient(180deg, rgba(255,255,255,0.45), rgba(255,255,255,0.2));
  touch-action:none;
}

.brain-graph-controls{
  position:absolute;top:12px;left:12px;display:flex;flex-wrap:wrap;gap:10px;
  padding:10px 12px;border-radius:12px;border:1px solid var(--border);
  background:rgba(255,255,255,0.88);backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px);
  box-shadow:var(--shadow);
}
.control-group{display:flex;flex-wrap:wrap;gap:8px;align-items:center}
.control-label{font-family:var(--font-mono);font-size:.58rem;text-transform:uppercase;letter-spacing:.08em;color:var(--text3);margin-right:4px}
.control-toggle{display:flex;align-items:center;gap:6px;font-size:.7rem;color:var(--text2);font-weight:600}
.control-toggle input{accent-color:var(--accent)}
.brain-graph-controls select{
  background:var(--surface);border:1px solid var(--border);border-radius:8px;padding:6px 8px;
  font-size:.7rem;color:var(--text2);font-family:var(--font);
}

.brain-legend{
  position:absolute;bottom:12px;left:12px;display:flex;gap:10px;flex-wrap:wrap;
  background:rgba(255,255,255,0.82);border:1px solid var(--border);border-radius:12px;
  padding:8px 10px;font-size:.7rem;color:var(--text2);backdrop-filter:blur(12px);
}
.legend-item{display:flex;align-items:center;gap:6px;font-weight:600}
.legend-shape{width:12px;height:12px;display:inline-block}
.legend-shape.memory{background:#3b6b9e;border-radius:50%}
.legend-shape.learning{background:#c4956a;transform:rotate(45deg)}
.legend-shape.file{background:#4ade80}
.legend-shape.session{background:#a78bfa;clip-path:polygon(25% 5%,75% 5%,100% 50%,75% 95%,25% 95%,0 50%)}

.brain-graph-empty{
  position:absolute;inset:0;display:flex;align-items:center;justify-content:center;
  background:rgba(243,239,230,0.82);color:var(--text3);font-size:.86rem;
  backdrop-filter:blur(6px);transition:opacity .2s ease;
}
.brain-graph-empty.hidden{opacity:0;pointer-events:none}

.brain-detail-panel{
  position:absolute;top:0;right:0;height:100%;width:min(360px,88vw);
  background:rgba(255,255,255,0.95);border-left:1px solid var(--border);
  transform:translateX(102%);transition:transform .2s ease;display:flex;flex-direction:column;
  box-shadow:-10px 0 28px rgba(26,27,46,0.12);backdrop-filter:blur(18px);
}
.brain-detail-panel.open{transform:translateX(0)}
.brain-detail-header{display:flex;align-items:center;justify-content:space-between;padding:14px 16px;border-bottom:1px solid var(--border)}
.detail-type{font-family:var(--font-mono);font-size:.62rem;letter-spacing:.08em;text-transform:uppercase;color:var(--text3);font-weight:600}
.detail-title{font-size:.92rem;font-weight:700;color:var(--text);margin-top:4px}
.brain-detail-body{padding:14px 16px;overflow:auto;display:flex;flex-direction:column;gap:10px}
.detail-row{display:flex;flex-direction:column;gap:4px;padding-bottom:10px;border-bottom:1px dashed var(--border-light)}
.detail-row:last-child{border-bottom:none}
.detail-row span{font-family:var(--font-mono);font-size:.6rem;letter-spacing:.08em;text-transform:uppercase;color:var(--text3);font-weight:600}
.detail-row p{font-size:.82rem;color:var(--text2);line-height:1.4;word-break:break-word}

.brain-search-bar{
  position:sticky;bottom:12px;display:flex;gap:8px;align-items:center;
  background:var(--card);border:1px solid var(--border);border-radius:999px;padding:10px 12px;
  box-shadow:var(--shadow-lg);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);
}
.brain-search-input{flex:1;display:flex;align-items:center;gap:8px}
.brain-search-input input{
  flex:1;border:none;background:transparent;font-size:.86rem;color:var(--text);outline:none;
  font-family:var(--font);
}
.brain-search-input input::placeholder{color:var(--text3)}
.brain-search-count{font-family:var(--font-mono);font-size:.62rem;color:var(--text3);font-weight:600}

@media(max-width:900px){
  .brain-graph-controls{position:static;margin:12px}
  .brain-legend{position:static;margin:0 12px 12px}
  .brain-detail-panel{position:fixed;top:0;right:0;bottom:0;width:100%;max-width:none;z-index:20}
  .brain-graph-shell{min-height:420px}
}

/* ===== TOAST ===== */
#toast-container{position:fixed;top:env(safe-area-inset-top,12px);left:16px;right:16px;z-index:9999;display:flex;flex-direction:column;gap:8px;pointer-events:none;padding-top:8px}
.toast{
  background:rgba(26,27,46,.90);
  backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);
  border-radius:14px;padding:13px 18px;font-size:.82rem;color:#f3efe6;
  animation:toastIn .3s cubic-bezier(.16,1,.3,1);
  font-weight:500;pointer-events:auto;text-align:center;
  border:1px solid var(--orange);
  box-shadow:0 4px 16px rgba(176,125,79,0.12);
}
@keyframes toastIn{from{opacity:0;transform:translateY(-20px)}to{opacity:1;transform:translateY(0)}}

/* ===== EMPTY ===== */
.empty{text-align:center;padding:32px 16px;color:var(--text3);font-size:.86rem}
.empty-icon{margin-bottom:8px;opacity:.25}
.grid-2{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-bottom:12px}

/* ===== TABBAR — frosted light ===== */
#tabbar{
  display:none;position:fixed;bottom:var(--keyboard-inset);left:0;right:0;
  background:rgba(243,239,230,.92);
  backdrop-filter:saturate(180%) blur(20px);-webkit-backdrop-filter:saturate(180%) blur(20px);
  border-top:1px solid var(--border);
  padding:6px 8px 0;
  padding-bottom:calc(var(--safe-bottom) + 6px);
  z-index:100;justify-content:flex-start;gap:6px;min-height:var(--tabh);
  overflow-x:auto;overflow-y:hidden;scrollbar-width:none;
  -webkit-overflow-scrolling:touch;scroll-snap-type:x mandatory;
}
#tabbar::-webkit-scrollbar{display:none}
.tab{
  background:none;border:none;color:var(--text3);padding:6px 10px 4px;cursor:pointer;
  display:flex;flex-direction:column;align-items:center;gap:3px;font-family:var(--font-mono);
  font-size:.6rem;font-weight:600;min-width:64px;min-height:var(--touch-min);flex:0 0 auto;
  scroll-snap-align:center;scroll-snap-stop:always;
}
.tab.active{color:var(--accent)}
.tab svg{flex-shrink:0}

#sidebar-toggle{
  position:fixed;top:calc(var(--safe-top) + 10px);left:12px;
  width:44px;height:44px;border-radius:12px;border:1px solid var(--border);
  background:rgba(243,239,230,.92);backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);
  display:none;align-items:center;justify-content:center;color:var(--accent);z-index:120;cursor:pointer;
  box-shadow:var(--shadow);
}
#sidebar-toggle svg{width:20px;height:20px}
#sidebar-scrim{
  position:fixed;inset:0;background:rgba(26,27,46,.25);opacity:0;pointer-events:none;
  transition:opacity .2s ease;z-index:110;
}
body.sidebar-open #sidebar-scrim{opacity:1;pointer-events:auto}
body.sidebar-open #sidebar{transform:translateX(0)}

/* ===== RESPONSIVE ===== */
@media(max-width:768px){
  :root{--tabh:calc(84px + var(--safe-bottom))}
  #sidebar{
    display:flex;position:fixed;top:0;bottom:0;left:0;
    width:min(84vw, 320px);min-width:unset;transform:translateX(-100%);
    transition:transform .2s ease;box-shadow:var(--shadow-lg);z-index:130;
  }
  #tabbar{display:flex}
  #sidebar-toggle{display:inline-flex}
  .sidebar-header{padding-top:max(24px, calc(var(--safe-top) + 12px))}
  .sidebar-footer{padding-bottom:calc(16px + var(--safe-bottom))}
  .view{
    padding:16px 16px calc(var(--tabh) + 12px + var(--keyboard-inset));
    padding-top:max(16px, var(--safe-top));
    scroll-padding-bottom:calc(var(--tabh) + 12px + var(--keyboard-inset));
  }
  .view.chat-view-wrap{padding-bottom:calc(var(--tabh) + var(--keyboard-inset))}
  .stats-grid{grid-template-columns:repeat(2,minmax(0,1fr))}
  .grid-2{grid-template-columns:1fr}
  .file-grid{grid-template-columns:repeat(auto-fill,minmax(90px,1fr))}
  button, .btn, .btn-icon, .nav-item, .tab, .filter-pill, .cl-pill, .cl-filter-label, .brain-tab, .sr-tab, .task-act, .task-check, .archive-back, .push-dismiss{
    min-height:var(--touch-min);min-width:var(--touch-min);
  }
  .task-icon{width:var(--touch-min);height:var(--touch-min)}
  .task-actions{gap:6px}
  input[type="text"],
  input[type="search"],
  input[type="email"],
  input[type="password"],
  input[type="number"],
  input[type="url"],
  input[type="tel"],
  input[type="date"],
  input[type="time"],
  input[type="datetime-local"],
  textarea,
  select{
    font-size:1rem;line-height:1.3;min-height:var(--touch-min);
    scroll-margin-bottom:calc(var(--tabh) + var(--keyboard-inset) + 16px);
  }
  .chat-input-row input{font-size:1rem}
  .search-bar input,
  .task-create-title,
  .task-create-desc,
  .task-edit-title,
  .task-edit-desc,
  .task-edit-row select,
  .task-create-form select,
  .task-edit-form select{
    font-size:1rem;
  }
  input[type="checkbox"], input[type="radio"]{
    width:var(--touch-min);height:var(--touch-min);
  }
}

@media(max-width:420px){
  :root{--tabh:calc(120px + var(--safe-bottom))}
  #tabbar{flex-wrap:wrap;overflow-x:hidden;justify-content:space-between;padding-left:6px;padding-right:6px}
  .tab{flex:1 1 25%;min-width:0}
}

@media(max-width:480px){
  .stats-grid{grid-template-columns:1fr}
}

/* ===== SKELETON LOADING ===== */
.sk{background:linear-gradient(90deg,var(--surface) 25%,rgba(59,107,158,0.08) 50%,var(--surface) 75%);background-size:200% 100%;animation:shimmer 1.4s ease-in-out infinite;margin-top:8px}
.sk-card{margin-bottom:12px}
@keyframes shimmer{0%{background-position:200% 0}100%{background-position:-200% 0}}

/* ===== STATUS PAGE ===== */
.stat-card.red-card .value{color:var(--red)}
.res-bar-wrap{margin-bottom:14px}
.res-bar-top{display:flex;justify-content:space-between;margin-bottom:4px}
.res-label{font-size:.78rem;font-weight:600;color:var(--text)}
.res-detail{font-family:var(--font-mono);font-size:.68rem;color:var(--text3)}
.res-bar{height:8px;background:var(--surface);border-radius:4px;overflow:hidden}
.res-fill{height:100%;border-radius:4px;transition:width .4s ease}
.res-fill.blue{background:linear-gradient(90deg,var(--accent),var(--green))}
.res-fill.red{background:linear-gradient(90deg,var(--red),#b85a5a)}
.load-row{display:flex;align-items:center;gap:10px;font-size:.82rem;color:var(--text3)}
.load-row strong{font-family:var(--font-display);font-size:1.1rem;color:var(--text);font-weight:700}
.svc-row{display:flex;align-items:center;gap:8px;padding:8px 0;border-bottom:1px solid var(--border-light)}
.svc-row:last-child{border:none}
.svc-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}
.svc-dot.green{background:var(--green);box-shadow:0 0 4px rgba(74,139,140,0.3)}
.svc-dot.red{background:var(--red);box-shadow:0 0 4px rgba(139,58,58,0.3)}
.svc-name{font-size:.84rem;font-weight:500;flex:1}
.svc-status{font-family:var(--font-mono);font-size:.7rem;color:var(--green);font-weight:500;text-transform:uppercase}
.svc-status.inactive{color:var(--red)}
.net-header,.proc-header{display:grid;grid-template-columns:1fr auto auto;gap:12px;font-family:var(--font-mono);font-size:.62rem;color:var(--text3);text-transform:uppercase;letter-spacing:.06em;font-weight:500;padding-bottom:6px;border-bottom:1px solid var(--border-light);margin-bottom:4px}
.net-row,.proc-row{display:grid;grid-template-columns:1fr auto auto;gap:12px;padding:6px 0;border-bottom:1px solid var(--border-light);font-size:.82rem}
.net-row:last-child,.proc-row:last-child{border:none}
.net-iface,.proc-name{font-weight:500;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.net-stat,.proc-val{font-family:var(--font-mono);color:var(--text3);font-size:.74rem;text-align:right;font-variant-numeric:tabular-nums}

/* Claude Code status */
.cc-instances{border-bottom:1px solid var(--border-light);padding-bottom:4px;margin-bottom:4px}
.cc-instance{display:grid;grid-template-columns:auto auto 1fr auto;gap:8px;align-items:center;padding:5px 0;font-size:.78rem}
.cc-pid{font-family:var(--font-mono);font-size:.72rem;color:var(--accent);font-weight:600}
.cc-mem{font-family:var(--font-mono);font-size:.72rem;color:var(--text3)}
.cc-elapsed{font-family:var(--font-mono);font-size:.72rem;color:var(--text3)}
.cc-cmd{font-family:var(--font-mono);font-size:.68rem;color:var(--text3);overflow:hidden;text-overflow:ellipsis;white-space:nowrap;text-align:right}
.cc-session{display:flex;justify-content:space-between;align-items:center;padding:8px 0;border-bottom:1px solid var(--border-light)}
.cc-sid{font-family:var(--font-mono);font-size:.7rem;color:var(--text3)}
.cc-loading{padding:8px 0}

/* Usage bars (like /usage) */
.cc-ubar{padding:12px 0;border-bottom:1px solid var(--border-light)}
.cc-ubar:last-of-type{border:none}
.cc-ubar-head{display:flex;justify-content:space-between;align-items:baseline;margin-bottom:6px}
.cc-ubar-label{font-size:.82rem;font-weight:700;color:var(--text)}
.cc-ubar-sub{font-size:.68rem;color:var(--text3)}
.cc-ubar-track{height:8px;background:var(--surface);border-radius:4px;overflow:hidden;margin-bottom:5px}
.cc-ubar-fill{height:100%;border-radius:4px;transition:width .4s ease}
.cc-ubar-fill.blue{background:var(--accent)}
.cc-ubar-fill.red{background:var(--red)}
.cc-ubar-foot{display:flex;justify-content:space-between}
.cc-ubar-cost{font-family:var(--font-mono);font-size:.74rem;font-weight:600;color:var(--accent);font-variant-numeric:tabular-nums}
.cc-ubar-pct{font-family:var(--font-mono);font-size:.72rem;color:var(--text3);font-variant-numeric:tabular-nums}

/* Token detail rows */
.cc-token-row{display:flex;flex-wrap:wrap;gap:4px 12px;padding:0 0 10px;border-bottom:1px solid var(--border-light);margin-bottom:2px}
.cc-token-row span{font-family:var(--font-mono);font-size:.66rem;color:var(--text3);font-variant-numeric:tabular-nums}

/* Section titles */
.cc-section-title{font-size:.68rem;font-weight:600;text-transform:uppercase;letter-spacing:.06em;color:var(--text3);margin:12px 0 4px;padding-top:6px;border-top:1px solid var(--border-light)}

/* Session list */
.cc-sessions-details summary::-webkit-details-marker{display:none}
.cc-sessions-details summary::marker{content:''}
.cc-sessions-details[open] .cc-section-title::after{content:' ▾';font-size:.6rem}
.cc-sessions-details:not([open]) .cc-section-title::after{content:' ▸';font-size:.6rem}

/* ===== TERMINAL VIEW ===== */
.terminal-layout{
  display:grid;
  grid-template-columns:minmax(220px, 300px) minmax(0,1fr);
  gap:14px;
  height:calc(100dvh - 190px);
  min-height:520px;
}
.terminal-sessions{
  display:flex;
  flex-direction:column;
  gap:8px;
  padding:14px;
}
.terminal-sessions-head{
  display:flex;align-items:center;justify-content:space-between;
  font-family:var(--font-mono);font-size:.65rem;text-transform:uppercase;
  letter-spacing:.1em;color:var(--text3);
}
.terminal-processes{color:var(--green);font-size:.62rem}
.terminal-session-list{
  display:flex;flex-direction:column;gap:8px;
  overflow:auto;padding-right:4px;
}
.terminal-session{
  border:1px solid var(--border);
  border-radius:var(--radius-sm);
  padding:10px 12px;
  background:var(--surface);
  cursor:pointer;transition:all .15s;
}
.terminal-session:hover{background:var(--surface-hover)}
.terminal-session.active{
  border-color:var(--accent);
  background:rgba(59,107,158,0.12);
  box-shadow:var(--shadow);
}
.term-sess-head{display:flex;align-items:center;justify-content:space-between;gap:8px}
.term-sess-id{font-family:var(--font-mono);font-size:.78rem;color:var(--text)}
.term-live{
  font-size:.58rem;font-weight:700;letter-spacing:.12em;
  padding:2px 6px;border-radius:999px;
  background:rgba(74,139,140,0.16);color:var(--green);
}
.term-sess-meta{font-size:.7rem;color:var(--text3);margin-top:4px}
.term-sess-activity{font-size:.74rem;color:var(--text2);margin-top:6px;line-height:1.35}

.terminal-pane{
  display:flex;flex-direction:column;gap:10px;min-height:0;
  --term-bg:#0f141b;
  --term-panel:#101821;
  --term-border:#22303b;
  --term-text:#e7eef6;
  --term-muted:#9fb1c6;
  --term-green:#9be37f;
  --term-amber:#f4c47f;
  --term-blue:#7bb7ff;
  --term-red:#ff7b7b;
}
.terminal-tabs{
  display:flex;gap:6px;overflow-x:auto;padding-bottom:4px;
}
.terminal-tabs::-webkit-scrollbar{display:none}
.terminal-tab{
  display:inline-flex;align-items:center;gap:6px;
  border:1px solid var(--border);border-radius:999px;
  padding:6px 10px;font-size:.72rem;font-weight:600;
  background:var(--card);color:var(--text2);cursor:pointer;white-space:nowrap;
}
.terminal-tab.active{border-color:var(--accent);color:var(--accent);background:var(--accent-glow)}
.term-dot{width:6px;height:6px;border-radius:50%;background:var(--green);box-shadow:0 0 6px rgba(74,139,140,0.4)}

.terminal-toolbar{
  display:flex;flex-wrap:wrap;align-items:center;gap:10px;
}
.terminal-search{
  display:flex;align-items:center;gap:6px;position:relative;
  background:var(--card);border:1px solid var(--border);
  border-radius:999px;padding:4px 10px;
}
.terminal-search input{
  border:none;background:transparent;outline:none;
  font-size:.8rem;color:var(--text);min-width:180px;
}
.terminal-clear{
  border:none;background:transparent;color:var(--text3);
  font-size:1rem;cursor:pointer;padding:0 4px;
}
.terminal-jump{
  margin-left:auto;
  border:1px dashed var(--border);border-radius:999px;
  padding:6px 12px;font-size:.72rem;
  background:transparent;color:var(--text2);cursor:pointer;
  opacity:0;pointer-events:none;transition:all .15s;
}
.terminal-jump.visible{opacity:1;pointer-events:auto}

.terminal-output{
  background:var(--term-bg);color:var(--term-text);
  border:1px solid var(--term-border);border-radius:var(--radius);
  padding:14px;overflow:auto;min-height:320px;flex:1;
  font-family:var(--font-mono);font-size:.78rem;line-height:1.5;
  box-shadow:var(--shadow-lg);
}
.terminal-output .empty{color:var(--term-muted)}

.terminal-input{
  display:flex;align-items:center;gap:10px;
  background:var(--term-panel);border:1px solid var(--term-border);
  border-radius:var(--radius);padding:10px 12px;
}
.terminal-prompt{color:var(--term-green);font-family:var(--font-mono)}
.terminal-input input{
  flex:1;border:none;background:transparent;outline:none;
  font-family:var(--font-mono);color:var(--term-text);
}
.terminal-input .btn-primary{padding:8px 14px}

.term-line{display:flex;align-items:flex-start;gap:8px;padding:6px 0;border-bottom:1px dashed rgba(34,48,59,0.35)}
.term-line:last-child{border-bottom:none}
.term-prefix{color:var(--term-blue);font-weight:700}
.term-text{white-space:pre-wrap;flex:1}
.term-time{color:var(--term-muted);font-size:.66rem;margin-left:auto}
.term-line.assistant .term-text{color:var(--term-text)}
.term-line.human .term-text{color:var(--term-blue)}
.term-line.system .term-tag{color:var(--term-amber)}
.term-line.system .term-text{color:var(--term-muted)}
.term-line.thinking summary{display:flex;align-items:center;gap:8px;cursor:pointer}
.term-line.thinking pre{margin-top:8px;white-space:pre-wrap;color:var(--term-muted)}
.term-line.thinking summary::-webkit-details-marker{display:none}
.term-line.thinking summary::marker{content:''}

.term-line.tool summary{display:flex;align-items:center;gap:8px;cursor:pointer}
.term-line.tool summary::-webkit-details-marker{display:none}
.term-line.tool summary::marker{content:''}
.term-tag{
  font-size:.6rem;letter-spacing:.12em;text-transform:uppercase;
  color:var(--term-amber);font-weight:700;
}
.term-cmd{color:var(--term-text);flex:1;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.term-tool-body{margin-top:8px}
.term-tool-input{color:var(--term-muted);white-space:pre-wrap;margin-bottom:6px}
.term-tool-output{background:#0c1117;border:1px solid rgba(34,48,59,0.5);border-radius:10px;padding:8px;color:var(--term-text);white-space:pre-wrap}
.term-line.tool.error .term-tag{color:var(--term-red)}
.term-line.tool-output{flex-direction:column}
.term-line.tool-output pre{white-space:pre-wrap;color:var(--term-text);width:100%}
.term-line.tool-output.error pre{color:var(--term-red)}

@media (max-width: 900px){
  .terminal-layout{grid-template-columns:1fr;height:auto;min-height:0}
  .terminal-output{min-height:240px;height:60vh}
  .terminal-jump{margin-left:0}
}
.cc-sess-list{max-height:340px;overflow-y:auto;-webkit-overflow-scrolling:touch}
.cc-sess-row{padding:7px 0;border-bottom:1px solid var(--border-light)}
.cc-sess-row:last-child{border:none}
.cc-sess-active{background:var(--accent-glow);margin:0 -8px;padding:7px 8px;border-radius:var(--radius-sm)}
.cc-sess-info{min-width:0}
.cc-sess-name{display:block;font-size:.78rem;font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.cc-dot-live{display:inline-block;width:6px;height:6px;border-radius:50%;background:var(--green);margin-right:5px;vertical-align:middle;animation:pulse-dot 2s infinite}
@keyframes pulse-dot{0%,100%{opacity:1}50%{opacity:.4}}
.cc-sess-meta{display:block;font-family:var(--font-mono);font-size:.64rem;color:var(--text3);margin-top:2px;font-variant-numeric:tabular-nums}

/* ===== CHANGELOG ===== */
.nav-badge{background:var(--accent);color:#fff;font-size:.6rem;font-weight:700;padding:1px 6px;border-radius:10px;margin-left:auto}
.cl-pills{display:flex;gap:6px;flex-wrap:wrap;margin-bottom:14px;padding:0 2px}
.cl-pill{background:var(--surface);border:1px solid var(--border);border-radius:20px;padding:6px 14px;font-size:.76rem;font-weight:500;cursor:pointer;color:var(--text2);font-family:var(--font-mono);transition:all .15s}
.cl-pill:hover{background:var(--surface-hover)}
.cl-pill.active{background:var(--accent);color:#fff;border-color:var(--accent)}
.cl-pill-badge{background:rgba(255,255,255,0.25);border-radius:8px;padding:0 5px;font-size:.64rem;margin-left:3px}
.cl-pill.active .cl-pill-badge{background:rgba(255,255,255,0.3)}
.cl-pill:not(.active) .cl-pill-badge{background:var(--accent);color:#fff}

.cl-actions{display:flex;align-items:center;justify-content:space-between;margin-bottom:10px;padding:0 2px}
.cl-filter-label{font-size:.76rem;color:var(--text2);display:flex;align-items:center;gap:6px;cursor:pointer}
.cl-filter-label input{accent-color:var(--accent)}

.cl-toolbar{display:flex;align-items:center;gap:8px;background:var(--card);border:1px solid var(--border);border-radius:var(--radius-sm);padding:8px 12px;margin-bottom:10px}
.cl-sel-count{font-size:.78rem;font-weight:600;color:var(--text);margin-right:auto}

.cl-entry{display:flex;align-items:flex-start;gap:10px;padding:10px 12px;background:var(--card);border:1px solid var(--border-light);border-radius:var(--radius-sm);margin-bottom:6px;transition:all .15s;position:relative}
.cl-entry:hover{border-color:var(--border)}
.cl-entry.cl-unread{border-left:3px solid var(--accent);background:rgba(59,107,158,0.04)}
.cl-entry.cl-selected{background:var(--accent-glow);border-color:var(--accent)}
.cl-entry-check{flex-shrink:0;padding-top:2px}
.cl-check{accent-color:var(--accent);cursor:pointer;width:16px;height:16px}
.cl-entry-body{flex:1;min-width:0}
.cl-summary{font-size:.82rem;font-weight:500;color:var(--text);line-height:1.3}
.cl-meta{display:flex;flex-wrap:wrap;gap:6px;margin-top:4px;align-items:center}
.cl-scope{font-family:var(--font-mono);font-size:.66rem;font-weight:600;color:var(--accent);background:var(--accent-glow);padding:1px 7px;border-radius:8px}
.cl-version{font-family:var(--font-mono);font-size:.64rem;color:var(--text3)}
.cl-date{font-family:var(--font-mono);font-size:.64rem;color:var(--text3)}
.cl-detail{font-size:.76rem;color:var(--text2);margin-top:4px;line-height:1.35}
.cl-unread-dot{width:8px;height:8px;border-radius:50%;background:var(--accent);flex-shrink:0;margin-top:6px}

/* Type badges */
.cl-type{display:flex;align-items:center;justify-content:center;width:24px;height:24px;border-radius:6px;font-size:.72rem;font-weight:700;flex-shrink:0;margin-top:1px}
.cl-added{background:rgba(74,139,140,0.12);color:var(--green)}
.cl-changed{background:rgba(59,107,158,0.10);color:var(--accent)}
.cl-fixed{background:rgba(74,139,140,0.12);color:var(--green)}
.cl-removed{background:var(--red-glow);color:var(--red)}
.cl-deprecated{background:rgba(176,125,79,0.10);color:var(--orange)}
.cl-security{background:var(--red-glow);color:var(--red)}
.cl-breaking{background:var(--red-glow);color:var(--red)}

/* Flag tags */
.cl-flag-tag{font-family:var(--font-mono);font-size:.62rem;font-weight:600;padding:1px 6px;border-radius:6px;background:rgba(176,125,79,0.12);color:var(--orange)}

/* Flag modal */
.cl-flag-modal{position:fixed;inset:0;background:rgba(0,0,0,0.4);z-index:100;display:flex;align-items:center;justify-content:center;padding:20px}
.cl-flag-modal-inner{background:var(--bg);border-radius:var(--radius);padding:20px;max-width:320px;width:100%;box-shadow:var(--shadow-lg)}
.cl-flag-title{font-size:.88rem;font-weight:600;margin-bottom:12px}
.cl-flag-options{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:14px}
.cl-flag-option{background:var(--surface);border:1px solid var(--border);border-radius:8px;padding:6px 12px;font-size:.76rem;font-weight:500;cursor:pointer;font-family:var(--font-mono);color:var(--text2);transition:all .12s}
.cl-flag-option:hover{background:var(--surface-hover);border-color:var(--accent);color:var(--accent)}

/* ===== System Review ===== */
.sr-tabs{display:flex;gap:4px;padding:0 16px;margin-bottom:16px;overflow-x:auto;-webkit-overflow-scrolling:touch}
.sr-tab{background:var(--surface);border:1px solid var(--border);border-radius:8px;padding:8px 16px;font-size:.78rem;font-weight:600;cursor:pointer;font-family:var(--font);color:var(--text2);transition:all .15s;white-space:nowrap}
.sr-tab.active{background:var(--accent);color:#fff;border-color:var(--accent)}
.sr-tab:hover:not(.active){background:var(--surface-hover);border-color:var(--accent)}

.sr-model-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:14px;padding:0 16px;margin-bottom:16px}
.sr-model-card{background:var(--card);border-radius:var(--radius);padding:16px;box-shadow:var(--shadow);display:flex;flex-direction:column;gap:12px}
.sr-model-head{display:flex;align-items:center;gap:10px}
.sr-model-name{font-size:.88rem;font-weight:700;color:var(--text)}
.sr-model-focus{font-size:.72rem;color:var(--text3);font-weight:500}
.sr-model-meta{display:flex;gap:10px;flex-wrap:wrap}
.sr-model-meta span{font-size:.68rem;font-family:var(--font-mono);color:var(--text3);background:var(--surface);padding:2px 8px;border-radius:6px}
.sr-findings-mini{display:flex;flex-direction:column;gap:6px}
.sr-finding-row{display:flex;align-items:center;gap:8px}
.sr-finding-title{font-size:.76rem;color:var(--text2);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.sr-more{font-size:.7rem;color:var(--text3);font-style:italic;padding-left:4px}
.sr-view-btn{margin-top:auto;align-self:flex-start}
.sr-sev{font-size:.64rem;font-weight:700;font-family:var(--font-mono);padding:2px 8px;border-radius:6px;white-space:nowrap;text-transform:uppercase;letter-spacing:.3px}

.sr-summary-card{margin:0 16px 16px}

.sr-sev-grid{display:flex;flex-direction:column;gap:8px;margin-top:8px}
.sr-bar-row{display:flex;align-items:center;gap:10px}
.sr-bar-label{font-size:.74rem;font-weight:600;width:60px;text-align:right;color:var(--text2)}
.sr-bar-track{flex:1;height:20px;background:var(--surface);border-radius:10px;overflow:hidden}
.sr-bar-fill{height:100%;border-radius:10px;transition:width .4s ease}
.sr-bar-count{font-size:.74rem;font-weight:700;font-family:var(--font-mono);color:var(--text);width:24px}

/* Model detail */
.sr-model-detail{background:var(--card);border-radius:var(--radius);margin:0 16px 16px;padding:20px;box-shadow:var(--shadow)}
.sr-detail-header{display:flex;align-items:center;gap:12px;flex-wrap:wrap;margin-bottom:16px}
.sr-detail-header h3{font-size:1.05rem;font-weight:700;margin:0;color:var(--text)}
.sr-detail-header p{font-size:.78rem;color:var(--text3);margin:0}
.sr-detail-stats{display:flex;gap:16px;margin-left:auto}
.sr-stat{display:flex;flex-direction:column;align-items:center}
.sr-stat-val{font-size:1.1rem;font-weight:800;font-family:var(--font-mono);color:var(--accent)}
.sr-stat-label{font-size:.62rem;color:var(--text3);text-transform:uppercase;letter-spacing:.5px}

.sr-section{margin-bottom:16px}
.sr-section-title{font-size:.82rem;font-weight:700;color:var(--text);margin-bottom:10px;padding-bottom:6px;border-bottom:1px solid var(--border-light)}
.sr-strengths,.sr-suggestions{padding-left:20px;margin:0}
.sr-strengths li,.sr-suggestions li{font-size:.78rem;color:var(--text2);line-height:1.5;margin-bottom:4px}

.sr-findings-list{display:flex;flex-direction:column;gap:10px}
.sr-finding-card{background:var(--surface);border-radius:var(--radius-sm);padding:12px;border:1px solid var(--border-light)}
.sr-finding-header{display:flex;align-items:center;gap:8px;margin-bottom:6px;flex-wrap:wrap}
.sr-finding-num{font-size:.68rem;font-weight:800;font-family:var(--font-mono);color:var(--accent);background:var(--accent-glow);padding:2px 6px;border-radius:4px}
.sr-finding-loc{font-size:.68rem;font-family:var(--font-mono);color:var(--text3);margin-bottom:4px}
.sr-finding-desc{font-size:.78rem;color:var(--text2);line-height:1.45}
.sr-finding-fix{font-size:.74rem;color:var(--green);margin-top:6px;padding:6px 10px;background:var(--green-glow);border-radius:8px;line-height:1.4}

/* Consensus */
.sr-consensus{padding:0 16px}
.sr-consensus-desc{font-size:.78rem;color:var(--text3);margin-bottom:12px}
.sr-table{width:100%;border-collapse:collapse;font-size:.78rem;background:var(--card);border-radius:var(--radius-sm);overflow:hidden;box-shadow:var(--shadow)}
.sr-table thead{background:var(--surface)}
.sr-table th{padding:10px 12px;text-align:left;font-weight:700;font-size:.72rem;text-transform:uppercase;letter-spacing:.5px;color:var(--text3);border-bottom:2px solid var(--border)}
.sr-table td{padding:8px 12px;border-bottom:1px solid var(--border-light);color:var(--text2)}
.sr-issue-cell{font-weight:500;max-width:200px}
.sr-check-cell{text-align:center;width:60px}
.sr-check{color:var(--green);font-weight:700;font-size:1rem}

.sr-fix-order{display:flex;flex-direction:column;gap:8px}
.sr-fix-item{display:flex;align-items:flex-start;gap:10px;padding:10px;background:var(--surface);border-radius:var(--radius-sm);border:1px solid var(--border-light)}
.sr-fix-num{font-size:.82rem;font-weight:800;font-family:var(--font-mono);color:#fff;background:var(--accent);width:26px;height:26px;display:flex;align-items:center;justify-content:center;border-radius:50%;flex-shrink:0}
.sr-fix-title{font-size:.82rem;font-weight:600;color:var(--text)}
.sr-fix-source{font-size:.68rem;color:var(--text3);margin-top:2px}

@media(max-width:768px){
  .sr-model-grid{grid-template-columns:1fr}
  .sr-detail-stats{margin-left:0;margin-top:8px}
  .sr-table{font-size:.7rem}
  .sr-table th,.sr-table td{padding:6px 8px}
  .sr-issue-cell{max-width:120px}
}

/* Archive view */
.archive-index{padding:20px}
.archive-index .section-header{margin-bottom:20px}
.archive-index .section-header h2{font-family:var(--font-display);font-size:1.4rem;color:var(--text);margin:0}
.archive-index .section-sub{font-size:.82rem;color:var(--text3);margin:4px 0 0}
.archive-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:14px}
.archive-card{display:flex;align-items:flex-start;gap:14px;padding:16px;background:var(--card);border:1px solid var(--border);border-radius:var(--radius);cursor:pointer;text-align:left;transition:border-color .15s,box-shadow .15s}
.archive-card:hover{border-color:var(--accent);box-shadow:var(--shadow)}
.archive-card svg{flex-shrink:0;color:var(--accent);margin-top:2px}
.archive-card-text{display:flex;flex-direction:column;gap:4px}
.archive-card-text strong{font-size:.88rem;color:var(--text);font-weight:600}
.archive-card-text span{font-size:.76rem;color:var(--text3);line-height:1.4}
.archive-child{padding:20px}
.archive-back{display:inline-flex;align-items:center;gap:6px;padding:8px 14px;margin-bottom:16px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text2);font-size:.82rem;font-weight:500;cursor:pointer;transition:background .15s}
.archive-back:hover{background:var(--surface-hover)}
@media(max-width:768px){.archive-grid{grid-template-columns:1fr}}

/* ===== NOTIFICATION BELL ===== */
.notif-bell{position:relative;background:none;border:none;cursor:pointer;color:var(--text2);padding:6px;border-radius:50%;transition:background .15s,color .15s;display:flex;align-items:center;justify-content:center}
.notif-bell:hover{background:var(--surface-hover);color:var(--accent)}
.notif-bell-badge{position:absolute;top:-2px;right:-2px;background:var(--red);color:#fff;font-size:.56rem;font-weight:700;min-width:16px;height:16px;border-radius:8px;display:flex;align-items:center;justify-content:center;padding:0 4px;font-family:var(--font-mono);line-height:1;box-shadow:0 1px 3px rgba(139,58,58,0.3)}
@keyframes bellPulse{0%{transform:scale(1)}50%{transform:scale(1.3)}100%{transform:scale(1)}}
.notif-bell-pulse{animation:bellPulse .4s cubic-bezier(.16,1,.3,1)}

/* ===== NOTIFICATION CENTER VIEW ===== */
.notif-header-row{display:flex;align-items:center;justify-content:space-between;gap:12px}
.notif-header-badge{display:inline-flex;align-items:center;justify-content:center;background:var(--red);color:#fff;font-size:.7rem;font-weight:700;min-width:20px;height:20px;border-radius:10px;padding:0 6px;font-family:var(--font-mono);vertical-align:middle;margin-left:4px}
.notif-filters{display:flex;gap:6px;margin-bottom:14px;flex-wrap:wrap}
.notif-list{display:flex;flex-direction:column;gap:2px}
.notif-card{display:flex;align-items:flex-start;gap:12px;padding:14px 16px;background:var(--card);border:1px solid var(--border-light);border-radius:var(--radius-sm);cursor:pointer;transition:all .15s;position:relative}
.notif-card:hover{border-color:var(--border);background:var(--surface-hover)}
.notif-unread{border-left:3px solid var(--accent);background:rgba(59,107,158,0.04)}
.notif-icon{flex-shrink:0;width:36px;height:36px;border-radius:10px;display:flex;align-items:center;justify-content:center}
.notif-icon-accent{background:var(--accent-glow);color:var(--accent)}
.notif-icon-green{background:var(--green-glow);color:var(--green)}
.notif-icon-red{background:var(--red-glow);color:var(--red)}
.notif-icon-orange{background:rgba(176,125,79,0.10);color:var(--orange)}
.notif-icon-purple{background:rgba(122,107,158,0.10);color:var(--purple)}
.notif-body{flex:1;min-width:0}
.notif-title{font-size:.84rem;font-weight:600;color:var(--text);line-height:1.3}
.notif-text{font-size:.76rem;color:var(--text2);margin-top:2px;line-height:1.35;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.notif-time{font-family:var(--font-mono);font-size:.62rem;color:var(--text3);margin-top:4px;font-weight:500}
.notif-dot{width:8px;height:8px;border-radius:50%;background:var(--accent);flex-shrink:0;margin-top:6px}
.notif-empty{text-align:center;padding:48px 16px;color:var(--text3)}
.notif-empty svg{margin-bottom:12px;opacity:.5}
.notif-empty-text{font-size:.92rem;font-weight:600;color:var(--green);margin-top:4px}

/* ===== DARK MODE ===== */
:root[data-theme="dark"]{
  --bg: #1a1a2e;
  --bg2: #16213e;
  --surface: rgba(255,255,255,0.06);
  --surface-hover: rgba(255,255,255,0.10);
  --card: rgba(30,40,60,0.85);
  --border: rgba(255,255,255,0.10);
  --border-light: rgba(255,255,255,0.05);
  --text: #e7edf7;
  --text2: #b0b8cc;
  --text3: #6b7280;
  --accent: #4ade80;
  --accent-glow: rgba(74,222,128,0.12);
  --accent-hover: #34d169;
  --green: #4ade80;
  --green-glow: rgba(74,222,128,0.10);
  --red: #f87171;
  --red-glow: rgba(248,113,113,0.10);
  --orange: #fb923c;
  --purple: #a78bfa;
  --shadow: 0 1px 4px rgba(0,0,0,0.3);
  --shadow-lg: 0 8px 24px rgba(0,0,0,0.4);
}
:root[data-theme="dark"] body::after{opacity:0.015}
:root[data-theme="dark"] .logo h1{color:var(--accent)}

/* ===== COMMAND PALETTE ===== */
.cmd-overlay{
  position:fixed;inset:0;z-index:9999;
  background:rgba(0,0,0,0.45);
  backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px);
  display:flex;align-items:flex-start;justify-content:center;
  padding-top:min(20vh,160px);
  opacity:0;pointer-events:none;
  transition:opacity .15s ease;
}
.cmd-overlay.open{opacity:1;pointer-events:auto}
.cmd-modal{
  width:100%;max-width:640px;
  background:var(--card);
  border:1px solid var(--border);
  border-radius:var(--radius);
  box-shadow:0 16px 48px rgba(0,0,0,0.25);
  backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);
  overflow:hidden;
  transform:scale(0.96) translateY(-8px);
  transition:transform .15s cubic-bezier(.16,1,.3,1), opacity .15s;
}
.cmd-overlay.open .cmd-modal{transform:scale(1) translateY(0)}
.cmd-input-wrap{
  display:flex;align-items:center;gap:10px;
  padding:14px 18px;
  border-bottom:1px solid var(--border);
}
.cmd-input-icon{color:var(--text3);flex-shrink:0;display:flex}
.cmd-input{
  flex:1;border:none;outline:none;background:none;
  font-family:var(--font);font-size:1rem;font-weight:500;
  color:var(--text);
}
.cmd-input::placeholder{color:var(--text3)}
.cmd-kbd{
  font-family:var(--font-mono);font-size:.6rem;
  padding:3px 7px;border-radius:5px;
  background:var(--surface);color:var(--text3);
  border:1px solid var(--border);
  font-weight:600;flex-shrink:0;
}
.cmd-results{
  max-height:360px;overflow-y:auto;-webkit-overflow-scrolling:touch;
  padding:6px 0;
}
.cmd-category{
  font-family:var(--font-mono);font-size:.6rem;
  text-transform:uppercase;letter-spacing:.1em;
  color:var(--text3);font-weight:600;
  padding:10px 18px 4px;
}
.cmd-item{
  display:flex;align-items:center;gap:12px;
  padding:10px 18px;cursor:pointer;
  transition:background .08s;
}
.cmd-item:hover,.cmd-item.selected{background:var(--surface-hover)}
.cmd-item.selected{background:var(--accent-glow)}
.cmd-item-icon{color:var(--text3);flex-shrink:0;display:flex}
.cmd-item.selected .cmd-item-icon{color:var(--accent)}
.cmd-item-text{flex:1;min-width:0;display:flex;flex-direction:column;gap:1px}
.cmd-item-title{font-size:.86rem;font-weight:500;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.cmd-item-sub{font-size:.68rem;color:var(--text3);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;font-family:var(--font-mono)}
.cmd-item-hint{font-family:var(--font-mono);font-size:.58rem;padding:2px 6px;border-radius:4px;background:var(--surface);color:var(--text3);border:1px solid var(--border);flex-shrink:0}
.cmd-empty{padding:24px 18px;text-align:center;color:var(--text3);font-size:.86rem}
.cmd-footer{
  display:flex;align-items:center;gap:16px;
  padding:10px 18px;
  border-top:1px solid var(--border);
  font-size:.62rem;color:var(--text3);
  font-family:var(--font-mono);
}
.cmd-footer kbd{
  display:inline-block;padding:1px 5px;border-radius:3px;
  background:var(--surface);border:1px solid var(--border);
  font-family:var(--font-mono);font-size:.58rem;font-weight:600;
  margin:0 2px;
}

/* Sidebar search button */
.sidebar-search-btn{
  width:32px;height:32px;border:none;border-radius:8px;
  background:var(--surface);color:var(--text3);
  cursor:pointer;display:flex;align-items:center;justify-content:center;
  transition:background .15s,color .15s;
  margin-left:auto;flex-shrink:0;
}
.sidebar-search-btn:hover{background:var(--surface-hover);color:var(--accent)}

@media(max-width:768px){
  .cmd-overlay{padding-top:16px;padding-left:12px;padding-right:12px}
  .cmd-modal{max-width:100%;border-radius:var(--radius-sm)}
}

/* ===== TASKS MISSION CONTROL ===== */
.task-mission{display:flex;flex-direction:column;gap:18px}
.mission-section{display:flex;flex-direction:column;gap:10px}
.section-title{font-family:var(--font-mono);font-size:.65rem;font-weight:600;text-transform:uppercase;letter-spacing:.12em;color:var(--text3)}

.agent-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:12px}
.agent-card{
  background:var(--card);
  border:1px solid var(--border);
  border-radius:var(--radius);
  padding:14px;
  box-shadow:var(--shadow);
  position:relative;
  overflow:hidden;
}
.agent-card::after{
  content:'';position:absolute;inset:auto -20% -40% -20%;height:60%;
  background:radial-gradient(circle at 50% 0, rgba(59,107,158,0.12), transparent 60%);
  pointer-events:none;
}
.agent-top{display:flex;justify-content:space-between;align-items:flex-start;gap:10px;position:relative;z-index:1}
.agent-title{font-family:var(--font-display);font-size:1.1rem;font-weight:700}
.agent-meta{font-family:var(--font-mono);font-size:.64rem;color:var(--text3);margin-top:2px}
.agent-pill{padding:4px 10px;border-radius:999px;background:var(--surface);border:1px solid var(--border);font-size:.62rem;font-family:var(--font-mono);color:var(--accent)}
.agent-task{margin-top:12px;position:relative;z-index:1}
.agent-task-label{font-size:.6rem;text-transform:uppercase;letter-spacing:.08em;color:var(--text3);font-family:var(--font-mono)}
.agent-task-title{margin-top:4px;font-size:.9rem;font-weight:600;color:var(--text)}
.agent-task-sub{margin-top:4px;font-size:.75rem;color:var(--text2)}
.agent-empty{padding:16px;border:1px dashed var(--border);border-radius:var(--radius);color:var(--text3);font-size:.86rem}

.task-filter-bar{display:flex;flex-wrap:wrap;gap:10px;align-items:end;background:var(--card);border:1px solid var(--border);border-radius:var(--radius);padding:12px;box-shadow:var(--shadow)}
.filter-group{display:flex;flex-direction:column;gap:4px;min-width:140px}
.filter-group label{font-family:var(--font-mono);font-size:.6rem;text-transform:uppercase;letter-spacing:.08em;color:var(--text3)}
.filter-group select,
.filter-search input{
  background:var(--bg2);
  border:1px solid var(--border);
  border-radius:10px;
  padding:7px 10px;
  font-size:.8rem;
  color:var(--text);
  font-family:var(--font);
}
.filter-search{flex:1;min-width:160px}
.task-create-toggle{margin-left:auto}
.task-create-inline{margin-top:10px;background:var(--card);border:1px solid var(--border);border-radius:var(--radius);padding:12px;display:flex;flex-direction:column;gap:8px}
.task-create-inline input,
.task-create-inline textarea{
  background:var(--bg2);
  border:1px solid var(--border);
  border-radius:10px;
  padding:8px 10px;
  font-size:.86rem;
  font-family:var(--font);
  color:var(--text);
}
.task-create-actions{display:flex;gap:8px;align-items:center;flex-wrap:wrap}

.kanban{display:grid;grid-template-columns:repeat(4,1fr);gap:12px}
.kanban-col{background:rgba(59,107,158,0.06);border:1px solid var(--border);border-radius:var(--radius);padding:10px;min-height:160px}
.kanban-header{display:flex;justify-content:space-between;align-items:center;font-family:var(--font-mono);font-size:.64rem;text-transform:uppercase;letter-spacing:.08em;color:var(--text3);margin-bottom:8px}
.kanban-header span{font-size:.7rem;color:var(--text2)}
.kanban-list{display:flex;flex-direction:column;gap:10px}
.task-empty{padding:14px;border:1px dashed var(--border);border-radius:var(--radius-sm);color:var(--text3);font-size:.8rem;text-align:center}

.task-card{background:var(--card);border:1px solid var(--border);border-radius:var(--radius-sm);padding:12px;box-shadow:var(--shadow);transition:transform .12s, box-shadow .2s, border-color .2s}
.task-card:hover{transform:translateY(-1px);box-shadow:var(--shadow-lg)}
.task-card.in_progress{border-color:var(--accent);box-shadow:0 0 0 1px rgba(59,107,158,0.2);animation:pulseTask 2s ease-in-out infinite}
.task-card.blocked{border-color:var(--orange)}
.task-card.failed{border-color:var(--red)}
.task-card.completed{border-color:var(--green)}
@keyframes pulseTask{0%,100%{box-shadow:0 0 0 0 rgba(59,107,158,0.25)}50%{box-shadow:0 0 0 6px rgba(59,107,158,0.05)}}

.task-card-title{font-weight:700;font-size:.92rem;color:var(--text)}
.task-card-desc{margin-top:4px;font-size:.8rem;color:var(--text2);line-height:1.3}
.task-active-form{margin-top:6px;font-size:.76rem;color:var(--accent);font-weight:600}
.task-card-meta{display:flex;flex-wrap:wrap;gap:8px;margin-top:6px;font-size:.68rem;color:var(--text3);font-family:var(--font-mono)}
.task-progress{margin-top:8px;display:flex;align-items:center;gap:8px;font-size:.66rem;color:var(--text3)}
.task-progress-bar{flex:1;height:6px;background:rgba(59,107,158,0.12);border-radius:999px;overflow:hidden}
.task-progress-fill{height:100%;background:linear-gradient(90deg,var(--accent),var(--green));width:0;transition:width .3s;border-radius:999px}
.task-progress span{font-family:var(--font-mono);min-width:36px;text-align:right}

.task-deps{margin-top:8px;font-size:.66rem;color:var(--text3);display:flex;flex-wrap:wrap;gap:6px;align-items:center}
.dep-chip{padding:2px 6px;border-radius:8px;background:var(--surface);border:1px solid var(--border);font-family:var(--font-mono);font-size:.62rem;color:var(--text2)}
.task-priority{padding:2px 6px;border-radius:8px;background:var(--surface);border:1px solid var(--border);font-family:var(--font-mono);font-size:.6rem}
.task-priority.prio-1{color:var(--orange)}
.task-priority.prio-2{color:var(--red)}

.task-expanded{margin-top:10px;border-top:1px dashed var(--border);padding-top:10px;display:flex;flex-direction:column;gap:10px}
.task-full{font-size:.82rem;color:var(--text2)}
.task-full.muted{color:var(--text3)}
.task-expanded-section{display:flex;flex-direction:column;gap:6px}
.task-expanded-title{font-family:var(--font-mono);font-size:.6rem;text-transform:uppercase;letter-spacing:.08em;color:var(--text3)}
.deps-graph{display:flex;flex-wrap:wrap;gap:6px;align-items:center;font-size:.7rem;color:var(--text2)}
.deps-graph.empty{color:var(--text3)}
.dep-node{padding:3px 8px;border-radius:10px;border:1px solid var(--border);background:var(--surface);font-family:var(--font-mono)}
.dep-node.current{background:var(--accent-glow);color:var(--accent)}
.dep-arrow{color:var(--text3);font-family:var(--font-mono)}

.task-log{display:flex;flex-direction:column;gap:6px}
.task-log-row{display:flex;gap:8px;align-items:center;font-size:.7rem;color:var(--text2)}
.task-log-time{font-family:var(--font-mono);color:var(--text3)}
.task-log-status{padding:2px 6px;border-radius:6px;font-family:var(--font-mono);font-size:.6rem;border:1px solid var(--border)}
.task-log-status.completed{color:var(--green)}
.task-log-status.failed{color:var(--red)}
.task-log-msg{flex:1}
.task-log-empty{font-size:.72rem;color:var(--text3)}
.task-expanded-actions{display:flex;gap:8px}

.timeline-wrap{background:var(--card);border:1px solid var(--border);border-radius:var(--radius);padding:12px;box-shadow:var(--shadow)}
.timeline-labels{display:flex;justify-content:space-between;font-family:var(--font-mono);font-size:.6rem;color:var(--text3);margin-bottom:6px}
.timeline{position:relative;height:18px;background:rgba(59,107,158,0.08);border-radius:999px}
.timeline-dot{position:absolute;top:50%;width:8px;height:8px;border-radius:50%;transform:translate(-50%,-50%);background:var(--green);box-shadow:0 0 8px rgba(74,139,140,0.4)}
.timeline-dot.failed{background:var(--red);box-shadow:0 0 8px rgba(139,58,58,0.4)}
.timeline-dot.completed{background:var(--green)}

/* ===== WORKFLOWS ===== */
.wf-toolbar{display:flex;flex-direction:column;gap:12px;margin-bottom:16px}
.wf-template-row{display:flex;flex-wrap:wrap;gap:10px}
.wf-template{
  border:1px solid var(--border);background:var(--card);border-radius:12px;padding:10px 12px;
  display:flex;flex-direction:column;gap:4px;cursor:pointer;min-width:160px;
  transition:all .15s;box-shadow:var(--shadow);
}
.wf-template:hover{border-color:var(--accent);transform:translateY(-1px)}
.wf-template span{font-weight:600;font-size:.82rem}
.wf-template em{font-style:normal;font-size:.66rem;color:var(--text3);font-family:var(--font-mono)}
.wf-layout{display:grid;grid-template-columns:1fr 1.4fr;gap:14px}
.wf-list{display:flex;flex-direction:column;gap:10px}
.wf-card{
  background:var(--card);border-radius:var(--radius);padding:14px;border:1px solid var(--border);
  box-shadow:var(--shadow);cursor:pointer;transition:all .12s;
}
.wf-card.active{border-color:var(--accent);box-shadow:0 6px 16px rgba(59,107,158,0.12)}
.wf-card.disabled{opacity:.6}
.wf-card-top{display:flex;align-items:center;justify-content:space-between;margin-bottom:8px}
.wf-card-title{font-weight:600;font-size:.9rem}
.wf-card-meta{display:flex;align-items:center;gap:8px;font-family:var(--font-mono);font-size:.64rem;color:var(--text3)}
.wf-card-meta .wf-icon{display:flex;color:var(--accent)}
.wf-card-footer{display:flex;align-items:center;justify-content:space-between;margin-top:10px}
.wf-last{font-size:.66rem;color:var(--text3);font-family:var(--font-mono)}
.wf-steps{padding:2px 6px;border-radius:8px;background:var(--surface);color:var(--text2)}
.wf-toggle{position:relative;width:38px;height:20px}
.wf-toggle input{opacity:0;width:0;height:0}
.wf-toggle span{
  position:absolute;inset:0;background:var(--surface);border-radius:999px;border:1px solid var(--border);
  transition:all .2s;
}
.wf-toggle span::after{
  content:'';position:absolute;top:2px;left:2px;width:14px;height:14px;border-radius:50%;
  background:var(--text3);transition:all .2s;
}
.wf-toggle input:checked + span{background:var(--accent-glow);border-color:var(--accent)}
.wf-toggle input:checked + span::after{left:20px;background:var(--accent)}
.wf-editor .card{height:100%}
.wf-editor-head{display:flex;justify-content:space-between;gap:12px;align-items:center;margin-bottom:12px}
.wf-editor-title{font-size:1rem;font-weight:700}
.wf-editor-sub{font-family:var(--font-mono);font-size:.62rem;color:var(--text3)}
.wf-editor-actions{display:flex;gap:8px;flex-wrap:wrap}
.wf-fields{display:flex;flex-direction:column;gap:10px;margin-bottom:14px}
.wf-field{display:flex;flex-direction:column;gap:6px;font-size:.72rem;color:var(--text2)}
.wf-field span{font-family:var(--font-mono);font-size:.62rem;text-transform:uppercase;letter-spacing:.08em;color:var(--text3)}
.wf-field em{font-style:normal;font-size:.6rem;color:var(--text3)}
.wf-input,.wf-select,.wf-textarea{
  background:var(--card);border:1px solid var(--border);border-radius:10px;padding:9px 12px;
  font-family:var(--font);font-size:.82rem;color:var(--text);
}
.wf-textarea{resize:vertical;min-height:64px}
.wf-trigger-config{margin-bottom:12px}
.wf-section-title{font-family:var(--font-mono);font-size:.62rem;text-transform:uppercase;letter-spacing:.1em;color:var(--text3);margin-bottom:6px}
.wf-steps-wrap{display:flex;flex-direction:column;gap:10px}
.wf-step{border:1px solid var(--border);border-radius:12px;background:var(--card);padding:10px}
.wf-step-head{display:flex;align-items:center;gap:8px;justify-content:space-between}
.wf-step-title{font-weight:600;font-size:.82rem}
.wf-step-actions{display:flex;gap:6px}
.wf-step-btn{
  background:var(--surface);border:1px solid var(--border);border-radius:8px;padding:4px 6px;
  font-size:.7rem;cursor:pointer;color:var(--text2);
}
.wf-step-btn:hover{border-color:var(--accent);color:var(--accent)}
.wf-step-body{margin-top:10px;display:flex;flex-direction:column;gap:8px}
.wf-help{font-size:.72rem;color:var(--text3)}
.wf-empty{font-size:.78rem;color:var(--text3);padding:10px 4px}
.wf-check{display:flex;align-items:center;gap:8px;font-size:.76rem;color:var(--text2)}
.wf-logs{margin-top:16px}
.wf-log-list{display:flex;flex-direction:column;gap:10px}
.wf-log{border:1px solid var(--border);border-radius:12px;padding:10px;background:var(--card)}
.wf-log-success{border-color:rgba(74,139,140,0.35)}
.wf-log-error{border-color:rgba(139,58,58,0.35)}
.wf-log-running{border-color:rgba(176,125,79,0.35)}
.wf-log-head{display:flex;justify-content:space-between;gap:8px;font-family:var(--font-mono);font-size:.62rem;color:var(--text3);margin-bottom:6px}
.wf-log-status{text-transform:uppercase;letter-spacing:.08em}
.wf-log-steps{display:flex;flex-direction:column;gap:8px}
.wf-log-step{background:var(--surface);border:1px solid var(--border-light);border-radius:10px;padding:8px}
.wf-log-step-head{display:flex;justify-content:space-between;font-size:.7rem;margin-bottom:6px}
.wf-log-step-status{font-family:var(--font-mono);font-size:.6rem}
.wf-log-step-status.error{color:var(--red)}
.wf-log-step-status.success{color:var(--green)}
.wf-log-step pre{font-family:var(--font-mono);font-size:.64rem;white-space:pre-wrap;word-break:break-word}
.wf-log-empty{font-size:.7rem;color:var(--text3)}

@media(max-width:1100px){
  .kanban{grid-template-columns:repeat(2,1fr)}
  .wf-layout{grid-template-columns:1fr}
}
@media(max-width:720px){
  .kanban{grid-template-columns:1fr}
  .task-filter-bar{flex-direction:column;align-items:stretch}
  .task-create-toggle{margin-left:0}
  .wf-toolbar{gap:10px}
  .wf-template{flex:1}
}

/* ===== Analytics View ===== */
.an-header { display:flex; align-items:center; gap:10px; margin-bottom:20px; }
.an-header svg { color:var(--accent); }
.an-header h2 { font-family:var(--font-display); font-size:1.6rem; margin:0; }
.an-kpi-grid { display:grid; grid-template-columns:repeat(4,1fr); gap:14px; margin-bottom:24px; }
.an-kpi { background:var(--card); border-radius:var(--radius); padding:18px 20px; box-shadow:var(--shadow); border-left:4px solid var(--accent); }
.an-kpi-value { font-family:var(--font-mono); font-size:1.8rem; font-weight:700; color:var(--text); line-height:1.2; }
.an-kpi-label { font-size:0.82rem; color:var(--text3); margin-top:4px; }
.an-kpi.purple { border-left-color:var(--purple); }
.an-kpi.green { border-left-color:var(--green); }
.an-kpi.orange { border-left-color:var(--orange); }
.an-charts-grid { display:grid; grid-template-columns:1fr 1fr; gap:18px; margin-bottom:24px; }
.an-chart-card { background:var(--card); border-radius:var(--radius); padding:18px; box-shadow:var(--shadow); }
.an-chart-card h3 { font-size:0.95rem; font-weight:600; color:var(--text2); margin:0 0 12px 0; }
.an-chart-card canvas { width:100%; height:220px; display:block; }
.an-chart-card.wide { grid-column:1/-1; }
.an-legend { display:flex; gap:16px; flex-wrap:wrap; margin-bottom:8px; font-size:0.78rem; color:var(--text3); }
.an-legend-item { display:flex; align-items:center; gap:5px; }
.an-legend-dot { width:10px; height:10px; border-radius:50%; display:inline-block; }
.an-table-wrap { overflow-x:auto; }
.an-table { width:100%; border-collapse:collapse; font-size:0.85rem; }
.an-table th { text-align:left; padding:8px 10px; color:var(--text3); font-weight:600; border-bottom:1px solid var(--border); font-size:0.78rem; text-transform:uppercase; letter-spacing:0.5px; }
.an-table td { padding:8px 10px; border-bottom:1px solid var(--border-light); }
.an-table tr:nth-child(even) td { background:var(--surface); }
.an-table .mono { font-family:var(--font-mono); font-size:0.82rem; }
.an-tooltip { position:fixed; pointer-events:none; background:var(--text); color:var(--bg); padding:6px 10px; border-radius:6px; font-size:0.78rem; font-family:var(--font-mono); z-index:1000; white-space:nowrap; box-shadow:var(--shadow-lg); }
.an-donut-wrap { display:flex; align-items:center; gap:20px; }
.an-donut-legend { font-size:0.82rem; color:var(--text2); }
.an-donut-legend div { display:flex; align-items:center; gap:6px; margin-bottom:6px; }
@media(max-width:900px) { .an-kpi-grid { grid-template-columns:1fr 1fr; } .an-charts-grid { grid-template-columns:1fr; } }
@media(max-width:600px) { .an-kpi-grid { grid-template-columns:1fr; } .an-kpi-value { font-size:1.4rem; } }
