@portkey-ai/hoot 0.11.1 → 0.12.0

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.
@@ -0,0 +1,12 @@
1
+ ### Added
2
+ - **Enhanced OAuth Detection**: Improved server auto-detection with parallel probing
3
+ - Simultaneously checks WWW-Authenticate header and RFC 9728 metadata
4
+ - Faster and more reliable OAuth server discovery
5
+ - Better handling of different OAuth implementation patterns
6
+
7
+ ### Changed
8
+ - **Build Configuration**: Split build commands for npm and Cloudflare deployments
9
+ - `npm run build` now defaults to `localhost:8008` backend (for npm package users)
10
+ - Added `npm run build:cloudflare` for cloud deployments with production backend
11
+ - Ensures npm/npx users connect to local backend server automatically
12
+
package/README.md CHANGED
@@ -6,7 +6,7 @@
6
6
  testing tool for MCP servers. like postman but for MCP.
7
7
 
8
8
 
9
- https://github.com/user-attachments/assets/76bad3b4-9206-4b68-ba3d-a1e299802740
9
+ https://github.com/user-attachments/assets/e3add38e-9636-4f40-99d8-f4a2b8f0f056
10
10
 
11
11
 
12
12
  ## why
@@ -27,6 +27,9 @@ npm install -g @portkey-ai/hoot
27
27
  hoot
