skimpyclaw 0.3.6 → 0.3.8
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/README.md +14 -6
- package/dist/__tests__/api.test.js +1 -0
- package/dist/__tests__/channels.test.js +1 -1
- package/dist/__tests__/code-agents-orchestrator.test.js +74 -7
- package/dist/__tests__/code-agents-sandbox.test.d.ts +1 -0
- package/dist/__tests__/code-agents-sandbox.test.js +163 -0
- package/dist/__tests__/context-manager.test.d.ts +1 -0
- package/dist/__tests__/context-manager.test.js +236 -0
- package/dist/__tests__/package-manager-detection.test.js +5 -5
- package/dist/__tests__/setup.test.js +7 -5
- package/dist/__tests__/skills.test.js +2 -2
- package/dist/__tests__/structured-context.test.d.ts +1 -0
- package/dist/__tests__/structured-context.test.js +100 -0
- package/dist/__tests__/tools.test.js +65 -3
- package/dist/agent.js +4 -5
- package/dist/api.js +10 -58
- package/dist/audit.js +5 -51
- package/dist/channels/telegram/handlers.js +2 -60
- package/dist/channels/telegram/index.js +0 -7
- package/dist/channels.js +1 -1
- package/dist/cli.js +151 -16
- package/dist/code-agents/executor.d.ts +9 -4
- package/dist/code-agents/executor.js +187 -13
- package/dist/code-agents/index.d.ts +1 -1
- package/dist/code-agents/index.js +23 -21
- package/dist/code-agents/orchestrator.d.ts +8 -2
- package/dist/code-agents/orchestrator.js +297 -27
- package/dist/code-agents/structured-context.d.ts +7 -0
- package/dist/code-agents/structured-context.js +54 -0
- package/dist/code-agents/types.d.ts +2 -0
- package/dist/code-agents/utils.js +12 -2
- package/dist/code-agents/worktree.d.ts +40 -0
- package/dist/code-agents/worktree.js +215 -0
- package/dist/config.d.ts +1 -0
- package/dist/config.js +5 -3
- package/dist/cron.js +18 -4
- package/dist/dashboard/assets/{index-CkonC7Cd.js → index-BoTHPby4.js} +20 -20
- package/dist/dashboard/assets/{index-EAg6lqF5.css → index-D4mufvBg.css} +1 -1
- package/dist/dashboard/index.html +2 -2
- package/dist/discord.js +4 -40
- package/dist/exec-approval.js +1 -1
- package/dist/file-lock.js +1 -1
- package/dist/gateway.js +3 -10
- package/dist/providers/anthropic.js +9 -5
- package/dist/providers/codex.js +10 -6
- package/dist/providers/context-manager.d.ts +22 -0
- package/dist/providers/context-manager.js +100 -0
- package/dist/providers/openai.js +9 -5
- package/dist/providers/types.d.ts +1 -0
- package/dist/security.js +9 -0
- package/dist/setup.js +112 -14
- package/dist/skills.js +9 -2
- package/dist/subagent.js +33 -2
- package/dist/tools/bash-tool.js +8 -0
- package/dist/tools/browser-tool.js +2 -1
- package/dist/tools/definitions.d.ts +0 -27
- package/dist/tools/definitions.js +0 -18
- package/dist/tools/execute-context.d.ts +4 -4
- package/dist/tools/file-tools.d.ts +1 -1
- package/dist/tools/file-tools.js +1 -1
- package/dist/tools.d.ts +5 -5
- package/dist/tools.js +87 -98
- package/dist/types.d.ts +14 -22
- package/dist/usage.d.ts +1 -0
- package/dist/usage.js +30 -46
- package/dist/utils.d.ts +18 -0
- package/dist/utils.js +71 -0
- package/dist/voice.js +9 -7
- package/package.json +1 -1
|
@@ -1 +1 @@
|
|
|
1
|
-
@import"https://fonts.googleapis.com/css2?family=Playfair+Display:wght@500;600;700;800&family=Noto+Sans:wght@400;500;600&display=swap";.sidebar{background:var(--bg-sidebar);display:flex;flex-direction:column;position:sticky;top:0;height:100vh;z-index:10;transition:background .3s ease;overflow-y:auto}.sidebar-header{padding:28px 24px 20px;display:flex;align-items:center;gap:12px}.sidebar-logo{width:40px;height:40px;background:transparent;border-radius:0;display:flex;align-items:center;justify-content:center;font-size:20px;box-shadow:none;flex-shrink:0}.sidebar-brand{display:flex;flex-direction:column}.sidebar-close-btn{display:none;margin-left:auto;width:30px;height:30px;border:1px solid var(--border);border-radius:var(--radius-sm);background:var(--surface);color:var(--text-dim);align-items:center;justify-content:center;cursor:pointer}.sidebar-close-btn:hover{background:var(--surface-hover);color:var(--text)}.sidebar-brand-name{font-family:var(--serif);font-size:17px;font-weight:800;color:var(--text);letter-spacing:-.01em}.sidebar-brand-status{font-size:11px;color:var(--success);display:flex;align-items:center;gap:5px;font-weight:500}.sidebar-brand-status:before{content:"";width:6px;height:6px;border-radius:50%;background:var(--success);display:inline-block}.sidebar-section{padding:0 12px;margin-bottom:8px}.sidebar-section-label{font-size:11px;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.06em;padding:16px 12px 8px}.sidebar-item{display:flex;align-items:center;gap:12px;padding:10px 12px;border-radius:var(--radius-sm);cursor:pointer;color:var(--text-dim);font-size:14px;font-weight:500;transition:all .15s ease;border:none;background:transparent;width:100%;text-align:left;font-family:var(--sans);position:relative}.sidebar-item:hover{background:var(--sidebar-hover);color:var(--text)}.sidebar-item.active{background:var(--sidebar-active);color:var(--text-dim);font-weight:600;box-shadow:var(--shadow-sm)}.sidebar-item.active:before{content:"";position:absolute;left:0;top:8px;bottom:8px;width:3px;border-radius:0 3px 3px 0;background:var(--accent)}.sidebar-item svg{width:20px;height:20px;flex-shrink:0;opacity:.6}.sidebar-item.active svg{opacity:1}.sidebar-item:hover svg{opacity:.85}.sidebar-item-icon{display:inline-flex;align-items:center;justify-content:center;line-height:0}.sidebar-item.active .sidebar-item-icon{color:var(--accent)}.sidebar-item-label{display:inline-flex;align-items:center;line-height:1.2}.sidebar-item .item-badge{margin-left:auto;font-size:11px;font-weight:600;padding:2px 8px;border-radius:999px;background:var(--warning-soft);color:var(--warning)}.sidebar-spacer{flex:1}.sidebar-footer{padding:16px 12px;border-top:1px solid var(--border-light)}.sidebar-footer-item{display:flex;align-items:center;gap:12px;padding:10px 12px;border-radius:var(--radius-sm);cursor:pointer;color:var(--text-muted);font-size:13px;font-weight:500;transition:all .15s ease;border:none;background:transparent;width:100%;text-align:left;font-family:var(--sans)}.sidebar-footer-item:hover{background:var(--sidebar-hover);color:var(--text-dim)}.sidebar-footer-item.active{background:var(--sidebar-active);color:var(--text-dim);font-weight:600}.sidebar-footer-item svg{width:18px;height:18px;flex-shrink:0;opacity:.5}.sidebar-footer-item.active .sidebar-item-icon{color:var(--accent)}@media (max-width: 980px){.sidebar-close-btn{display:inline-flex}}:root,:root[data-theme=light],[data-theme=light]{--text: #0c0303;--background: #fffaf5;--text-dim: #5a4a40;--text-muted: #9a8a80;--bg: var(--background);--bg-sidebar: var(--background);--surface: #ffffff;--surface-alt: #f5ebe5;--surface-hover: #ebe0d8;--primary: #d33b36;--primary-hover: #c65a24;--primary-soft: rgba(219, 111, 57, .16);--primary-soft-2: rgba(219, 111, 57, .08);--secondary: #f2ded2;--secondary-soft: rgba(242, 222, 210, .22);--accent: #dfaa6d;--accent-hover: #e07030;--accent-soft: rgba(243, 134, 70, .16);--accent-soft-2: rgba(243, 134, 70, .08);--success: #5a9b5a;--success-soft: rgba(90, 155, 90, .16);--warning: #c9a43c;--warning-soft: rgba(201, 164, 60, .12);--error: #d94a4a;--error-soft: rgba(217, 74, 74, .12);--border: rgba(23, 16, 11, .08);--border-light: rgba(23, 16, 11, .05);--shadow-sm: 0 1px 2px rgba(23, 16, 11, .04);--shadow: 0 2px 8px rgba(23, 16, 11, .06);--shadow-md: 0 4px 16px rgba(23, 16, 11, .08);--sidebar-active: #ffffff;--sidebar-hover: rgba(23, 16, 11, .04);--welcome-from: #db6f39;--welcome-to: #f38646;--welcome-shadow: rgba(219, 111, 57, .3);--welcome-text: #ffffff;--log-info: #5a4a40;--log-warn: #b08a1a;--log-error: #d94a4a;--highlight: #f38646;--info: #7bb8f9;--info-soft: rgba(123, 184, 249, .12);--chip-telegram: #4a7a99;--chip-telegram-bg: rgba(109, 166, 214, .13);--chip-discord: #5a5a99;--chip-discord-bg: rgba(130, 146, 235, .14);--chip-cron: #9a7f3e;--chip-cron-bg: rgba(203, 169, 93, .14);--pending: #7a8a91;--pending-soft: rgba(142, 154, 166, .1);--mono: "JetBrains Mono", "SF Mono", "Fira Code", monospace;--sans: "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;--serif: "Playfair Display", Georgia, "Times New Roman", serif;--radius: 16px;--radius-md: 12px;--radius-sm: 8px;--sidebar-width: 260px}:root[data-theme=dark],[data-theme=dark]{--text: #fcf3f3;--background: #121212;--text-dim: #d4ccc6;--text-muted: #948c86;--bg: var(--background);--bg-sidebar: var(--background);--surface: #1a120c;--surface-alt: #251c14;--surface-hover: #30261c;--primary: #c9312c;--primary-hover: #db6f39;--primary-soft: rgba(198, 90, 36, .2);--primary-soft-2: rgba(198, 90, 36, .1);--secondary: #f2ded2;--secondary-soft: rgba(242, 222, 210, .22);--accent: #dfaa6d;--accent-hover: #d65a1a;--accent-soft: rgba(187, 76, 12, .2);--accent-soft-2: rgba(187, 76, 12, .1);--success: #5ab85a;--success-soft: rgba(90, 184, 90, .18);--warning: #d4b45a;--warning-soft: rgba(212, 180, 90, .14);--error: #e07a6a;--error-soft: rgba(224, 122, 106, .14);--border: rgba(243, 236, 231, .08);--border-light: rgba(243, 236, 231, .05);--shadow-sm: 0 1px 2px rgba(0, 0, 0, .3);--shadow: 0 2px 8px rgba(0, 0, 0, .35);--shadow-md: 0 4px 16px rgba(0, 0, 0, .4);--sidebar-active: rgba(198, 90, 36, .2);--sidebar-hover: rgba(243, 236, 231, .04);--welcome-from: #c65a24;--welcome-to: #e07a40;--welcome-shadow: rgba(198, 90, 36, .4);--welcome-text: #f3ece7;--log-info: #d4ccc6;--log-warn: #d4b45a;--log-error: #e07a6a;--highlight: #bb4c0c;--info: #7ab8f9;--info-soft: rgba(122, 184, 249, .14);--chip-telegram: #8eb8e0;--chip-telegram-bg: rgba(126, 184, 224, .16);--chip-discord: #9e9eed;--chip-discord-bg: rgba(158, 158, 237, .16);--chip-cron: #d4b45a;--chip-cron-bg: rgba(212, 180, 90, .16);--pending: #9ba5b0;--pending-soft: rgba(155, 165, 176, .14)}*{margin:0;padding:0;box-sizing:border-box}html{font-size:100%}body{font-family:"Noto Sans",var(--sans);font-weight:400;background:var(--bg);color:var(--text);min-height:100vh;font-size:14px;line-height:1.55;transition:background .3s ease,color .3s ease;-webkit-font-smoothing:antialiased}h1,h2,h3,h4,h5{font-family:var(--serif);font-weight:700}h1{font-size:4.21rem}h2{font-size:3.158rem}h3{font-size:2.369rem}h4{font-size:1.777rem}h5{font-size:1.333rem}small{font-size:.75rem}a{color:var(--accent);text-decoration:none}a:hover{text-decoration:underline}.shell{display:grid;grid-template-columns:var(--sidebar-width) 1fr;min-height:100vh}.main{position:relative;overflow-y:auto;padding:32px 36px}.btn{padding:8px 16px;border:1px solid var(--border);border-radius:var(--radius-sm);background:var(--surface);color:var(--text);font-family:var(--sans);font-weight:500;font-size:13px;cursor:pointer;transition:all .12s ease}.btn:hover{background:var(--surface-hover)}.btn-primary{background:var(--accent);border-color:var(--accent);color:#fff}.btn-primary:hover{background:var(--accent-hover)}.btn-success{background:var(--success);border-color:var(--success);color:#fff}.btn-success:hover{opacity:.9}.btn-danger{background:var(--error-soft);border-color:#ef444433;color:var(--error)}.btn-danger:hover{background:#ef44441f}.btn-sm,.btn-small{padding:5px 12px;font-size:12px}.btn-refresh{display:inline-flex;align-items:center;gap:6px;padding:7px 14px;border:1px solid var(--border-light);border-radius:999px;background:var(--surface-alt);color:var(--text-dim);font-family:var(--sans);font-weight:500;font-size:13px;cursor:pointer;transition:all .15s ease;box-shadow:var(--shadow-sm)}.btn-refresh:hover{background:var(--surface-hover);border-color:var(--border);color:var(--text);box-shadow:var(--shadow)}.btn-refresh:focus-visible{outline:2px solid var(--accent);outline-offset:2px}.btn-refresh:active{transform:scale(.98)}input:not([type=checkbox]):not([type=radio]),select,textarea{width:100%;padding:10px 12px;border:1px solid var(--border);border-radius:var(--radius-sm);background:var(--surface-alt);color:var(--text);font-family:var(--sans);font-size:13px;line-height:1.5;outline:none;transition:border-color .12s ease,box-shadow .12s ease,background .12s ease}textarea{resize:vertical;min-height:90px}input:not([type=checkbox]):not([type=radio]):focus,select:focus,textarea:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-soft);background:var(--surface)}input::placeholder,textarea::placeholder{color:var(--text-muted)}.form-grid{display:grid;gap:10px}.form-grid.two{grid-template-columns:1fr 1fr}.form-grid.three{grid-template-columns:repeat(3,minmax(0,1fr))}.form-field{display:flex;flex-direction:column;gap:6px}.form-label{font-size:12px;color:var(--text-dim);font-weight:600;letter-spacing:.01em}.form-help{font-size:11px;color:var(--text-muted)}.form-actions{display:flex;gap:8px;align-items:center;margin-top:12px}.form-checkbox{display:flex;align-items:center;gap:10px;font-size:13px;line-height:1.35;color:var(--text-dim);cursor:pointer;-webkit-user-select:none;user-select:none}.form-checkbox input[type=checkbox]{-moz-appearance:none;appearance:none;-webkit-appearance:none;width:18px;height:18px;flex:0 0 18px;border:1px solid var(--border);border-radius:5px;background:var(--surface);display:inline-grid;place-content:center;margin:0;cursor:pointer;transition:border-color .12s ease,box-shadow .12s ease,background .12s ease}.form-checkbox input[type=checkbox]:before{content:"";width:10px;height:10px;transform:scale(0);transition:transform .1s ease-in-out;background:#fff;clip-path:polygon(14% 44%,0 63%,44% 100%,100% 18%,82% 0,40% 64%)}.form-checkbox input[type=checkbox]:checked{border-color:var(--accent);background:var(--accent)}.form-checkbox input[type=checkbox]:checked:before{transform:scale(1)}.form-checkbox input[type=checkbox]:focus-visible{outline:none;box-shadow:0 0 0 3px var(--accent-soft)}.form-check-row{display:flex;gap:20px;align-items:center;flex-wrap:wrap}.form-check-row.tight{gap:12px}.form-check-col{display:flex;flex-direction:column;gap:6px}.form-divider{height:1px;background:var(--border-light);margin:12px 0}.toast-container{position:fixed;bottom:24px;right:24px;z-index:1000;display:flex;flex-direction:column;gap:8px}.toast{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-sm);padding:12px 18px;font-size:13px;box-shadow:var(--shadow-md);animation:toast-in .2s ease}.toast.success{border-left:3px solid var(--success)}.toast.error{border-left:3px solid var(--error)}.toast.warning{border-left:3px solid var(--warning)}@keyframes toast-in{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.section{margin-bottom:28px}.section-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px}.section-title{font-family:var(--serif);font-size:18px;font-weight:800;color:var(--text);letter-spacing:-.01em}.section-link{font-size:13px;color:var(--accent);cursor:pointer;text-decoration:none;font-weight:500}.section-link:hover{text-decoration:underline}.section-link-content{display:inline-flex;align-items:center;gap:6px}.page-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:28px}.page-title{font-family:var(--serif);font-size:26px;font-weight:800;letter-spacing:-.02em;color:var(--text)}.header-actions{display:flex;gap:10px;align-items:center;flex-wrap:nowrap}.page-header .header-actions{margin-right:72px}.header-meta{font-size:12px;color:var(--text-muted);font-family:var(--mono)}.theme-toggle{width:36px;height:36px;border:1px solid var(--border);background:var(--surface);border-radius:var(--radius-sm);cursor:pointer;font-size:16px;display:flex;align-items:center;justify-content:center;transition:all .15s ease;color:var(--text)}.theme-toggle:hover{background:var(--surface-hover)}.global-theme-toggle{position:absolute;top:32px;right:36px;width:37px;height:37px;border:1px solid var(--border);background:var(--surface);border-radius:var(--radius-sm);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .15s ease;box-shadow:var(--shadow-sm);color:var(--text);z-index:100}.global-theme-toggle:hover{background:var(--surface-hover);box-shadow:var(--shadow)}.global-sidebar-toggle,.sidebar-backdrop{display:none}.stats-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:18px;margin-bottom:10px}.cards-link-row{display:flex;justify-content:flex-end;margin-bottom:22px}.stat-card{background:var(--surface);border-radius:var(--radius);padding:22px 24px;box-shadow:var(--shadow-sm);transition:all .2s ease;border:1px solid var(--border-light);display:flex;align-items:center;gap:16px;min-height:138px}.stat-card:hover{box-shadow:var(--shadow);transform:translateY(-1px)}.stat-icon{width:48px;height:48px;border-radius:var(--radius-sm);display:flex;align-items:center;justify-content:center;font-size:18px;flex:0 0 auto}.stat-icon svg{width:20px;height:20px}.stat-icon.sage{background:var(--accent-soft);color:var(--accent)}.stat-icon.green{background:var(--success-soft);color:var(--success)}.stat-icon.amber{background:var(--warning-soft);color:var(--warning)}.stat-icon.blue{background:var(--info-soft);color:var(--info)}.stat-icon.rose{background:#f43f5e14;color:#f43f5e}.stats-grid-5{grid-template-columns:repeat(5,1fr)}.stats-grid-5 .stat-card{min-height:120px;padding:18px 20px;gap:12px}.stats-grid-5 .stat-icon{width:42px;height:42px}.stats-grid-5 .stat-icon svg{width:18px;height:18px}.stats-grid-5 .stat-value{font-size:26px}.stats-grid-5 .stat-value-md{font-size:18px}.stat-body{display:flex;flex-direction:column;justify-content:center;min-width:0}.stat-value{font-family:var(--serif);font-size:32px;font-weight:700;line-height:1.02;letter-spacing:-.02em}.stat-value-md{font-size:22px}.stat-subtitle{font-size:11px;color:var(--text-dim);font-weight:500;line-height:1.2}.feed-card{background:var(--surface);border-radius:var(--radius);box-shadow:var(--shadow-sm);border:1px solid var(--border-light);overflow:hidden}.feed{display:flex;flex-direction:column}.feed-item{display:grid;grid-template-columns:40px 1fr auto;gap:14px;align-items:start;padding:16px 20px;transition:background .12s ease;border-bottom:1px solid var(--border-light)}.feed-item:last-child{border-bottom:none}.feed-item:hover{background:var(--surface-alt)}.feed-icon{width:40px;height:40px;border-radius:var(--radius-sm);display:flex;align-items:center;justify-content:center;font-size:16px;flex-shrink:0}.feed-icon.telegram{background:var(--accent-soft);color:var(--accent)}.feed-icon.cron{background:var(--warning-soft);color:var(--warning)}.feed-icon.system{background:var(--surface-alt);color:var(--text-muted)}.feed-icon.code{background:var(--accent-soft);color:var(--accent)}.feed-title{font-weight:600;font-size:14px;margin-bottom:3px}.feed-detail{font-size:13px;color:var(--text-dim);line-height:1.45}.feed-time{font-size:11px;color:var(--text-muted);font-family:var(--mono);white-space:nowrap;padding-top:2px}.cron-grid{display:grid;grid-template-columns:1fr 1fr;gap:14px}.cron-card{background:var(--surface);border:1px solid var(--border-light);border-radius:var(--radius);padding:20px 22px;display:flex;justify-content:space-between;align-items:center;box-shadow:var(--shadow-sm);transition:all .15s ease}.cron-card:hover{box-shadow:var(--shadow);transform:translateY(-1px)}.cron-info{flex:1}.cron-name{font-weight:600;font-size:14px;margin-bottom:4px;color:var(--text)}.cron-schedule{font-size:12px;color:var(--text-dim);font-family:var(--mono)}.cron-next{font-size:12px;color:var(--success);font-family:var(--mono);text-align:right;font-weight:500}.welcome-banner{background:linear-gradient(135deg,var(--welcome-from),var(--welcome-to));border-radius:var(--radius);padding:28px 32px;margin-bottom:28px;color:var(--welcome-text);position:relative;overflow:hidden}.welcome-banner:after{content:"";position:absolute;right:-20px;top:-20px;width:200px;height:200px;border-radius:50%;background:#ffffff14}.welcome-banner:before{content:"";position:absolute;right:80px;bottom:-40px;width:120px;height:120px;border-radius:50%;background:#ffffff0d}.welcome-greeting{font-family:var(--serif);font-size:24px;font-weight:800;margin-bottom:6px;letter-spacing:-.01em;position:relative;z-index:1}.welcome-sub{font-size:14px;opacity:.85;font-weight:400;position:relative;z-index:1}.approval-banner{background:var(--warning-soft);border:1px solid rgba(245,158,11,.15);border-radius:var(--radius);padding:18px 22px;margin-bottom:24px;display:flex;align-items:center;gap:16px}.approval-banner-icon{font-size:22px;flex-shrink:0}.approval-banner-content{flex:1}.approval-banner-title{font-weight:600;font-size:14px;margin-bottom:3px}.approval-banner-detail{font-size:13px;color:var(--text-dim);font-family:var(--mono)}.approval-banner-actions{display:flex;gap:8px}.approval-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:18px 24px;margin-bottom:10px;display:flex;align-items:center;gap:16px;box-shadow:var(--shadow-sm)}.approval-card-icon{width:44px;height:44px;border-radius:var(--radius-sm);background:var(--warning-soft);color:var(--warning);display:flex;align-items:center;justify-content:center;flex-shrink:0}.approval-card-content{flex:1;min-width:0}.approval-card-title{font-weight:700;font-size:15px;color:var(--text);margin-bottom:4px}.approval-card-detail{font-size:13px;color:var(--text-dim);display:flex;align-items:center;gap:6px;flex-wrap:wrap}.approval-cmd{font-family:var(--mono);font-size:12px;background:var(--surface-alt);border:1px solid var(--border);border-radius:4px;padding:2px 8px;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:480px}.approval-card-cwd{font-size:11px;color:var(--text-muted);font-family:var(--mono);margin-top:3px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.approval-card-time{font-family:var(--mono);font-size:14px;color:var(--warning);font-weight:600;flex-shrink:0;min-width:40px;text-align:right}.approval-card-actions{display:flex;gap:8px;flex-shrink:0}.approval-btn-deny{padding:8px 18px;font-size:13px;font-weight:600;border-radius:var(--radius-sm);border:1.5px solid var(--border);background:var(--surface);color:var(--text);cursor:pointer;transition:all .12s ease}.approval-btn-deny:hover{background:var(--surface-alt);border-color:var(--text-muted)}.approval-btn-deny:disabled{opacity:.5;cursor:not-allowed}.approval-btn-approve{padding:8px 20px;font-size:13px;font-weight:600;border-radius:var(--radius-sm);border:none;background:var(--accent);color:#fff;cursor:pointer;display:inline-flex;align-items:center;gap:6px;transition:all .12s ease}.approval-btn-approve:hover{background:var(--accent-hover)}.approval-btn-approve:disabled{opacity:.5;cursor:not-allowed}.approvals-page{display:flex;flex-direction:column;gap:0}.appr-auto-refresh{display:inline-flex;align-items:center;gap:6px;font-family:var(--mono);font-size:12px;color:var(--text-muted);border:1px solid var(--border);border-radius:999px;padding:5px 14px}.appr-auto-dot{width:7px;height:7px;border-radius:50%;background:var(--success);display:inline-block}.appr-section-label{font-size:11px;font-weight:700;letter-spacing:.06em;color:var(--text-muted);text-transform:uppercase;margin-bottom:12px;margin-top:8px}.appr-list{display:flex;flex-direction:column;gap:14px}.appr-item{display:flex;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow-sm)}.appr-item-border{width:4px;flex-shrink:0}.appr-item-border.pending{background:var(--warning)}.appr-item-border.approved{background:var(--success)}.appr-item-border.denied{background:var(--error)}.appr-item-border.expired{background:var(--text-muted)}.appr-item-body{flex:1;padding:16px 20px;display:flex;flex-direction:column;gap:10px;min-width:0}.appr-item-head{display:flex;align-items:center;gap:8px;flex-wrap:wrap}.appr-item-icon{width:36px;height:36px;border-radius:var(--radius-sm);display:flex;align-items:center;justify-content:center;flex-shrink:0}.appr-item-icon.pending{background:var(--warning-soft);color:var(--warning)}.appr-item-icon.approved{background:var(--success-soft);color:var(--success)}.appr-item-icon.denied{background:var(--error-soft);color:var(--error)}.appr-item-icon.expired{background:var(--surface-alt);color:var(--text-muted)}.appr-item-id{font-family:var(--mono);font-weight:600;font-size:14px;color:var(--text)}.appr-chip{display:inline-block;font-family:var(--mono);font-size:10px;font-weight:700;letter-spacing:.04em;padding:2px 8px;border-radius:4px;text-transform:uppercase}.appr-chip.tier{background:var(--surface-alt);color:var(--text-dim)}.appr-chip.tier.tier-1{background:var(--info-soft);color:var(--info)}.appr-chip.tier.tier-2{background:var(--warning-soft);color:var(--warning)}.appr-chip.tier.tier-3{background:var(--error-soft);color:var(--error)}.appr-chip.pending{background:var(--warning-soft);color:var(--warning)}.appr-chip.approved{background:var(--success-soft);color:var(--success)}.appr-chip.denied{background:var(--error-soft);color:var(--error)}.appr-chip.expired{background:var(--surface-alt);color:var(--text-muted)}.appr-tier-legend{margin-top:10px;display:grid;grid-template-columns:auto 1fr;gap:6px 10px;align-items:center}.appr-tier-label{font-size:12px;color:var(--text-dim)}.appr-elapsed{display:inline-flex;align-items:center;gap:4px;font-family:var(--mono);font-size:13px;color:var(--warning);font-weight:600}.appr-actions{display:flex;gap:8px}.appr-reason{font-size:14px;color:var(--text-dim)}.appr-cmd-block{font-family:var(--mono);font-size:13px;background:var(--surface-alt);border:1px solid var(--border);border-radius:var(--radius-sm);padding:10px 14px;color:var(--text);overflow-x:auto;white-space:pre}.appr-footer{display:flex;align-items:center;gap:8px;flex-wrap:wrap;font-size:12px;color:var(--text-muted)}.appr-footer-item{display:inline-flex;align-items:center;gap:4px;font-family:var(--mono)}.appr-footer-sep{color:var(--border)}.appr-footer-resolution{font-style:italic;color:var(--text-muted)}.spinner{width:20px;height:20px;border:2px solid var(--border);border-top-color:var(--accent);border-radius:50%;animation:spin .7s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.empty-state{text-align:center;padding:48px 24px;color:var(--text-muted)}.empty-state-icon{font-size:36px;margin-bottom:12px}.empty-state-text{font-size:14px}.markdown-view{font-size:14px;line-height:1.55;color:var(--text-dim)}.markdown-view h1,.markdown-view h2,.markdown-view h3,.markdown-view h4,.markdown-view h5,.markdown-view h6{font-family:var(--serif);color:var(--text);font-weight:800;margin:0 0 8px}.markdown-view p{margin:0 0 7px}.markdown-view ul,.markdown-view ol{padding-left:20px;margin:0 0 7px}.markdown-view code{font-family:var(--mono);background:var(--surface-alt);padding:1px 4px;border-radius:4px;font-size:12px}.markdown-view pre{margin:0 0 9px;background:var(--surface-alt);border:1px solid var(--border-light);border-radius:var(--radius-sm);padding:12px;overflow:auto}.markdown-view pre code{background:transparent;padding:0}.markdown-view blockquote{border-left:3px solid var(--accent);padding-left:10px;margin:0 0 9px;color:var(--text-muted)}.chat-list{display:flex;flex-direction:column;gap:10px}.chat-row{display:flex;flex-direction:column}.chat-row.user{align-items:flex-end}.chat-row.assistant{align-items:flex-start}.chat-meta{font-size:11px;color:var(--text-muted);font-family:var(--mono);margin-bottom:4px}.chat-bubble{max-width:82%;padding:10px 12px;border-radius:12px;font-size:14px;line-height:1.5;border:1px solid var(--border-light)}.chat-bubble.user{background:var(--accent-soft);color:var(--text)}.chat-bubble.assistant{background:var(--surface-alt);color:var(--text-dim)}.chat-bubble .markdown-view p:last-child,.chat-bubble .markdown-view ul:last-child,.chat-bubble .markdown-view ol:last-child,.chat-bubble .markdown-view pre:last-child,.chat-bubble .markdown-view blockquote:last-child{margin-bottom:0}.messages-page{height:calc(100vh - 118px);display:flex;flex-direction:column}.messages-chat-card{flex:1;height:100%;min-height:0;display:flex;flex-direction:column;margin-bottom:0}.messages-chat-list{flex:1;min-height:0;overflow-y:auto;padding-right:4px;padding-bottom:8px;-ms-overflow-style:none;scrollbar-width:none}.messages-chat-list::-webkit-scrollbar{width:0;height:0;display:none}.messages-composer-inline{margin-top:auto;padding-top:12px;border-top:1px solid var(--border-light)}.messages-filler{flex:1;display:flex;align-items:center;justify-content:center}.card{background:var(--surface);border:1px solid var(--border-light);border-radius:var(--radius);padding:20px 22px;margin-bottom:14px;box-shadow:var(--shadow-sm)}.card-title{font-size:14px;color:var(--text);margin-bottom:8px;font-weight:500}.toolbar{display:flex;gap:8px;align-items:center;margin-bottom:12px;flex-wrap:wrap}.split{display:grid;grid-template-columns:320px 1fr;gap:18px;height:calc(100vh - 180px)}.split-list{background:var(--surface);border:1px solid var(--border-light);border-radius:var(--radius);overflow-y:auto;box-shadow:var(--shadow-sm)}.split-detail{background:var(--surface);border:1px solid var(--border-light);border-radius:var(--radius);overflow-y:auto;padding:24px;box-shadow:var(--shadow-sm)}.list-item{padding:16px 20px;border-bottom:1px solid var(--border-light);cursor:pointer;transition:background .12s ease}.list-item:last-child{border-bottom:none}.list-item:hover{background:var(--surface-alt)}.list-item.active{background:var(--accent-soft-2);border-left:3px solid var(--accent)}.list-item-title{font-weight:600;font-size:14px;margin-bottom:3px;color:var(--text)}.list-item-sub,.list-item-meta{font-size:12px;color:var(--text-dim);font-family:var(--mono)}.audit-entry{background:var(--surface);border:1px solid var(--border-light);border-radius:var(--radius);padding:16px 18px;margin-bottom:10px}.audit-header{display:flex;justify-content:space-between;align-items:start;gap:10px;margin-bottom:8px}.audit-id{font-family:var(--mono);font-size:12px;color:var(--accent);font-weight:600}.audit-meta{display:flex;align-items:center;gap:8px;font-size:11px;color:var(--text-muted);font-family:var(--mono)}.audit-summary{font-size:13px;color:var(--text-dim);line-height:1.5}.audit-page{display:flex;flex-direction:column;gap:12px}.audit-header-meta{font-family:var(--mono);font-size:11px;color:var(--text-muted)}.audit-top-stats{background:var(--surface);border:1px solid var(--border-light);border-radius:var(--radius);padding:10px 14px;display:flex;justify-content:space-between;align-items:center;gap:12px;flex-wrap:wrap}.audit-stat-left{display:flex;align-items:baseline;gap:8px}.audit-big{font-family:var(--serif);font-size:20px;line-height:1}.audit-big.ok{color:var(--success)}.audit-big.error{color:var(--error)}.audit-big.running{color:var(--warning)}.audit-stat-label{font-size:11px;color:var(--text-muted);font-weight:600}.audit-stat-triggers{display:flex;gap:8px;flex-wrap:wrap}.audit-filters-row{display:flex;flex-direction:column;gap:8px;align-items:stretch}.audit-search{width:100%;min-width:0;max-width:none;display:inline-flex;align-items:center;gap:8px;border:1px solid var(--border-light);background:var(--surface);color:var(--text-muted);border-radius:14px;padding:10px 14px;min-height:56px}.audit-search input{border:none;background:transparent;color:var(--text);width:100%;min-width:120px;font-size:11px;font-weight:500}.audit-search input:focus{outline:none}.audit-search svg{width:20px;height:20px}.audit-filter-controls{display:flex;gap:8px;align-items:center}.audit-filter-controls>.btn.btn-sm{min-height:32px;height:32px;min-width:160px;width:auto;border-radius:10px;font-size:12px;font-weight:500;padding:5px 12px}.audit-timeline{display:flex;flex-direction:column;gap:8px}.audit-row{display:grid;grid-template-columns:56px 1fr;gap:12px}.audit-time-col{display:flex;flex-direction:column;align-items:center;color:var(--text-muted)}.audit-time{font-family:var(--mono);font-size:10px;margin-top:12px}.audit-time-line{width:1px;flex:1;min-height:40px;background:var(--border);margin-top:8px}.audit-card{background:var(--surface);border:1px solid var(--border-light);border-radius:var(--radius);padding:12px 14px}.audit-card-head{display:flex;justify-content:space-between;align-items:center;gap:10px;margin-bottom:6px}.audit-chip-row{display:flex;gap:6px;align-items:center;flex-wrap:wrap}.audit-chip{display:inline-flex;align-items:center;gap:6px;border:1px solid var(--border-light);border-radius:999px;padding:2px 8px;font-size:9px;line-height:1.4;font-family:var(--mono);color:var(--text-muted);text-transform:uppercase;letter-spacing:.01em}.audit-chip strong{color:var(--text-dim);font-weight:600}.audit-chip.muted{background:var(--surface-alt)}.audit-chip.id{text-transform:none;letter-spacing:0}.audit-chip.trigger.telegram{background:var(--chip-telegram-bg);color:var(--chip-telegram);border-color:transparent}.audit-chip.trigger.discord{background:var(--chip-discord-bg);color:var(--chip-discord);border-color:transparent}.audit-chip.trigger.cron{background:var(--chip-cron-bg);color:var(--chip-cron);border-color:transparent}.audit-chip.trigger.system,.audit-chip.trigger.gateway,.audit-chip.trigger.dashboard{background:var(--surface-alt);border-color:transparent;color:var(--text-dim)}.audit-chip.status.success{background:var(--success-soft);color:var(--success);border-color:transparent}.audit-chip.status.error{background:var(--error-soft);color:var(--error);border-color:transparent}.audit-chip.status.running{background:var(--warning-soft);color:var(--warning);border-color:transparent}.audit-chip.soft{background:var(--surface-alt);text-transform:none}.audit-duration{font-family:var(--mono);font-size:10px;color:var(--text-muted);white-space:nowrap}.audit-title-line{font-size:14px;line-height:1.35;color:var(--text-dim);margin-bottom:8px}.audit-event-pills{display:flex;gap:6px;flex-wrap:wrap}.audit-load-more-wrap{text-align:center;margin-top:8px}.audit-card-expandable:hover{border-color:var(--border)}.audit-card-head-right{display:flex;align-items:center;gap:6px}.audit-expand-icon{color:var(--text-muted);display:flex;align-items:center}.audit-detail-section{margin-top:10px;border-top:1px solid var(--border-light);padding-top:8px;display:flex;flex-direction:column;gap:0}.audit-event-row{display:grid;grid-template-columns:90px 1fr auto;gap:8px;align-items:baseline;padding:5px 2px;border-bottom:1px solid var(--border-light)}.audit-event-row:last-child{border-bottom:none}.audit-event-type-label{font-family:var(--mono);font-size:10px;color:var(--text-muted);text-transform:uppercase;letter-spacing:.04em;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.audit-event-type-label.tool{color:var(--accent, #7c6af0)}.audit-event-content{font-size:12px;color:var(--text-dim);line-height:1.4;word-break:break-word;overflow:hidden}.audit-event-content.mono{font-family:var(--mono);font-size:11px}.audit-event-dur{font-family:var(--mono);font-size:10px;color:var(--text-muted);white-space:nowrap;text-align:right}.audit-event-detail{display:flex;flex-direction:column;gap:4px}.audit-event-detail-label{font-family:var(--mono);font-size:10px;color:var(--text-muted);text-transform:uppercase;letter-spacing:.04em}.audit-json-block{background:var(--surface-alt);border:1px solid var(--border-light);border-radius:var(--radius-sm);padding:10px 12px;font-family:var(--mono);font-size:11px;line-height:1.6;color:var(--text-dim);white-space:pre;overflow-x:auto;-moz-tab-size:2;tab-size:2}.audit-kv-list{display:flex;flex-direction:column;gap:2px;margin:0;padding:8px 10px;background:var(--surface-alt);border:1px solid var(--border-light);border-radius:var(--radius-sm)}.audit-kv-row{display:grid;grid-template-columns:minmax(80px,28%) 1fr;gap:8px;align-items:baseline;min-height:20px}.audit-kv-row dt,.audit-kv-key{font-family:var(--mono);font-size:11px;font-weight:600;color:var(--text-muted);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.audit-kv-row dd,.audit-kv-val{font-family:var(--mono);font-size:11px;color:var(--text-dim);margin:0;word-break:break-word}.audit-kv-inline{font-family:var(--mono);font-size:11px;color:var(--text-muted);background:transparent;padding:0;white-space:pre-wrap;word-break:break-all}.audit-detail-text{font-family:var(--mono);font-size:11px;line-height:1.6;color:var(--text-dim);padding:8px 12px;background:var(--surface-alt);border:1px solid var(--border-light);border-radius:var(--radius-sm);white-space:pre-wrap;word-break:break-word;display:block}@media (max-width: 900px){.audit-row{grid-template-columns:1fr}.audit-time-col{align-items:flex-start;flex-direction:row;gap:8px}.audit-time-line{display:none}.audit-filter-controls{flex-direction:column;align-items:stretch}.audit-filter-controls>.btn.btn-sm{width:100%}}.coding-page{--coding-accent: #ad5038;--coding-accent-soft: rgba(173, 80, 56, .08)}.coding-page .page-header{margin-bottom:18px}.coding-refresh-pill{display:inline-flex;align-items:center;gap:8px;padding:7px 14px;border:1px solid var(--border-light);border-radius:999px;background:var(--surface-alt);color:var(--text-dim);font-size:13px;font-family:var(--sans);font-weight:500;box-shadow:var(--shadow-sm);line-height:1}.coding-refresh-pill .dot{width:6px;height:6px;border-radius:50%;background:var(--success)}.coding-page .btn{display:inline-flex;align-items:center;gap:6px}.coding-body{display:flex;flex-direction:column;gap:14px}.coding-stats-grid{display:flex;gap:12px;margin-bottom:6px;flex-wrap:wrap}.coding-stat-card{background:var(--surface);border:1px solid var(--border-light);border-radius:var(--radius);padding:14px 20px;display:flex;align-items:center;gap:10px;min-width:140px;flex:1}.coding-stat-icon{width:38px;height:38px;border-radius:var(--radius-sm);display:inline-flex;align-items:center;justify-content:center}.coding-stat-icon svg{width:18px;height:18px}.coding-stat-content{display:flex;flex-direction:column;justify-content:center;gap:0;min-width:0}.coding-stat-icon.running{background:var(--coding-accent-soft);color:var(--coding-accent)}.coding-stat-icon.completed{background:var(--success-soft);color:var(--success)}.coding-stat-icon.failed{background:var(--error-soft);color:var(--error)}.coding-stat-icon.cost{background:var(--warning-soft);color:var(--warning)}.coding-stat-value{font-family:var(--serif);font-size:18px;font-weight:500;line-height:1;color:var(--text)}.coding-stat-label{font-size:10px;color:var(--text-muted);font-weight:400;margin-top:2px;line-height:1.1}.coding-task-card{background:var(--surface);border:1px solid var(--border-light);border-top-width:3px;border-top-color:var(--card-accent, var(--coding-accent));border-radius:var(--radius);padding:0;overflow:hidden;box-shadow:var(--shadow-sm)}.coding-task-main{padding:18px 22px 0;display:grid;grid-template-columns:36px 1fr auto;gap:14px;align-items:start}.coding-task-icon{width:36px;height:36px;border-radius:var(--radius-sm);display:inline-flex;align-items:center;justify-content:center;margin-top:2px}.coding-task-icon.running{background:var(--coding-accent-soft);color:var(--coding-accent)}.coding-task-card.running .coding-task-icon.running{background:var(--card-accent-soft, var(--coding-accent-soft));color:var(--card-accent, var(--coding-accent))}.coding-task-icon.completed{background:var(--success-soft);color:var(--success)}.coding-task-icon.failed{background:var(--error-soft);color:var(--error)}.coding-task-icon.pending{background:var(--pending-soft);color:var(--pending)}.coding-task-content{min-width:0}.coding-task-pills{display:flex;align-items:center;gap:8px;flex-wrap:wrap;margin-bottom:6px}.coding-pill{display:inline-flex;align-items:center;border:1px solid var(--border-light);background:var(--surface-alt);color:var(--text-muted);border-radius:999px;padding:2px 8px;font-size:9px;text-transform:uppercase;letter-spacing:.04em;font-family:var(--sans);font-weight:500}.coding-pill.id{border:none;background:transparent;color:var(--card-accent, var(--coding-accent));padding:0;font-size:12px;letter-spacing:0;text-transform:none;font-family:var(--mono);font-weight:500}.coding-pill.status.running{color:var(--card-accent, var(--coding-accent));background:var(--card-accent-soft, var(--coding-accent-soft));border-color:transparent}.coding-pill.status.completed{color:var(--success);background:var(--success-soft);border-color:transparent}.coding-pill.status.failed{color:var(--error);background:var(--error-soft);border-color:transparent}.coding-pill.status.pending{color:var(--pending)}.coding-task-title{margin-top:0;font-size:13px;color:var(--text);font-weight:400;line-height:1.5}.coding-task-submeta{padding:10px 0 16px;display:flex;align-items:center;gap:14px;flex-wrap:wrap;font-size:11px;color:var(--text-muted);font-family:var(--mono)}.coding-task-submeta span{display:inline-flex;align-items:center;gap:6px}.coding-task-action{align-self:flex-start;border:1px solid transparent;background:transparent;color:var(--text-dim);border-radius:999px;font-size:11px;font-weight:500;padding:6px 14px;display:inline-flex;align-items:center;gap:6px}.coding-task-action.running{color:var(--card-accent, var(--coding-accent));border-color:color-mix(in srgb,var(--card-accent, var(--coding-accent)) 25%,transparent);background:color-mix(in srgb,var(--card-accent, var(--coding-accent)) 8%,transparent)}.coding-task-action.failed{color:var(--error);border-color:#c254504d;background:#c254500a}.coding-task-progress{height:1px;background:var(--border-light)}.coding-task-progress.running{background:linear-gradient(to right,var(--card-accent, var(--coding-accent)) 56%,var(--border-light) 56%)}.coding-task-progress.failed{background:linear-gradient(to right,var(--error) 32%,var(--border-light) 32%)}.coding-task-progress.completed{background:linear-gradient(to right,var(--success) 100%,var(--success) 100%)}.coding-task-progress.pending{background:linear-gradient(to right,var(--pending) 20%,var(--border-light) 20%)}.coding-subagents,.coding-output{border-top:1px solid var(--border-light);padding:8px 22px}.coding-subagents>summary,.coding-output>summary{list-style:none;cursor:pointer;font-size:10px;color:var(--text-muted);text-transform:uppercase;letter-spacing:.04em;font-weight:500;display:inline-flex;align-items:center;gap:6px}.coding-subagents>summary::-webkit-details-marker,.coding-output>summary::-webkit-details-marker{display:none}.coding-subagents-list{margin-top:10px;border-left:2px solid var(--border);padding-left:16px;margin-left:8px}.coding-subagent-row{margin-top:8px;border:1px solid var(--border-light);background:var(--surface-alt);border-radius:var(--radius-sm);padding:12px 14px;display:grid;grid-template-columns:40px auto auto auto 1fr auto;gap:8px;align-items:center}.coding-subagent-icon{width:24px;height:24px;border-radius:6px;display:inline-flex;align-items:center;justify-content:center}.coding-subagent-icon.running{background:var(--card-accent-soft, var(--coding-accent-soft));color:var(--card-accent, var(--coding-accent))}.coding-subagent-icon.completed{background:var(--success-soft);color:var(--success)}.coding-subagent-icon.failed{background:var(--error-soft);color:var(--error)}.coding-subagent-icon.pending{background:var(--pending-soft);color:var(--pending)}.coding-subagent-task{font-size:12px;color:var(--text-dim);line-height:1.45;font-weight:400}.coding-subagent-time{font-size:11px;color:var(--text-muted);font-family:var(--mono)}.ca-status-badge{display:inline-flex;align-items:center;padding:3px 10px;border-radius:999px;font-size:11px;font-weight:700;letter-spacing:.05em;text-transform:uppercase}.ca-status-badge.running{background:var(--accent-soft);color:var(--accent)}.ca-status-badge.validating{background:var(--warning-soft);color:var(--warning)}.ca-status-badge.completed{background:var(--success-soft);color:var(--success)}.ca-status-badge.failed,.ca-status-badge.timeout,.ca-status-badge.cancelled{background:var(--error-soft);color:var(--error)}.tree-container{display:flex;flex-direction:column;gap:8px}.ca-tree{margin-bottom:12px}.ca-tree-children{margin:8px 0 0 18px;padding-left:14px;border-left:2px solid var(--border-light)}.ca-tree-child{background:var(--surface-alt);border:1px solid var(--border);border-radius:var(--radius-sm);padding:10px 12px;margin-bottom:8px}.ca-output{background:var(--surface);border:1px solid var(--border-light);border-radius:var(--radius-sm);padding:10px 12px;font-size:12px;line-height:1.6;max-height:260px;overflow-y:auto;margin-top:8px}.ca-output.markdown-content{font-family:var(--sans)}.ca-output.markdown-content code,.ca-output.markdown-content pre{font-family:var(--mono)}.ca-error{background:var(--error-soft);border-color:#c2545033;color:var(--error)}.usage-stats-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:18px;margin-bottom:28px}.usage-table{width:100%;border-collapse:collapse;font-size:13px}.usage-table th{background:var(--surface-alt);font-weight:600;font-size:11px;text-transform:uppercase;letter-spacing:.04em;color:var(--text-muted);padding:10px 14px;text-align:left;border-bottom:1px solid var(--border-light)}.usage-table td{padding:10px 14px;border-bottom:1px solid var(--border-light);color:var(--text-dim);font-family:var(--mono);font-size:12px}.usage-table tr:last-child td{border-bottom:none}.usage-table tr:hover td{background:var(--surface-alt)}.usage-cost-cell{font-weight:600;color:var(--text)}.usage-model-pill{font-family:var(--mono);font-size:11px;background:var(--surface-alt);border:1px solid var(--border-light);border-radius:4px;padding:2px 6px;color:var(--text)}.digest-header{margin-bottom:14px}.digest-title{font-family:var(--serif);font-size:24px;font-weight:700;line-height:1.2}.digest-meta{font-size:12px;color:var(--text-muted);font-family:var(--mono);margin-top:4px}.digest-reader{background:var(--surface);border:1px solid var(--border-light);border-radius:var(--radius);padding:16px 18px;word-break:break-word;line-height:1.65;font-size:14px;color:var(--text-dim)}.digest-articles{padding:6px 0}.digest-article-card{padding:12px 0;border-bottom:1px solid var(--border-light)}.digest-article-card:last-child{border-bottom:none}.digest-article-card .source-badge{font-size:11px;color:var(--accent);font-weight:600;text-transform:uppercase;letter-spacing:.04em}.digest-article-card .article-title{display:inline-block;font-size:15px;font-weight:600;color:var(--text);margin-top:4px;text-decoration:none}.digest-article-card .article-title:hover{color:var(--accent);text-decoration:underline}.digest-article-card .article-stats{font-size:12px;color:var(--text-muted);margin-top:5px}.skills-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:14px}.skill-card{background:var(--surface);border:1px solid var(--border-light);border-radius:var(--radius);padding:18px 20px;box-shadow:var(--shadow-sm)}.skill-header{display:flex;justify-content:space-between;align-items:center;gap:10px;margin-bottom:8px}.skill-name{font-weight:600;font-size:15px}.skill-desc{font-size:13px;color:var(--text-dim);line-height:1.5;margin-bottom:10px}.skill-tags{display:flex;gap:6px;flex-wrap:wrap;margin-bottom:10px}.skill-tag{font-size:11px;font-family:var(--mono);padding:2px 8px;border-radius:999px;background:var(--surface-alt);color:var(--text-muted);border:1px solid var(--border-light)}.markdown-content{line-height:1.65;color:var(--text-dim)}.markdown-content h1,.markdown-content h2,.markdown-content h3,.markdown-content h4,.markdown-content h5,.markdown-content h6{font-family:var(--serif);color:var(--text);font-weight:800;margin:16px 0 10px;line-height:1.3}.markdown-content h1:first-child,.markdown-content h2:first-child,.markdown-content h3:first-child,.markdown-content h4:first-child,.markdown-content h5:first-child,.markdown-content h6:first-child{margin-top:0}.markdown-content h1{font-size:22px}.markdown-content h2{font-size:19px}.markdown-content h3{font-size:17px}.markdown-content h4{font-size:15px}.markdown-content h5{font-size:14px}.markdown-content h6{font-size:13px}.markdown-content p{margin:0 0 10px}.markdown-content p:last-child{margin-bottom:0}.markdown-content ul,.markdown-content ol{padding-left:20px;margin:0 0 10px}.markdown-content li{margin-bottom:4px}.markdown-content a{color:var(--accent);text-decoration:none}.markdown-content a:hover{text-decoration:underline}.markdown-content code{font-family:var(--mono);background:var(--surface-alt);padding:2px 6px;border-radius:4px;font-size:12px;color:var(--text)}.markdown-content pre{margin:0 0 12px;background:var(--surface-alt);border:1px solid var(--border-light);border-radius:var(--radius-sm);padding:12px;overflow:auto}.markdown-content pre code{background:transparent;padding:0;font-size:12px}.markdown-content blockquote{border-left:3px solid var(--accent);padding-left:12px;margin:0 0 12px;color:var(--text-muted);font-style:italic}.markdown-content table{width:100%;border-collapse:collapse;margin:0 0 12px;font-size:13px}.markdown-content th,.markdown-content td{border:1px solid var(--border-light);padding:8px 10px;text-align:left}.markdown-content th{background:var(--surface-alt);font-weight:600;color:var(--text)}.markdown-content td{color:var(--text-dim)}.markdown-content hr{border:none;border-top:1px solid var(--border-light);margin:16px 0}.markdown-content strong,.markdown-content b{font-weight:600;color:var(--text)}.markdown-content em,.markdown-content i{font-style:italic}.templates-page{display:flex;flex-direction:column;gap:0}.templates-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:28px;position:relative;z-index:1;padding-right:72px}.templates-loading{display:flex;justify-content:center;align-items:center;padding:64px}.templates-layout{display:grid;grid-template-columns:280px 1fr;gap:24px;align-items:stretch;min-height:600px}.templates-sidebar{background:var(--surface);border:1px solid var(--border-light);border-radius:var(--radius);box-shadow:var(--shadow-sm);display:flex;flex-direction:column;height:100%}.templates-sidebar-header{padding:20px 20px 16px;border-bottom:1px solid var(--border-light)}.templates-sidebar-label{font-size:11px;font-weight:700;letter-spacing:.06em;color:var(--text-muted);text-transform:uppercase;margin-bottom:10px}.templates-agent-select{width:100%;padding:8px 12px;border:1px solid var(--border);border-radius:var(--radius-sm);background:var(--surface-alt);color:var(--text-dim);font-family:var(--sans);font-size:13px;font-weight:500;cursor:pointer;outline:none}.templates-agent-select:disabled{opacity:.6;cursor:not-allowed}.templates-list{display:flex;flex-direction:column;flex:1;overflow-y:auto}.templates-list-item{display:flex;align-items:center;gap:12px;padding:14px 20px;border:none;border-bottom:1px solid var(--border-light);background:transparent;cursor:pointer;transition:background .15s ease;text-align:left;width:100%;position:relative}.templates-list-item:last-child{border-bottom:none}.templates-list-item:hover{background:var(--surface-alt)}.templates-list-item.active{background:var(--accent-soft-2)}.templates-list-item.active:before{content:"";position:absolute;left:0;top:0;bottom:0;width:3px;background:var(--accent)}.templates-list-icon{width:32px;height:32px;border-radius:var(--radius-sm);background:var(--surface-alt);display:flex;align-items:center;justify-content:center;color:var(--text-dim);flex-shrink:0;font-family:var(--mono);font-size:12px;font-weight:600;letter-spacing:.02em}.templates-list-item.active .templates-list-icon{background:var(--accent-soft);color:var(--accent)}.templates-list-content{flex:1;min-width:0}.templates-list-title{font-size:13px;font-weight:500;color:var(--text);margin-bottom:2px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.templates-list-item.active .templates-list-title{color:var(--accent);font-weight:600}.templates-list-meta{font-size:11px;font-family:var(--mono);color:var(--text-muted)}.templates-main{background:var(--surface);border:1px solid var(--border-light);border-radius:var(--radius);box-shadow:var(--shadow-sm);display:flex;flex-direction:column;height:100%}.templates-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:80px 32px;color:var(--text-muted);gap:12px}.templates-empty p{font-size:14px;margin:0}.templates-editor-header{display:flex;justify-content:space-between;align-items:center;padding:20px 28px;border-bottom:1px solid var(--border-light);gap:16px}.templates-editor-title-row{display:flex;align-items:center;gap:12px;flex:1;min-width:0}.templates-editor-title{font-family:var(--serif);font-size:20px;font-weight:700;color:var(--text);margin:0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.templates-unsaved-pill{display:inline-flex;align-items:center;padding:4px 12px;border-radius:999px;background:var(--warning-soft);color:var(--warning);font-size:11px;font-weight:600;letter-spacing:.02em;white-space:nowrap}.templates-editor-actions{display:flex;gap:10px;align-items:center}.templates-discard-btn{padding:8px 16px;border:none;border-radius:var(--radius-sm);background:transparent;color:var(--text-dim);font-family:var(--sans);font-weight:500;font-size:13px;cursor:pointer;transition:all .15s ease}.templates-discard-btn:hover{color:var(--text);background:var(--surface-alt)}.templates-save-btn{padding:8px 20px;border:none;border-radius:var(--radius-sm);background:var(--accent);color:#fff;font-family:var(--sans);font-weight:600;font-size:13px;cursor:pointer;transition:all .15s ease}.templates-save-btn:hover{background:var(--accent-hover)}.templates-save-btn:disabled{opacity:.5;cursor:not-allowed}.templates-tabs{display:flex;gap:0;padding:0 28px;border-bottom:1px solid var(--border-light)}.templates-tab{padding:12px 20px;border:none;background:transparent;color:var(--text-muted);font-family:var(--sans);font-weight:500;font-size:13px;cursor:pointer;position:relative;transition:color .15s ease}.templates-tab:hover{color:var(--text-dim)}.templates-tab.active{color:var(--accent)}.templates-tab.active:after{content:"";position:absolute;left:0;right:0;bottom:-1px;height:2px;background:var(--accent)}.templates-metadata{display:grid;grid-template-columns:auto auto auto 1fr;gap:24px;padding:16px 28px;border-bottom:1px solid var(--border-light);background:var(--surface-alt)}.templates-metadata-item{display:flex;flex-direction:column;gap:4px}.templates-metadata-label{font-size:10px;font-weight:700;letter-spacing:.06em;color:var(--text-muted);text-transform:uppercase}.templates-metadata-value{font-size:12px;font-family:var(--mono);color:var(--text-dim);font-weight:500}.templates-metadata-path{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.templates-content{flex:1;display:flex;flex-direction:column;overflow:hidden}.templates-textarea{flex:1;width:100%;min-height:500px;padding:24px 28px;border:none;background:var(--surface);color:var(--text);font-family:var(--mono);font-size:13px;line-height:1.65;resize:none;outline:none}.templates-markdown-preview{flex:1;padding:28px 32px;overflow-y:auto}.templates-markdown-preview .markdown-view{max-width:800px;margin:0 auto}.templates-markdown-preview .markdown-view h1,.templates-markdown-preview .markdown-view h2,.templates-markdown-preview .markdown-view h3,.templates-markdown-preview .markdown-view h4,.templates-markdown-preview .markdown-view h5,.templates-markdown-preview .markdown-view h6{font-family:var(--serif);color:var(--text);font-weight:800;margin:16px 0 8px;line-height:1.3}.templates-markdown-preview .markdown-view h1:first-child,.templates-markdown-preview .markdown-view h2:first-child,.templates-markdown-preview .markdown-view h3:first-child{margin-top:0}.templates-markdown-preview .markdown-view h1{font-size:28px;padding-bottom:8px;border-bottom:1px solid var(--border-light)}.templates-markdown-preview .markdown-view h2{font-size:22px}.templates-markdown-preview .markdown-view h3{font-size:18px}.templates-markdown-preview .markdown-view p{margin:0 0 8px;line-height:1.58}.templates-markdown-preview .markdown-view blockquote{border-left:4px solid var(--accent);padding-left:16px;margin:10px 0;color:var(--text-dim);font-style:italic}.templates-markdown-preview .markdown-view hr{border:none;border-top:1px solid var(--border-light);margin:18px 0}.templates-markdown-preview .markdown-view code{font-family:var(--mono);background:var(--surface-alt);padding:2px 6px;border-radius:4px;font-size:12px;color:var(--text)}.templates-markdown-preview .markdown-view pre{background:var(--surface-alt);border:1px solid var(--border-light);border-radius:var(--radius-sm);padding:12px;margin:10px 0;overflow-x:auto}.templates-markdown-preview .markdown-view pre code{background:transparent;padding:0}[data-theme=dark] .split-list,[data-theme=dark] .split-detail,[data-theme=dark] .templates-list,[data-theme=dark] .templates-markdown-preview,[data-theme=dark] .ca-output{scrollbar-width:thin;scrollbar-color:rgba(255,255,255,.12) transparent}[data-theme=dark] .split-list::-webkit-scrollbar,[data-theme=dark] .split-detail::-webkit-scrollbar,[data-theme=dark] .templates-list::-webkit-scrollbar,[data-theme=dark] .templates-markdown-preview::-webkit-scrollbar,[data-theme=dark] .ca-output::-webkit-scrollbar{width:6px}[data-theme=dark] .split-list::-webkit-scrollbar-thumb,[data-theme=dark] .split-detail::-webkit-scrollbar-thumb,[data-theme=dark] .templates-list::-webkit-scrollbar-thumb,[data-theme=dark] .templates-markdown-preview::-webkit-scrollbar-thumb,[data-theme=dark] .ca-output::-webkit-scrollbar-thumb{background:#ffffff1f;border-radius:3px}[data-theme=dark] .split-list::-webkit-scrollbar-track,[data-theme=dark] .split-detail::-webkit-scrollbar-track,[data-theme=dark] .templates-list::-webkit-scrollbar-track,[data-theme=dark] .templates-markdown-preview::-webkit-scrollbar-track,[data-theme=dark] .ca-output::-webkit-scrollbar-track{background:transparent}@media (max-width: 980px){.shell{grid-template-columns:1fr}.shell.shell-narrow .sidebar{position:fixed;top:0;left:0;height:100vh;width:min(86vw,320px);border-right:1px solid var(--border-light);box-shadow:var(--shadow-md);transform:translate(-104%);transition:transform .2s ease;z-index:210}.shell.shell-narrow.sidebar-open .sidebar{transform:translate(0)}.global-sidebar-toggle{position:fixed;top:20px;left:16px;width:37px;height:37px;border:1px solid var(--border);background:var(--surface);border-radius:var(--radius-sm);cursor:pointer;display:inline-flex;align-items:center;justify-content:center;transition:all .15s ease;box-shadow:var(--shadow-sm);color:var(--text);z-index:220}.global-sidebar-toggle:hover{background:var(--surface-hover);box-shadow:var(--shadow)}.sidebar-backdrop{display:block;position:fixed;top:0;right:0;bottom:0;left:0;border:none;padding:0;background:#00000042;z-index:205}.main{padding:20px 16px}.page-header{padding-left:56px;min-height:40px}.global-theme-toggle{top:20px;right:16px;z-index:220}.page-header .header-actions{margin-right:62px;flex-wrap:wrap}.split{grid-template-columns:1fr;height:auto}.split-list{max-height:280px}.stats-grid,.stats-grid-5,.usage-stats-grid{grid-template-columns:1fr 1fr}.stat-card{min-height:116px;padding:18px;gap:12px}.stat-icon{width:44px;height:44px}.stat-icon svg{width:18px;height:18px}.stat-value{font-size:24px}.stat-value-md{font-size:18px}.stat-subtitle{font-size:10px}.coding-stats-grid{grid-template-columns:1fr 1fr}.coding-tl-row{grid-template-columns:56px 1fr 46px}.coding-subagent-row,.cron-grid{grid-template-columns:1fr}.templates-layout{grid-template-columns:1fr;gap:16px}.templates-sidebar{max-height:280px;overflow-y:auto}.templates-metadata{grid-template-columns:1fr 1fr;gap:16px}.templates-editor-header{flex-direction:column;align-items:stretch}.templates-editor-title-row{flex-direction:column;align-items:flex-start;gap:8px}.templates-editor-actions{width:100%;justify-content:flex-end}}
|
|
1
|
+
@import"https://fonts.googleapis.com/css2?family=Playfair+Display:wght@500;600;700;800&family=Noto+Sans:wght@400;500;600&display=swap";.sidebar{background:var(--bg-sidebar);display:flex;flex-direction:column;position:sticky;top:0;height:100vh;z-index:10;transition:background .3s ease;overflow-y:auto}.sidebar-header{padding:28px 24px 20px;display:flex;align-items:center;gap:12px}.sidebar-logo{width:40px;height:40px;background:transparent;border-radius:0;display:flex;align-items:center;justify-content:center;font-size:20px;box-shadow:none;flex-shrink:0}.sidebar-brand{display:flex;flex-direction:column}.sidebar-close-btn{display:none;margin-left:auto;width:30px;height:30px;border:1px solid var(--border);border-radius:var(--radius-sm);background:var(--surface);color:var(--text-dim);align-items:center;justify-content:center;cursor:pointer}.sidebar-close-btn:hover{background:var(--surface-hover);color:var(--text)}.sidebar-brand-name{font-family:var(--serif);font-size:17px;font-weight:800;color:var(--text);letter-spacing:-.01em}.sidebar-brand-status{font-size:11px;color:var(--success);display:flex;align-items:center;gap:5px;font-weight:500}.sidebar-brand-status:before{content:"";width:6px;height:6px;border-radius:50%;background:var(--success);display:inline-block}.sidebar-section{padding:0 12px;margin-bottom:8px}.sidebar-section-label{font-size:11px;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.06em;padding:16px 12px 8px}.sidebar-item{display:flex;align-items:center;gap:12px;padding:10px 12px;border-radius:var(--radius-sm);cursor:pointer;color:var(--text-dim);font-size:14px;font-weight:500;transition:all .15s ease;border:none;background:transparent;width:100%;text-align:left;font-family:var(--sans);position:relative}.sidebar-item:hover{background:var(--sidebar-hover);color:var(--text)}.sidebar-item.active{background:var(--sidebar-active);color:var(--text-dim);font-weight:600;box-shadow:var(--shadow-sm)}.sidebar-item.active:before{content:"";position:absolute;left:0;top:8px;bottom:8px;width:3px;border-radius:0 3px 3px 0;background:var(--accent)}.sidebar-item svg{width:20px;height:20px;flex-shrink:0;opacity:.6}.sidebar-item.active svg{opacity:1}.sidebar-item:hover svg{opacity:.85}.sidebar-item-icon{display:inline-flex;align-items:center;justify-content:center;line-height:0}.sidebar-item.active .sidebar-item-icon{color:var(--accent)}.sidebar-item-label{display:inline-flex;align-items:center;line-height:1.2}.sidebar-item .item-badge{margin-left:auto;font-size:11px;font-weight:600;padding:2px 8px;border-radius:999px;background:var(--warning-soft);color:var(--warning)}.sidebar-spacer{flex:1}.sidebar-footer{padding:16px 12px;border-top:1px solid var(--border-light)}.sidebar-footer-item{display:flex;align-items:center;gap:12px;padding:10px 12px;border-radius:var(--radius-sm);cursor:pointer;color:var(--text-muted);font-size:13px;font-weight:500;transition:all .15s ease;border:none;background:transparent;width:100%;text-align:left;font-family:var(--sans)}.sidebar-footer-item:hover{background:var(--sidebar-hover);color:var(--text-dim)}.sidebar-footer-item.active{background:var(--sidebar-active);color:var(--text-dim);font-weight:600}.sidebar-footer-item svg{width:18px;height:18px;flex-shrink:0;opacity:.5}.sidebar-footer-item.active .sidebar-item-icon{color:var(--accent)}@media (max-width: 980px){.sidebar-close-btn{display:inline-flex}}:root,:root[data-theme=light],[data-theme=light]{--text: #0c0303;--background: #fffaf5;--text-dim: #5a4a40;--text-muted: #9a8a80;--bg: var(--background);--bg-sidebar: var(--background);--surface: #ffffff;--surface-alt: #f5ebe5;--surface-hover: #ebe0d8;--primary: #d33b36;--primary-hover: #c65a24;--primary-soft: rgba(219, 111, 57, .16);--primary-soft-2: rgba(219, 111, 57, .08);--secondary: #f2ded2;--secondary-soft: rgba(242, 222, 210, .22);--accent: #dfaa6d;--accent-hover: #e07030;--accent-soft: rgba(243, 134, 70, .16);--accent-soft-2: rgba(243, 134, 70, .08);--success: #5a9b5a;--success-soft: rgba(90, 155, 90, .16);--warning: #c9a43c;--warning-soft: rgba(201, 164, 60, .12);--error: #d94a4a;--error-soft: rgba(217, 74, 74, .12);--border: rgba(23, 16, 11, .08);--border-light: rgba(23, 16, 11, .05);--shadow-sm: 0 1px 2px rgba(23, 16, 11, .04);--shadow: 0 2px 8px rgba(23, 16, 11, .06);--shadow-md: 0 4px 16px rgba(23, 16, 11, .08);--sidebar-active: #ffffff;--sidebar-hover: rgba(23, 16, 11, .04);--welcome-from: #db6f39;--welcome-to: #f38646;--welcome-shadow: rgba(219, 111, 57, .3);--welcome-text: #ffffff;--log-info: #5a4a40;--log-warn: #b08a1a;--log-error: #d94a4a;--highlight: #f38646;--info: #7bb8f9;--info-soft: rgba(123, 184, 249, .12);--chip-telegram: #4a7a99;--chip-telegram-bg: rgba(109, 166, 214, .13);--chip-discord: #5a5a99;--chip-discord-bg: rgba(130, 146, 235, .14);--chip-cron: #9a7f3e;--chip-cron-bg: rgba(203, 169, 93, .14);--pending: #7a8a91;--pending-soft: rgba(142, 154, 166, .1);--mono: "JetBrains Mono", "SF Mono", "Fira Code", monospace;--sans: "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;--serif: "Playfair Display", Georgia, "Times New Roman", serif;--radius: 16px;--radius-md: 12px;--radius-sm: 8px;--sidebar-width: 260px}:root[data-theme=dark],[data-theme=dark]{--text: #fcf3f3;--background: #121212;--text-dim: #d4ccc6;--text-muted: #948c86;--bg: var(--background);--bg-sidebar: var(--background);--surface: #1a120c;--surface-alt: #251c14;--surface-hover: #30261c;--primary: #c9312c;--primary-hover: #db6f39;--primary-soft: rgba(198, 90, 36, .2);--primary-soft-2: rgba(198, 90, 36, .1);--secondary: #f2ded2;--secondary-soft: rgba(242, 222, 210, .22);--accent: #dfaa6d;--accent-hover: #d65a1a;--accent-soft: rgba(187, 76, 12, .2);--accent-soft-2: rgba(187, 76, 12, .1);--success: #5ab85a;--success-soft: rgba(90, 184, 90, .18);--warning: #d4b45a;--warning-soft: rgba(212, 180, 90, .14);--error: #e07a6a;--error-soft: rgba(224, 122, 106, .14);--border: rgba(243, 236, 231, .08);--border-light: rgba(243, 236, 231, .05);--shadow-sm: 0 1px 2px rgba(0, 0, 0, .3);--shadow: 0 2px 8px rgba(0, 0, 0, .35);--shadow-md: 0 4px 16px rgba(0, 0, 0, .4);--sidebar-active: rgba(198, 90, 36, .2);--sidebar-hover: rgba(243, 236, 231, .04);--welcome-from: #c65a24;--welcome-to: #e07a40;--welcome-shadow: rgba(198, 90, 36, .4);--welcome-text: #f3ece7;--log-info: #d4ccc6;--log-warn: #d4b45a;--log-error: #e07a6a;--highlight: #bb4c0c;--info: #7ab8f9;--info-soft: rgba(122, 184, 249, .14);--chip-telegram: #8eb8e0;--chip-telegram-bg: rgba(126, 184, 224, .16);--chip-discord: #9e9eed;--chip-discord-bg: rgba(158, 158, 237, .16);--chip-cron: #d4b45a;--chip-cron-bg: rgba(212, 180, 90, .16);--pending: #9ba5b0;--pending-soft: rgba(155, 165, 176, .14)}*{margin:0;padding:0;box-sizing:border-box}html{font-size:100%}body{font-family:"Noto Sans",var(--sans);font-weight:400;background:var(--bg);color:var(--text);min-height:100vh;font-size:14px;line-height:1.55;transition:background .3s ease,color .3s ease;-webkit-font-smoothing:antialiased}h1,h2,h3,h4,h5{font-family:var(--serif);font-weight:700}h1{font-size:4.21rem}h2{font-size:3.158rem}h3{font-size:2.369rem}h4{font-size:1.777rem}h5{font-size:1.333rem}small{font-size:.75rem}a{color:var(--accent);text-decoration:none}a:hover{text-decoration:underline}.shell{display:grid;grid-template-columns:var(--sidebar-width) 1fr;min-height:100vh}.main{position:relative;overflow-y:auto;padding:32px 36px}.btn{padding:8px 16px;border:1px solid var(--border);border-radius:var(--radius-sm);background:var(--surface);color:var(--text);font-family:var(--sans);font-weight:500;font-size:13px;cursor:pointer;transition:all .12s ease}.btn:hover{background:var(--surface-hover)}.btn-primary{background:var(--accent);border-color:var(--accent);color:#fff}.btn-primary:hover{background:var(--accent-hover)}.btn-success{background:var(--success);border-color:var(--success);color:#fff}.btn-success:hover{opacity:.9}.btn-danger{background:var(--error-soft);border-color:#ef444433;color:var(--error)}.btn-danger:hover{background:#ef44441f}.btn-sm,.btn-small{padding:5px 12px;font-size:12px}.btn-refresh{display:inline-flex;align-items:center;gap:6px;padding:7px 14px;border:1px solid var(--border-light);border-radius:999px;background:var(--surface-alt);color:var(--text-dim);font-family:var(--sans);font-weight:500;font-size:13px;cursor:pointer;transition:all .15s ease;box-shadow:var(--shadow-sm)}.btn-refresh:hover{background:var(--surface-hover);border-color:var(--border);color:var(--text);box-shadow:var(--shadow)}.btn-refresh:focus-visible{outline:2px solid var(--accent);outline-offset:2px}.btn-refresh:active{transform:scale(.98)}input:not([type=checkbox]):not([type=radio]),select,textarea{width:100%;padding:10px 12px;border:1px solid var(--border);border-radius:var(--radius-sm);background:var(--surface-alt);color:var(--text);font-family:var(--sans);font-size:13px;line-height:1.5;outline:none;transition:border-color .12s ease,box-shadow .12s ease,background .12s ease}textarea{resize:vertical;min-height:90px}input:not([type=checkbox]):not([type=radio]):focus,select:focus,textarea:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-soft);background:var(--surface)}input::placeholder,textarea::placeholder{color:var(--text-muted)}.form-grid{display:grid;gap:10px}.form-grid.two{grid-template-columns:1fr 1fr}.form-grid.three{grid-template-columns:repeat(3,minmax(0,1fr))}.form-field{display:flex;flex-direction:column;gap:6px}.form-label{font-size:12px;color:var(--text-dim);font-weight:600;letter-spacing:.01em}.form-help{font-size:11px;color:var(--text-muted)}.form-actions{display:flex;gap:8px;align-items:center;margin-top:12px}.form-checkbox{display:flex;align-items:center;gap:10px;font-size:13px;line-height:1.35;color:var(--text-dim);cursor:pointer;-webkit-user-select:none;user-select:none}.form-checkbox input[type=checkbox]{-moz-appearance:none;appearance:none;-webkit-appearance:none;width:18px;height:18px;flex:0 0 18px;border:1px solid var(--border);border-radius:5px;background:var(--surface);display:inline-grid;place-content:center;margin:0;cursor:pointer;transition:border-color .12s ease,box-shadow .12s ease,background .12s ease}.form-checkbox input[type=checkbox]:before{content:"";width:10px;height:10px;transform:scale(0);transition:transform .1s ease-in-out;background:#fff;clip-path:polygon(14% 44%,0 63%,44% 100%,100% 18%,82% 0,40% 64%)}.form-checkbox input[type=checkbox]:checked{border-color:var(--accent);background:var(--accent)}.form-checkbox input[type=checkbox]:checked:before{transform:scale(1)}.form-checkbox input[type=checkbox]:focus-visible{outline:none;box-shadow:0 0 0 3px var(--accent-soft)}.form-check-row{display:flex;gap:20px;align-items:center;flex-wrap:wrap}.form-check-row.tight{gap:12px}.form-check-col{display:flex;flex-direction:column;gap:6px}.form-divider{height:1px;background:var(--border-light);margin:12px 0}.toast-container{position:fixed;bottom:24px;right:24px;z-index:1000;display:flex;flex-direction:column;gap:8px}.toast{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-sm);padding:12px 18px;font-size:13px;box-shadow:var(--shadow-md);animation:toast-in .2s ease}.toast.success{border-left:3px solid var(--success)}.toast.error{border-left:3px solid var(--error)}.toast.warning{border-left:3px solid var(--warning)}@keyframes toast-in{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.section{margin-bottom:28px}.section-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px}.section-title{font-family:var(--serif);font-size:18px;font-weight:800;color:var(--text);letter-spacing:-.01em}.section-link{font-size:13px;color:var(--accent);cursor:pointer;text-decoration:none;font-weight:500}.section-link:hover{text-decoration:underline}.section-link-content{display:inline-flex;align-items:center;gap:6px}.page-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:28px}.page-title{font-family:var(--serif);font-size:26px;font-weight:800;letter-spacing:-.02em;color:var(--text)}.header-actions{display:flex;gap:10px;align-items:center;flex-wrap:nowrap}.page-header .header-actions{margin-right:72px}.header-meta{font-size:12px;color:var(--text-muted);font-family:var(--mono)}.theme-toggle{width:36px;height:36px;border:1px solid var(--border);background:var(--surface);border-radius:var(--radius-sm);cursor:pointer;font-size:16px;display:flex;align-items:center;justify-content:center;transition:all .15s ease;color:var(--text)}.theme-toggle:hover{background:var(--surface-hover)}.global-theme-toggle{position:absolute;top:32px;right:36px;width:37px;height:37px;border:1px solid var(--border);background:var(--surface);border-radius:var(--radius-sm);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .15s ease;box-shadow:var(--shadow-sm);color:var(--text);z-index:100}.global-theme-toggle:hover{background:var(--surface-hover);box-shadow:var(--shadow)}.global-sidebar-toggle,.sidebar-backdrop{display:none}.stats-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:18px;margin-bottom:10px}.cards-link-row{display:flex;justify-content:flex-end;margin-bottom:22px}.stat-card{background:var(--surface);border-radius:var(--radius);padding:22px 24px;box-shadow:var(--shadow-sm);transition:all .2s ease;border:1px solid var(--border-light);display:flex;align-items:center;gap:16px;min-height:138px}.stat-card:hover{box-shadow:var(--shadow);transform:translateY(-1px)}.stat-icon{width:48px;height:48px;border-radius:var(--radius-sm);display:flex;align-items:center;justify-content:center;font-size:18px;flex:0 0 auto}.stat-icon svg{width:20px;height:20px}.stat-icon.sage{background:var(--accent-soft);color:var(--accent)}.stat-icon.green{background:var(--success-soft);color:var(--success)}.stat-icon.amber{background:var(--warning-soft);color:var(--warning)}.stat-icon.blue{background:var(--info-soft);color:var(--info)}.stat-icon.rose{background:#f43f5e14;color:#f43f5e}.stats-grid-5{grid-template-columns:repeat(5,1fr)}.stats-grid-5 .stat-card{min-height:120px;padding:18px 20px;gap:12px}.stats-grid-5 .stat-icon{width:42px;height:42px}.stats-grid-5 .stat-icon svg{width:18px;height:18px}.stats-grid-5 .stat-value{font-size:26px}.stats-grid-5 .stat-value-md{font-size:18px}.stat-body{display:flex;flex-direction:column;justify-content:center;min-width:0}.stat-value{font-family:var(--serif);font-size:32px;font-weight:700;line-height:1.02;letter-spacing:-.02em}.stat-value-md{font-size:22px}.stat-subtitle{font-size:11px;color:var(--text-dim);font-weight:500;line-height:1.2}.feed-card{background:var(--surface);border-radius:var(--radius);box-shadow:var(--shadow-sm);border:1px solid var(--border-light);overflow:hidden}.feed{display:flex;flex-direction:column}.feed-item{display:grid;grid-template-columns:40px 1fr auto;gap:14px;align-items:start;padding:16px 20px;transition:background .12s ease;border-bottom:1px solid var(--border-light)}.feed-item:last-child{border-bottom:none}.feed-item:hover{background:var(--surface-alt)}.feed-icon{width:40px;height:40px;border-radius:var(--radius-sm);display:flex;align-items:center;justify-content:center;font-size:16px;flex-shrink:0}.feed-icon.telegram{background:var(--accent-soft);color:var(--accent)}.feed-icon.cron{background:var(--warning-soft);color:var(--warning)}.feed-icon.system{background:var(--surface-alt);color:var(--text-muted)}.feed-icon.code{background:var(--accent-soft);color:var(--accent)}.feed-title{font-weight:600;font-size:14px;margin-bottom:3px}.feed-detail{font-size:13px;color:var(--text-dim);line-height:1.45}.feed-time{font-size:11px;color:var(--text-muted);font-family:var(--mono);white-space:nowrap;padding-top:2px}.cron-grid{display:grid;grid-template-columns:1fr 1fr;gap:14px}.cron-card{background:var(--surface);border:1px solid var(--border-light);border-radius:var(--radius);padding:20px 22px;display:flex;justify-content:space-between;align-items:center;box-shadow:var(--shadow-sm);transition:all .15s ease}.cron-card:hover{box-shadow:var(--shadow);transform:translateY(-1px)}.cron-info{flex:1}.cron-name{font-weight:600;font-size:14px;margin-bottom:4px;color:var(--text)}.cron-schedule{font-size:12px;color:var(--text-dim);font-family:var(--mono)}.cron-next{font-size:12px;color:var(--success);font-family:var(--mono);text-align:right;font-weight:500}.welcome-banner{background:linear-gradient(135deg,var(--welcome-from),var(--welcome-to));border-radius:var(--radius);padding:28px 32px;margin-bottom:28px;color:var(--welcome-text);position:relative;overflow:hidden}.welcome-banner:after{content:"";position:absolute;right:-20px;top:-20px;width:200px;height:200px;border-radius:50%;background:#ffffff14}.welcome-banner:before{content:"";position:absolute;right:80px;bottom:-40px;width:120px;height:120px;border-radius:50%;background:#ffffff0d}.welcome-greeting{font-family:var(--serif);font-size:24px;font-weight:800;margin-bottom:6px;letter-spacing:-.01em;position:relative;z-index:1}.welcome-sub{font-size:14px;opacity:.85;font-weight:400;position:relative;z-index:1}.approval-banner{background:var(--warning-soft);border:1px solid rgba(245,158,11,.15);border-radius:var(--radius);padding:18px 22px;margin-bottom:24px;display:flex;align-items:center;gap:16px}.approval-banner-icon{font-size:22px;flex-shrink:0}.approval-banner-content{flex:1}.approval-banner-title{font-weight:600;font-size:14px;margin-bottom:3px}.approval-banner-detail{font-size:13px;color:var(--text-dim);font-family:var(--mono)}.approval-banner-actions{display:flex;gap:8px}.approval-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:18px 24px;margin-bottom:10px;display:flex;align-items:center;gap:16px;box-shadow:var(--shadow-sm)}.approval-card-icon{width:44px;height:44px;border-radius:var(--radius-sm);background:var(--warning-soft);color:var(--warning);display:flex;align-items:center;justify-content:center;flex-shrink:0}.approval-card-content{flex:1;min-width:0}.approval-card-title{font-weight:700;font-size:15px;color:var(--text);margin-bottom:4px}.approval-card-detail{font-size:13px;color:var(--text-dim);display:flex;align-items:center;gap:6px;flex-wrap:wrap}.approval-cmd{font-family:var(--mono);font-size:12px;background:var(--surface-alt);border:1px solid var(--border);border-radius:4px;padding:2px 8px;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:480px}.approval-card-cwd{font-size:11px;color:var(--text-muted);font-family:var(--mono);margin-top:3px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.approval-card-time{font-family:var(--mono);font-size:14px;color:var(--warning);font-weight:600;flex-shrink:0;min-width:40px;text-align:right}.approval-card-actions{display:flex;gap:8px;flex-shrink:0}.approval-btn-deny{padding:8px 18px;font-size:13px;font-weight:600;border-radius:var(--radius-sm);border:1.5px solid var(--border);background:var(--surface);color:var(--text);cursor:pointer;transition:all .12s ease}.approval-btn-deny:hover{background:var(--surface-alt);border-color:var(--text-muted)}.approval-btn-deny:disabled{opacity:.5;cursor:not-allowed}.approval-btn-approve{padding:8px 20px;font-size:13px;font-weight:600;border-radius:var(--radius-sm);border:none;background:var(--accent);color:#fff;cursor:pointer;display:inline-flex;align-items:center;gap:6px;transition:all .12s ease}.approval-btn-approve:hover{background:var(--accent-hover)}.approval-btn-approve:disabled{opacity:.5;cursor:not-allowed}.approvals-page{display:flex;flex-direction:column;gap:0}.appr-auto-refresh{display:inline-flex;align-items:center;gap:6px;font-family:var(--mono);font-size:12px;color:var(--text-muted);border:1px solid var(--border);border-radius:999px;padding:5px 14px}.appr-auto-dot{width:7px;height:7px;border-radius:50%;background:var(--success);display:inline-block}.appr-section-label{font-size:11px;font-weight:700;letter-spacing:.06em;color:var(--text-muted);text-transform:uppercase;margin-bottom:12px;margin-top:8px}.appr-list{display:flex;flex-direction:column;gap:14px}.appr-item{display:flex;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow-sm)}.appr-item-border{width:4px;flex-shrink:0}.appr-item-border.pending{background:var(--warning)}.appr-item-border.approved{background:var(--success)}.appr-item-border.denied{background:var(--error)}.appr-item-border.expired{background:var(--text-muted)}.appr-item-body{flex:1;padding:16px 20px;display:flex;flex-direction:column;gap:10px;min-width:0}.appr-item-head{display:flex;align-items:center;gap:8px;flex-wrap:wrap}.appr-item-icon{width:36px;height:36px;border-radius:var(--radius-sm);display:flex;align-items:center;justify-content:center;flex-shrink:0}.appr-item-icon.pending{background:var(--warning-soft);color:var(--warning)}.appr-item-icon.approved{background:var(--success-soft);color:var(--success)}.appr-item-icon.denied{background:var(--error-soft);color:var(--error)}.appr-item-icon.expired{background:var(--surface-alt);color:var(--text-muted)}.appr-item-id{font-family:var(--mono);font-weight:600;font-size:14px;color:var(--text)}.appr-chip{display:inline-block;font-family:var(--mono);font-size:10px;font-weight:700;letter-spacing:.04em;padding:2px 8px;border-radius:4px;text-transform:uppercase}.appr-chip.tier{background:var(--surface-alt);color:var(--text-dim)}.appr-chip.tier.tier-1{background:var(--info-soft);color:var(--info)}.appr-chip.tier.tier-2{background:var(--warning-soft);color:var(--warning)}.appr-chip.tier.tier-3{background:var(--error-soft);color:var(--error)}.appr-chip.pending{background:var(--warning-soft);color:var(--warning)}.appr-chip.approved{background:var(--success-soft);color:var(--success)}.appr-chip.denied{background:var(--error-soft);color:var(--error)}.appr-chip.expired{background:var(--surface-alt);color:var(--text-muted)}.appr-tier-legend{margin-top:10px;display:grid;grid-template-columns:auto 1fr;gap:6px 10px;align-items:center}.appr-tier-label{font-size:12px;color:var(--text-dim)}.appr-elapsed{display:inline-flex;align-items:center;gap:4px;font-family:var(--mono);font-size:13px;color:var(--warning);font-weight:600}.appr-actions{display:flex;gap:8px}.appr-reason{font-size:14px;color:var(--text-dim)}.appr-cmd-block{font-family:var(--mono);font-size:13px;background:var(--surface-alt);border:1px solid var(--border);border-radius:var(--radius-sm);padding:10px 14px;color:var(--text);overflow-x:auto;white-space:pre}.appr-footer{display:flex;align-items:center;gap:8px;flex-wrap:wrap;font-size:12px;color:var(--text-muted)}.appr-footer-item{display:inline-flex;align-items:center;gap:4px;font-family:var(--mono)}.appr-footer-sep{color:var(--border)}.appr-footer-resolution{font-style:italic;color:var(--text-muted)}.spinner{width:20px;height:20px;border:2px solid var(--border);border-top-color:var(--accent);border-radius:50%;animation:spin .7s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.empty-state{text-align:center;padding:48px 24px;color:var(--text-muted)}.empty-state-icon{font-size:36px;margin-bottom:12px}.empty-state-text{font-size:14px}.markdown-view{font-size:14px;line-height:1.55;color:var(--text-dim)}.markdown-view h1,.markdown-view h2,.markdown-view h3,.markdown-view h4,.markdown-view h5,.markdown-view h6{font-family:var(--serif);color:var(--text);font-weight:800;margin:0 0 8px}.markdown-view p{margin:0 0 7px}.markdown-view ul,.markdown-view ol{padding-left:20px;margin:0 0 7px}.markdown-view code{font-family:var(--mono);background:var(--surface-alt);padding:1px 4px;border-radius:4px;font-size:12px}.markdown-view pre{margin:0 0 9px;background:var(--surface-alt);border:1px solid var(--border-light);border-radius:var(--radius-sm);padding:12px;overflow:auto}.markdown-view pre code{background:transparent;padding:0}.markdown-view blockquote{border-left:3px solid var(--accent);padding-left:10px;margin:0 0 9px;color:var(--text-muted)}.chat-list{display:flex;flex-direction:column;gap:10px}.chat-row{display:flex;flex-direction:column}.chat-row.user{align-items:flex-end}.chat-row.assistant{align-items:flex-start}.chat-meta{font-size:11px;color:var(--text-muted);font-family:var(--mono);margin-bottom:4px}.chat-bubble{max-width:82%;padding:10px 12px;border-radius:12px;font-size:14px;line-height:1.5;border:1px solid var(--border-light)}.chat-bubble.user{background:var(--accent-soft);color:var(--text)}.chat-bubble.assistant{background:var(--surface-alt);color:var(--text-dim)}.chat-bubble .markdown-view p:last-child,.chat-bubble .markdown-view ul:last-child,.chat-bubble .markdown-view ol:last-child,.chat-bubble .markdown-view pre:last-child,.chat-bubble .markdown-view blockquote:last-child{margin-bottom:0}.messages-page{height:calc(100vh - 118px);display:flex;flex-direction:column}.messages-chat-card{flex:1;height:100%;min-height:0;display:flex;flex-direction:column;margin-bottom:0}.messages-chat-list{flex:1;min-height:0;overflow-y:auto;padding-right:4px;padding-bottom:8px;-ms-overflow-style:none;scrollbar-width:none}.messages-chat-list::-webkit-scrollbar{width:0;height:0;display:none}.messages-composer-inline{margin-top:auto;padding-top:12px;border-top:1px solid var(--border-light)}.messages-filler{flex:1;display:flex;align-items:center;justify-content:center}.card{background:var(--surface);border:1px solid var(--border-light);border-radius:var(--radius);padding:20px 22px;margin-bottom:14px;box-shadow:var(--shadow-sm)}.card-title{font-size:14px;color:var(--text);margin-bottom:8px;font-weight:500}.toolbar{display:flex;gap:8px;align-items:center;margin-bottom:12px;flex-wrap:wrap}.split{display:grid;grid-template-columns:320px 1fr;gap:18px;height:calc(100vh - 180px)}.split-list{background:var(--surface);border:1px solid var(--border-light);border-radius:var(--radius);overflow-y:auto;box-shadow:var(--shadow-sm)}.split-detail{background:var(--surface);border:1px solid var(--border-light);border-radius:var(--radius);overflow-y:auto;padding:24px;box-shadow:var(--shadow-sm)}.list-item{padding:16px 20px;border-bottom:1px solid var(--border-light);cursor:pointer;transition:background .12s ease}.list-item:last-child{border-bottom:none}.list-item:hover{background:var(--surface-alt)}.list-item.active{background:var(--accent-soft-2);border-left:3px solid var(--accent)}.list-item-title{font-weight:600;font-size:14px;margin-bottom:3px;color:var(--text)}.list-item-sub,.list-item-meta{font-size:12px;color:var(--text-dim);font-family:var(--mono)}.audit-entry{background:var(--surface);border:1px solid var(--border-light);border-radius:var(--radius);padding:16px 18px;margin-bottom:10px}.audit-header{display:flex;justify-content:space-between;align-items:start;gap:10px;margin-bottom:8px}.audit-id{font-family:var(--mono);font-size:12px;color:var(--accent);font-weight:600}.audit-meta{display:flex;align-items:center;gap:8px;font-size:11px;color:var(--text-muted);font-family:var(--mono)}.audit-summary{font-size:13px;color:var(--text-dim);line-height:1.5}.audit-page{display:flex;flex-direction:column;gap:12px}.audit-header-meta{font-family:var(--mono);font-size:11px;color:var(--text-muted)}.audit-top-stats{background:var(--surface);border:1px solid var(--border-light);border-radius:var(--radius);padding:10px 14px;display:flex;justify-content:space-between;align-items:center;gap:12px;flex-wrap:wrap}.audit-stat-left{display:flex;align-items:baseline;gap:8px}.audit-big{font-family:var(--serif);font-size:20px;line-height:1}.audit-big.ok{color:var(--success)}.audit-big.error{color:var(--error)}.audit-big.running{color:var(--warning)}.audit-stat-label{font-size:11px;color:var(--text-muted);font-weight:600}.audit-stat-triggers{display:flex;gap:8px;flex-wrap:wrap}.audit-filters-row{display:flex;flex-direction:column;gap:8px;align-items:stretch}.audit-search{width:100%;min-width:0;max-width:none;display:inline-flex;align-items:center;gap:8px;border:1px solid var(--border-light);background:var(--surface);color:var(--text-muted);border-radius:14px;padding:10px 14px;min-height:56px}.audit-search input{border:none;background:transparent;color:var(--text);width:100%;min-width:120px;font-size:11px;font-weight:500}.audit-search input:focus{outline:none}.audit-search svg{width:20px;height:20px}.audit-filter-controls{display:flex;gap:8px;align-items:center}.audit-filter-controls>.btn.btn-sm{min-height:32px;height:32px;min-width:160px;width:auto;border-radius:10px;font-size:12px;font-weight:500;padding:5px 12px}.audit-timeline{display:flex;flex-direction:column;gap:8px}.audit-row{display:grid;grid-template-columns:56px 1fr;gap:12px}.audit-time-col{display:flex;flex-direction:column;align-items:center;color:var(--text-muted)}.audit-time{font-family:var(--mono);font-size:10px;margin-top:12px}.audit-time-line{width:1px;flex:1;min-height:40px;background:var(--border);margin-top:8px}.audit-card{background:var(--surface);border:1px solid var(--border-light);border-radius:var(--radius);padding:12px 14px}.audit-card-head{display:flex;justify-content:space-between;align-items:center;gap:10px;margin-bottom:6px}.audit-chip-row{display:flex;gap:6px;align-items:center;flex-wrap:wrap}.audit-chip{display:inline-flex;align-items:center;gap:6px;border:1px solid var(--border-light);border-radius:999px;padding:2px 8px;font-size:9px;line-height:1.4;font-family:var(--mono);color:var(--text-muted);text-transform:uppercase;letter-spacing:.01em}.audit-chip strong{color:var(--text-dim);font-weight:600}.audit-chip.muted{background:var(--surface-alt)}.audit-chip.id{text-transform:none;letter-spacing:0}.audit-chip.trigger.telegram{background:var(--chip-telegram-bg);color:var(--chip-telegram);border-color:transparent}.audit-chip.trigger.discord{background:var(--chip-discord-bg);color:var(--chip-discord);border-color:transparent}.audit-chip.trigger.cron{background:var(--chip-cron-bg);color:var(--chip-cron);border-color:transparent}.audit-chip.trigger.system,.audit-chip.trigger.gateway,.audit-chip.trigger.dashboard{background:var(--surface-alt);border-color:transparent;color:var(--text-dim)}.audit-chip.status.success{background:var(--success-soft);color:var(--success);border-color:transparent}.audit-chip.status.error{background:var(--error-soft);color:var(--error);border-color:transparent}.audit-chip.status.running{background:var(--warning-soft);color:var(--warning);border-color:transparent}.audit-chip.soft{background:var(--surface-alt);text-transform:none}.audit-duration{font-family:var(--mono);font-size:10px;color:var(--text-muted);white-space:nowrap}.audit-title-line{font-size:14px;line-height:1.35;color:var(--text-dim);margin-bottom:8px}.audit-event-pills{display:flex;gap:6px;flex-wrap:wrap}.audit-load-more-wrap{text-align:center;margin-top:8px}.audit-card-expandable:hover{border-color:var(--border)}.audit-card-head-right{display:flex;align-items:center;gap:6px}.audit-expand-icon{color:var(--text-muted);display:flex;align-items:center}.audit-detail-section{margin-top:10px;border-top:1px solid var(--border-light);padding-top:8px;display:flex;flex-direction:column;gap:0}.audit-event-row{display:grid;grid-template-columns:90px 1fr auto;gap:8px;align-items:baseline;padding:5px 2px;border-bottom:1px solid var(--border-light)}.audit-event-row:last-child{border-bottom:none}.audit-event-type-label{font-family:var(--mono);font-size:10px;color:var(--text-muted);text-transform:uppercase;letter-spacing:.04em;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.audit-event-type-label.tool{color:var(--accent, #7c6af0)}.audit-event-content{font-size:12px;color:var(--text-dim);line-height:1.4;word-break:break-word;overflow:hidden}.audit-event-content.mono{font-family:var(--mono);font-size:11px}.audit-event-dur{font-family:var(--mono);font-size:10px;color:var(--text-muted);white-space:nowrap;text-align:right}.audit-event-detail{display:flex;flex-direction:column;gap:4px}.audit-event-detail-label{font-family:var(--mono);font-size:10px;color:var(--text-muted);text-transform:uppercase;letter-spacing:.04em}.audit-json-block{background:var(--surface-alt);border:1px solid var(--border-light);border-radius:var(--radius-sm);padding:10px 12px;font-family:var(--mono);font-size:11px;line-height:1.6;color:var(--text-dim);white-space:pre;overflow-x:auto;-moz-tab-size:2;tab-size:2}.audit-kv-list{display:flex;flex-direction:column;gap:2px;margin:0;padding:8px 10px;background:var(--surface-alt);border:1px solid var(--border-light);border-radius:var(--radius-sm)}.audit-kv-row{display:grid;grid-template-columns:minmax(80px,28%) 1fr;gap:8px;align-items:baseline;min-height:20px}.audit-kv-row dt,.audit-kv-key{font-family:var(--mono);font-size:11px;font-weight:600;color:var(--text-muted);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.audit-kv-row dd,.audit-kv-val{font-family:var(--mono);font-size:11px;color:var(--text-dim);margin:0;word-break:break-word}.audit-kv-inline{font-family:var(--mono);font-size:11px;color:var(--text-muted);background:transparent;padding:0;white-space:pre-wrap;word-break:break-all}.audit-detail-text{font-family:var(--mono);font-size:11px;line-height:1.6;color:var(--text-dim);padding:8px 12px;background:var(--surface-alt);border:1px solid var(--border-light);border-radius:var(--radius-sm);white-space:pre-wrap;word-break:break-word;display:block}@media (max-width: 900px){.audit-row{grid-template-columns:1fr}.audit-time-col{align-items:flex-start;flex-direction:row;gap:8px}.audit-time-line{display:none}.audit-filter-controls{flex-direction:column;align-items:stretch}.audit-filter-controls>.btn.btn-sm{width:100%}}.coding-page{--coding-accent: #ad5038;--coding-accent-soft: rgba(173, 80, 56, .08)}.coding-page .page-header{margin-bottom:18px}.coding-refresh-pill{display:inline-flex;align-items:center;gap:8px;padding:7px 14px;border:1px solid var(--border-light);border-radius:999px;background:var(--surface-alt);color:var(--text-dim);font-size:13px;font-family:var(--sans);font-weight:500;box-shadow:var(--shadow-sm);line-height:1}.coding-refresh-pill .dot{width:6px;height:6px;border-radius:50%;background:var(--success)}.coding-page .btn{display:inline-flex;align-items:center;gap:6px}.coding-body{display:flex;flex-direction:column;gap:14px}.coding-stats-grid{display:flex;gap:12px;margin-bottom:6px;flex-wrap:wrap}.coding-stat-card{background:var(--surface);border:1px solid var(--border-light);border-radius:var(--radius);padding:14px 20px;display:flex;align-items:center;gap:10px;min-width:140px;flex:1}.coding-stat-icon{width:38px;height:38px;border-radius:var(--radius-sm);display:inline-flex;align-items:center;justify-content:center}.coding-stat-icon svg{width:18px;height:18px}.coding-stat-content{display:flex;flex-direction:column;justify-content:center;gap:0;min-width:0}.coding-stat-icon.running{background:var(--coding-accent-soft);color:var(--coding-accent)}.coding-stat-icon.completed{background:var(--success-soft);color:var(--success)}.coding-stat-icon.failed{background:var(--error-soft);color:var(--error)}.coding-stat-icon.cost{background:var(--warning-soft);color:var(--warning)}.coding-stat-value{font-family:var(--serif);font-size:18px;font-weight:500;line-height:1;color:var(--text)}.coding-stat-label{font-size:10px;color:var(--text-muted);font-weight:400;margin-top:2px;line-height:1.1}.coding-task-card{background:var(--surface);border:1px solid var(--border-light);border-top-width:3px;border-top-color:var(--card-accent, var(--coding-accent));border-radius:var(--radius);padding:0;overflow:hidden;box-shadow:var(--shadow-sm)}.coding-task-main{padding:18px 22px 0;display:grid;grid-template-columns:36px 1fr auto;gap:14px;align-items:start}.coding-task-icon{width:36px;height:36px;border-radius:var(--radius-sm);display:inline-flex;align-items:center;justify-content:center;margin-top:2px}.coding-task-icon.running{background:var(--coding-accent-soft);color:var(--coding-accent)}.coding-task-card.running .coding-task-icon.running{background:var(--card-accent-soft, var(--coding-accent-soft));color:var(--card-accent, var(--coding-accent))}.coding-task-icon.completed{background:var(--success-soft);color:var(--success)}.coding-task-icon.failed{background:var(--error-soft);color:var(--error)}.coding-task-icon.pending{background:var(--pending-soft);color:var(--pending)}.coding-task-content{min-width:0}.coding-task-pills{display:flex;align-items:center;gap:8px;flex-wrap:wrap;margin-bottom:6px}.coding-pill{display:inline-flex;align-items:center;border:1px solid var(--border-light);background:var(--surface-alt);color:var(--text-muted);border-radius:999px;padding:2px 8px;font-size:9px;text-transform:uppercase;letter-spacing:.04em;font-family:var(--sans);font-weight:500}.coding-pill.id{border:none;background:transparent;color:var(--card-accent, var(--coding-accent));padding:0;font-size:12px;letter-spacing:0;text-transform:none;font-family:var(--mono);font-weight:500}.coding-pill.status.running{color:var(--card-accent, var(--coding-accent));background:var(--card-accent-soft, var(--coding-accent-soft));border-color:transparent}.coding-pill.status.completed{color:var(--success);background:var(--success-soft);border-color:transparent}.coding-pill.status.failed{color:var(--error);background:var(--error-soft);border-color:transparent}.coding-pill.status.pending{color:var(--pending)}.coding-task-title{margin-top:0;font-size:13px;color:var(--text);font-weight:400;line-height:1.5}.coding-task-submeta{padding:10px 0 16px;display:flex;align-items:center;gap:14px;flex-wrap:wrap;font-size:11px;color:var(--text-muted);font-family:var(--mono)}.coding-task-submeta span{display:inline-flex;align-items:center;gap:6px}.coding-task-action{align-self:flex-start;border:1px solid transparent;background:transparent;color:var(--text-dim);border-radius:999px;font-size:11px;font-weight:500;padding:6px 14px;display:inline-flex;align-items:center;gap:6px}.coding-task-action.running{color:var(--card-accent, var(--coding-accent));border-color:color-mix(in srgb,var(--card-accent, var(--coding-accent)) 25%,transparent);background:color-mix(in srgb,var(--card-accent, var(--coding-accent)) 8%,transparent)}.coding-task-action.failed{color:var(--error);border-color:#c254504d;background:#c254500a}.coding-task-progress{height:1px;background:var(--border-light)}.coding-task-progress.running{background:linear-gradient(to right,var(--card-accent, var(--coding-accent)) 56%,var(--border-light) 56%)}.coding-task-progress.failed{background:linear-gradient(to right,var(--error) 32%,var(--border-light) 32%)}.coding-task-progress.completed{background:linear-gradient(to right,var(--success) 100%,var(--success) 100%)}.coding-task-progress.pending{background:linear-gradient(to right,var(--pending) 20%,var(--border-light) 20%)}.coding-subagents,.coding-output{border-top:1px solid var(--border-light);padding:8px 22px}.coding-subagents>summary,.coding-output>summary{list-style:none;cursor:pointer;font-size:10px;color:var(--text-muted);text-transform:uppercase;letter-spacing:.04em;font-weight:500;display:inline-flex;align-items:center;gap:6px}.coding-subagents>summary::-webkit-details-marker,.coding-output>summary::-webkit-details-marker{display:none}.coding-subagents-list{margin-top:10px;border-left:2px solid var(--border);padding-left:16px;margin-left:8px}.coding-subagent-row{margin-top:8px;border:1px solid var(--border-light);background:var(--surface-alt);border-radius:var(--radius-sm);padding:12px 14px;display:grid;grid-template-columns:40px auto auto auto 1fr auto;gap:8px;align-items:center}.coding-subagent-icon{width:24px;height:24px;border-radius:6px;display:inline-flex;align-items:center;justify-content:center}.coding-subagent-icon.running{background:var(--card-accent-soft, var(--coding-accent-soft));color:var(--card-accent, var(--coding-accent))}.coding-subagent-icon.completed{background:var(--success-soft);color:var(--success)}.coding-subagent-icon.failed{background:var(--error-soft);color:var(--error)}.coding-subagent-icon.pending{background:var(--pending-soft);color:var(--pending)}.coding-subagent-task{font-size:12px;color:var(--text-dim);line-height:1.45;font-weight:400}.coding-subagent-time{font-size:11px;color:var(--text-muted);font-family:var(--mono);display:inline-flex;align-items:center;gap:3px}.coding-subagent-card{margin-top:8px;border:1px solid var(--border-light);background:var(--surface-alt);border-radius:var(--radius-sm);overflow:hidden;transition:border-color .15s}.coding-subagent-card.running{border-left:2px solid var(--card-accent, var(--coding-accent))}.coding-subagent-card.completed{border-left:2px solid var(--success)}.coding-subagent-card.failed{border-left:2px solid var(--error)}.coding-subagent-card.pending{border-left:2px solid var(--border);opacity:.7}.coding-subagent-header{padding:10px 14px;display:flex;align-items:center;gap:8px;cursor:pointer;list-style:none;font-size:12px}.coding-subagent-header::-webkit-details-marker{display:none}.coding-subagent-chevron{flex-shrink:0;transition:transform .15s;color:var(--text-muted)}.coding-subagent-card[open]>.coding-subagent-header .coding-subagent-chevron{transform:rotate(0)}.coding-subagent-card:not([open])>.coding-subagent-header .coding-subagent-chevron{transform:rotate(-90deg)}.coding-subagent-body{padding:0 14px 12px;border-top:1px solid var(--border-light)}.coding-subagent-body .coding-subagent-task{padding:8px 0 4px}.ca-subagent-output{max-height:300px;overflow-y:auto;font-size:12px;padding:8px;background:#0000001a;border-radius:var(--radius-sm);margin-top:6px}.ca-status-badge{display:inline-flex;align-items:center;padding:3px 10px;border-radius:999px;font-size:11px;font-weight:700;letter-spacing:.05em;text-transform:uppercase}.ca-status-badge.running{background:var(--accent-soft);color:var(--accent)}.ca-status-badge.validating{background:var(--warning-soft);color:var(--warning)}.ca-status-badge.completed{background:var(--success-soft);color:var(--success)}.ca-status-badge.failed,.ca-status-badge.timeout,.ca-status-badge.cancelled{background:var(--error-soft);color:var(--error)}.tree-container{display:flex;flex-direction:column;gap:8px}.ca-tree{margin-bottom:12px}.ca-tree-children{margin:8px 0 0 18px;padding-left:14px;border-left:2px solid var(--border-light)}.ca-tree-child{background:var(--surface-alt);border:1px solid var(--border);border-radius:var(--radius-sm);padding:10px 12px;margin-bottom:8px}.ca-output{background:var(--surface);border:1px solid var(--border-light);border-radius:var(--radius-sm);padding:10px 12px;font-size:12px;line-height:1.6;max-height:260px;overflow-y:auto;margin-top:8px}.ca-output.markdown-content{font-family:var(--sans)}.ca-output.markdown-content code,.ca-output.markdown-content pre{font-family:var(--mono)}.ca-error{background:var(--error-soft);border-color:#c2545033;color:var(--error)}.usage-stats-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:18px;margin-bottom:28px}.usage-table{width:100%;border-collapse:collapse;font-size:13px}.usage-table th{background:var(--surface-alt);font-weight:600;font-size:11px;text-transform:uppercase;letter-spacing:.04em;color:var(--text-muted);padding:10px 14px;text-align:left;border-bottom:1px solid var(--border-light)}.usage-table td{padding:10px 14px;border-bottom:1px solid var(--border-light);color:var(--text-dim);font-family:var(--mono);font-size:12px}.usage-table tr:last-child td{border-bottom:none}.usage-table tr:hover td{background:var(--surface-alt)}.usage-cost-cell{font-weight:600;color:var(--text)}.usage-model-pill{font-family:var(--mono);font-size:11px;background:var(--surface-alt);border:1px solid var(--border-light);border-radius:4px;padding:2px 6px;color:var(--text)}.digest-header{margin-bottom:14px}.digest-title{font-family:var(--serif);font-size:24px;font-weight:700;line-height:1.2}.digest-meta{font-size:12px;color:var(--text-muted);font-family:var(--mono);margin-top:4px}.digest-reader{background:var(--surface);border:1px solid var(--border-light);border-radius:var(--radius);padding:16px 18px;word-break:break-word;line-height:1.65;font-size:14px;color:var(--text-dim)}.digest-articles{padding:6px 0}.digest-article-card{padding:12px 0;border-bottom:1px solid var(--border-light)}.digest-article-card:last-child{border-bottom:none}.digest-article-card .source-badge{font-size:11px;color:var(--accent);font-weight:600;text-transform:uppercase;letter-spacing:.04em}.digest-article-card .article-title{display:inline-block;font-size:15px;font-weight:600;color:var(--text);margin-top:4px;text-decoration:none}.digest-article-card .article-title:hover{color:var(--accent);text-decoration:underline}.digest-article-card .article-stats{font-size:12px;color:var(--text-muted);margin-top:5px}.skills-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:14px}.skill-card{background:var(--surface);border:1px solid var(--border-light);border-radius:var(--radius);padding:18px 20px;box-shadow:var(--shadow-sm)}.skill-header{display:flex;justify-content:space-between;align-items:center;gap:10px;margin-bottom:8px}.skill-name{font-weight:600;font-size:15px}.skill-desc{font-size:13px;color:var(--text-dim);line-height:1.5;margin-bottom:10px}.skill-tags{display:flex;gap:6px;flex-wrap:wrap;margin-bottom:10px}.skill-tag{font-size:11px;font-family:var(--mono);padding:2px 8px;border-radius:999px;background:var(--surface-alt);color:var(--text-muted);border:1px solid var(--border-light)}.markdown-content{line-height:1.65;color:var(--text-dim)}.markdown-content h1,.markdown-content h2,.markdown-content h3,.markdown-content h4,.markdown-content h5,.markdown-content h6{font-family:var(--serif);color:var(--text);font-weight:800;margin:16px 0 10px;line-height:1.3}.markdown-content h1:first-child,.markdown-content h2:first-child,.markdown-content h3:first-child,.markdown-content h4:first-child,.markdown-content h5:first-child,.markdown-content h6:first-child{margin-top:0}.markdown-content h1{font-size:22px}.markdown-content h2{font-size:19px}.markdown-content h3{font-size:17px}.markdown-content h4{font-size:15px}.markdown-content h5{font-size:14px}.markdown-content h6{font-size:13px}.markdown-content p{margin:0 0 10px}.markdown-content p:last-child{margin-bottom:0}.markdown-content ul,.markdown-content ol{padding-left:20px;margin:0 0 10px}.markdown-content li{margin-bottom:4px}.markdown-content a{color:var(--accent);text-decoration:none}.markdown-content a:hover{text-decoration:underline}.markdown-content code{font-family:var(--mono);background:var(--surface-alt);padding:2px 6px;border-radius:4px;font-size:12px;color:var(--text)}.markdown-content pre{margin:0 0 12px;background:var(--surface-alt);border:1px solid var(--border-light);border-radius:var(--radius-sm);padding:12px;overflow:auto}.markdown-content pre code{background:transparent;padding:0;font-size:12px}.markdown-content blockquote{border-left:3px solid var(--accent);padding-left:12px;margin:0 0 12px;color:var(--text-muted);font-style:italic}.markdown-content table{width:100%;border-collapse:collapse;margin:0 0 12px;font-size:13px}.markdown-content th,.markdown-content td{border:1px solid var(--border-light);padding:8px 10px;text-align:left}.markdown-content th{background:var(--surface-alt);font-weight:600;color:var(--text)}.markdown-content td{color:var(--text-dim)}.markdown-content hr{border:none;border-top:1px solid var(--border-light);margin:16px 0}.markdown-content strong,.markdown-content b{font-weight:600;color:var(--text)}.markdown-content em,.markdown-content i{font-style:italic}.templates-page{display:flex;flex-direction:column;gap:0}.templates-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:28px;position:relative;z-index:1;padding-right:72px}.templates-loading{display:flex;justify-content:center;align-items:center;padding:64px}.templates-layout{display:grid;grid-template-columns:280px 1fr;gap:24px;align-items:stretch;min-height:600px}.templates-sidebar{background:var(--surface);border:1px solid var(--border-light);border-radius:var(--radius);box-shadow:var(--shadow-sm);display:flex;flex-direction:column;height:100%}.templates-sidebar-header{padding:20px 20px 16px;border-bottom:1px solid var(--border-light)}.templates-sidebar-label{font-size:11px;font-weight:700;letter-spacing:.06em;color:var(--text-muted);text-transform:uppercase;margin-bottom:10px}.templates-agent-select{width:100%;padding:8px 12px;border:1px solid var(--border);border-radius:var(--radius-sm);background:var(--surface-alt);color:var(--text-dim);font-family:var(--sans);font-size:13px;font-weight:500;cursor:pointer;outline:none}.templates-agent-select:disabled{opacity:.6;cursor:not-allowed}.templates-list{display:flex;flex-direction:column;flex:1;overflow-y:auto}.templates-list-item{display:flex;align-items:center;gap:12px;padding:14px 20px;border:none;border-bottom:1px solid var(--border-light);background:transparent;cursor:pointer;transition:background .15s ease;text-align:left;width:100%;position:relative}.templates-list-item:last-child{border-bottom:none}.templates-list-item:hover{background:var(--surface-alt)}.templates-list-item.active{background:var(--accent-soft-2)}.templates-list-item.active:before{content:"";position:absolute;left:0;top:0;bottom:0;width:3px;background:var(--accent)}.templates-list-icon{width:32px;height:32px;border-radius:var(--radius-sm);background:var(--surface-alt);display:flex;align-items:center;justify-content:center;color:var(--text-dim);flex-shrink:0;font-family:var(--mono);font-size:12px;font-weight:600;letter-spacing:.02em}.templates-list-item.active .templates-list-icon{background:var(--accent-soft);color:var(--accent)}.templates-list-content{flex:1;min-width:0}.templates-list-title{font-size:13px;font-weight:500;color:var(--text);margin-bottom:2px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.templates-list-item.active .templates-list-title{color:var(--accent);font-weight:600}.templates-list-meta{font-size:11px;font-family:var(--mono);color:var(--text-muted)}.templates-main{background:var(--surface);border:1px solid var(--border-light);border-radius:var(--radius);box-shadow:var(--shadow-sm);display:flex;flex-direction:column;height:100%}.templates-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:80px 32px;color:var(--text-muted);gap:12px}.templates-empty p{font-size:14px;margin:0}.templates-editor-header{display:flex;justify-content:space-between;align-items:center;padding:20px 28px;border-bottom:1px solid var(--border-light);gap:16px}.templates-editor-title-row{display:flex;align-items:center;gap:12px;flex:1;min-width:0}.templates-editor-title{font-family:var(--serif);font-size:20px;font-weight:700;color:var(--text);margin:0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.templates-unsaved-pill{display:inline-flex;align-items:center;padding:4px 12px;border-radius:999px;background:var(--warning-soft);color:var(--warning);font-size:11px;font-weight:600;letter-spacing:.02em;white-space:nowrap}.templates-editor-actions{display:flex;gap:10px;align-items:center}.templates-discard-btn{padding:8px 16px;border:none;border-radius:var(--radius-sm);background:transparent;color:var(--text-dim);font-family:var(--sans);font-weight:500;font-size:13px;cursor:pointer;transition:all .15s ease}.templates-discard-btn:hover{color:var(--text);background:var(--surface-alt)}.templates-save-btn{padding:8px 20px;border:none;border-radius:var(--radius-sm);background:var(--accent);color:#fff;font-family:var(--sans);font-weight:600;font-size:13px;cursor:pointer;transition:all .15s ease}.templates-save-btn:hover{background:var(--accent-hover)}.templates-save-btn:disabled{opacity:.5;cursor:not-allowed}.templates-tabs{display:flex;gap:0;padding:0 28px;border-bottom:1px solid var(--border-light)}.templates-tab{padding:12px 20px;border:none;background:transparent;color:var(--text-muted);font-family:var(--sans);font-weight:500;font-size:13px;cursor:pointer;position:relative;transition:color .15s ease}.templates-tab:hover{color:var(--text-dim)}.templates-tab.active{color:var(--accent)}.templates-tab.active:after{content:"";position:absolute;left:0;right:0;bottom:-1px;height:2px;background:var(--accent)}.templates-metadata{display:grid;grid-template-columns:auto auto auto 1fr;gap:24px;padding:16px 28px;border-bottom:1px solid var(--border-light);background:var(--surface-alt)}.templates-metadata-item{display:flex;flex-direction:column;gap:4px}.templates-metadata-label{font-size:10px;font-weight:700;letter-spacing:.06em;color:var(--text-muted);text-transform:uppercase}.templates-metadata-value{font-size:12px;font-family:var(--mono);color:var(--text-dim);font-weight:500}.templates-metadata-path{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.templates-content{flex:1;display:flex;flex-direction:column;overflow:hidden}.templates-textarea{flex:1;width:100%;min-height:500px;padding:24px 28px;border:none;background:var(--surface);color:var(--text);font-family:var(--mono);font-size:13px;line-height:1.65;resize:none;outline:none}.templates-markdown-preview{flex:1;padding:28px 32px;overflow-y:auto}.templates-markdown-preview .markdown-view{max-width:800px;margin:0 auto}.templates-markdown-preview .markdown-view h1,.templates-markdown-preview .markdown-view h2,.templates-markdown-preview .markdown-view h3,.templates-markdown-preview .markdown-view h4,.templates-markdown-preview .markdown-view h5,.templates-markdown-preview .markdown-view h6{font-family:var(--serif);color:var(--text);font-weight:800;margin:16px 0 8px;line-height:1.3}.templates-markdown-preview .markdown-view h1:first-child,.templates-markdown-preview .markdown-view h2:first-child,.templates-markdown-preview .markdown-view h3:first-child{margin-top:0}.templates-markdown-preview .markdown-view h1{font-size:28px;padding-bottom:8px;border-bottom:1px solid var(--border-light)}.templates-markdown-preview .markdown-view h2{font-size:22px}.templates-markdown-preview .markdown-view h3{font-size:18px}.templates-markdown-preview .markdown-view p{margin:0 0 8px;line-height:1.58}.templates-markdown-preview .markdown-view blockquote{border-left:4px solid var(--accent);padding-left:16px;margin:10px 0;color:var(--text-dim);font-style:italic}.templates-markdown-preview .markdown-view hr{border:none;border-top:1px solid var(--border-light);margin:18px 0}.templates-markdown-preview .markdown-view code{font-family:var(--mono);background:var(--surface-alt);padding:2px 6px;border-radius:4px;font-size:12px;color:var(--text)}.templates-markdown-preview .markdown-view pre{background:var(--surface-alt);border:1px solid var(--border-light);border-radius:var(--radius-sm);padding:12px;margin:10px 0;overflow-x:auto}.templates-markdown-preview .markdown-view pre code{background:transparent;padding:0}[data-theme=dark] .split-list,[data-theme=dark] .split-detail,[data-theme=dark] .templates-list,[data-theme=dark] .templates-markdown-preview,[data-theme=dark] .ca-output{scrollbar-width:thin;scrollbar-color:rgba(255,255,255,.12) transparent}[data-theme=dark] .split-list::-webkit-scrollbar,[data-theme=dark] .split-detail::-webkit-scrollbar,[data-theme=dark] .templates-list::-webkit-scrollbar,[data-theme=dark] .templates-markdown-preview::-webkit-scrollbar,[data-theme=dark] .ca-output::-webkit-scrollbar{width:6px}[data-theme=dark] .split-list::-webkit-scrollbar-thumb,[data-theme=dark] .split-detail::-webkit-scrollbar-thumb,[data-theme=dark] .templates-list::-webkit-scrollbar-thumb,[data-theme=dark] .templates-markdown-preview::-webkit-scrollbar-thumb,[data-theme=dark] .ca-output::-webkit-scrollbar-thumb{background:#ffffff1f;border-radius:3px}[data-theme=dark] .split-list::-webkit-scrollbar-track,[data-theme=dark] .split-detail::-webkit-scrollbar-track,[data-theme=dark] .templates-list::-webkit-scrollbar-track,[data-theme=dark] .templates-markdown-preview::-webkit-scrollbar-track,[data-theme=dark] .ca-output::-webkit-scrollbar-track{background:transparent}@media (max-width: 980px){.shell{grid-template-columns:1fr}.shell.shell-narrow .sidebar{position:fixed;top:0;left:0;height:100vh;width:min(86vw,320px);border-right:1px solid var(--border-light);box-shadow:var(--shadow-md);transform:translate(-104%);transition:transform .2s ease;z-index:210}.shell.shell-narrow.sidebar-open .sidebar{transform:translate(0)}.global-sidebar-toggle{position:fixed;top:20px;left:16px;width:37px;height:37px;border:1px solid var(--border);background:var(--surface);border-radius:var(--radius-sm);cursor:pointer;display:inline-flex;align-items:center;justify-content:center;transition:all .15s ease;box-shadow:var(--shadow-sm);color:var(--text);z-index:220}.global-sidebar-toggle:hover{background:var(--surface-hover);box-shadow:var(--shadow)}.sidebar-backdrop{display:block;position:fixed;top:0;right:0;bottom:0;left:0;border:none;padding:0;background:#00000042;z-index:205}.main{padding:20px 16px}.page-header{padding-left:56px;min-height:40px}.global-theme-toggle{top:20px;right:16px;z-index:220}.page-header .header-actions{margin-right:62px;flex-wrap:wrap}.split{grid-template-columns:1fr;height:auto}.split-list{max-height:280px}.stats-grid,.stats-grid-5,.usage-stats-grid{grid-template-columns:1fr 1fr}.stat-card{min-height:116px;padding:18px;gap:12px}.stat-icon{width:44px;height:44px}.stat-icon svg{width:18px;height:18px}.stat-value{font-size:24px}.stat-value-md{font-size:18px}.stat-subtitle{font-size:10px}.coding-stats-grid{grid-template-columns:1fr 1fr}.coding-tl-row{grid-template-columns:56px 1fr 46px}.coding-subagent-row,.cron-grid{grid-template-columns:1fr}.templates-layout{grid-template-columns:1fr;gap:16px}.templates-sidebar{max-height:280px;overflow-y:auto}.templates-metadata{grid-template-columns:1fr 1fr;gap:16px}.templates-editor-header{flex-direction:column;align-items:stretch}.templates-editor-title-row{flex-direction:column;align-items:flex-start;gap:8px}.templates-editor-actions{width:100%;justify-content:flex-end}}
|
|
@@ -6,8 +6,8 @@
|
|
|
6
6
|
<title>SkimpyClaw Dashboard</title>
|
|
7
7
|
<link rel="icon" type="image/svg+xml" href="/favicon.svg" />
|
|
8
8
|
<link href="https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700&family=Playfair+Display:wght@600;700;800&display=swap" rel="stylesheet">
|
|
9
|
-
<script type="module" crossorigin src="/assets/index-
|
|
10
|
-
<link rel="stylesheet" crossorigin href="/assets/index-
|
|
9
|
+
<script type="module" crossorigin src="/assets/index-BoTHPby4.js"></script>
|
|
10
|
+
<link rel="stylesheet" crossorigin href="/assets/index-D4mufvBg.css">
|
|
11
11
|
</head>
|
|
12
12
|
<body>
|
|
13
13
|
<div id="app"></div>
|
package/dist/discord.js
CHANGED
|
@@ -9,7 +9,6 @@ import { runAgentTurn } from './agent.js';
|
|
|
9
9
|
import { runHeartbeatCheck } from './heartbeat.js';
|
|
10
10
|
import { isAllowed, isRateLimited } from './security.js';
|
|
11
11
|
import { getActiveCodeAgents, getRecentCodeAgents } from './tools.js';
|
|
12
|
-
import { getActiveTasks, getRecentTasks, cancelTask } from './subagent.js';
|
|
13
12
|
import { listApprovals, approveRequest, denyRequest, getApproval, onApprovalEvent, } from './exec-approval.js';
|
|
14
13
|
import { transcribeAudio, synthesizeSpeech } from './voice.js';
|
|
15
14
|
import * as sessions from './sessions.js';
|
|
@@ -33,8 +32,8 @@ const BOT_COMMANDS = [
|
|
|
33
32
|
{ command: 'compact', description: 'Compress conversation history' },
|
|
34
33
|
{ command: 'silence', description: 'Pause proactive messages' },
|
|
35
34
|
{ command: 'cron', description: 'List or run scheduled jobs' },
|
|
36
|
-
{ command: 'tasks', description: '
|
|
37
|
-
{ command: 'cancel', description: 'Cancel a
|
|
35
|
+
{ command: 'tasks', description: 'List active coding agents and cron jobs' },
|
|
36
|
+
{ command: 'cancel', description: 'Cancel a coding agent (use dashboard) or cron job' },
|
|
38
37
|
{ command: 'approvals', description: 'List pending exec approvals' },
|
|
39
38
|
{ command: 'approve', description: 'Approve an exec request by ID' },
|
|
40
39
|
{ command: 'deny', description: 'Deny an exec request by ID' },
|
|
@@ -380,46 +379,11 @@ async function handleCommand(message, command, args) {
|
|
|
380
379
|
return;
|
|
381
380
|
}
|
|
382
381
|
if (command === 'tasks') {
|
|
383
|
-
|
|
384
|
-
const recent = getRecentTasks(5);
|
|
385
|
-
if (recent.length === 0) {
|
|
386
|
-
await message.reply('No agent tasks yet. Subagents spawn automatically for complex requests.');
|
|
387
|
-
return;
|
|
388
|
-
}
|
|
389
|
-
const formatTask = (t) => {
|
|
390
|
-
const elapsed = ((t.completedAt || new Date()).getTime() - t.createdAt.getTime()) / 1000;
|
|
391
|
-
const elapsedStr = elapsed < 60 ? `${Math.round(elapsed)}s` : `${Math.round(elapsed / 60)}m`;
|
|
392
|
-
const status = {
|
|
393
|
-
pending: '⏳ Pending',
|
|
394
|
-
running: `🔄 Running (${elapsedStr})`,
|
|
395
|
-
completed: `✅ Done (${elapsedStr})`,
|
|
396
|
-
failed: `❌ Failed (${elapsedStr})`,
|
|
397
|
-
cancelled: '🚫 Cancelled',
|
|
398
|
-
};
|
|
399
|
-
const promptPreview = t.prompt.slice(0, 60) + (t.prompt.length > 60 ? '...' : '');
|
|
400
|
-
return `${t.id}: ${status[t.status] || t.status} [${t.type}] ${promptPreview}`;
|
|
401
|
-
};
|
|
402
|
-
const lines = recent.map(formatTask).join('\n');
|
|
403
|
-
await sendLongText(message, `Agent tasks:\n\n${lines}`);
|
|
382
|
+
await message.reply('Use `/agents` to list active coding agents, or `/cron` to manage scheduled tasks.');
|
|
404
383
|
return;
|
|
405
384
|
}
|
|
406
385
|
if (command === 'cancel') {
|
|
407
|
-
|
|
408
|
-
if (!id) {
|
|
409
|
-
await message.reply('Usage: /cancel <task-id>\nExample: /cancel t1');
|
|
410
|
-
return;
|
|
411
|
-
}
|
|
412
|
-
const task = cancelTask(id);
|
|
413
|
-
if (!task) {
|
|
414
|
-
await message.reply(`No task found: ${id}`);
|
|
415
|
-
return;
|
|
416
|
-
}
|
|
417
|
-
if (task.status === 'cancelled') {
|
|
418
|
-
await message.reply(`Cancelled ${id}.`);
|
|
419
|
-
}
|
|
420
|
-
else {
|
|
421
|
-
await message.reply(`Task ${id} is already ${task.status}.`);
|
|
422
|
-
}
|
|
386
|
+
await message.reply('Use the dashboard to cancel coding agents, or `/cron` to manage scheduled tasks.');
|
|
423
387
|
return;
|
|
424
388
|
}
|
|
425
389
|
if (command === 'clear') {
|
package/dist/exec-approval.js
CHANGED
package/dist/file-lock.js
CHANGED
package/dist/gateway.js
CHANGED
|
@@ -3,7 +3,7 @@ import Fastify from 'fastify';
|
|
|
3
3
|
import { existsSync } from 'fs';
|
|
4
4
|
import { fileURLToPath } from 'url';
|
|
5
5
|
import { join } from 'path';
|
|
6
|
-
import {
|
|
6
|
+
import { validateBearerToken } from './utils.js';
|
|
7
7
|
import { runAgentTurn } from './agent.js';
|
|
8
8
|
import { getCronJobs, runCronJob } from './cron.js';
|
|
9
9
|
import { registerDashboardAPI } from './api.js';
|
|
@@ -120,15 +120,8 @@ export async function createGateway(cfg) {
|
|
|
120
120
|
return; // GET /health, GET /status are fine
|
|
121
121
|
if (!dashboardToken)
|
|
122
122
|
return; // No token configured, allow access
|
|
123
|
-
|
|
124
|
-
|
|
125
|
-
return reply.code(401).send({ error: 'Unauthorized: Bearer token required' });
|
|
126
|
-
}
|
|
127
|
-
const provided = authHeader.slice(7);
|
|
128
|
-
const tokenBuf = Buffer.from(dashboardToken, 'utf8');
|
|
129
|
-
const providedBuf = Buffer.from(provided, 'utf8');
|
|
130
|
-
if (tokenBuf.length !== providedBuf.length || !timingSafeEqual(tokenBuf, providedBuf)) {
|
|
131
|
-
return reply.code(401).send({ error: 'Unauthorized: Invalid token' });
|
|
123
|
+
if (!validateBearerToken(dashboardToken, request.headers.authorization)) {
|
|
124
|
+
return reply.code(401).send({ error: 'Unauthorized: Invalid or missing token' });
|
|
132
125
|
}
|
|
133
126
|
});
|
|
134
127
|
// Register dashboard API routes (includes auth hook)
|
|
@@ -1,9 +1,11 @@
|
|
|
1
1
|
// Anthropic Provider
|
|
2
2
|
import { startObservation } from '@langfuse/tracing';
|
|
3
3
|
import { buildSystemParam, addToolCacheBreakpoint, contentToText, stripProvider, buildThinkingConfig, truncateToolResult } from './utils.js';
|
|
4
|
+
import { compactAnthropicMessages } from './context-manager.js';
|
|
4
5
|
import { toAnthropicUsageDetails, toCostDetails } from './observability.js';
|
|
5
6
|
import { getToolDefinitions, executeTool } from '../tools.js';
|
|
6
7
|
import { ToolCallGuard } from './tool-guard.js';
|
|
8
|
+
import { toErrorMessage } from '../utils.js';
|
|
7
9
|
import { startTrace, addEvent } from '../audit.js';
|
|
8
10
|
import { buildUsageRecord, recordUsage } from '../usage.js';
|
|
9
11
|
let anthropicClient = null;
|
|
@@ -108,7 +110,7 @@ export async function chatAnthropic(params) {
|
|
|
108
110
|
return text;
|
|
109
111
|
}
|
|
110
112
|
catch (err) {
|
|
111
|
-
const errorMessage =
|
|
113
|
+
const errorMessage = toErrorMessage(err);
|
|
112
114
|
genObs?.update({ level: 'ERROR', statusMessage: errorMessage, output: { error: errorMessage } });
|
|
113
115
|
genObs?.end();
|
|
114
116
|
throw err;
|
|
@@ -123,7 +125,7 @@ export async function chatWithToolsAnthropic(params) {
|
|
|
123
125
|
const maxIterations = toolConfig.maxIterations || 20;
|
|
124
126
|
// Resolve tools once at start of agent loop
|
|
125
127
|
const includeSpawn = !!(toolContext?.fullConfig && (toolContext?.chatId || toolContext?.isCronJob));
|
|
126
|
-
const toolDefs = await getToolDefinitions(toolConfig, {
|
|
128
|
+
const toolDefs = await getToolDefinitions(toolConfig, { includeAgentTools: includeSpawn, projects: toolContext?.fullConfig?.projects });
|
|
127
129
|
// Enable prompt caching for system + tools
|
|
128
130
|
const cacheEnabled = config.models?.promptCaching !== false;
|
|
129
131
|
if (cacheEnabled)
|
|
@@ -149,10 +151,12 @@ export async function chatWithToolsAnthropic(params) {
|
|
|
149
151
|
toolCalls: toolLog,
|
|
150
152
|
};
|
|
151
153
|
}
|
|
154
|
+
// Compact old tool results if context is growing large
|
|
155
|
+
const messagesForApi = compactAnthropicMessages(apiMessages, toolConfig.contextManagement, i + 1);
|
|
152
156
|
const anthropicParams = {
|
|
153
157
|
model: modelId,
|
|
154
158
|
max_tokens: options.maxTokens || 16384,
|
|
155
|
-
messages:
|
|
159
|
+
messages: messagesForApi,
|
|
156
160
|
tools: toolDefs,
|
|
157
161
|
};
|
|
158
162
|
if (systemParam) {
|
|
@@ -195,7 +199,7 @@ export async function chatWithToolsAnthropic(params) {
|
|
|
195
199
|
guard.recordTokens(response.usage?.input_tokens ?? 0, response.usage?.output_tokens ?? 0);
|
|
196
200
|
}
|
|
197
201
|
catch (err) {
|
|
198
|
-
const errorMessage =
|
|
202
|
+
const errorMessage = toErrorMessage(err);
|
|
199
203
|
genObs?.update({ level: 'ERROR', statusMessage: errorMessage, output: { error: errorMessage } });
|
|
200
204
|
genObs?.end();
|
|
201
205
|
throw err;
|
|
@@ -279,7 +283,7 @@ export async function chatWithToolsAnthropic(params) {
|
|
|
279
283
|
}
|
|
280
284
|
}
|
|
281
285
|
catch (err) {
|
|
282
|
-
const errorMessage =
|
|
286
|
+
const errorMessage = toErrorMessage(err);
|
|
283
287
|
toolObs?.update({ level: 'ERROR', statusMessage: errorMessage, output: { error: errorMessage } });
|
|
284
288
|
toolObs?.end();
|
|
285
289
|
if (toolContext?.auditTraceId) {
|
package/dist/providers/codex.js
CHANGED
|
@@ -3,6 +3,8 @@ import { readFileSync, existsSync } from 'fs';
|
|
|
3
3
|
import { join } from 'path';
|
|
4
4
|
import { homedir } from 'os';
|
|
5
5
|
import { stripProvider, truncateToolResult } from './utils.js';
|
|
6
|
+
import { toErrorMessage } from '../utils.js';
|
|
7
|
+
import { compactCodexMessages } from './context-manager.js';
|
|
6
8
|
import { toCodexContent, toCodexToolDefinitions } from './content.js';
|
|
7
9
|
import { toNumericUsageDetails, toCostDetails } from './observability.js';
|
|
8
10
|
import { executeTool } from '../tools.js';
|
|
@@ -256,7 +258,7 @@ export async function chatCodex(params) {
|
|
|
256
258
|
return parsed.outputText || '[No response from Codex]';
|
|
257
259
|
}
|
|
258
260
|
catch (err) {
|
|
259
|
-
const errorMessage =
|
|
261
|
+
const errorMessage = toErrorMessage(err);
|
|
260
262
|
genObs?.update({ level: 'ERROR', statusMessage: errorMessage, output: { error: errorMessage } });
|
|
261
263
|
genObs?.end();
|
|
262
264
|
throw err;
|
|
@@ -288,7 +290,7 @@ export async function chatWithToolsCodex(params) {
|
|
|
288
290
|
const { getToolDefinitions } = await import('../tools.js');
|
|
289
291
|
const includeSpawn = !!(toolContext?.fullConfig && (toolContext?.chatId || toolContext?.isCronJob));
|
|
290
292
|
const toolDefs = await getToolDefinitions(toolConfig, {
|
|
291
|
-
|
|
293
|
+
includeAgentTools: includeSpawn,
|
|
292
294
|
includeMcp: false,
|
|
293
295
|
projects: toolContext?.fullConfig?.projects
|
|
294
296
|
});
|
|
@@ -305,10 +307,12 @@ export async function chatWithToolsCodex(params) {
|
|
|
305
307
|
toolCalls: toolLog,
|
|
306
308
|
};
|
|
307
309
|
}
|
|
310
|
+
// Compact old tool results if context is growing large
|
|
311
|
+
const inputForApi = compactCodexMessages(input, toolConfig.contextManagement, i + 1);
|
|
308
312
|
const body = {
|
|
309
313
|
model: modelId,
|
|
310
314
|
instructions,
|
|
311
|
-
input,
|
|
315
|
+
input: inputForApi,
|
|
312
316
|
store: false,
|
|
313
317
|
stream: true,
|
|
314
318
|
reasoning: { effort: 'medium', summary: 'auto' },
|
|
@@ -343,7 +347,7 @@ export async function chatWithToolsCodex(params) {
|
|
|
343
347
|
guard.recordTokens(parsed.response?.usage?.input_tokens ?? 0, parsed.response?.usage?.output_tokens ?? 0);
|
|
344
348
|
}
|
|
345
349
|
catch (err) {
|
|
346
|
-
const errorMessage =
|
|
350
|
+
const errorMessage = toErrorMessage(err);
|
|
347
351
|
genObs?.update({ level: 'ERROR', statusMessage: errorMessage, output: { error: errorMessage } });
|
|
348
352
|
genObs?.end();
|
|
349
353
|
throw err;
|
|
@@ -390,7 +394,7 @@ export async function chatWithToolsCodex(params) {
|
|
|
390
394
|
finalText = finalized.outputText?.trim() || '';
|
|
391
395
|
}
|
|
392
396
|
catch (err) {
|
|
393
|
-
const msg =
|
|
397
|
+
const msg = toErrorMessage(err);
|
|
394
398
|
console.warn(`[codex] Finalization pass failed: ${msg}`);
|
|
395
399
|
}
|
|
396
400
|
}
|
|
@@ -473,7 +477,7 @@ export async function chatWithToolsCodex(params) {
|
|
|
473
477
|
}
|
|
474
478
|
}
|
|
475
479
|
catch (err) {
|
|
476
|
-
const errorMessage =
|
|
480
|
+
const errorMessage = toErrorMessage(err);
|
|
477
481
|
toolObs?.update({ level: 'ERROR', statusMessage: errorMessage, output: { error: errorMessage } });
|
|
478
482
|
toolObs?.end();
|
|
479
483
|
if (toolContext?.auditTraceId) {
|
|
@@ -0,0 +1,22 @@
|
|
|
1
|
+
import type { ContextManagementConfig } from './types.js';
|
|
2
|
+
export type { ContextManagementConfig };
|
|
3
|
+
/** Rough token estimate: 1 token ≈ 4 chars of JSON. */
|
|
4
|
+
export declare function estimateTokens(data: any[]): number;
|
|
5
|
+
/**
|
|
6
|
+
* Compact Anthropic-format apiMessages when over threshold.
|
|
7
|
+
* Truncates content of old tool_result blocks; leaves last KEEP_TAIL messages intact.
|
|
8
|
+
* Does NOT mutate the input array — returns a new array.
|
|
9
|
+
*/
|
|
10
|
+
export declare function compactAnthropicMessages(messages: any[], config?: ContextManagementConfig, iteration?: number): any[];
|
|
11
|
+
/**
|
|
12
|
+
* Compact OpenAI-format apiMessages when over threshold.
|
|
13
|
+
* Truncates content of old `role: 'tool'` messages; leaves last KEEP_TAIL messages intact.
|
|
14
|
+
* Does NOT mutate the input array — returns a new array.
|
|
15
|
+
*/
|
|
16
|
+
export declare function compactOpenAIMessages(messages: any[], config?: ContextManagementConfig, iteration?: number): any[];
|
|
17
|
+
/**
|
|
18
|
+
* Compact Codex-format input items when over threshold.
|
|
19
|
+
* Truncates output of old function_call_output items; leaves last KEEP_TAIL items intact.
|
|
20
|
+
* Does NOT mutate the input array — returns a new array.
|
|
21
|
+
*/
|
|
22
|
+
export declare function compactCodexMessages(input: any[], config?: ContextManagementConfig, iteration?: number): any[];
|