28
28
  ```
29
29
 
30
+ ![npx-hoot](https://github.com/user-attachments/assets/3c8c80e2-6ad3-439e-80eb-e2f6c4d22d8e)
31
+
32
+
30
33
  ## what works
31
34
 
32
35
  - connect to MCP servers (http/sse)
@@ -7,4 +7,4 @@
7
7
 
8
8
  Outdated base version: https://github.com/primer/github-syntax-dark
9
9
  Current colors taken from GitHub's CSS
10
- */.hljs{color:#c9d1d9;background:#0d1117}.hljs-doctag,.hljs-keyword,.hljs-meta .hljs-keyword,.hljs-template-tag,.hljs-template-variable,.hljs-type,.hljs-variable.language_{color:#ff7b72}.hljs-title,.hljs-title.class_,.hljs-title.class_.inherited__,.hljs-title.function_{color:#d2a8ff}.hljs-attr,.hljs-attribute,.hljs-literal,.hljs-meta,.hljs-number,.hljs-operator,.hljs-variable,.hljs-selector-attr,.hljs-selector-class,.hljs-selector-id{color:#79c0ff}.hljs-regexp,.hljs-string,.hljs-meta .hljs-string{color:#a5d6ff}.hljs-built_in,.hljs-symbol{color:#ffa657}.hljs-comment,.hljs-code,.hljs-formula{color:#8b949e}.hljs-name,.hljs-quote,.hljs-selector-tag,.hljs-selector-pseudo{color:#7ee787}.hljs-subst{color:#c9d1d9}.hljs-section{color:#1f6feb;font-weight:700}.hljs-bullet{color:#f2cc60}.hljs-emphasis{color:#c9d1d9;font-style:italic}.hljs-strong{color:#c9d1d9;font-weight:700}.hljs-addition{color:#aff5b4;background-color:#033a16}.hljs-deletion{color:#ffdcd7;background-color:#67060c}.mention-input-wrapper{display:flex;flex-direction:column;flex:1}.mention-input-container{position:relative;display:flex;flex-direction:column;flex:1;background:var(--bg-primary);border:1px solid var(--border-bright);border-radius:8px;transition:border-color .15s ease,box-shadow .15s ease}.mention-input-container:focus-within{border-color:var(--theme-accent-primary);box-shadow:0 0 0 3px color-mix(in srgb,var(--theme-accent-primary) 15%,transparent)}.mention-tags{display:flex;flex-wrap:wrap;align-items:center;gap:.375rem;padding:.5rem .5rem 0}.mention-tag{display:inline-flex;align-items:center;gap:.25rem;padding:.25rem .5rem;background:var(--theme-accent-primary);color:var(--theme-text-on-accent);border-radius:6px;font-size:.75rem;font-family:var(--font-mono);font-weight:500;transition:all .15s ease}.mention-tag:hover{background:var(--theme-accent-tertiary);color:var(--theme-text-on-accent)}.mention-tag-favicon{width:12px;height:12px;object-fit:contain;flex-shrink:0}.mention-tag-server{opacity:.8}.mention-tag-separator{opacity:.6;margin:0 -.125rem}.mention-tag-remove{display:flex;align-items:center;justify-content:center;width:16px;height:16px;margin-left:.125rem;background:#0003;border:none;border-radius:3px;color:currentColor;font-size:1rem;line-height:1;cursor:pointer;transition:all .15s ease}.mention-tag-remove:hover{background:#0000004d}.mention-add-button{display:flex;align-items:center;justify-content:center;width:24px;height:24px;background:var(--bg-secondary);border:1px dashed var(--border-color);border-radius:6px;color:var(--text-secondary);font-size:1rem;line-height:1;cursor:pointer;transition:all .15s ease}.mention-add-button:hover:not(:disabled){background:var(--bg-hover);border-color:var(--theme-accent-primary);color:var(--theme-accent-primary)}.mention-add-button:disabled{opacity:.5;cursor:not-allowed}.mention-add-button-initial{position:absolute;top:.75rem;right:3.5rem;z-index:1}.mention-filter-button{display:flex;align-items:center;gap:.5rem;padding:.375rem .625rem;margin:.5rem .5rem 0;background:transparent;border:1px dashed var(--border-color);border-radius:6px;color:var(--text-secondary);font-size:.8125rem;font-weight:500;cursor:pointer;transition:all .15s ease;width:fit-content}.mention-filter-button:hover:not(:disabled){border-color:var(--theme-accent-primary);color:var(--theme-accent-primary);background:transparent}.mention-filter-button:disabled{opacity:.5;cursor:not-allowed}.mention-input{flex:1;background:transparent;border:none;padding:.75rem;color:var(--text-primary);font-family:var(--font-sans);font-size:.875rem;resize:none;max-height:120px;line-height:1.4}.mention-input:focus{outline:none}.mention-input::placeholder{color:var(--text-placeholder)}.mention-input:disabled{opacity:.6;cursor:not-allowed}.mention-dropdown{position:absolute;left:0;right:0;background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:8px;box-shadow:0 8px 24px #0006;z-index:1000;max-height:300px;overflow:hidden;display:flex;flex-direction:column}.mention-dropdown-down{top:calc(100% + .5rem)}.mention-dropdown-up{bottom:calc(100% + .5rem)}.mention-dropdown-header{padding:.75rem;border-bottom:1px solid var(--border-color);background:var(--bg-tertiary)}.mention-dropdown-search{width:100%;background:var(--bg-primary);border:1px solid var(--border-color);border-radius:6px;padding:.5rem .75rem;color:var(--text-primary);font-family:var(--font-sans);font-size:.8125rem;transition:border-color .15s ease}.mention-dropdown-search:focus{outline:none;border-color:var(--theme-accent-primary)}.mention-dropdown-search::placeholder{color:var(--text-placeholder)}.mention-dropdown-list{overflow-y:auto;max-height:260px}.mention-dropdown-item{display:flex;align-items:center;gap:.5rem;padding:.625rem .75rem;cursor:pointer;transition:all .1s ease;border-bottom:1px solid var(--border-color)}.mention-dropdown-item:last-child{border-bottom:none}.mention-dropdown-item:hover,.mention-dropdown-item.selected{background:var(--bg-hover)}.mention-dropdown-item.selected{background:color-mix(in srgb,var(--theme-accent-primary) 10%,transparent);border-left:2px solid var(--theme-accent-primary);padding-left:calc(.75rem - 2px)}.mention-dropdown-item-icon{display:flex;align-items:center;justify-content:center;width:20px;height:20px;flex-shrink:0;color:var(--text-secondary)}.mention-dropdown-item.selected .mention-dropdown-item-icon{color:var(--theme-accent-primary)}.mention-dropdown-item-content{flex:1;display:flex;flex-direction:column;gap:.125rem;min-width:0}.mention-dropdown-item-name{font-size:.8125rem;font-weight:500;color:var(--text-primary);font-family:var(--font-mono);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.mention-dropdown-item-meta{font-size:.7rem;color:var(--text-tertiary);font-family:var(--font-mono)}.mention-dropdown-item-type{font-size:.7rem;font-weight:600;text-transform:uppercase;color:var(--text-tertiary);padding:.125rem .375rem;background:var(--bg-primary);border-radius:3px;font-family:var(--font-mono)}.mention-dropdown-item.selected .mention-dropdown-item-type{background:var(--theme-accent-primary);color:var(--theme-text-on-accent)}.mention-dropdown-list::-webkit-scrollbar{width:6px}.mention-dropdown-list::-webkit-scrollbar-track{background:var(--bg-secondary)}.mention-dropdown-list::-webkit-scrollbar-thumb{background:var(--border-bright);border-radius:3px}.mention-dropdown-list::-webkit-scrollbar-thumb:hover{background:var(--bg-active)}.mention-dropdown-empty{padding:2rem;text-align:center;color:var(--text-tertiary);font-size:.875rem}.hybrid-interface{display:flex;flex-direction:column;height:100%;background:var(--bg-primary);overflow:hidden}.chat-info-bar{display:flex;align-items:center;gap:.5rem;padding:.5rem 1rem;background:var(--bg-secondary);border-bottom:1px solid var(--border-color);font-size:.8125rem;color:var(--text-secondary)}.chat-info-left{display:flex;align-items:center;gap:.75rem;flex:1}.info-item{display:flex;align-items:center;gap:.375rem}.info-divider{opacity:.3}.info-settings-button{display:flex;align-items:center;gap:.5rem;padding:.375rem .625rem;background:var(--bg-tertiary);border:1px solid var(--border-color);border-radius:5px;color:var(--text-secondary);font-size:.8125rem;cursor:pointer;transition:all .2s ease;position:relative}.info-settings-button:has(.btn-shortcut-hint){padding-right:3rem}.info-settings-button .btn-shortcut-hint{position:absolute;right:.5rem;font-family:var(--font-mono);font-size:.75rem;font-weight:700;padding:.25rem .5rem;border-radius:3px;background:var(--bg-primary);border:1px solid var(--border-color);opacity:.6;transition:opacity var(--transition-fast);line-height:1}.info-settings-button:hover .btn-shortcut-hint{opacity:1}.info-settings-button:hover{background:var(--bg-hover);color:var(--text-primary);border-color:var(--theme-accent-primary)}.info-settings-button.needs-setup{border-color:var(--theme-info);background:color-mix(in srgb,var(--theme-info) 10%,transparent)}.info-settings-button.needs-setup:hover{border-color:var(--theme-info);background:color-mix(in srgb,var(--theme-info) 15%,transparent)}.info-settings-button.filter-toggle-button.filter-active{border-color:var(--theme-accent-primary);background:color-mix(in srgb,var(--theme-accent-primary) 10%,transparent);color:var(--theme-accent-primary)}.info-settings-button.filter-toggle-button.filter-active:hover{border-color:var(--theme-accent-primary);background:color-mix(in srgb,var(--theme-accent-primary) 20%,transparent)}.info-settings-button.filter-toggle-button.filter-inactive{border-color:var(--border-color);background:var(--bg-tertiary);color:var(--text-secondary);opacity:.7}.info-settings-button.filter-toggle-button.filter-inactive:hover{opacity:1;border-color:var(--text-secondary);background:var(--bg-hover)}.setup-indicator{font-size:.75rem;font-weight:500;color:var(--orange-500)}.hybrid-content{flex:1;display:flex;overflow:hidden}.chat-pane{flex:1;display:flex;flex-direction:column;border-right:1px solid var(--border-color);transition:all .3s ease;overflow:hidden;position:relative}.chat-pane.full-width{flex:1;border-right:none}.chat-messages-scroll-wrapper{flex:1;overflow-y:auto;overflow-x:hidden;min-height:0;scroll-behavior:auto}.chat-messages-hybrid{padding:2rem 1.5rem 1rem;display:flex;flex-direction:column;gap:1rem;max-width:48rem;margin:0 auto;width:100%}.chat-message-hybrid{display:flex;animation:fadeInHybrid .3s ease}.chat-message-hybrid.chat-message-user .message-content-hybrid{background:var(--bg-tertiary);border-radius:1.125rem;padding:.75rem 1rem;max-width:70%}.chat-message-hybrid.chat-message-user .message-text-hybrid{color:var(--text-primary);line-height:1.6;font-size:.9375rem}.chat-message-hybrid.chat-message-assistant .message-content-hybrid,.chat-message-hybrid.chat-message-tool,.chat-message-hybrid.chat-message-system{width:100%;font-family:var(--font-mono)}@keyframes fadeInHybrid{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.chat-message-hybrid.has-api-data{cursor:pointer;padding:.5rem;margin:-.5rem;border-radius:8px}.chat-message-hybrid.has-api-data:hover{background:var(--bg-tertiary)}.chat-message-hybrid.selected{background:var(--bg-active);border:1px solid var(--theme-accent-primary);padding:calc(.5rem - 1px);margin:-.5rem;border-radius:8px}.message-content-hybrid{display:flex;flex-direction:column;gap:.25rem;min-width:0}.message-text-hybrid{color:var(--text-primary);line-height:1.6;font-size:.9375rem}.api-indicator{display:flex;align-items:center;gap:.375rem;font-size:.75rem;color:var(--theme-accent-primary);margin-top:.25rem;opacity:.7}.typing-indicator-hybrid{display:flex;gap:.25rem;padding:.5rem 0}.typing-indicator-hybrid span{width:8px;height:8px;border-radius:50%;background:var(--text-tertiary);animation:bounceHybrid 1.4s infinite ease-in-out}.typing-indicator-hybrid span:nth-child(1){animation-delay:-.32s}.typing-indicator-hybrid span:nth-child(2){animation-delay:-.16s}@keyframes bounceHybrid{0%,80%,to{transform:scale(.8);opacity:.5}40%{transform:scale(1);opacity:1}}.chat-input-container-hybrid{padding:1rem 2rem 2rem;flex:0 0 auto;background:var(--bg-primary);z-index:10}.chat-input-wrapper-hybrid{display:flex;gap:.625rem;align-items:flex-end;max-width:48rem;margin:0 auto;width:100%;padding:0 .5rem;position:relative}.input-shortcut-hint{position:absolute;right:4.5rem;bottom:.75rem;font-family:var(--font-mono);font-size:.875rem;font-weight:700;padding:.375rem .625rem;border-radius:4px;background:var(--bg-secondary);border:1px solid var(--border-color);color:var(--text-tertiary);opacity:.6;pointer-events:none;transition:opacity .2s ease}.chat-input-hybrid{flex:1;background:var(--bg-primary);border:1px solid var(--border-bright);border-radius:8px;padding:.75rem;color:var(--text-primary);font-family:var(--font-sans);font-size:.875rem;resize:none;max-height:120px;line-height:1.4}.chat-input-hybrid:focus{outline:none;border-color:var(--theme-accent-primary);box-shadow:0 0 0 3px color-mix(in srgb,var(--theme-accent-primary) 15%,transparent)}.chat-input-hybrid::placeholder{color:var(--text-placeholder)}.chat-send-button-hybrid{background:var(--theme-accent-primary);border:none;border-radius:6px;padding:.625rem;color:var(--theme-bg-primary);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s ease;flex-shrink:0;height:42px;width:42px}.chat-send-button-hybrid:hover:not(:disabled){background:var(--theme-accent-tertiary);transform:translateY(-1px)}.chat-send-button-hybrid:disabled{opacity:.5;cursor:not-allowed}.api-pane{width:45%;display:flex;flex-direction:column;background:var(--bg-secondary)}.api-pane-header{padding:1rem 1.25rem;border-bottom:1px solid var(--border-color);display:flex;align-items:center;gap:.5rem;font-weight:600;font-size:.875rem;color:var(--text-primary);background:var(--bg-tertiary)}.api-close-button{margin-left:auto;background:none;border:none;color:var(--text-secondary);font-size:1.25rem;line-height:1;cursor:pointer;padding:.25rem .5rem;border-radius:4px;transition:all .2s ease}.api-close-button:hover{background:var(--bg-hover);color:var(--text-primary)}.api-pane-content{flex:1;overflow-y:auto;padding:1rem;display:flex;flex-direction:column;gap:1rem;position:relative}.api-pane-content:after{content:"";position:absolute;bottom:0;left:0;right:0;height:120px;background-image:var(--hills-api-pane);background-size:cover;background-position:bottom;background-repeat:no-repeat;pointer-events:none;opacity:.4;z-index:0}.api-block{background:var(--bg-primary);border:1px solid var(--border-bright);border-radius:8px;overflow:hidden;margin-bottom:.5rem;display:flex;flex-direction:column;max-height:none;position:relative;z-index:1}.api-block-header{padding:.625rem .875rem;display:flex;align-items:center;justify-content:space-between;font-size:.8125rem;font-weight:600;border-bottom:1px solid var(--border-color)}.api-copy-button{display:flex;align-items:center;justify-content:center;padding:.375rem;background:var(--bg-tertiary);border:1px solid var(--border-bright);border-radius:4px;color:var(--text-secondary);cursor:pointer;transition:all .2s ease}.api-copy-button:hover{background:var(--bg-hover);color:var(--text-primary);border-color:var(--theme-accent-primary)}.api-block-header.request{background:var(--bg-tertiary);color:var(--theme-accent-primary)}.api-block-header.response{background:var(--bg-tertiary);color:var(--theme-success)}.api-block-header.tool-call{background:var(--bg-tertiary);color:var(--theme-info)}.api-block-header.tool-result{background:var(--bg-tertiary);color:var(--theme-success)}.api-method,.api-status{font-size:.75rem;font-weight:500;color:var(--text-tertiary)}.tool-name{font-family:var(--font-mono);font-size:.75rem;color:var(--text-secondary)}.api-json-viewer{margin:0;border:none;border-radius:0;background:var(--bg-primary);max-height:none}.api-block .json-viewer{max-height:600px!important;overflow-y:auto!important;padding-bottom:2rem!important;flex:1}.api-empty{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.75rem;color:var(--text-tertiary);text-align:center;padding:2rem;position:relative;overflow:hidden}.api-empty>*{position:relative;z-index:1}.api-empty p{margin:0;font-size:.9375rem}.api-hint{font-size:.8125rem;color:var(--text-tertiary);opacity:.7}.chat-messages-scroll-wrapper::-webkit-scrollbar,.api-pane-content::-webkit-scrollbar{width:8px;height:8px}.chat-messages-scroll-wrapper::-webkit-scrollbar-track,.api-pane-content::-webkit-scrollbar-track{background:var(--bg-primary);border-radius:4px}.chat-messages-scroll-wrapper::-webkit-scrollbar-thumb,.api-pane-content::-webkit-scrollbar-thumb{background:var(--border-bright);border-radius:4px}.chat-messages-scroll-wrapper::-webkit-scrollbar-thumb:hover,.api-pane-content::-webkit-scrollbar-thumb:hover{background:var(--bg-active)}.chat-messages-scroll-wrapper,.api-pane-content{scrollbar-width:thin;scrollbar-color:var(--border-bright) var(--bg-primary)}.filter-metrics-card{position:relative;display:inline-flex;align-items:center;gap:.5rem;padding:.375rem .625rem;border-radius:6px;font-size:.75rem;color:var(--text-secondary);font-family:var(--font-mono);transition:all .2s ease;cursor:default;max-width:fit-content;max-height:fit-content}.filter-metrics-card:hover{background:var(--bg-hover);border-color:var(--theme-accent-primary)}.filter-metrics-main{display:flex;align-items:center;gap:.375rem}.filter-metrics-text{color:var(--text-secondary)}.filter-metrics-text strong{color:var(--text-primary);font-weight:600}.filter-metrics-time{padding:.125rem .375rem;background:var(--bg-primary);border-radius:3px;font-size:.7rem;color:var(--text-tertiary);font-family:var(--font-mono)}.filter-metrics-hover-card{position:absolute;top:100%;left:0;margin-top:.25rem;min-width:300px;width:max(40vw,400px);max-width:min(90vw,700px);max-height:400px;overflow-y:auto;background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:8px;padding:.75rem;box-shadow:0 8px 24px #0006;z-index:9999;opacity:0;pointer-events:none;transform:translateY(-4px);transition:opacity .2s ease,transform .2s ease;display:none;isolation:isolate}.filter-metrics-card:hover .filter-metrics-hover-card{opacity:1;pointer-events:auto;transform:translateY(0);display:block}.filter-metrics-hover-card:hover{opacity:1;pointer-events:auto}.filter-metrics-card:after{content:"";position:absolute;top:100%;left:0;right:0;height:.25rem;opacity:0;pointer-events:auto}.filter-metrics-hover-card::-webkit-scrollbar{width:6px}.filter-metrics-hover-card::-webkit-scrollbar-track{background:var(--bg-tertiary);border-radius:3px}.filter-metrics-hover-card::-webkit-scrollbar-thumb{background:var(--border-bright);border-radius:3px}.filter-metrics-hover-card::-webkit-scrollbar-thumb:hover{background:var(--bg-active)}.filter-metrics-hover-card{scrollbar-width:thin;scrollbar-color:var(--border-bright) var(--bg-tertiary)}.filter-hover-server{display:flex;flex-direction:column;gap:.5rem;padding:.5rem;border-radius:6px}.filter-hover-server:not(:last-child){border-bottom:1px solid var(--border-color);margin-bottom:.5rem;padding-bottom:.75rem}.filter-hover-server-header{display:flex;align-items:center;gap:.5rem}.filter-hover-favicon{width:14px;height:14px;object-fit:contain;flex-shrink:0}.filter-hover-favicon-placeholder{width:14px;height:14px;display:flex;align-items:center;justify-content:center;background:var(--bg-primary);border-radius:3px;flex-shrink:0}.filter-hover-server-name{font-size:.8125rem;font-weight:600;color:var(--text-primary);font-family:var(--font-mono)}.filter-hover-tool-count{margin-left:auto;padding:.125rem .375rem;background:var(--bg-primary);border-radius:10px;font-size:.7rem;color:var(--text-tertiary);font-family:var(--font-mono);font-weight:600}.filter-hover-tools{display:flex;flex-wrap:wrap;gap:.375rem;padding-left:1.5rem}.filter-hover-tool{padding:.25rem .5rem;background:var(--bg-primary);border:1px solid var(--border-color);border-radius:4px;font-size:.7rem;color:var(--text-secondary);font-family:var(--font-mono);transition:all .15s ease}.filter-hover-tool:hover{background:var(--bg-tertiary);border-color:var(--theme-accent-primary);color:var(--text-primary)}.filter-metrics-indicator{display:flex;align-items:center;gap:6px;padding:6px 12px;margin:4px auto;max-width:fit-content;background:#10b98114;border-radius:12px;font-size:11px;color:var(--text-secondary);opacity:.8;transition:opacity .2s}.filter-metrics-indicator:hover{opacity:1}.filter-metrics-indicator svg{color:#10b981;flex-shrink:0}.filter-metrics-indicator .filter-time{opacity:.7;font-size:10px}.chat-message-hybrid.chat-message-system{display:flex;justify-content:flex-start;padding:0;margin:4px 0;border:none;background:transparent;cursor:default;max-height:fit-content;overflow:visible}.chat-message-hybrid.chat-message-system:hover{background:transparent}.chat-message-hybrid.chat-message-tool{padding:0;margin:.5rem 0}.chat-message-hybrid.chat-message-tool .message-content-hybrid{width:100%}.tool-call-card{background:var(--bg-tertiary);border:1px solid color-mix(in srgb,var(--theme-accent-primary) 30%,transparent);border-radius:8px;overflow:hidden;cursor:pointer;transition:all .15s ease}.tool-call-card:hover{border-color:var(--theme-accent-primary);background:var(--bg-secondary)}.tool-call-header{display:flex;align-items:center;gap:.25rem;padding:.75rem 1rem;-webkit-user-select:none;user-select:none}.tool-call-icon{display:flex;align-items:center;justify-content:center;width:24px;height:24px;border-radius:4px;color:var(--theme-text-on-accent);flex-shrink:0}.tool-call-favicon{width:16px;height:16px;object-fit:contain}.tool-call-info{flex:1;display:flex;flex-direction:column;gap:.125rem;min-width:0}.tool-call-name{font-size:.875rem;font-weight:500;color:var(--text-primary);font-family:var(--font-mono)}.tool-call-meta{display:flex;align-items:center;gap:.375rem;font-size:.75rem;color:var(--text-tertiary);font-family:var(--font-mono)}.tool-call-server{color:var(--text-secondary)}.tool-call-meta-divider{color:var(--text-tertiary);opacity:.5}.tool-call-time{color:var(--text-tertiary)}.tool-call-chevron{color:var(--text-tertiary);flex-shrink:0;transition:transform .15s ease}.tool-call-card:hover .tool-call-chevron{transform:translate(2px);color:var(--theme-accent-primary)}.oauth-callback{display:flex;align-items:center;justify-content:center;min-height:100vh;background:var(--bg-primary);padding:var(--spacing-2xl)}.oauth-callback-content{max-width:480px;width:100%;background:linear-gradient(135deg,var(--theme-bg-secondary) 0%,var(--theme-bg-primary) 100%);border:1px solid color-mix(in srgb,var(--theme-accent-primary) 15%,transparent);border-radius:16px;padding:48px 40px;text-align:center;box-shadow:var(--shadow-lg),0 0 0 1px color-mix(in srgb,var(--theme-text-white) 5%,transparent);animation:fadeIn .3s ease-out}.oauth-callback-content.error{border-color:color-mix(in srgb,var(--theme-error) 30%,transparent);background:linear-gradient(135deg,color-mix(in srgb,var(--theme-error) 15%,var(--theme-bg-secondary)),color-mix(in srgb,var(--theme-error) 10%,var(--theme-bg-primary)))}.oauth-icon{font-size:72px;margin-bottom:32px;line-height:1;filter:drop-shadow(0 4px 12px color-mix(in srgb,var(--theme-accent-primary) 30%,transparent))}.oauth-processing{animation:pulse 1.5s ease-in-out infinite}.success-icon{color:var(--green-500);font-size:72px;animation:scaleIn .4s cubic-bezier(.175,.885,.32,1.275)}.error-icon{color:var(--red-500);font-size:72px;animation:shake .5s ease-in-out}.oauth-title{font-size:26px;font-weight:700;color:var(--text-primary);margin-bottom:16px;letter-spacing:-.5px;line-height:1.3}.oauth-message{font-size:15px;color:var(--text-secondary);margin-bottom:32px;line-height:1.6;max-width:450px;margin-left:auto;margin-right:auto;white-space:pre-line;word-wrap:break-word}.oauth-redirect{font-size:13px;color:var(--text-tertiary);font-style:italic;margin-top:24px;opacity:.8}@keyframes scaleIn{0%{transform:scale(0);opacity:0}50%{transform:scale(1.1)}to{transform:scale(1);opacity:1}}@keyframes shake{0%,to{transform:translate(0)}25%{transform:translate(-10px)}75%{transform:translate(10px)}}@keyframes pulse{0%,to{transform:scale(1);opacity:1}50%{transform:scale(1.1);opacity:.8}}@keyframes fadeIn{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.welcome-modal{padding:var(--spacing-md);max-width:600px;margin:0 auto}.welcome-header{text-align:center;margin-bottom:var(--spacing-2xl)}.welcome-logo{font-size:64px;display:block;margin-bottom:var(--spacing-lg);animation:welcomeBounce .6s ease-out}.welcome-title{font-size:28px;font-weight:700;color:var(--theme-text-primary);margin-bottom:var(--spacing-sm);font-family:var(--font-mono);letter-spacing:-.5px}.welcome-subtitle{font-size:16px;color:var(--theme-text-secondary);line-height:1.5;max-width:500px;margin:0 auto}.welcome-features{display:grid;gap:var(--spacing-lg);margin-bottom:var(--spacing-2xl)}.welcome-feature{display:flex;gap:var(--spacing-md);align-items:flex-start;padding:var(--spacing-md);background:var(--theme-bg-secondary);border-radius:var(--radius-md);transition:all var(--transition-fast);cursor:default}.welcome-feature:hover{background:var(--theme-bg-tertiary);transform:translateY(-2px)}.feature-icon{display:flex;align-items:center;justify-content:center;width:48px;height:48px;background:var(--theme-bg-tertiary);border-radius:var(--radius-md);color:var(--theme-accent-primary);flex-shrink:0}.feature-content h3{font-size:16px;font-weight:600;color:var(--theme-text-primary);margin-bottom:var(--spacing-xs);font-family:var(--font-mono)}.feature-content p{font-size:14px;color:var(--theme-text-secondary);line-height:1.5;margin:0}.feature-content kbd{display:inline-flex;align-items:center;justify-content:center;padding:2px 6px;font-size:12px;font-family:var(--font-mono);background:var(--theme-bg-tertiary);border:1px solid var(--theme-border-color);border-radius:4px;color:var(--theme-text-secondary);box-shadow:0 1px 2px #0000001a}.welcome-footer{display:flex;flex-direction:column;gap:var(--spacing-lg);padding-top:var(--spacing-lg);border-top:1px solid var(--theme-border-color)}.welcome-footer label{cursor:pointer}.welcome-actions{display:flex;justify-content:flex-end;gap:var(--spacing-md)}.welcome-actions .btn{min-width:120px;cursor:pointer}@keyframes welcomeBounce{0%{opacity:0;transform:scale(.3)}50%{transform:scale(1.05)}70%{transform:scale(.9)}to{opacity:1;transform:scale(1)}}@media(max-width:768px){.welcome-modal{padding:var(--spacing-sm)}.welcome-logo{font-size:48px}.welcome-title{font-size:24px}.welcome-subtitle{font-size:14px}.welcome-features{gap:var(--spacing-md)}.welcome-feature{flex-direction:column;text-align:center}.feature-icon{margin:0 auto}}.toast-container{position:fixed;top:var(--spacing-2xl);right:var(--spacing-2xl);z-index:9999;display:flex;flex-direction:column;gap:var(--spacing-md);pointer-events:none}.toast{min-width:320px;max-width:480px;background:var(--bg-secondary);border:1px solid var(--border-bright);border-radius:var(--radius-md);padding:var(--spacing-lg);display:flex;align-items:flex-start;gap:var(--spacing-md);box-shadow:var(--shadow-lg);pointer-events:all;animation:slideIn .3s cubic-bezier(.16,1,.3,1)}.toast-icon{flex-shrink:0;display:flex;align-items:center;justify-content:center;width:32px;height:32px;border-radius:var(--radius-sm)}.toast-success .toast-icon{color:var(--theme-success);background:color-mix(in srgb,var(--theme-success) 15%,transparent)}.toast-error .toast-icon{color:var(--theme-error);background:color-mix(in srgb,var(--theme-error) 15%,transparent)}.toast-warning .toast-icon{color:var(--theme-info);background:color-mix(in srgb,var(--theme-info) 15%,transparent)}.toast-info .toast-icon{color:var(--theme-accent-primary);background:color-mix(in srgb,var(--theme-accent-primary) 15%,transparent)}.toast-content{flex:1;min-width:0}.toast-message{font-size:14px;font-weight:600;color:var(--text-primary);margin-bottom:4px;line-height:1.4}.toast-description{font-size:13px;color:var(--text-secondary);line-height:1.5}.toast-close{flex-shrink:0;background:transparent;border:none;color:var(--text-tertiary);cursor:pointer;padding:4px;border-radius:var(--radius-sm);display:flex;align-items:center;justify-content:center;transition:all var(--transition-fast)}.toast-close:hover{background:var(--bg-hover);color:var(--text-primary)}@keyframes slideIn{0%{transform:translate(100%);opacity:0}to{transform:translate(0);opacity:1}}@media(max-width:768px){.toast-container{top:var(--spacing-lg);right:var(--spacing-lg);left:var(--spacing-lg)}.toast{min-width:unset;width:100%}}.error-boundary{display:flex;align-items:center;justify-content:center;min-height:400px;padding:var(--spacing-2xl);background:var(--bg-primary)}.error-boundary-content{max-width:520px;text-align:center}.error-icon{display:inline-flex;align-items:center;justify-content:center;width:96px;height:96px;border-radius:50%;background:#f2877926;color:var(--red-500);margin-bottom:var(--spacing-xl);animation:shake .5s ease-in-out}.error-title{font-size:24px;font-weight:700;color:var(--theme-error);margin-bottom:var(--spacing-md);letter-spacing:-.5px}.error-message{font-size:15px;color:var(--text-secondary);line-height:1.6;margin-bottom:var(--spacing-xl)}.error-details{margin:var(--spacing-xl) 0;text-align:left;background:var(--bg-tertiary);border:1px solid var(--border-color);border-radius:var(--radius-md);padding:var(--spacing-md)}.error-details summary{font-size:13px;font-weight:600;color:var(--text-primary);cursor:pointer;-webkit-user-select:none;user-select:none;padding:var(--spacing-sm)}.error-details summary:hover{color:var(--text-primary)}.error-stack{margin-top:var(--spacing-md);font-family:var(--font-mono);font-size:12px;color:var(--text-tertiary);overflow-x:auto;padding:var(--spacing-md);background:var(--bg-primary);border-radius:var(--radius-sm);line-height:1.6}.error-boundary .btn{display:inline-flex;align-items:center;gap:var(--spacing-sm)}@keyframes shake{0%,to{transform:translate(0)}20%,60%{transform:translate(-8px)}40%,80%{transform:translate(8px)}}.theme-switcher-header{position:relative}.theme-trigger{display:flex;align-items:center;justify-content:center;width:36px;height:36px;color:var(--theme-accent-tertiary);background:transparent;border:none;border-radius:var(--radius-sm);cursor:pointer;transition:all .2s ease}.theme-trigger:hover{background:var(--bg-hover);color:var(--theme-accent-secondary)}.theme-dropdown{position:absolute;top:calc(100% + 12px);right:0;background:var(--bg-secondary);border:1px solid var(--border-bright);border-radius:8px;padding:4px;display:flex;gap:4px;box-shadow:0 4px 16px #00000080;opacity:0;visibility:hidden;transform:translateY(-8px);transition:opacity .2s,transform .2s,visibility 0s .2s;z-index:10000}.theme-switcher-header:hover .theme-dropdown,.theme-dropdown:hover{opacity:1;visibility:visible;transform:translateY(0);transition:opacity .2s,transform .2s,visibility 0s 0s}.theme-switcher-header:before{content:"";position:absolute;top:100%;left:0;right:0;height:12px;opacity:0}.theme-option{display:flex;align-items:center;justify-content:center;width:36px;height:36px;padding:0;background:var(--bg-tertiary);border:1px solid var(--border-color);border-radius:6px;cursor:pointer;transition:all .15s;position:relative;font-size:18px}.theme-option-dark{background:color-mix(in srgb,var(--bg-tertiary) 85%,black);border-color:color-mix(in srgb,var(--border-color) 80%,black)}.theme-option-light{background:color-mix(in srgb,var(--bg-tertiary) 85%,white);border-color:color-mix(in srgb,var(--border-color) 85%,white)}.theme-option-system{background:linear-gradient(135deg,color-mix(in srgb,var(--bg-tertiary) 85%,black) 50%,color-mix(in srgb,var(--bg-tertiary) 85%,white) 50%);border-color:var(--border-bright)}.theme-divider{width:1px;height:36px;background:var(--border-color);margin:0 4px}.theme-option:hover{background:var(--bg-hover);border-color:var(--border-bright);transform:scale(1.1)}.theme-option-dark:hover{background:color-mix(in srgb,var(--bg-hover) 90%,black)}.theme-option-light:hover{background:color-mix(in srgb,var(--bg-hover) 90%,white)}.theme-option.active{background:var(--theme-accent-primary);border-color:var(--theme-accent-primary);box-shadow:0 0 12px color-mix(in srgb,var(--theme-accent-primary) 50%,transparent)}.theme-emoji{font-size:18px;line-height:1}.theme-name{display:none}.theme-option:after{content:attr(data-tooltip);position:absolute;bottom:calc(100% + 8px);left:50%;transform:translate(-50%);background:var(--bg-primary);border:1px solid var(--border-bright);color:var(--text-primary);padding:6px 12px;border-radius:6px;font-size:12px;font-weight:500;white-space:nowrap;opacity:0;pointer-events:none;transition:opacity .2s,transform .2s;box-shadow:0 4px 12px #0006;z-index:10001}.theme-option:hover:after{opacity:1;transform:translate(-50%) translateY(-4px)}.theme-option:before{content:"";position:absolute;bottom:calc(100% + 2px);left:50%;transform:translate(-50%);width:0;height:0;border-left:5px solid transparent;border-right:5px solid transparent;border-top:5px solid var(--border-bright);opacity:0;pointer-events:none;transition:opacity .2s,transform .2s;z-index:10001}.theme-option:hover:before{opacity:1;transform:translate(-50%) translateY(-4px)}.keyboard-shortcuts-modal{max-width:700px;max-height:80vh}.keyboard-shortcuts-modal .modal-body{max-height:60vh;overflow-y:auto}.modal-title-row{display:flex;align-items:center;gap:12px;justify-content:center}.shortcuts-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:24px}.shortcut-category{display:flex;flex-direction:column;gap:12px}.shortcut-category-title{font-size:14px;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:var(--primary-color);margin:0;padding-bottom:8px;border-bottom:1px solid var(--border-color)}.shortcut-list{display:flex;flex-direction:column;gap:8px}.shortcut-item{display:flex;justify-content:space-between;align-items:center;gap:16px;padding:8px;border-radius:6px;transition:background-color .2s}.shortcut-item:hover{background-color:#5ccfe60d}.shortcut-description{font-size:14px;color:var(--text-primary);flex:1}.shortcut-key{display:inline-flex;align-items:center;gap:4px;font-family:SF Mono,Monaco,Inconsolata,Roboto Mono,Courier New,monospace;font-size:12px;font-weight:600;padding:4px 8px;border-radius:4px;background:linear-gradient(180deg,var(--bg-tertiary) 0%,var(--bg-secondary) 100%);border:1px solid var(--border-color);box-shadow:0 2px 4px #0003;color:var(--text-primary);white-space:nowrap;min-width:50px;text-align:center;justify-content:center}@media(max-width:768px){.shortcuts-grid{grid-template-columns:1fr}.keyboard-shortcuts-modal{max-width:90vw}}.app{display:flex;height:100vh;overflow:hidden;flex-direction:column}.app-header{display:flex;align-items:center;justify-content:space-between;padding:.75rem 1.5rem;background:var(--bg-secondary);border-bottom:1px solid var(--border-color);gap:2rem;flex-shrink:0}.app-header-left{display:flex;align-items:center;gap:1.5rem;flex:1;min-width:0}.app-branding{display:flex;align-items:center;gap:.625rem;min-width:0;flex-shrink:0}.logo-icon{font-size:1.75rem;line-height:1;flex-shrink:0}.app-title{margin:0;font-size:1.5rem;font-weight:700;color:var(--text-primary);letter-spacing:-.02em;flex-shrink:0;text-shadow:0 0 30px rgba(136,192,208,.2)}.app-tagline{font-size:.8125rem;color:var(--theme-accent-tertiary);font-weight:500;margin-left:.5rem;padding-left:.75rem;border-left:1px solid var(--theme-accent-deep);flex-shrink:0}.app-nav{display:flex;gap:.5rem;padding-left:1rem;border-left:1px solid var(--border-color)}.nav-button{display:flex;align-items:center;gap:.5rem;padding:.5rem 1rem;background:transparent;border:none;color:var(--theme-accent-tertiary);opacity:.6;font-size:.875rem;font-weight:500;cursor:pointer;transition:all .2s ease;border-radius:var(--radius-sm);position:relative}.nav-button:hover{background:var(--bg-hover);opacity:.8}.nav-button.active{background:transparent;color:var(--theme-accent-primary);opacity:1}.nav-button.active:after{content:"";position:absolute;bottom:-.75rem;left:.5rem;right:.5rem;height:2px;background:var(--theme-accent-primary);border-radius:1px}.nav-button span{font-weight:500}.demo-badge{margin-left:.375rem;padding:.125rem .375rem;background:var(--orange-500);color:var(--bg-primary);font-size:.625rem;font-weight:700;border-radius:3px;text-transform:uppercase;letter-spacing:.025em}.app-actions{display:flex;align-items:center;gap:.75rem;min-width:0}.header-link{display:flex;align-items:center;justify-content:center;width:36px;height:36px;color:var(--theme-accent-tertiary);border-radius:var(--radius-sm);transition:all .2s ease;text-decoration:none;border:none;background:transparent;cursor:pointer;padding:0}.header-link:hover{background:var(--bg-hover);color:var(--theme-accent-secondary)}.version-badge{display:flex;align-items:center;gap:.5rem;padding:.375rem .75rem;background:color-mix(in srgb,var(--theme-accent-tertiary) 10%,transparent);border:1px solid color-mix(in srgb,var(--theme-accent-tertiary) 20%,transparent);border-radius:var(--radius-sm);font-size:.6875rem;font-weight:600;color:var(--theme-accent-tertiary);font-family:var(--font-mono);text-decoration:none;transition:all .2s ease;cursor:pointer}.version-badge:hover{background:color-mix(in srgb,var(--theme-accent-tertiary) 15%,transparent);color:var(--theme-accent-secondary);border-color:var(--theme-accent-primary)}.app-content{flex:1;overflow:hidden;display:flex}.test-layout{display:flex;flex:1;overflow:hidden}.app-content>.hybrid-interface{flex:1;width:100%}:root{--font-sans: "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;--font-mono: "JetBrains Mono", "Monaco", "Menlo", "Courier New", monospace;--spacing-xs: 4px;--spacing-sm: 8px;--spacing-md: 12px;--spacing-lg: 16px;--spacing-xl: 20px;--spacing-2xl: 24px;--radius-sm: 6px;--radius-md: 8px;--radius-lg: 12px;--shadow-sm: 0 1px 2px 0 rgba(0, 0, 0, .05);--shadow-md: 0 4px 6px -1px rgba(0, 0, 0, .1), 0 2px 4px -1px rgba(0, 0, 0, .06);--shadow-lg: 0 10px 15px -3px rgba(0, 0, 0, .1), 0 4px 6px -2px rgba(0, 0, 0, .05);--transition-fast: .15s cubic-bezier(0, 0, .2, 1);--transition-base: .2s cubic-bezier(.4, 0, .2, 1);--hills-main-area: url("data:image/svg+xml,%3Csvg viewBox='0 0 1920 150' xmlns='http://www.w3.org/2000/svg' preserveAspectRatio='none'%3E%3C/svg%3E");--hills-tools-sidebar: url("data:image/svg+xml,%3Csvg viewBox='0 0 1920 150' xmlns='http://www.w3.org/2000/svg' preserveAspectRatio='none'%3E%3C/svg%3E");--hills-server-sidebar: url("data:image/svg+xml,%3Csvg viewBox='0 0 1920 150' xmlns='http://www.w3.org/2000/svg' preserveAspectRatio='none'%3E%3C/svg%3E");--hills-empty-state: url("data:image/svg+xml,%3Csvg viewBox='0 0 1920 150' xmlns='http://www.w3.org/2000/svg' preserveAspectRatio='none'%3E%3C/svg%3E");--hills-api-pane: url("data:image/svg+xml,%3Csvg viewBox='0 0 1920 150' xmlns='http://www.w3.org/2000/svg' preserveAspectRatio='none'%3E%3C/svg%3E")}*{margin:0;padding:0;box-sizing:border-box}*{scrollbar-gutter:stable}::-webkit-scrollbar{width:12px;height:12px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:color-mix(in srgb,var(--text-tertiary) 20%,transparent);border-radius:6px;border:3px solid transparent;background-clip:padding-box;transition:background-color .2s ease}*:hover::-webkit-scrollbar-thumb,*:focus-within::-webkit-scrollbar-thumb,*:active::-webkit-scrollbar-thumb{background:color-mix(in srgb,var(--text-tertiary) 35%,transparent);background-clip:padding-box}*:hover::-webkit-scrollbar-thumb:hover,*::-webkit-scrollbar-thumb:active{background:color-mix(in srgb,var(--text-tertiary) 55%,transparent);background-clip:padding-box}*{scrollbar-width:thin;scrollbar-color:color-mix(in srgb,var(--text-tertiary) 20%,transparent) transparent}*:hover,*:focus-within,*:active{scrollbar-color:color-mix(in srgb,var(--text-tertiary) 35%,transparent) transparent}html{overscroll-behavior:none;overscroll-behavior-y:none}body{font-family:var(--font-sans);background:var(--bg-primary);color:var(--text-primary);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-feature-settings:"liga" 1,"calt" 1;overscroll-behavior:none;overscroll-behavior-y:none}#root{height:100vh;overflow:hidden;transform:translateZ(0);will-change:auto}button,.clickable{-webkit-user-select:none;user-select:none}code,pre{font-family:var(--font-mono);font-variant-ligatures:common-ligatures}::-webkit-scrollbar{width:10px;height:10px}::-webkit-scrollbar-track{background:var(--theme-bg-primary)}::-webkit-scrollbar-thumb{background:linear-gradient(180deg,var(--theme-accent-primary) 0%,var(--theme-accent-tertiary) 100%);border-radius:4px;border:2px solid var(--theme-bg-primary)}::-webkit-scrollbar-thumb:hover{background:linear-gradient(180deg,var(--theme-accent-secondary) 0%,var(--theme-accent-primary) 100%)}*:focus-visible:not(input):not(textarea):not(select){outline:2px solid var(--theme-accent-primary);outline-offset:2px}input:focus-visible,textarea:focus-visible,select:focus-visible{outline:none}::selection{background:var(--theme-accent-primary);color:var(--theme-bg-primary)}@keyframes fadeIn{0%{opacity:0;transform:translateY(4px)}to{opacity:1;transform:translateY(0)}}@keyframes slideIn{0%{opacity:0;transform:translate(-8px)}to{opacity:1;transform:translate(0)}}@keyframes spin{to{transform:rotate(360deg)}}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}@keyframes frost-pulse{0%,to{opacity:.3;transform:scale(1)}50%{opacity:0;transform:scale(1.5)}}@keyframes aurora-glow{0%,to{box-shadow:0 0 20px color-mix(in srgb,var(--theme-accent-primary) 30%,transparent)}33%{box-shadow:0 0 20px color-mix(in srgb,var(--theme-success) 30%,transparent)}66%{box-shadow:0 0 20px color-mix(in srgb,var(--theme-special) 30%,transparent)}}.animate-fade-in{animation:fadeIn .2s ease-out}.animate-slide-in{animation:slideIn .3s ease-out}.animate-spin{animation:spin 1s linear infinite}.animate-pulse{animation:pulse 2s cubic-bezier(.4,0,.6,1) infinite}.gpu-accelerated{transform:translateZ(0);backface-visibility:hidden;perspective:1000px}.font-mono{font-family:var(--font-mono)}
10
+ */.hljs{color:#c9d1d9;background:#0d1117}.hljs-doctag,.hljs-keyword,.hljs-meta .hljs-keyword,.hljs-template-tag,.hljs-template-variable,.hljs-type,.hljs-variable.language_{color:#ff7b72}.hljs-title,.hljs-title.class_,.hljs-title.class_.inherited__,.hljs-title.function_{color:#d2a8ff}.hljs-attr,.hljs-attribute,.hljs-literal,.hljs-meta,.hljs-number,.hljs-operator,.hljs-variable,.hljs-selector-attr,.hljs-selector-class,.hljs-selector-id{color:#79c0ff}.hljs-regexp,.hljs-string,.hljs-meta .hljs-string{color:#a5d6ff}.hljs-built_in,.hljs-symbol{color:#ffa657}.hljs-comment,.hljs-code,.hljs-formula{color:#8b949e}.hljs-name,.hljs-quote,.hljs-selector-tag,.hljs-selector-pseudo{color:#7ee787}.hljs-subst{color:#c9d1d9}.hljs-section{color:#1f6feb;font-weight:700}.hljs-bullet{color:#f2cc60}.hljs-emphasis{color:#c9d1d9;font-style:italic}.hljs-strong{color:#c9d1d9;font-weight:700}.hljs-addition{color:#aff5b4;background-color:#033a16}.hljs-deletion{color:#ffdcd7;background-color:#67060c}.mention-input-wrapper{display:flex;flex-direction:column;flex:1}.mention-input-container{position:relative;display:flex;flex-direction:column;flex:1;background:var(--bg-primary);border:1px solid var(--border-bright);border-radius:8px;transition:border-color .15s ease,box-shadow .15s ease}.mention-input-container:focus-within{border-color:var(--theme-accent-primary);box-shadow:0 0 0 3px color-mix(in srgb,var(--theme-accent-primary) 15%,transparent)}.mention-tags{display:flex;flex-wrap:wrap;align-items:center;gap:.375rem;padding:.5rem .5rem 0}.mention-tag{display:inline-flex;align-items:center;gap:.25rem;padding:.25rem .5rem;background:var(--theme-accent-primary);color:var(--theme-text-on-accent);border-radius:6px;font-size:.75rem;font-family:var(--font-mono);font-weight:500;transition:all .15s ease}.mention-tag:hover{background:var(--theme-accent-tertiary);color:var(--theme-text-on-accent)}.mention-tag-favicon{width:12px;height:12px;object-fit:contain;flex-shrink:0}.mention-tag-server{opacity:.8}.mention-tag-separator{opacity:.6;margin:0 -.125rem}.mention-tag-remove{display:flex;align-items:center;justify-content:center;width:16px;height:16px;margin-left:.125rem;background:#0003;border:none;border-radius:3px;color:currentColor;font-size:1rem;line-height:1;cursor:pointer;transition:all .15s ease}.mention-tag-remove:hover{background:#0000004d}.mention-add-button{display:flex;align-items:center;justify-content:center;width:24px;height:24px;background:var(--bg-secondary);border:1px dashed var(--border-color);border-radius:6px;color:var(--text-secondary);font-size:1rem;line-height:1;cursor:pointer;transition:all .15s ease}.mention-add-button:hover:not(:disabled){background:var(--bg-hover);border-color:var(--theme-accent-primary);color:var(--theme-accent-primary)}.mention-add-button:disabled{opacity:.5;cursor:not-allowed}.mention-add-button-initial{position:absolute;top:.75rem;right:3.5rem;z-index:1}.mention-filter-button{display:flex;align-items:center;gap:.5rem;padding:.375rem .625rem;margin:.5rem .5rem 0;background:transparent;border:1px dashed var(--border-color);border-radius:6px;color:var(--text-secondary);font-size:.8125rem;font-weight:500;cursor:pointer;transition:all .15s ease;width:fit-content}.mention-filter-button:hover:not(:disabled){border-color:var(--theme-accent-primary);color:var(--theme-accent-primary);background:transparent}.mention-filter-button:disabled{opacity:.5;cursor:not-allowed}.mention-input{flex:1;background:transparent;border:none;padding:.75rem;color:var(--text-primary);font-family:var(--font-sans);font-size:.875rem;resize:none;max-height:120px;line-height:1.4}.mention-input:focus{outline:none}.mention-input::placeholder{color:var(--text-placeholder)}.mention-input:disabled{opacity:.6;cursor:not-allowed}.mention-dropdown{position:absolute;left:0;right:0;background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:8px;box-shadow:0 8px 24px #0006;z-index:1000;max-height:300px;overflow:hidden;display:flex;flex-direction:column}.mention-dropdown-down{top:calc(100% + .5rem)}.mention-dropdown-up{bottom:calc(100% + .5rem)}.mention-dropdown-header{padding:.75rem;border-bottom:1px solid var(--border-color);background:var(--bg-tertiary)}.mention-dropdown-search{width:100%;background:var(--bg-primary);border:1px solid var(--border-color);border-radius:6px;padding:.5rem .75rem;color:var(--text-primary);font-family:var(--font-sans);font-size:.8125rem;transition:border-color .15s ease}.mention-dropdown-search:focus{outline:none;border-color:var(--theme-accent-primary)}.mention-dropdown-search::placeholder{color:var(--text-placeholder)}.mention-dropdown-list{overflow-y:auto;max-height:260px}.mention-dropdown-item{display:flex;align-items:center;gap:.5rem;padding:.625rem .75rem;cursor:pointer;transition:all .1s ease;border-bottom:1px solid var(--border-color)}.mention-dropdown-item:last-child{border-bottom:none}.mention-dropdown-item:hover,.mention-dropdown-item.selected{background:var(--bg-hover)}.mention-dropdown-item.selected{background:color-mix(in srgb,var(--theme-accent-primary) 10%,transparent);border-left:2px solid var(--theme-accent-primary);padding-left:calc(.75rem - 2px)}.mention-dropdown-item-icon{display:flex;align-items:center;justify-content:center;width:20px;height:20px;flex-shrink:0;color:var(--text-secondary)}.mention-dropdown-item.selected .mention-dropdown-item-icon{color:var(--theme-accent-primary)}.mention-dropdown-item-content{flex:1;display:flex;flex-direction:column;gap:.125rem;min-width:0}.mention-dropdown-item-name{font-size:.8125rem;font-weight:500;color:var(--text-primary);font-family:var(--font-mono);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.mention-dropdown-item-meta{font-size:.7rem;color:var(--text-tertiary);font-family:var(--font-mono)}.mention-dropdown-item-type{font-size:.7rem;font-weight:600;text-transform:uppercase;color:var(--text-tertiary);padding:.125rem .375rem;background:var(--bg-primary);border-radius:3px;font-family:var(--font-mono)}.mention-dropdown-item.selected .mention-dropdown-item-type{background:var(--theme-accent-primary);color:var(--theme-text-on-accent)}.mention-dropdown-list::-webkit-scrollbar{width:6px}.mention-dropdown-list::-webkit-scrollbar-track{background:var(--bg-secondary)}.mention-dropdown-list::-webkit-scrollbar-thumb{background:var(--border-bright);border-radius:3px}.mention-dropdown-list::-webkit-scrollbar-thumb:hover{background:var(--bg-active)}.mention-dropdown-empty{padding:2rem;text-align:center;color:var(--text-tertiary);font-size:.875rem}.hybrid-interface{display:flex;flex-direction:column;height:100%;background:var(--bg-primary);overflow:hidden}.chat-info-bar{display:flex;align-items:center;gap:.5rem;padding:.5rem 1rem;background:var(--bg-secondary);border-bottom:1px solid var(--border-color);font-size:.8125rem;color:var(--text-secondary)}.chat-info-left{display:flex;align-items:center;gap:.75rem;flex:1}.info-item{display:flex;align-items:center;gap:.375rem}.info-divider{opacity:.3}.info-settings-button{display:flex;align-items:center;gap:.5rem;padding:.375rem .625rem;background:var(--bg-tertiary);border:1px solid var(--border-color);border-radius:5px;color:var(--text-secondary);font-size:.8125rem;cursor:pointer;transition:all .2s ease;position:relative}.info-settings-button:has(.btn-shortcut-hint){padding-right:3rem}.info-settings-button .btn-shortcut-hint{position:absolute;right:.5rem;font-family:var(--font-mono);font-size:.75rem;font-weight:700;padding:.25rem .5rem;border-radius:3px;background:var(--bg-primary);border:1px solid var(--border-color);opacity:.6;transition:opacity var(--transition-fast);line-height:1}.info-settings-button:hover .btn-shortcut-hint{opacity:1}.info-settings-button:hover{background:var(--bg-hover);color:var(--text-primary);border-color:var(--theme-accent-primary)}.info-settings-button.needs-setup{border-color:var(--theme-info);background:color-mix(in srgb,var(--theme-info) 10%,transparent)}.info-settings-button.needs-setup:hover{border-color:var(--theme-info);background:color-mix(in srgb,var(--theme-info) 15%,transparent)}.info-settings-button.filter-toggle-button.filter-active{border-color:var(--theme-accent-primary);background:color-mix(in srgb,var(--theme-accent-primary) 10%,transparent);color:var(--theme-accent-primary)}.info-settings-button.filter-toggle-button.filter-active:hover{border-color:var(--theme-accent-primary);background:color-mix(in srgb,var(--theme-accent-primary) 20%,transparent)}.info-settings-button.filter-toggle-button.filter-inactive{border-color:var(--border-color);background:var(--bg-tertiary);color:var(--text-secondary);opacity:.7}.info-settings-button.filter-toggle-button.filter-inactive:hover{opacity:1;border-color:var(--text-secondary);background:var(--bg-hover)}.setup-indicator{font-size:.75rem;font-weight:500;color:var(--orange-500)}.hybrid-content{flex:1;display:flex;overflow:hidden}.chat-pane{flex:1;display:flex;flex-direction:column;border-right:1px solid var(--border-color);transition:all .3s ease;overflow:hidden;position:relative}.chat-pane.full-width{flex:1;border-right:none}.chat-messages-scroll-wrapper{flex:1;overflow-y:auto;overflow-x:hidden;min-height:0;scroll-behavior:auto}.chat-messages-hybrid{padding:2rem 1.5rem 1rem;display:flex;flex-direction:column;gap:1rem;max-width:48rem;margin:0 auto;width:100%}.chat-message-hybrid{display:flex;animation:fadeInHybrid .3s ease}.chat-message-hybrid.chat-message-user .message-content-hybrid{background:var(--bg-tertiary);border-radius:1.125rem;padding:.75rem 1rem;max-width:70%}.chat-message-hybrid.chat-message-user .message-text-hybrid{color:var(--text-primary);line-height:1.6;font-size:.9375rem}.chat-message-hybrid.chat-message-assistant .message-content-hybrid,.chat-message-hybrid.chat-message-tool,.chat-message-hybrid.chat-message-system{width:100%;font-family:var(--font-mono)}@keyframes fadeInHybrid{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.chat-message-hybrid.has-api-data{cursor:pointer;padding:.5rem;margin:-.5rem;border-radius:8px}.chat-message-hybrid.has-api-data:hover{background:var(--bg-tertiary)}.chat-message-hybrid.selected{background:var(--bg-active);border:1px solid var(--theme-accent-primary);padding:calc(.5rem - 1px);margin:-.5rem;border-radius:8px}.message-content-hybrid{display:flex;flex-direction:column;gap:.25rem;min-width:0}.message-text-hybrid{color:var(--text-primary);line-height:1.6;font-size:.9375rem}.api-indicator{display:flex;align-items:center;gap:.375rem;font-size:.75rem;color:var(--theme-accent-primary);margin-top:.25rem;opacity:.7}.typing-indicator-hybrid{display:flex;gap:.25rem;padding:.5rem 0}.typing-indicator-hybrid span{width:8px;height:8px;border-radius:50%;background:var(--text-tertiary);animation:bounceHybrid 1.4s infinite ease-in-out}.typing-indicator-hybrid span:nth-child(1){animation-delay:-.32s}.typing-indicator-hybrid span:nth-child(2){animation-delay:-.16s}@keyframes bounceHybrid{0%,80%,to{transform:scale(.8);opacity:.5}40%{transform:scale(1);opacity:1}}.chat-input-container-hybrid{padding:1rem 2rem 2rem;flex:0 0 auto;background:var(--bg-primary);z-index:10}.chat-input-wrapper-hybrid{display:flex;gap:.625rem;align-items:flex-end;max-width:48rem;margin:0 auto;width:100%;padding:0 .5rem;position:relative}.input-shortcut-hint{position:absolute;right:4.5rem;bottom:.75rem;font-family:var(--font-mono);font-size:.875rem;font-weight:700;padding:.375rem .625rem;border-radius:4px;background:var(--bg-secondary);border:1px solid var(--border-color);color:var(--text-tertiary);opacity:.6;pointer-events:none;transition:opacity .2s ease}.chat-input-hybrid{flex:1;background:var(--bg-primary);border:1px solid var(--border-bright);border-radius:8px;padding:.75rem;color:var(--text-primary);font-family:var(--font-sans);font-size:.875rem;resize:none;max-height:120px;line-height:1.4}.chat-input-hybrid:focus{outline:none;border-color:var(--theme-accent-primary);box-shadow:0 0 0 3px color-mix(in srgb,var(--theme-accent-primary) 15%,transparent)}.chat-input-hybrid::placeholder{color:var(--text-placeholder)}.chat-send-button-hybrid{background:var(--theme-accent-primary);border:none;border-radius:6px;padding:.625rem;color:var(--theme-bg-primary);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s ease;flex-shrink:0;height:42px;width:42px}.chat-send-button-hybrid:hover:not(:disabled){background:var(--theme-accent-tertiary);transform:translateY(-1px)}.chat-send-button-hybrid:disabled{opacity:.5;cursor:not-allowed}.api-pane{width:45%;display:flex;flex-direction:column;background:var(--bg-secondary)}.api-pane-header{padding:1rem 1.25rem;border-bottom:1px solid var(--border-color);display:flex;align-items:center;gap:.5rem;font-weight:600;font-size:.875rem;color:var(--text-primary);background:var(--bg-tertiary)}.api-close-button{margin-left:auto;background:none;border:none;color:var(--text-secondary);font-size:1.25rem;line-height:1;cursor:pointer;padding:.25rem .5rem;border-radius:4px;transition:all .2s ease}.api-close-button:hover{background:var(--bg-hover);color:var(--text-primary)}.api-pane-content{flex:1;overflow-y:auto;padding:1rem;display:flex;flex-direction:column;gap:1rem;position:relative}.api-pane-content:after{content:"";position:absolute;bottom:0;left:0;right:0;height:120px;background-image:var(--hills-api-pane);background-size:cover;background-position:bottom;background-repeat:no-repeat;pointer-events:none;opacity:.4;z-index:0}.api-block{background:var(--bg-primary);border:1px solid var(--border-bright);border-radius:8px;overflow:hidden;margin-bottom:.5rem;display:flex;flex-direction:column;max-height:none;position:relative;z-index:1}.api-block-header{padding:.625rem .875rem;display:flex;align-items:center;justify-content:space-between;font-size:.8125rem;font-weight:600;border-bottom:1px solid var(--border-color)}.api-copy-button{display:flex;align-items:center;justify-content:center;padding:.375rem;background:var(--bg-tertiary);border:1px solid var(--border-bright);border-radius:4px;color:var(--text-secondary);cursor:pointer;transition:all .2s ease}.api-copy-button:hover{background:var(--bg-hover);color:var(--text-primary);border-color:var(--theme-accent-primary)}.api-block-header.request{background:var(--bg-tertiary);color:var(--theme-accent-primary)}.api-block-header.response{background:var(--bg-tertiary);color:var(--theme-success)}.api-block-header.tool-call{background:var(--bg-tertiary);color:var(--theme-info)}.api-block-header.tool-result{background:var(--bg-tertiary);color:var(--theme-success)}.api-method,.api-status{font-size:.75rem;font-weight:500;color:var(--text-tertiary)}.tool-name{font-family:var(--font-mono);font-size:.75rem;color:var(--text-secondary)}.api-json-viewer{margin:0;border:none;border-radius:0;background:var(--bg-primary);max-height:none}.api-block .json-viewer{max-height:600px!important;overflow-y:auto!important;padding-bottom:2rem!important;flex:1}.api-empty{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.75rem;color:var(--text-tertiary);text-align:center;padding:2rem;position:relative;overflow:hidden}.api-empty>*{position:relative;z-index:1}.api-empty p{margin:0;font-size:.9375rem}.api-hint{font-size:.8125rem;color:var(--text-tertiary);opacity:.7}.chat-messages-scroll-wrapper::-webkit-scrollbar,.api-pane-content::-webkit-scrollbar{width:8px;height:8px}.chat-messages-scroll-wrapper::-webkit-scrollbar-track,.api-pane-content::-webkit-scrollbar-track{background:var(--bg-primary);border-radius:4px}.chat-messages-scroll-wrapper::-webkit-scrollbar-thumb,.api-pane-content::-webkit-scrollbar-thumb{background:var(--border-bright);border-radius:4px}.chat-messages-scroll-wrapper::-webkit-scrollbar-thumb:hover,.api-pane-content::-webkit-scrollbar-thumb:hover{background:var(--bg-active)}.chat-messages-scroll-wrapper,.api-pane-content{scrollbar-width:thin;scrollbar-color:var(--border-bright) var(--bg-primary)}.filter-metrics-card{position:relative;display:inline-flex;align-items:center;gap:.5rem;padding:.375rem .625rem;border-radius:6px;font-size:.75rem;color:var(--text-secondary);font-family:var(--font-mono);transition:all .2s ease;cursor:default;max-width:fit-content;max-height:fit-content}.filter-metrics-card:hover{background:var(--bg-hover);border-color:var(--theme-accent-primary)}.filter-metrics-main{display:flex;align-items:center;gap:.375rem}.filter-metrics-text{color:var(--text-secondary)}.filter-metrics-text strong{color:var(--text-primary);font-weight:600}.filter-metrics-time{padding:.125rem .375rem;background:var(--bg-primary);border-radius:3px;font-size:.7rem;color:var(--text-tertiary);font-family:var(--font-mono)}.filter-metrics-hover-card{position:absolute;top:100%;left:0;margin-top:.25rem;min-width:300px;width:max(40vw,400px);max-width:min(90vw,700px);max-height:400px;overflow-y:auto;background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:8px;padding:.75rem;box-shadow:0 8px 24px #0006;z-index:9999;opacity:0;pointer-events:none;transform:translateY(-4px);transition:opacity .2s ease,transform .2s ease;display:none;isolation:isolate}.filter-metrics-card:hover .filter-metrics-hover-card{opacity:1;pointer-events:auto;transform:translateY(0);display:block}.filter-metrics-hover-card:hover{opacity:1;pointer-events:auto}.filter-metrics-card:after{content:"";position:absolute;top:100%;left:0;right:0;height:.25rem;opacity:0;pointer-events:auto}.filter-metrics-hover-card::-webkit-scrollbar{width:6px}.filter-metrics-hover-card::-webkit-scrollbar-track{background:var(--bg-tertiary);border-radius:3px}.filter-metrics-hover-card::-webkit-scrollbar-thumb{background:var(--border-bright);border-radius:3px}.filter-metrics-hover-card::-webkit-scrollbar-thumb:hover{background:var(--bg-active)}.filter-metrics-hover-card{scrollbar-width:thin;scrollbar-color:var(--border-bright) var(--bg-tertiary)}.filter-hover-server{display:flex;flex-direction:column;gap:.5rem;padding:.5rem;border-radius:6px}.filter-hover-server:not(:last-child){border-bottom:1px solid var(--border-color);margin-bottom:.5rem;padding-bottom:.75rem}.filter-hover-server-header{display:flex;align-items:center;gap:.5rem}.filter-hover-favicon{width:14px;height:14px;object-fit:contain;flex-shrink:0}.filter-hover-favicon-placeholder{width:14px;height:14px;display:flex;align-items:center;justify-content:center;background:var(--bg-primary);border-radius:3px;flex-shrink:0}.filter-hover-server-name{font-size:.8125rem;font-weight:600;color:var(--text-primary);font-family:var(--font-mono)}.filter-hover-tool-count{margin-left:auto;padding:.125rem .375rem;background:var(--bg-primary);border-radius:10px;font-size:.7rem;color:var(--text-tertiary);font-family:var(--font-mono);font-weight:600}.filter-hover-tools{display:flex;flex-wrap:wrap;gap:.375rem;padding-left:1.5rem}.filter-hover-tool{padding:.25rem .5rem;background:var(--bg-primary);border:1px solid var(--border-color);border-radius:4px;font-size:.7rem;color:var(--text-secondary);font-family:var(--font-mono);transition:all .15s ease}.filter-hover-tool:hover{background:var(--bg-tertiary);border-color:var(--theme-accent-primary);color:var(--text-primary)}.filter-metrics-indicator{display:flex;align-items:center;gap:6px;padding:6px 12px;margin:4px auto;max-width:fit-content;background:#10b98114;border-radius:12px;font-size:11px;color:var(--text-secondary);opacity:.8;transition:opacity .2s}.filter-metrics-indicator:hover{opacity:1}.filter-metrics-indicator svg{color:#10b981;flex-shrink:0}.filter-metrics-indicator .filter-time{opacity:.7;font-size:10px}.chat-message-hybrid.chat-message-system{display:flex;justify-content:flex-start;padding:0;margin:4px 0;border:none;background:transparent;cursor:default;max-height:fit-content;overflow:visible}.chat-message-hybrid.chat-message-system:hover{background:transparent}.chat-message-hybrid.chat-message-tool{padding:0;margin:.5rem 0}.chat-message-hybrid.chat-message-tool .message-content-hybrid{width:100%}.tool-call-card{background:var(--bg-tertiary);border:1px solid color-mix(in srgb,var(--theme-accent-primary) 30%,transparent);border-radius:8px;overflow:hidden;cursor:pointer;transition:all .15s ease}.tool-call-card:hover{border-color:var(--theme-accent-primary);background:var(--bg-secondary)}.tool-call-header{display:flex;align-items:center;gap:.25rem;padding:.75rem 1rem;-webkit-user-select:none;user-select:none}.tool-call-icon{display:flex;align-items:center;justify-content:center;width:24px;height:24px;border-radius:4px;color:var(--theme-text-on-accent);flex-shrink:0}.tool-call-favicon{width:16px;height:16px;object-fit:contain}.tool-call-info{flex:1;display:flex;flex-direction:column;gap:.125rem;min-width:0}.tool-call-name{font-size:.875rem;font-weight:500;color:var(--text-primary);font-family:var(--font-mono)}.tool-call-meta{display:flex;align-items:center;gap:.375rem;font-size:.75rem;color:var(--text-tertiary);font-family:var(--font-mono)}.tool-call-server{color:var(--text-secondary)}.tool-call-meta-divider{color:var(--text-tertiary);opacity:.5}.tool-call-time{color:var(--text-tertiary)}.tool-call-chevron{color:var(--text-tertiary);flex-shrink:0;transition:transform .15s ease}.tool-call-card:hover .tool-call-chevron{transform:translate(2px);color:var(--theme-accent-primary)}.oauth-callback{display:flex;align-items:center;justify-content:center;min-height:100vh;background:var(--bg-primary);padding:var(--spacing-2xl)}.oauth-callback-content{max-width:480px;width:100%;background:linear-gradient(135deg,var(--theme-bg-secondary) 0%,var(--theme-bg-primary) 100%);border:1px solid color-mix(in srgb,var(--theme-accent-primary) 15%,transparent);border-radius:16px;padding:48px 40px;text-align:center;box-shadow:var(--shadow-lg),0 0 0 1px color-mix(in srgb,var(--theme-text-white) 5%,transparent);animation:fadeIn .3s ease-out}.oauth-callback-content.error{border-color:color-mix(in srgb,var(--theme-error) 30%,transparent);background:linear-gradient(135deg,color-mix(in srgb,var(--theme-error) 15%,var(--theme-bg-secondary)),color-mix(in srgb,var(--theme-error) 10%,var(--theme-bg-primary)))}.oauth-icon{font-size:72px;margin-bottom:32px;line-height:1;filter:drop-shadow(0 4px 12px color-mix(in srgb,var(--theme-accent-primary) 30%,transparent))}.oauth-processing{animation:pulse 1.5s ease-in-out infinite}.success-icon{color:var(--green-500);font-size:72px;animation:scaleIn .4s cubic-bezier(.175,.885,.32,1.275)}.error-icon{color:var(--red-500);font-size:72px;animation:shake .5s ease-in-out}.oauth-title{font-size:26px;font-weight:700;color:var(--text-primary);margin-bottom:16px;letter-spacing:-.5px;line-height:1.3}.oauth-message{font-size:15px;color:var(--text-secondary);margin-bottom:32px;line-height:1.6;max-width:450px;margin-left:auto;margin-right:auto;white-space:pre-line;word-wrap:break-word}.oauth-redirect{font-size:13px;color:var(--text-tertiary);font-style:italic;margin-top:24px;opacity:.8}@keyframes scaleIn{0%{transform:scale(0);opacity:0}50%{transform:scale(1.1)}to{transform:scale(1);opacity:1}}@keyframes shake{0%,to{transform:translate(0)}25%{transform:translate(-10px)}75%{transform:translate(10px)}}@keyframes pulse{0%,to{transform:scale(1);opacity:1}50%{transform:scale(1.1);opacity:.8}}@keyframes fadeIn{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.oauth-compliance-container{padding:2rem;max-width:1400px;margin:0 auto;color:var(--text-primary);height:100%;overflow-y:auto;overflow-x:hidden}.oauth-compliance-header{margin-bottom:2rem;display:flex;justify-content:space-between;align-items:center;padding:2rem;background:linear-gradient(135deg,color-mix(in srgb,var(--theme-accent-primary) 10%,var(--bg-secondary)) 0%,var(--bg-secondary) 100%);border:1px solid var(--border);border-radius:var(--radius-md)}.header-content{display:flex;align-items:center;gap:1.5rem}.header-icon{display:flex;align-items:center;justify-content:center;width:64px;height:64px;background:color-mix(in srgb,var(--theme-accent-primary) 15%,var(--bg-primary));border:2px solid var(--theme-accent-primary);border-radius:var(--radius-md);color:var(--theme-accent-primary)}.header-text h1{font-size:2rem;margin:0 0 .25rem;color:var(--text-primary)}.header-text p{margin:0;color:var(--text-secondary);font-size:1rem}.refresh-button{display:flex;align-items:center;gap:.5rem;padding:.75rem 1.25rem;background:var(--theme-accent-primary);color:#fff;border:none;border-radius:var(--radius-sm);cursor:pointer;font-size:.9rem;font-weight:600;transition:all .2s;box-shadow:0 2px 4px #0000001a}.refresh-button:hover{background:var(--theme-accent-secondary);transform:translateY(-1px);box-shadow:0 4px 8px #00000026}.summary-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1rem;margin-bottom:2rem}.summary-card{background:var(--bg-secondary);border:1px solid var(--border);border-radius:var(--radius-md);padding:1.5rem;display:flex;align-items:center;gap:1rem;transition:all .2s}.summary-card:hover{transform:translateY(-2px);box-shadow:0 4px 12px #0000001a}.summary-icon{display:flex;align-items:center;justify-content:center;width:48px;height:48px;border-radius:var(--radius-sm);flex-shrink:0}.summary-card .summary-icon{background:color-mix(in srgb,var(--text-secondary) 10%,var(--bg-primary));color:var(--text-secondary)}.summary-card-success .summary-icon{background:color-mix(in srgb,var(--color-success) 15%,var(--bg-primary));color:var(--color-success)}.summary-card-warning .summary-icon{background:color-mix(in srgb,var(--color-warning) 15%,var(--bg-primary));color:var(--color-warning)}.summary-content{flex:1}.summary-card-success{border-color:var(--color-success);background:color-mix(in srgb,var(--color-success) 10%,var(--bg-secondary))}.summary-card-warning{border-color:var(--color-warning);background:color-mix(in srgb,var(--color-warning) 10%,var(--bg-secondary))}.summary-card-info{border-color:var(--theme-accent-primary);background:color-mix(in srgb,var(--theme-accent-primary) 10%,var(--bg-secondary))}.summary-number{font-size:2.5rem;font-weight:700;color:var(--text-primary);margin-bottom:.5rem}.summary-label{font-size:.9rem;color:var(--text-secondary);font-weight:500}.summary-subtitle{font-size:.85rem;color:var(--text-tertiary);margin-top:.25rem}.specs-section{background:var(--bg-secondary);border:1px solid var(--border);border-radius:var(--radius-md);padding:1.5rem;margin-bottom:2rem}.specs-section h3{margin-top:0;margin-bottom:1rem;color:var(--text-primary);display:flex;align-items:center;gap:.5rem}.specs-list{list-style:none;padding:0;margin:0;display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:.5rem}.specs-list li{padding:.75rem;background:var(--bg-primary);border-radius:var(--radius-sm);font-size:.9rem;display:flex;align-items:center;gap:.5rem;color:var(--text-secondary)}.spec-item-clickable{cursor:pointer;transition:all var(--transition-fast);position:relative}.spec-item-clickable:hover{background:var(--bg-hover);transform:translateY(-2px);box-shadow:var(--shadow-md)}.spec-info-icon{margin-left:auto;color:var(--text-tertiary);opacity:.5;transition:all var(--transition-fast)}.spec-item-clickable:hover .spec-info-icon{opacity:1;color:var(--theme-accent-primary)}.specs-list li svg{color:var(--color-success);flex-shrink:0}.controls-bar{display:flex;gap:2rem;align-items:center;margin-bottom:1.5rem;padding:1rem;background:var(--bg-secondary);border-radius:var(--radius-md);border:1px solid var(--border)}.filter-group,.sort-group{display:flex;align-items:center;gap:.75rem}.filter-group svg,.sort-group svg{color:var(--text-tertiary);flex-shrink:0}.filter-group label,.sort-group label{font-size:.9rem;color:var(--text-secondary);font-weight:500}.filter-group select,.sort-group select{padding:.5rem;border:1px solid var(--border);border-radius:var(--radius-sm);background:var(--bg-primary);color:var(--text-primary);font-size:.9rem}.sort-order-button{padding:.5rem .75rem;border:1px solid var(--border);border-radius:var(--radius-sm);background:var(--bg-primary);color:var(--text-primary);cursor:pointer;font-size:1rem;transition:all .2s}.sort-order-button:hover{background:var(--bg-tertiary)}.results-table{border:1px solid var(--border);border-radius:var(--radius-md);overflow:hidden;background:var(--bg-secondary)}.results-header{display:grid;grid-template-columns:2fr 1.5fr 1fr 1.5fr 80px;padding:1rem;background:var(--bg-tertiary);border-bottom:2px solid var(--border);font-weight:600;font-size:.85rem;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.05em}.result-row{border-bottom:1px solid var(--border)}.result-row:last-child{border-bottom:none}.result-main{display:grid;grid-template-columns:2fr 1.5fr 1fr 1.5fr 80px;padding:1rem;align-items:center;transition:background .2s}.result-main:hover{background:var(--bg-primary)}.col-name{display:flex;flex-direction:column;gap:.25rem}.server-name-with-icon{display:flex;align-items:center;gap:.75rem}.server-favicon{width:20px;height:20px;object-fit:contain;flex-shrink:0;border-radius:4px}.server-favicon-placeholder{width:20px;height:20px;display:flex;align-items:center;justify-content:center;flex-shrink:0;color:var(--text-tertiary);background:var(--bg-tertiary);border-radius:4px}.server-info{display:flex;flex-direction:column;gap:.25rem;min-width:0}.server-name{font-weight:600;color:var(--text-primary)}.server-url{font-size:.85rem;color:var(--text-tertiary);font-family:Monaco,Courier New,monospace}.col-score{display:flex;align-items:center;gap:.75rem}.score-bar-container{flex:1;height:8px;background:var(--bg-tertiary);border-radius:4px;overflow:hidden}.score-bar-fill{height:100%;transition:width .3s ease}.score-text{font-weight:700;font-size:.9rem;min-width:45px}.score-na{display:flex;flex-direction:column;align-items:center;gap:.25rem}.na-badge{display:inline-block;padding:.25rem .75rem;background:color-mix(in srgb,var(--color-success) 20%,var(--bg-primary));color:var(--color-success);border:1px solid var(--color-success);border-radius:var(--radius-sm);font-weight:700;font-size:.9rem}.na-text{font-size:.7rem;color:var(--text-tertiary);text-align:center}.status-badge{display:inline-flex;align-items:center;gap:.35rem;padding:.35rem .75rem;border-radius:var(--radius-sm);font-size:.8rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em}.status-oauth{background:color-mix(in srgb,var(--color-success) 20%,var(--bg-primary));color:var(--color-success);border:1px solid var(--color-success)}.status-header-auth{background:color-mix(in srgb,var(--color-warning) 20%,var(--bg-primary));color:var(--color-warning);border:1px solid var(--color-warning)}.status-no-auth{background:color-mix(in srgb,var(--color-success) 15%,var(--bg-primary));color:var(--color-success);border:1px solid var(--color-success)}.status-error{background:color-mix(in srgb,var(--color-error) 20%,var(--bg-primary));color:var(--color-error);border:1px solid var(--color-error)}.status-unknown{background:var(--bg-tertiary);color:var(--text-tertiary);border:1px solid var(--border)}.checks-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:.35rem;font-size:.75rem}.checks-grid span{display:flex;align-items:center;gap:.25rem;cursor:help;transition:all var(--transition-fast)}.checks-grid span:hover{transform:translateY(-1px)}.check-pass{color:var(--color-success);font-weight:500}.check-fail{color:var(--text-tertiary);opacity:.6}.check-sdk.check-fail{color:var(--text-tertiary);opacity:.4}.expand-button{padding:.5rem;background:transparent;border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text-secondary);cursor:pointer;transition:all .2s;width:36px;height:36px;display:flex;align-items:center;justify-content:center}.expand-button:hover{background:var(--bg-tertiary);color:var(--text-primary)}.result-details{padding:1.5rem;background:var(--bg-primary);border-top:1px solid var(--border)}.result-details h4{margin-top:0;margin-bottom:1rem;color:var(--text-primary);display:flex;align-items:center;gap:.5rem}.details-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:1rem;margin-bottom:1rem}.detail-item{display:flex;flex-direction:column;gap:.25rem}.detail-full{grid-column:1 / -1}.detail-label{font-size:.75rem;color:var(--text-tertiary);font-weight:600;text-transform:uppercase;letter-spacing:.05em}.detail-value{font-size:.9rem;color:var(--text-primary)}.detail-code{font-family:Monaco,Courier New,monospace;font-size:.85rem;word-break:break-all}.detail-highlight{color:var(--theme-accent-primary);font-weight:600}.detail-link{color:var(--theme-accent-primary);text-decoration:none;word-break:break-all;display:inline-flex;align-items:center;gap:.35rem;transition:all .2s}.detail-link:hover{color:var(--theme-accent-secondary);text-decoration:underline}.detail-link:visited{color:color-mix(in srgb,var(--theme-accent-primary) 80%,var(--text-tertiary))}.detail-link svg{flex-shrink:0}.detail-json{margin:0;padding:1rem;background:var(--bg-secondary);border:1px solid var(--border);border-radius:var(--radius-sm);font-size:.85rem;overflow-x:auto;color:var(--text-primary)}.error-label{color:var(--color-error)}.error-message{color:var(--color-error);font-weight:500}.oauth-compliance-empty,.oauth-compliance-loading,.oauth-compliance-error{display:flex;align-items:center;justify-content:center;min-height:400px;height:100%;text-align:center;padding:2rem}.empty-state{max-width:400px}.empty-icon{color:var(--theme-accent-primary);margin-bottom:1rem;display:flex;justify-content:center}.empty-icon svg{opacity:.5}.empty-state h2{margin-bottom:.5rem;color:var(--text-primary)}.empty-state p{color:var(--text-secondary);margin-bottom:1.5rem}.empty-state .command{display:block;padding:.75rem;background:var(--bg-secondary);border:1px solid var(--border);border-radius:var(--radius-sm);font-family:Monaco,Courier New,monospace;margin-bottom:1.5rem;color:var(--theme-accent-primary)}.load-button,.retry-button{display:inline-flex;align-items:center;gap:.5rem;padding:.75rem 1.5rem;background:var(--theme-accent-primary);color:#fff;border:none;border-radius:var(--radius-sm);cursor:pointer;font-size:1rem;font-weight:600;transition:all .2s;box-shadow:0 2px 4px #0000001a}.load-button:hover,.retry-button:hover{background:var(--theme-accent-secondary);transform:translateY(-1px);box-shadow:0 4px 8px #00000026}.spinner{width:40px;height:40px;border:4px solid var(--border);border-top-color:var(--theme-accent-primary);border-radius:50%;animation:spin 1s linear infinite;margin:0 auto 1rem}.no-results{padding:3rem;text-align:center;color:var(--text-secondary)}.results-footer{margin-top:2rem;padding:1.5rem;background:var(--bg-secondary);border:1px solid var(--border);border-radius:var(--radius-md);text-align:center}.results-footer p{margin:.5rem 0;color:var(--text-secondary);font-size:.9rem}.footer-note code{padding:.25rem .5rem;background:var(--bg-primary);border-radius:var(--radius-sm);font-family:Monaco,Courier New,monospace;color:var(--theme-accent-primary)}.spec-modal-overlay{position:fixed;inset:0;background:#000000b3;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:1000;padding:2rem;animation:fadeIn .2s ease-out}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.spec-modal{background:var(--bg-primary);border:1px solid var(--border);border-radius:var(--radius-lg);max-width:800px;width:100%;max-height:90vh;overflow-y:auto;box-shadow:0 20px 25px -5px #0000004d,0 10px 10px -5px #0003;animation:slideUp .3s ease-out}@keyframes slideUp{0%{transform:translateY(20px);opacity:0}to{transform:translateY(0);opacity:1}}.spec-modal-header{display:flex;align-items:center;justify-content:space-between;padding:1.5rem 2rem;border-bottom:2px solid var(--border);background:var(--bg-secondary);border-radius:var(--radius-lg) var(--radius-lg) 0 0;position:sticky;top:0;z-index:10}.spec-modal-header h2{margin:0;font-size:1.5rem;color:var(--text-primary);display:flex;align-items:center;gap:.75rem}.spec-modal-header h2 svg{color:var(--theme-accent-primary)}.spec-modal-close{padding:.5rem;background:transparent;border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text-secondary);cursor:pointer;transition:all var(--transition-fast);display:flex;align-items:center;justify-content:center}.spec-modal-close:hover{background:var(--bg-hover);border-color:var(--theme-accent-primary);color:var(--theme-accent-primary)}.spec-modal-content{padding:2rem}.spec-modal-section{margin-bottom:2rem}.spec-modal-section:last-child{margin-bottom:0}.spec-modal-section h3{font-size:1.1rem;color:var(--text-primary);margin:0 0 1rem;display:flex;align-items:center;gap:.5rem;padding-bottom:.5rem;border-bottom:1px solid var(--border)}.spec-modal-section h3 svg{color:var(--theme-accent-primary)}.spec-modal-section p{margin:0 0 1rem;color:var(--text-secondary);line-height:1.6}.spec-modal-note{font-size:.95rem;color:var(--text-tertiary);margin-bottom:.75rem!important}.spec-modal-list{margin:0;padding-left:1.5rem;color:var(--text-secondary)}.spec-modal-list li{margin-bottom:.75rem;line-height:1.6}.spec-modal-list li:last-child{margin-bottom:0}.spec-modal-list code{padding:.125rem .375rem;background:var(--bg-tertiary);border-radius:var(--radius-sm);font-family:Monaco,Courier New,monospace;font-size:.9em;color:var(--theme-accent-primary)}.spec-modal-criteria{list-style:none;padding-left:0}.spec-modal-criteria li{display:flex;align-items:flex-start;gap:.5rem}.criteria-icon{color:var(--color-success);flex-shrink:0;margin-top:.25rem}.spec-modal-footer{margin-top:2rem;padding:1rem 1.5rem;background:color-mix(in srgb,var(--theme-accent-primary) 10%,transparent);border:1px solid color-mix(in srgb,var(--theme-accent-primary) 30%,transparent);border-radius:var(--radius-md)}.spec-modal-footer p{margin:0;color:var(--text-secondary);font-size:.9rem;line-height:1.6}.spec-modal-footer strong{color:var(--text-primary)}@media(max-width:1024px){.results-header,.result-main{grid-template-columns:2fr 1fr 1fr 80px}.col-checks{display:none}}@media(max-width:768px){.oauth-compliance-container{padding:1rem}.summary-grid{grid-template-columns:1fr 1fr}.controls-bar{flex-direction:column;align-items:stretch;gap:1rem}.results-header{display:none}.result-main{grid-template-columns:1fr auto;gap:1rem}.col-score,.col-status{display:none}.col-name{grid-column:1;grid-row:1}.col-actions{grid-column:2;grid-row:1}}.welcome-modal{padding:var(--spacing-md);max-width:600px;margin:0 auto}.welcome-header{text-align:center;margin-bottom:var(--spacing-2xl)}.welcome-logo{font-size:64px;display:block;margin-bottom:var(--spacing-lg);animation:welcomeBounce .6s ease-out}.welcome-title{font-size:28px;font-weight:700;color:var(--theme-text-primary);margin-bottom:var(--spacing-sm);font-family:var(--font-mono);letter-spacing:-.5px}.welcome-subtitle{font-size:16px;color:var(--theme-text-secondary);line-height:1.5;max-width:500px;margin:0 auto}.welcome-features{display:grid;gap:var(--spacing-lg);margin-bottom:var(--spacing-2xl)}.welcome-feature{display:flex;gap:var(--spacing-md);align-items:flex-start;padding:var(--spacing-md);background:var(--theme-bg-secondary);border-radius:var(--radius-md);transition:all var(--transition-fast);cursor:default}.welcome-feature:hover{background:var(--theme-bg-tertiary);transform:translateY(-2px)}.feature-icon{display:flex;align-items:center;justify-content:center;width:48px;height:48px;background:var(--theme-bg-tertiary);border-radius:var(--radius-md);color:var(--theme-accent-primary);flex-shrink:0}.feature-content h3{font-size:16px;font-weight:600;color:var(--theme-text-primary);margin-bottom:var(--spacing-xs);font-family:var(--font-mono)}.feature-content p{font-size:14px;color:var(--theme-text-secondary);line-height:1.5;margin:0}.feature-content kbd{display:inline-flex;align-items:center;justify-content:center;padding:2px 6px;font-size:12px;font-family:var(--font-mono);background:var(--theme-bg-tertiary);border:1px solid var(--theme-border-color);border-radius:4px;color:var(--theme-text-secondary);box-shadow:0 1px 2px #0000001a}.welcome-footer{display:flex;flex-direction:column;gap:var(--spacing-lg);padding-top:var(--spacing-lg);border-top:1px solid var(--theme-border-color)}.welcome-footer label{cursor:pointer}.welcome-actions{display:flex;justify-content:flex-end;gap:var(--spacing-md)}.welcome-actions .btn{min-width:120px;cursor:pointer}@keyframes welcomeBounce{0%{opacity:0;transform:scale(.3)}50%{transform:scale(1.05)}70%{transform:scale(.9)}to{opacity:1;transform:scale(1)}}@media(max-width:768px){.welcome-modal{padding:var(--spacing-sm)}.welcome-logo{font-size:48px}.welcome-title{font-size:24px}.welcome-subtitle{font-size:14px}.welcome-features{gap:var(--spacing-md)}.welcome-feature{flex-direction:column;text-align:center}.feature-icon{margin:0 auto}}.toast-container{position:fixed;top:var(--spacing-2xl);right:var(--spacing-2xl);z-index:9999;display:flex;flex-direction:column;gap:var(--spacing-md);pointer-events:none}.toast{min-width:320px;max-width:480px;background:var(--bg-secondary);border:1px solid var(--border-bright);border-radius:var(--radius-md);padding:var(--spacing-lg);display:flex;align-items:flex-start;gap:var(--spacing-md);box-shadow:var(--shadow-lg);pointer-events:all;animation:slideIn .3s cubic-bezier(.16,1,.3,1)}.toast-icon{flex-shrink:0;display:flex;align-items:center;justify-content:center;width:32px;height:32px;border-radius:var(--radius-sm)}.toast-success .toast-icon{color:var(--theme-success);background:color-mix(in srgb,var(--theme-success) 15%,transparent)}.toast-error .toast-icon{color:var(--theme-error);background:color-mix(in srgb,var(--theme-error) 15%,transparent)}.toast-warning .toast-icon{color:var(--theme-info);background:color-mix(in srgb,var(--theme-info) 15%,transparent)}.toast-info .toast-icon{color:var(--theme-accent-primary);background:color-mix(in srgb,var(--theme-accent-primary) 15%,transparent)}.toast-content{flex:1;min-width:0}.toast-message{font-size:14px;font-weight:600;color:var(--text-primary);margin-bottom:4px;line-height:1.4}.toast-description{font-size:13px;color:var(--text-secondary);line-height:1.5}.toast-close{flex-shrink:0;background:transparent;border:none;color:var(--text-tertiary);cursor:pointer;padding:4px;border-radius:var(--radius-sm);display:flex;align-items:center;justify-content:center;transition:all var(--transition-fast)}.toast-close:hover{background:var(--bg-hover);color:var(--text-primary)}@keyframes slideIn{0%{transform:translate(100%);opacity:0}to{transform:translate(0);opacity:1}}@media(max-width:768px){.toast-container{top:var(--spacing-lg);right:var(--spacing-lg);left:var(--spacing-lg)}.toast{min-width:unset;width:100%}}.error-boundary{display:flex;align-items:center;justify-content:center;min-height:400px;padding:var(--spacing-2xl);background:var(--bg-primary)}.error-boundary-content{max-width:520px;text-align:center}.error-icon{display:inline-flex;align-items:center;justify-content:center;width:96px;height:96px;border-radius:50%;background:#f2877926;color:var(--red-500);margin-bottom:var(--spacing-xl);animation:shake .5s ease-in-out}.error-title{font-size:24px;font-weight:700;color:var(--theme-error);margin-bottom:var(--spacing-md);letter-spacing:-.5px}.error-message{font-size:15px;color:var(--text-secondary);line-height:1.6;margin-bottom:var(--spacing-xl)}.error-details{margin:var(--spacing-xl) 0;text-align:left;background:var(--bg-tertiary);border:1px solid var(--border-color);border-radius:var(--radius-md);padding:var(--spacing-md)}.error-details summary{font-size:13px;font-weight:600;color:var(--text-primary);cursor:pointer;-webkit-user-select:none;user-select:none;padding:var(--spacing-sm)}.error-details summary:hover{color:var(--text-primary)}.error-stack{margin-top:var(--spacing-md);font-family:var(--font-mono);font-size:12px;color:var(--text-tertiary);overflow-x:auto;padding:var(--spacing-md);background:var(--bg-primary);border-radius:var(--radius-sm);line-height:1.6}.error-boundary .btn{display:inline-flex;align-items:center;gap:var(--spacing-sm)}@keyframes shake{0%,to{transform:translate(0)}20%,60%{transform:translate(-8px)}40%,80%{transform:translate(8px)}}.theme-switcher-header{position:relative}.theme-trigger{display:flex;align-items:center;justify-content:center;width:36px;height:36px;color:var(--theme-accent-tertiary);background:transparent;border:none;border-radius:var(--radius-sm);cursor:pointer;transition:all .2s ease}.theme-trigger:hover{background:var(--bg-hover);color:var(--theme-accent-secondary)}.theme-dropdown{position:absolute;top:calc(100% + 12px);right:0;background:var(--bg-secondary);border:1px solid var(--border-bright);border-radius:8px;padding:4px;display:flex;gap:4px;box-shadow:0 4px 16px #00000080;opacity:0;visibility:hidden;transform:translateY(-8px);transition:opacity .2s,transform .2s,visibility 0s .2s;z-index:10000}.theme-switcher-header:hover .theme-dropdown,.theme-dropdown:hover{opacity:1;visibility:visible;transform:translateY(0);transition:opacity .2s,transform .2s,visibility 0s 0s}.theme-switcher-header:before{content:"";position:absolute;top:100%;left:0;right:0;height:12px;opacity:0}.theme-option{display:flex;align-items:center;justify-content:center;width:36px;height:36px;padding:0;background:var(--bg-tertiary);border:1px solid var(--border-color);border-radius:6px;cursor:pointer;transition:all .15s;position:relative;font-size:18px}.theme-option-dark{background:color-mix(in srgb,var(--bg-tertiary) 85%,black);border-color:color-mix(in srgb,var(--border-color) 80%,black)}.theme-option-light{background:color-mix(in srgb,var(--bg-tertiary) 85%,white);border-color:color-mix(in srgb,var(--border-color) 85%,white)}.theme-option-system{background:linear-gradient(135deg,color-mix(in srgb,var(--bg-tertiary) 85%,black) 50%,color-mix(in srgb,var(--bg-tertiary) 85%,white) 50%);border-color:var(--border-bright)}.theme-divider{width:1px;height:36px;background:var(--border-color);margin:0 4px}.theme-option:hover{background:var(--bg-hover);border-color:var(--border-bright);transform:scale(1.1)}.theme-option-dark:hover{background:color-mix(in srgb,var(--bg-hover) 90%,black)}.theme-option-light:hover{background:color-mix(in srgb,var(--bg-hover) 90%,white)}.theme-option.active{background:var(--theme-accent-primary);border-color:var(--theme-accent-primary);box-shadow:0 0 12px color-mix(in srgb,var(--theme-accent-primary) 50%,transparent)}.theme-emoji{font-size:18px;line-height:1}.theme-name{display:none}.theme-option:after{content:attr(data-tooltip);position:absolute;bottom:calc(100% + 8px);left:50%;transform:translate(-50%);background:var(--bg-primary);border:1px solid var(--border-bright);color:var(--text-primary);padding:6px 12px;border-radius:6px;font-size:12px;font-weight:500;white-space:nowrap;opacity:0;pointer-events:none;transition:opacity .2s,transform .2s;box-shadow:0 4px 12px #0006;z-index:10001}.theme-option:hover:after{opacity:1;transform:translate(-50%) translateY(-4px)}.theme-option:before{content:"";position:absolute;bottom:calc(100% + 2px);left:50%;transform:translate(-50%);width:0;height:0;border-left:5px solid transparent;border-right:5px solid transparent;border-top:5px solid var(--border-bright);opacity:0;pointer-events:none;transition:opacity .2s,transform .2s;z-index:10001}.theme-option:hover:before{opacity:1;transform:translate(-50%) translateY(-4px)}.keyboard-shortcuts-modal{max-width:700px;max-height:80vh}.keyboard-shortcuts-modal .modal-body{max-height:60vh;overflow-y:auto}.modal-title-row{display:flex;align-items:center;gap:12px;justify-content:center}.shortcuts-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:24px}.shortcut-category{display:flex;flex-direction:column;gap:12px}.shortcut-category-title{font-size:14px;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:var(--primary-color);margin:0;padding-bottom:8px;border-bottom:1px solid var(--border-color)}.shortcut-list{display:flex;flex-direction:column;gap:8px}.shortcut-item{display:flex;justify-content:space-between;align-items:center;gap:16px;padding:8px;border-radius:6px;transition:background-color .2s}.shortcut-item:hover{background-color:#5ccfe60d}.shortcut-description{font-size:14px;color:var(--text-primary);flex:1}.shortcut-key{display:inline-flex;align-items:center;gap:4px;font-family:SF Mono,Monaco,Inconsolata,Roboto Mono,Courier New,monospace;font-size:12px;font-weight:600;padding:4px 8px;border-radius:4px;background:linear-gradient(180deg,var(--bg-tertiary) 0%,var(--bg-secondary) 100%);border:1px solid var(--border-color);box-shadow:0 2px 4px #0003;color:var(--text-primary);white-space:nowrap;min-width:50px;text-align:center;justify-content:center}@media(max-width:768px){.shortcuts-grid{grid-template-columns:1fr}.keyboard-shortcuts-modal{max-width:90vw}}.app{display:flex;height:100vh;overflow:hidden;flex-direction:column}.app-header{display:flex;align-items:center;justify-content:space-between;padding:.75rem 1.5rem;background:var(--bg-secondary);border-bottom:1px solid var(--border-color);gap:2rem;flex-shrink:0}.app-header-left{display:flex;align-items:center;gap:1.5rem;flex:1;min-width:0}.app-branding{display:flex;align-items:center;gap:.625rem;min-width:0;flex-shrink:0}.logo-icon{font-size:1.75rem;line-height:1;flex-shrink:0}.app-title{margin:0;font-size:1.5rem;font-weight:700;color:var(--text-primary);letter-spacing:-.02em;flex-shrink:0;text-shadow:0 0 30px rgba(136,192,208,.2)}.app-tagline{font-size:.8125rem;color:var(--theme-accent-tertiary);font-weight:500;margin-left:.5rem;padding-left:.75rem;border-left:1px solid var(--theme-accent-deep);flex-shrink:0}.app-nav{display:flex;gap:.5rem;padding-left:1rem;border-left:1px solid var(--border-color)}.nav-button{display:flex;align-items:center;gap:.5rem;padding:.5rem 1rem;background:transparent;border:none;color:var(--theme-accent-tertiary);opacity:.6;font-size:.875rem;font-weight:500;cursor:pointer;transition:all .2s ease;border-radius:var(--radius-sm);position:relative}.nav-button:hover{background:var(--bg-hover);opacity:.8}.nav-button.active{background:transparent;color:var(--theme-accent-primary);opacity:1}.nav-button.active:after{content:"";position:absolute;bottom:-.75rem;left:.5rem;right:.5rem;height:2px;background:var(--theme-accent-primary);border-radius:1px}.nav-button span{font-weight:500}.demo-badge{margin-left:.375rem;padding:.125rem .375rem;background:var(--orange-500);color:var(--bg-primary);font-size:.625rem;font-weight:700;border-radius:3px;text-transform:uppercase;letter-spacing:.025em}.app-actions{display:flex;align-items:center;gap:.75rem;min-width:0}.header-link{display:flex;align-items:center;justify-content:center;width:36px;height:36px;color:var(--theme-accent-tertiary);border-radius:var(--radius-sm);transition:all .2s ease;text-decoration:none;border:none;background:transparent;cursor:pointer;padding:0}.header-link:hover{background:var(--bg-hover);color:var(--theme-accent-secondary)}.version-badge{display:flex;align-items:center;gap:.5rem;padding:.375rem .75rem;background:color-mix(in srgb,var(--theme-accent-tertiary) 10%,transparent);border:1px solid color-mix(in srgb,var(--theme-accent-tertiary) 20%,transparent);border-radius:var(--radius-sm);font-size:.6875rem;font-weight:600;color:var(--theme-accent-tertiary);font-family:var(--font-mono);text-decoration:none;transition:all .2s ease;cursor:pointer}.version-badge:hover{background:color-mix(in srgb,var(--theme-accent-tertiary) 15%,transparent);color:var(--theme-accent-secondary);border-color:var(--theme-accent-primary)}.app-content{flex:1;overflow:hidden;display:flex}.test-layout{display:flex;flex:1;overflow:hidden}.app-content>.hybrid-interface{flex:1;width:100%}:root{--font-sans: "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;--font-mono: "JetBrains Mono", "Monaco", "Menlo", "Courier New", monospace;--spacing-xs: 4px;--spacing-sm: 8px;--spacing-md: 12px;--spacing-lg: 16px;--spacing-xl: 20px;--spacing-2xl: 24px;--radius-sm: 6px;--radius-md: 8px;--radius-lg: 12px;--shadow-sm: 0 1px 2px 0 rgba(0, 0, 0, .05);--shadow-md: 0 4px 6px -1px rgba(0, 0, 0, .1), 0 2px 4px -1px rgba(0, 0, 0, .06);--shadow-lg: 0 10px 15px -3px rgba(0, 0, 0, .1), 0 4px 6px -2px rgba(0, 0, 0, .05);--transition-fast: .15s cubic-bezier(0, 0, .2, 1);--transition-base: .2s cubic-bezier(.4, 0, .2, 1);--hills-main-area: url("data:image/svg+xml,%3Csvg viewBox='0 0 1920 150' xmlns='http://www.w3.org/2000/svg' preserveAspectRatio='none'%3E%3C/svg%3E");--hills-tools-sidebar: url("data:image/svg+xml,%3Csvg viewBox='0 0 1920 150' xmlns='http://www.w3.org/2000/svg' preserveAspectRatio='none'%3E%3C/svg%3E");--hills-server-sidebar: url("data:image/svg+xml,%3Csvg viewBox='0 0 1920 150' xmlns='http://www.w3.org/2000/svg' preserveAspectRatio='none'%3E%3C/svg%3E");--hills-empty-state: url("data:image/svg+xml,%3Csvg viewBox='0 0 1920 150' xmlns='http://www.w3.org/2000/svg' preserveAspectRatio='none'%3E%3C/svg%3E");--hills-api-pane: url("data:image/svg+xml,%3Csvg viewBox='0 0 1920 150' xmlns='http://www.w3.org/2000/svg' preserveAspectRatio='none'%3E%3C/svg%3E")}*{margin:0;padding:0;box-sizing:border-box}*{scrollbar-gutter:stable}::-webkit-scrollbar{width:12px;height:12px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:color-mix(in srgb,var(--text-tertiary) 20%,transparent);border-radius:6px;border:3px solid transparent;background-clip:padding-box;transition:background-color .2s ease}*:hover::-webkit-scrollbar-thumb,*:focus-within::-webkit-scrollbar-thumb,*:active::-webkit-scrollbar-thumb{background:color-mix(in srgb,var(--text-tertiary) 35%,transparent);background-clip:padding-box}*:hover::-webkit-scrollbar-thumb:hover,*::-webkit-scrollbar-thumb:active{background:color-mix(in srgb,var(--text-tertiary) 55%,transparent);background-clip:padding-box}*{scrollbar-width:thin;scrollbar-color:color-mix(in srgb,var(--text-tertiary) 20%,transparent) transparent}*:hover,*:focus-within,*:active{scrollbar-color:color-mix(in srgb,var(--text-tertiary) 35%,transparent) transparent}html{overscroll-behavior:none;overscroll-behavior-y:none}body{font-family:var(--font-sans);background:var(--bg-primary);color:var(--text-primary);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-feature-settings:"liga" 1,"calt" 1;overscroll-behavior:none;overscroll-behavior-y:none}#root{height:100vh;overflow:hidden;transform:translateZ(0);will-change:auto}button,.clickable{-webkit-user-select:none;user-select:none}code,pre{font-family:var(--font-mono);font-variant-ligatures:common-ligatures}::-webkit-scrollbar{width:10px;height:10px}::-webkit-scrollbar-track{background:var(--theme-bg-primary)}::-webkit-scrollbar-thumb{background:linear-gradient(180deg,var(--theme-accent-primary) 0%,var(--theme-accent-tertiary) 100%);border-radius:4px;border:2px solid var(--theme-bg-primary)}::-webkit-scrollbar-thumb:hover{background:linear-gradient(180deg,var(--theme-accent-secondary) 0%,var(--theme-accent-primary) 100%)}*:focus-visible:not(input):not(textarea):not(select){outline:2px solid var(--theme-accent-primary);outline-offset:2px}input:focus-visible,textarea:focus-visible,select:focus-visible{outline:none}::selection{background:var(--theme-accent-primary);color:var(--theme-bg-primary)}@keyframes fadeIn{0%{opacity:0;transform:translateY(4px)}to{opacity:1;transform:translateY(0)}}@keyframes slideIn{0%{opacity:0;transform:translate(-8px)}to{opacity:1;transform:translate(0)}}@keyframes spin{to{transform:rotate(360deg)}}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}@keyframes frost-pulse{0%,to{opacity:.3;transform:scale(1)}50%{opacity:0;transform:scale(1.5)}}@keyframes aurora-glow{0%,to{box-shadow:0 0 20px color-mix(in srgb,var(--theme-accent-primary) 30%,transparent)}33%{box-shadow:0 0 20px color-mix(in srgb,var(--theme-success) 30%,transparent)}66%{box-shadow:0 0 20px color-mix(in srgb,var(--theme-special) 30%,transparent)}}.animate-fade-in{animation:fadeIn .2s ease-out}.animate-slide-in{animation:slideIn .3s ease-out}.animate-spin{animation:spin 1s linear infinite}.animate-pulse{animation:pulse 2s cubic-bezier(.4,0,.6,1) infinite}.gpu-accelerated{transform:translateZ(0);backface-visibility:hidden;perspective:1000px}.font-mono{font-family:var(--font-mono)}