:root{--color-primary: #D97757;--color-primary-hover: #C56643;--color-primary-light: #F4E8E3;--color-secondary: #5B7C99;--color-accent: #7A9CB8;--color-bg: #FAFAFA;--color-surface: #FFFFFF;--color-border: #E5E5E5;--color-border-light: #F0F0F0;--color-text-primary: #1A1A1A;--color-text-secondary: #6B6B6B;--color-text-tertiary: #999999;--color-success: #4CAF50;--color-warning: #FF9800;--color-error: #F44336;--color-error-hover: #E53935;--color-info: #2196F3;--color-info-hover: #1976D2;--color-info-dark: #42A5F5;--color-info-light: #64B5F6;--color-info-lighter: #90CAF9;--color-info-bg: #E3F2FD;--color-notification-bg: #1E3A5F;--color-notification-border: #2C5282;--shadow-sm: 0 1px 2px rgba(0, 0, 0, .05);--shadow-md: 0 4px 6px rgba(0, 0, 0, .07);--shadow-lg: 0 10px 15px rgba(0, 0, 0, .1);--shadow-xl: 0 20px 25px rgba(0, 0, 0, .15);--spacing-xs: .25rem;--spacing-sm: .5rem;--spacing-md: 1rem;--spacing-lg: 1.5rem;--spacing-xl: 2rem;--radius-sm: .375rem;--radius-md: .5rem;--radius-lg: .75rem;--radius-xl: 1rem;--sidebar-width: 280px;--header-height: 64px}*{margin:0;padding:0;box-sizing:border-box}html,body{height:100%;overflow:hidden;overscroll-behavior:none}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica Neue,Arial,sans-serif;line-height:1.6;color:var(--color-text-primary);background-color:var(--color-bg);font-size:15px;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}#app{display:flex;flex-direction:column;height:100vh;overflow:hidden}.app-header{height:var(--header-height);background:var(--color-surface);border-bottom:1px solid var(--color-border);display:flex;align-items:center;padding:0 var(--spacing-xl);flex-shrink:0}.header-content{display:flex;align-items:center;justify-content:space-between;width:100%}.app-branding{display:flex;align-items:center;gap:var(--spacing-sm)}.app-icon{width:32px;height:32px;flex-shrink:0}.app-title{font-size:1.5rem;font-weight:600;color:var(--color-text-primary);letter-spacing:-.02em}.header-actions{display:flex;gap:var(--spacing-sm)}.icon-btn{width:40px;height:40px;border-radius:var(--radius-md);border:1px solid var(--color-border);background:var(--color-surface);color:var(--color-text-secondary);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s ease}.icon-btn:hover{background:var(--color-bg);color:var(--color-text-primary);border-color:var(--color-text-tertiary)}.icon-btn:active{transform:scale(.95)}.mobile-only{display:none}.main-content{display:flex;flex:1;overflow:hidden}.sidebar{width:var(--sidebar-width);background:var(--color-surface);border-right:1px solid var(--color-border);display:flex;flex-direction:column;overflow:hidden}.sidebar-section{padding:var(--spacing-lg);border-bottom:1px solid var(--color-border-light)}.sidebar-section:last-child{flex:1;overflow:hidden;display:flex;flex-direction:column}.sidebar-title{font-size:.8125rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:var(--color-text-tertiary);margin-bottom:var(--spacing-md)}.sidebar-btn{width:100%;padding:var(--spacing-sm) var(--spacing-md);border-radius:var(--radius-md);border:1px solid var(--color-border);background:var(--color-surface);color:var(--color-text-primary);font-size:.9375rem;font-weight:500;cursor:pointer;display:flex;align-items:center;gap:var(--spacing-sm);transition:all .2s ease}.sidebar-btn:hover{background:var(--color-bg);border-color:var(--color-text-tertiary)}.sidebar-btn svg{color:var(--color-text-secondary)}.folder-info{margin-top:var(--spacing-md);padding:var(--spacing-md);background:var(--color-primary-light);border-radius:var(--radius-md);font-size:.875rem;color:var(--color-text-primary);word-break:break-all}.folder-info:empty{display:none}.folder-info strong{display:block;margin-bottom:var(--spacing-xs);color:var(--color-primary)}.live-updates-indicator{color:var(--color-success);font-size:.9em}.new-workspace-btn{margin-top:var(--spacing-sm);font-size:.85rem}.new-workspace-btn[hidden]{display:none}.workspace-list{display:flex;flex-direction:column;gap:var(--spacing-xs);margin-top:var(--spacing-sm);max-height:200px;overflow-y:auto;scrollbar-width:thin;scrollbar-color:var(--color-border) transparent}.workspace-list[hidden]{display:none}.workspace-list::-webkit-scrollbar{width:4px}.workspace-list::-webkit-scrollbar-track{background:transparent}.workspace-list::-webkit-scrollbar-thumb{background:var(--color-border);border-radius:2px}.workspace-list-item{display:flex;align-items:center;gap:var(--spacing-sm);padding:var(--spacing-sm) var(--spacing-md);border-radius:var(--radius-sm);cursor:pointer;font-size:.8125rem;color:var(--color-text-secondary);transition:background .15s ease,color .15s ease;min-height:32px}.workspace-list-item:hover{background:var(--color-bg);color:var(--color-text-primary)}.workspace-list-item.active{background:var(--color-primary-light);color:var(--color-primary);font-weight:500}.workspace-list-item-icon{flex-shrink:0;color:inherit;opacity:.7}.workspace-list-item.active .workspace-list-item-icon{opacity:1}.workspace-list-item-name{flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.workspace-list-item-copy,.workspace-list-item-delete{flex-shrink:0;display:flex;align-items:center;justify-content:center;width:20px;height:20px;border:none;background:transparent;color:var(--color-text-tertiary);border-radius:var(--radius-sm);cursor:pointer;opacity:0;transition:all .15s ease;padding:0}.workspace-list-item:hover .workspace-list-item-copy,.workspace-list-item:hover .workspace-list-item-delete,.workspace-list-item:focus-within .workspace-list-item-copy,.workspace-list-item:focus-within .workspace-list-item-delete{opacity:1}.workspace-list-item-copy:focus-visible,.workspace-list-item-delete:focus-visible{opacity:1;outline:2px solid var(--color-primary);outline-offset:1px}.workspace-list-item-copy:hover{background:var(--color-bg);color:var(--color-text-primary)}.workspace-list-item-delete:hover{background:var(--color-error);color:#fff}.file-list{flex:1;overflow-y:auto;margin-top:var(--spacing-sm)}.file-list::-webkit-scrollbar{width:6px}.file-list::-webkit-scrollbar-track{background:transparent}.file-list::-webkit-scrollbar-thumb{background:var(--color-border);border-radius:3px}.file-list::-webkit-scrollbar-thumb:hover{background:var(--color-text-tertiary)}.file-item{padding:var(--spacing-sm) var(--spacing-md);margin-bottom:var(--spacing-xs);background:var(--color-surface);border-radius:var(--radius-sm);display:flex;align-items:center;gap:var(--spacing-sm);font-size:.875rem;color:var(--color-text-primary);cursor:pointer;transition:background .15s ease}.file-item:hover{background:var(--color-bg)}.file-icon{font-size:1rem;flex-shrink:0}.file-name{flex:1;font-family:SF Mono,Monaco,Courier New,monospace;font-size:.8125rem;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.file-tree-dir{border:none;margin:0}.file-tree-dir>summary{list-style:none}.file-tree-dir>summary::-webkit-details-marker{display:none}.file-tree-dir-header{display:flex;align-items:center;gap:var(--spacing-sm);padding:var(--spacing-sm) var(--spacing-md);margin-bottom:var(--spacing-xs);background:var(--color-surface);border-radius:var(--radius-sm);font-size:.875rem;color:var(--color-text-primary);cursor:pointer;user-select:none;transition:background .15s ease}.file-tree-dir-header:hover{background:var(--color-bg)}.file-tree-chevron{font-size:.6rem;flex-shrink:0;color:var(--color-text-tertiary);transition:transform .2s ease}.file-tree-dir[open]>.file-tree-dir-header .file-tree-chevron{transform:rotate(90deg)}.chat-area{flex:1;display:flex;flex-direction:column;overflow:hidden;background:var(--color-bg)}.conversation-tabs{display:flex;align-items:center;background:var(--color-surface);border-bottom:1px solid var(--color-border);padding:var(--spacing-xs) var(--spacing-sm);gap:var(--spacing-xs);flex-shrink:0;min-height:44px;overflow:hidden}.tabs-container{display:flex;gap:var(--spacing-xs);flex:1;overflow-x:auto;scrollbar-width:none;-ms-overflow-style:none}.tabs-container::-webkit-scrollbar{display:none}.conversation-tab{display:flex;align-items:center;gap:var(--spacing-sm);padding:var(--spacing-sm) var(--spacing-md);background:var(--color-bg);border:1px solid var(--color-border);border-radius:var(--radius-md);cursor:pointer;font-size:.875rem;font-weight:500;color:var(--color-text-secondary);transition:all .15s ease;white-space:nowrap;max-width:200px;min-width:100px;position:relative;flex-shrink:0}.conversation-tab:hover{background:var(--color-border-light);border-color:var(--color-text-tertiary)}.conversation-tab.active{background:var(--color-primary-light);border-color:var(--color-primary);color:var(--color-primary)}.conversation-tab.active:hover{background:var(--color-primary-light)}.tab-content{display:flex;align-items:center;flex:1;min-width:0;cursor:pointer;background:transparent;border:none;padding:0;font:inherit;color:inherit;text-align:left}.tab-content:focus{outline:2px solid var(--color-primary);outline-offset:2px;border-radius:var(--radius-sm)}.tab-content:focus:not(:focus-visible){outline:none}.tab-title{overflow:hidden;text-overflow:ellipsis;white-space:nowrap;flex:1;text-align:left}.tab-title-input{width:100%;padding:2px 4px;border:1px solid var(--color-primary);border-radius:var(--radius-sm);background:var(--color-bg);color:inherit;font:inherit;font-size:inherit;outline:none;box-sizing:border-box}.tab-title-input:focus{border-color:var(--color-primary);box-shadow:0 0 0 2px var(--color-primary-light)}.tab-close{display:flex;align-items:center;justify-content:center;width:18px;height:18px;border:none;background:transparent;color:var(--color-text-tertiary);border-radius:var(--radius-sm);cursor:pointer;transition:all .15s ease;opacity:0;flex-shrink:0}.conversation-tab:hover .tab-close{opacity:1}.tab-close:hover{background:var(--color-border);color:var(--color-text-primary)}.conversation-tab.active .tab-close:hover{background:var(--color-primary);color:#fff}.tab-notification{position:absolute;top:-4px;right:-4px;width:10px;height:10px;background:var(--color-primary);border-radius:50%;border:2px solid var(--color-surface);animation:pulse 2s infinite}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}.new-tab-btn{display:flex;align-items:center;justify-content:center;width:32px;height:32px;border:1px solid var(--color-border);background:var(--color-surface);border-radius:var(--radius-md);cursor:pointer;color:var(--color-text-secondary);transition:all .15s ease;flex-shrink:0}.new-tab-btn:hover{background:var(--color-bg);border-color:var(--color-text-tertiary);color:var(--color-text-primary)}.new-tab-btn:active{transform:scale(.95)}.chat-container{flex:1;overflow-y:auto;padding:var(--spacing-xl)}.chat-container::-webkit-scrollbar{width:8px}.chat-container::-webkit-scrollbar-track{background:transparent}.chat-container::-webkit-scrollbar-thumb{background:var(--color-border);border-radius:4px}.chat-container::-webkit-scrollbar-thumb:hover{background:var(--color-text-tertiary)}.messages{display:flex;flex-direction:column;gap:var(--spacing-lg);max-width:none;margin:0 auto;padding:0 var(--spacing-lg)}.message{padding:var(--spacing-md) var(--spacing-lg);border-radius:var(--radius-lg);font-size:.9375rem;line-height:1.6;word-wrap:break-word}.message.user{align-self:flex-end;background:var(--color-primary);color:#fff;margin-left:auto;max-width:70%}.message.assistant{align-self:stretch;background:var(--color-surface);color:var(--color-text-primary);border:1px solid var(--color-border);box-shadow:var(--shadow-sm);width:100%;max-width:calc(100% - var(--spacing-xl))}.markdown-wrapper{position:relative;max-height:400px;overflow:hidden;transition:max-height .3s ease}.markdown-wrapper.expanded{max-height:calc(100vh - 200px);overflow-y:auto;scrollbar-width:thin;scrollbar-color:var(--color-border) transparent}.markdown-wrapper.expanded::-webkit-scrollbar{width:8px}.markdown-wrapper.expanded::-webkit-scrollbar-track{background:transparent}.markdown-wrapper.expanded::-webkit-scrollbar-thumb{background:var(--color-border);border-radius:4px}.markdown-wrapper.expanded::-webkit-scrollbar-thumb:hover{background:var(--color-text-tertiary)}.markdown-wrapper.expanded:focus-visible{outline:2px solid var(--color-primary);outline-offset:2px}.markdown-wrapper:not(.expanded).truncated:after{content:"";position:absolute;bottom:0;left:0;right:0;height:60px;background:linear-gradient(to bottom,transparent,var(--color-surface));pointer-events:none}.message.assistant .markdown-iframe{display:block;width:100%;min-height:24px;border:none;background:transparent;overflow:hidden}.markdown-expand-btn{display:none;width:100%;padding:var(--spacing-sm) var(--spacing-md);margin-top:var(--spacing-sm);border:1px solid var(--color-border);border-radius:var(--radius-md);background:var(--color-bg);color:var(--color-text-secondary);font-size:.875rem;font-weight:500;cursor:pointer;transition:all .2s ease}.markdown-expand-btn:hover{background:var(--color-border-light);color:var(--color-text-primary)}.markdown-wrapper.truncated .markdown-expand-btn,.markdown-wrapper.expanded .markdown-expand-btn{display:block}.message.system{align-self:center;background:var(--color-warning);color:#fff;text-align:center;font-size:.875rem;max-width:90%}.message.error{align-self:center;background:var(--color-error);color:#fff;text-align:center;font-size:.875rem;max-width:90%}.tool-call{background:var(--color-surface);border:1px solid var(--color-border);border-left:3px solid var(--color-accent);padding:var(--spacing-md);margin:var(--spacing-sm) 0;border-radius:var(--radius-md);font-size:.875rem;max-width:600px}.tool-call-name{font-weight:600;color:var(--color-accent);margin-bottom:var(--spacing-xs);display:flex;align-items:center;gap:var(--spacing-xs)}.tool-call-args{font-family:SF Mono,Monaco,Courier New,monospace;font-size:.8125rem;color:var(--color-text-secondary);background:var(--color-bg);padding:var(--spacing-sm);border-radius:var(--radius-sm);overflow-x:auto;white-space:pre-wrap;word-break:break-all}.tool-activity-group{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);margin:var(--spacing-md) 0;max-width:600px;overflow:hidden}.tool-activity-header{display:flex;align-items:center;gap:var(--spacing-sm);padding:var(--spacing-md);background:var(--color-bg);cursor:pointer;user-select:none;transition:background-color .15s ease}.tool-activity-header:hover{background:var(--color-border-light)}.tool-activity-icon{font-size:1rem;line-height:1}.tool-activity-summary{flex:1;font-size:.875rem;font-weight:500;color:var(--color-text-secondary)}.tool-activity-toggle{font-size:.75rem;color:var(--color-text-tertiary);transition:transform .2s ease}.tool-activity-content{max-height:0;overflow:hidden;transition:max-height .3s ease-out}.tool-activity-group.expanded .tool-activity-content{max-height:70vh;overflow-y:auto;transition:max-height .5s ease-in}.tool-activity-item{padding:var(--spacing-md);border-top:1px solid var(--color-border-light)}.tool-activity-item:first-child{border-top:none}.tool-item-header{display:flex;align-items:center;gap:var(--spacing-sm)}.tool-item-icon{font-size:.875rem}.tool-item-name{flex:1;font-family:SF Mono,Monaco,Courier New,monospace;font-size:.8125rem;font-weight:600;color:var(--color-text-primary)}.tool-item-status{font-size:.75rem;padding:2px 8px;border-radius:var(--radius-sm);font-weight:500}.tool-item-status.pending{background:var(--color-info);color:#fff}.tool-item-status.completed{background:var(--color-success);color:#fff}.tool-item-details{margin-top:var(--spacing-sm)}.tool-item-details summary{cursor:pointer;font-size:.75rem;font-weight:500;color:var(--color-text-tertiary);padding:var(--spacing-xs) 0;user-select:none}.tool-item-details summary:hover{color:var(--color-text-secondary)}.tool-item-details[open] summary{margin-bottom:var(--spacing-xs)}.tool-item-args,.tool-item-result{font-family:SF Mono,Monaco,Courier New,monospace;font-size:.75rem;color:var(--color-text-secondary);background:var(--color-bg);padding:var(--spacing-sm);border-radius:var(--radius-sm);overflow-x:auto;white-space:pre-wrap;word-break:break-all;margin:0;max-height:200px;overflow-y:auto}.tool-result-details .tool-item-result{border-left:2px solid var(--color-success)}.tool-output-block{align-self:stretch;background:var(--color-surface);border:1px solid var(--color-border);border-left:3px solid var(--color-accent);border-radius:var(--radius-lg);padding:var(--spacing-md) var(--spacing-lg);width:100%;max-width:calc(100% - var(--spacing-xl));box-shadow:var(--shadow-sm)}.tool-output-header{display:flex;align-items:center;gap:var(--spacing-sm);margin-bottom:var(--spacing-sm)}.tool-output-name{font-family:SF Mono,Monaco,Courier New,monospace;font-size:.8125rem;font-weight:600;color:var(--color-accent)}.tool-output-meta{font-size:.75rem;color:var(--color-text-tertiary)}.tool-output-content{font-family:SF Mono,Monaco,Courier New,monospace;font-size:.8125rem;line-height:1.5;color:var(--color-text-primary);background:var(--color-bg);padding:var(--spacing-md);border-radius:var(--radius-md);overflow-x:auto;overflow-y:auto;max-height:400px;white-space:pre;margin:0;scrollbar-width:thin;scrollbar-color:var(--color-border) transparent}.tool-output-content::-webkit-scrollbar{width:8px;height:8px}.tool-output-content::-webkit-scrollbar-track{background:transparent}.tool-output-content::-webkit-scrollbar-thumb{background:var(--color-border);border-radius:4px}.tool-output-content::-webkit-scrollbar-thumb:hover{background:var(--color-text-tertiary)}.chat-input-wrapper{background:var(--color-surface);border-top:1px solid var(--color-border);padding:var(--spacing-lg) var(--spacing-xl);flex-shrink:0}.status-bar{margin-bottom:var(--spacing-md);padding:var(--spacing-sm) var(--spacing-md);border-radius:var(--radius-md);font-size:.875rem;display:none;align-items:center;justify-content:space-between;gap:var(--spacing-sm)}.status-message{flex:1}.status-dismiss{background:none;border:none;cursor:pointer;font-size:1.25rem;line-height:1;padding:0 var(--spacing-xs);opacity:.6;color:inherit;transition:opacity .2s ease}.status-dismiss:hover{opacity:1}.status-dismiss:focus-visible{outline:2px solid currentColor;outline-offset:2px;border-radius:var(--radius-sm)}.status-bar.info{display:flex;background:#e3f2fd;color:#1976d2;border:1px solid #90CAF9}.status-bar.success{display:flex;background:#e8f5e9;color:#388e3c;border:1px solid #A5D6A7}.status-bar.error{display:flex;background:#ffebee;color:#c62828;border:1px solid #EF9A9A}.chat-input-container{display:flex;gap:var(--spacing-md);align-items:flex-end;max-width:1200px;margin:0 auto}@media(min-width:1400px){.chat-input-container{max-width:none}}.chat-input-wrapper-inner{flex:1;position:relative;display:flex;align-items:center}.chat-input{flex:1;padding:var(--spacing-md) var(--spacing-lg);padding-right:48px;border:1px solid var(--color-border);border-radius:var(--radius-lg);font-size:.9375rem;font-family:inherit;resize:none;max-height:200px;overflow-y:auto;line-height:1.5;transition:border-color .2s ease}.chat-input:focus{outline:none;border-color:var(--color-primary)}.chat-input::placeholder{color:var(--color-text-tertiary)}.voice-btn{position:absolute;right:8px;top:50%;transform:translateY(-50%);width:32px;height:32px;border-radius:var(--radius-md);border:none;background:transparent;color:var(--color-text-secondary);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s ease;flex-shrink:0;z-index:1}.voice-btn:hover{background:var(--color-bg);color:var(--color-text-primary)}.voice-btn:active{transform:translateY(-50%) scale(.95)}.voice-btn:disabled{background:transparent;cursor:not-allowed;opacity:.3}.voice-btn:focus-visible{outline:2px solid var(--color-primary);outline-offset:2px}.voice-btn.recording{background:var(--color-error);color:#fff;animation:pulse-recording 1.5s ease-in-out infinite}.voice-btn.recording:hover{background:var(--color-error-hover);color:#fff}@keyframes pulse-recording{0%,to{opacity:1;transform:translateY(-50%) scale(1)}50%{opacity:.85;transform:translateY(-50%) scale(1.08)}}@media(prefers-reduced-motion:reduce){.voice-btn.recording{animation:none}}.voice-btn.error{background:var(--color-error);color:#fff}.send-btn{width:44px;height:44px;border-radius:var(--radius-lg);border:none;background:var(--color-primary);color:#fff;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s ease;flex-shrink:0}.send-btn:hover{background:var(--color-primary-hover);transform:translateY(-1px);box-shadow:var(--shadow-md)}.send-btn:active{transform:translateY(0)}.send-btn:disabled{background:var(--color-border);cursor:not-allowed;transform:none}dialog.modal{border:none;padding:0;background:transparent;max-width:none;max-height:none;width:auto;height:auto;overflow:visible}dialog.modal::backdrop{background:#0006;backdrop-filter:blur(2px)}dialog.modal[open]{display:flex;align-items:center;justify-content:center}.modal-content{position:relative;background:var(--color-surface);border-radius:var(--radius-xl);box-shadow:var(--shadow-xl);max-width:500px;width:90%;max-height:80vh;display:flex;flex-direction:column}.modal-header{display:flex;align-items:center;justify-content:space-between;padding:var(--spacing-xl);border-bottom:1px solid var(--color-border-light)}.modal-header h2{font-size:1.25rem;font-weight:600;color:var(--color-text-primary)}.modal-close{width:32px;height:32px;border-radius:var(--radius-md);border:none;background:transparent;color:var(--color-text-secondary);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s ease}.modal-close:hover{background:var(--color-bg);color:var(--color-text-primary)}.modal-body{padding:var(--spacing-xl);overflow-y:auto}.modal-body::-webkit-scrollbar{width:6px}.modal-body::-webkit-scrollbar-track{background:transparent}.modal-body::-webkit-scrollbar-thumb{background:var(--color-border);border-radius:3px}.form-group{margin-bottom:var(--spacing-lg)}.form-group:last-child{margin-bottom:0}.form-group label{display:block;font-weight:600;font-size:.875rem;margin-bottom:var(--spacing-sm);color:var(--color-text-primary)}.form-input,.form-select{width:100%;padding:var(--spacing-sm) var(--spacing-md);border:1px solid var(--color-border);border-radius:var(--radius-md);font-size:.9375rem;font-family:inherit;transition:border-color .2s ease;background:var(--color-surface);color:var(--color-text-primary)}.form-input:focus,.form-select:focus{outline:none;border-color:var(--color-primary)}.form-hint{display:block;margin-top:var(--spacing-sm);color:var(--color-text-secondary);font-size:.8125rem;line-height:1.4}.provider-warning{display:flex;align-items:flex-start;gap:var(--spacing-sm);margin-top:var(--spacing-sm);padding:var(--spacing-sm) var(--spacing-md);background:#fff3cd;border:1px solid #FFC107;border-radius:var(--radius-md);font-size:.8125rem;color:#856404}.provider-warning svg{flex-shrink:0;color:#f57c00;margin-top:2px}.provider-warning[hidden]{display:none}@media(prefers-color-scheme:dark){.provider-warning{background:#3e2723;border-color:#5d4037;color:#ffcc80}.provider-warning svg{color:#ffb74d}}.tool-permissions{display:flex;flex-direction:column;gap:var(--spacing-md)}.permission-item{display:flex;align-items:center;justify-content:space-between;padding:var(--spacing-md);background:var(--color-bg);border-radius:var(--radius-md);gap:var(--spacing-md)}.tool-name{font-weight:500;font-size:.9375rem;color:var(--color-text-primary)}.permission-select{padding:var(--spacing-xs) var(--spacing-sm);border:1px solid var(--color-border);border-radius:var(--radius-sm);font-size:.875rem;min-width:140px;background:var(--color-surface);color:var(--color-text-primary);cursor:pointer}.permission-select:focus{outline:none;border-color:var(--color-primary)}.permission-group{border:1px solid var(--color-border);border-radius:var(--radius-md);overflow:hidden}.permission-group+.permission-group{margin-top:var(--spacing-md)}.permission-group-header{display:flex;align-items:center;gap:var(--spacing-sm);padding:var(--spacing-md);background:var(--color-bg);cursor:pointer;user-select:none;font-weight:600;font-size:.9375rem;color:var(--color-text-primary);list-style:none;transition:background-color .15s ease}.permission-group-header::-webkit-details-marker{display:none}.permission-group-header:hover{background:var(--color-border-light)}.permission-group-chevron{flex-shrink:0;transition:transform .2s ease}.permission-group[open] .permission-group-chevron{transform:rotate(90deg)}.permission-group-content{padding:var(--spacing-sm);background:var(--color-surface)}.permission-group-content .permission-item{margin-bottom:var(--spacing-xs)}.permission-group-content .permission-item:last-child{margin-bottom:0}.wasm-tools-section{display:flex;flex-direction:column;gap:var(--spacing-md)}.wasm-tools-list{display:flex;flex-direction:column;gap:var(--spacing-xs)}.wasm-tools-empty{padding:var(--spacing-lg);text-align:center;color:var(--color-text-tertiary);font-size:.875rem;background:var(--color-bg);border-radius:var(--radius-md)}.wasm-tools-actions{display:flex;justify-content:center;align-items:center;gap:var(--spacing-sm);margin-top:var(--spacing-md)}.wasm-install-btn{display:inline-flex;align-items:center;gap:var(--spacing-sm);cursor:pointer}.wasm-install-btn svg{flex-shrink:0}.wasm-info-btn{display:flex;align-items:center;justify-content:center;width:32px;height:32px;border-radius:var(--radius-md);border:1px solid var(--color-border);background:var(--color-surface);color:var(--color-text-secondary);cursor:pointer;transition:all .2s ease;text-decoration:none;flex-shrink:0}.wasm-info-btn:hover{background:var(--color-bg);color:var(--color-text-primary);border-color:var(--color-text-tertiary)}.wasm-info-btn:focus-visible{outline:2px solid var(--color-primary);outline-offset:2px}.wasm-tool-item{display:flex;align-items:center;justify-content:space-between;padding:var(--spacing-md);background:var(--color-bg);border-radius:var(--radius-md);gap:var(--spacing-md)}.wasm-tool-info{flex:1;min-width:0;display:flex;flex-direction:column}.wasm-tool-name-row{display:flex;align-items:center;gap:var(--spacing-sm)}.wasm-tool-name{font-weight:500;font-size:.9375rem;color:var(--color-text-primary)}.wasm-tool-download-badge{font-size:.6875rem;font-weight:500;color:var(--color-info);background:var(--color-info-bg);padding:1px 6px;border-radius:8px;white-space:nowrap}.wasm-tool-description{font-size:.8125rem;color:var(--color-text-secondary);margin-top:var(--spacing-xs);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.wasm-tool-meta{font-size:.75rem;color:var(--color-text-tertiary);margin-top:var(--spacing-xs)}.wasm-tool-controls{display:flex;align-items:center;gap:var(--spacing-sm)}.wasm-tool-toggle{position:relative;width:44px;height:24px;background:var(--color-border);border-radius:12px;border:none;cursor:pointer;transition:background-color .2s ease}.wasm-tool-toggle:before{content:"";position:absolute;top:2px;left:2px;width:20px;height:20px;background:#fff;border-radius:50%;transition:transform .2s ease;box-shadow:var(--shadow-sm)}.wasm-tool-toggle.enabled{background:var(--color-success)}.wasm-tool-toggle.enabled:before{transform:translate(20px)}.wasm-tool-toggle.downloading{background:var(--color-info);pointer-events:none;opacity:.7}.wasm-tool-toggle.downloading:before{animation:wasm-download-pulse 1s ease-in-out infinite}@keyframes wasm-download-pulse{0%,to{opacity:1}50%{opacity:.4}}.wasm-tool-delete{width:28px;height:28px;border:1px solid var(--color-border);background:var(--color-surface);border-radius:var(--radius-sm);cursor:pointer;display:flex;align-items:center;justify-content:center;color:var(--color-text-tertiary);transition:all .2s ease}.wasm-tool-delete:hover{background:#ffebee;border-color:var(--color-error);color:var(--color-error)}@media(prefers-color-scheme:dark){.permission-group-header:hover{background:#333}.wasm-tool-toggle{background:#4a4a4a}.wasm-tool-toggle:before{background:#e0e0e0}.wasm-tool-toggle.enabled{background:var(--color-success)}.wasm-tool-toggle.enabled:before{background:#fff}.wasm-tool-download-badge{background:#1a3a5c;color:var(--color-info-light)}.wasm-tool-toggle.downloading{background:var(--color-info-dark)}.wasm-tool-delete:hover{background:#4a1a1a;border-color:var(--color-error);color:#ef9a9a}}dialog.permission-dialog{border:none;background:var(--color-surface);padding:var(--spacing-xl);border-radius:var(--radius-xl);box-shadow:var(--shadow-xl);max-width:500px;max-height:80vh;width:90%;margin:auto;display:flex;flex-direction:column;overflow:hidden}.permission-dialog .tool-call{flex-shrink:1;min-height:0;overflow:hidden;display:flex;flex-direction:column;margin-bottom:var(--spacing-md)}.permission-dialog .tool-call-args{max-height:200px;overflow-y:auto;flex-shrink:1;margin:0}dialog.permission-dialog::backdrop{background:#0006;backdrop-filter:blur(2px)}dialog.permission-dialog[open]{display:block}.permission-dialog h3{margin-bottom:var(--spacing-md);color:var(--color-text-primary);font-size:1.125rem;font-weight:600}.permission-dialog p{margin-bottom:var(--spacing-lg);color:var(--color-text-secondary);font-size:.9375rem;line-height:1.5}.session-permission-label{display:flex;align-items:center;gap:var(--spacing-sm);margin-bottom:var(--spacing-md);color:var(--color-text-secondary);font-size:.875rem;cursor:pointer;user-select:none}.session-permission-checkbox{accent-color:var(--color-success);width:16px;height:16px}.permission-dialog-buttons{display:flex;gap:var(--spacing-md);justify-content:flex-end}.permission-dialog button{padding:var(--spacing-sm) var(--spacing-lg);border:none;border-radius:var(--radius-md);cursor:pointer;font-size:.9375rem;font-weight:600;transition:all .2s ease}.permission-dialog .approve-btn{background-color:var(--color-success);color:#fff}.permission-dialog .approve-btn:hover{background-color:#45a049;transform:translateY(-1px);box-shadow:var(--shadow-md)}.permission-dialog .deny-btn{background-color:var(--color-error);color:#fff}.permission-dialog .deny-btn:hover{background-color:#e53935;transform:translateY(-1px);box-shadow:var(--shadow-md)}.permission-dialog .cancel-btn{background-color:var(--color-border);color:var(--color-text-primary)}.permission-dialog .cancel-btn:hover{background-color:var(--color-text-tertiary);color:#fff}.permission-hint{margin-top:var(--spacing-md);margin-bottom:0;color:var(--color-text-tertiary);text-align:center;font-size:.8125rem}.batch-permission-dialog{max-width:600px;max-height:80vh;display:flex;flex-direction:column}.batch-tool-list{max-height:300px;overflow-y:auto;margin-bottom:var(--spacing-md);border:1px solid var(--color-border);border-radius:var(--radius-md);background:var(--color-background)}.batch-tool-item{display:flex;align-items:flex-start;gap:var(--spacing-md);padding:var(--spacing-md);border-bottom:1px solid var(--color-border)}.batch-tool-item:last-child{border-bottom:none}.batch-tool-item .tool-call{flex:1;margin:0;animation:none}.batch-tool-item .tool-call-args{max-height:100px;overflow-y:auto}.batch-tool-checkbox{display:flex;align-items:center;justify-content:center;cursor:pointer;padding-top:var(--spacing-xs)}.batch-tool-checkbox input[type=checkbox]{width:18px;height:18px;cursor:pointer;accent-color:var(--color-primary)}.batch-selection-controls{display:flex;gap:var(--spacing-sm);margin-bottom:var(--spacing-md)}.batch-selection-controls button{padding:var(--spacing-xs) var(--spacing-md);border:1px solid var(--color-border);border-radius:var(--radius-sm);background:var(--color-surface);color:var(--color-text-secondary);font-size:.8125rem;cursor:pointer;transition:all .2s ease}.batch-selection-controls button:hover{background:var(--color-border);color:var(--color-text-primary)}.sidebar-overlay{display:none;position:fixed;inset:0;background:#0006;backdrop-filter:blur(2px);z-index:99}.sidebar-overlay.active{display:block}@media(max-width:768px){.mobile-only{display:flex}.sidebar{position:fixed;left:-100%;top:var(--header-height);height:calc(100vh - var(--header-height));z-index:100;transition:left .3s ease;box-shadow:var(--shadow-xl)}.sidebar.open{left:0}.main-content{width:100%}.chat-area{height:calc(100vh - var(--header-height))}.conversation-tabs{padding:var(--spacing-xs);min-height:40px}.conversation-tab{padding:var(--spacing-xs) var(--spacing-sm);font-size:.8125rem;min-width:80px;max-width:150px}.tab-close{opacity:1;width:20px;height:20px}.new-tab-btn{width:28px;height:28px}.chat-container{padding:var(--spacing-md);padding-bottom:140px}.chat-input-wrapper{position:fixed;bottom:0;left:0;right:0;padding:var(--spacing-md);background:var(--color-surface);border-top:1px solid var(--color-border);box-shadow:var(--shadow-md);z-index:50}.chat-input-container{max-width:100%}.chat-input{font-size:16px;min-height:44px;padding-right:52px}.voice-btn{width:36px;height:36px;right:6px}.send-btn{width:48px;height:48px}.message.user{max-width:85%}.message.assistant{width:100%;max-width:calc(100% - var(--spacing-lg))}.status-bar{position:static}.tool-call,.tool-activity-group,.message,.modal-content,dialog.modal[open],dialog.permission-dialog[open],dialog.batch-permission-dialog[open]{animation:none!important}.batch-permission-dialog{max-height:90vh;width:95%}.batch-tool-list{max-height:200px}.batch-selection-controls{justify-content:center}}.info-content h3{font-size:1.125rem;font-weight:600;margin-top:var(--spacing-lg);margin-bottom:var(--spacing-md);color:var(--color-text-primary)}.info-content h3:first-child{margin-top:0}.info-content p{margin-bottom:var(--spacing-md);color:var(--color-text-secondary);line-height:1.6}.info-content a{color:var(--color-primary);text-decoration:none;font-weight:500}.info-content a:hover{text-decoration:underline}.info-content ul{margin:var(--spacing-md) 0;padding-left:var(--spacing-xl);color:var(--color-text-secondary)}.info-content li{margin-bottom:var(--spacing-sm);line-height:1.6}.warning-box{display:flex;gap:var(--spacing-md);padding:var(--spacing-lg);background:#fff3cd;border:1px solid #FFC107;border-left:4px solid #FF9800;border-radius:var(--radius-md);margin:var(--spacing-md) 0}.warning-box svg{flex-shrink:0;color:#f57c00;margin-top:var(--spacing-xs)}.warning-box strong{display:block;margin-bottom:var(--spacing-sm);color:#e65100}.warning-box p{margin:0;color:#5d4037;font-size:.9375rem}#network-btn{position:relative}.network-status-dot{position:absolute;top:4px;right:4px;width:8px;height:8px;border-radius:50%;background:var(--color-error);border:2px solid var(--color-surface);pointer-events:none}.network-status-dot.connected{background:var(--color-success)}.violation-badge{position:absolute;top:-2px;right:-2px;min-width:16px;height:16px;padding:0 4px;border-radius:8px;background:var(--color-error);color:#fff;font-size:.625rem;font-weight:700;line-height:16px;text-align:center;pointer-events:none;border:2px solid var(--color-surface)}.network-modal-content{max-width:600px}.network-modal-body{padding:0!important}.csp-banner{display:flex;align-items:center;gap:var(--spacing-md);padding:var(--spacing-md) var(--spacing-lg);border-bottom:1px solid var(--color-border-light);background:#ffebee}.csp-banner.locked{background:#e8f5e9}.csp-banner-icon{flex-shrink:0;color:var(--color-error)}.csp-banner.locked .csp-banner-icon{color:var(--color-success)}.csp-banner-text{display:flex;flex-direction:column;gap:2px;min-width:0}.csp-banner-text strong{font-size:.9375rem;color:var(--color-text-primary)}.csp-banner-detail{font-size:.8125rem;color:var(--color-text-secondary);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.network-log-header{display:flex;align-items:center;justify-content:space-between;padding:var(--spacing-sm) var(--spacing-lg);border-bottom:1px solid var(--color-border-light)}.network-log-count{font-size:.8125rem;color:var(--color-text-secondary);font-weight:500}.network-log-actions{display:flex;gap:var(--spacing-sm)}.network-action-btn{padding:var(--spacing-xs) var(--spacing-sm)!important;font-size:.8125rem!important}.network-log-list{max-height:400px;overflow-y:auto;padding:0}.network-log-empty{text-align:center;padding:var(--spacing-xl);color:var(--color-text-tertiary);font-size:.875rem}.network-log-entry{display:flex;align-items:flex-start;gap:var(--spacing-sm);padding:var(--spacing-sm) var(--spacing-lg);border-bottom:1px solid var(--color-border-light);font-size:.8125rem;transition:background-color .15s ease}.network-log-entry:last-child{border-bottom:none}.network-log-entry:hover{background:var(--color-bg)}.network-log-entry.blocked,.network-log-entry.violation{background:#fff3e0}.network-log-entry.blocked:hover,.network-log-entry.violation:hover{background:#ffe0b2}.network-log-entry.error{background:#ffebee}.network-log-entry.error:hover{background:#ffcdd2}.network-log-entry-icon{flex-shrink:0;width:16px;height:16px;display:flex;align-items:center;justify-content:center;margin-top:1px}.network-log-entry-icon.success{color:var(--color-success)}.network-log-entry-icon.cached{color:var(--color-info)}.network-log-entry-icon.blocked,.network-log-entry-icon.violation{color:var(--color-error)}.network-log-entry-icon.error{color:var(--color-warning)}.network-log-entry-icon.opaque{color:var(--color-text-tertiary)}.network-log-entry-body{flex:1;min-width:0}.network-log-entry-url{color:var(--color-text-primary);word-break:break-all;font-family:ui-monospace,SFMono-Regular,SF Mono,Menlo,monospace;font-size:.75rem}.network-log-entry-meta{color:var(--color-text-tertiary);font-size:.75rem;margin-top:2px}.network-log-entry-time{flex-shrink:0;color:var(--color-text-tertiary);font-size:.6875rem;font-family:ui-monospace,SFMono-Regular,SF Mono,Menlo,monospace;margin-top:1px}@media(prefers-color-scheme:dark){:root{--color-bg: #1A1A1A;--color-surface: #2A2A2A;--color-border: #3A3A3A;--color-border-light: #333333;--color-text-primary: #F5F5F5;--color-text-secondary: #B0B0B0;--color-text-tertiary: #808080;--color-primary-light: #3A2F2A}.csp-banner{background:#4a1a1a}.csp-banner.locked{background:#1b4d3e}.network-log-entry.blocked,.network-log-entry.violation{background:#3e2723}.network-log-entry.blocked:hover,.network-log-entry.violation:hover{background:#4e3730}.network-log-entry.error{background:#5c1a1a}.network-log-entry.error:hover{background:#6c2a2a}.network-log-entry:hover{background:#333}.network-status-dot,.violation-badge{border-color:#2a2a2a}.message.assistant{background:#35322f;border:1px solid rgba(217,119,87,.12);box-shadow:0 2px 8px #0000004d}.message.assistant .markdown-wrapper:not(.expanded).truncated:after{background:linear-gradient(to bottom,transparent,#35322F)}.message.assistant .markdown-expand-btn{background:#2a2725;border-color:#d977571a;color:var(--color-text-secondary)}.message.assistant .markdown-expand-btn:hover{background:#3a3633;color:var(--color-text-primary)}.tool-output-block{background:#35322f;border-color:#d977571f;box-shadow:0 2px 8px #0000004d}.tool-output-block .tool-output-content{background:#2a2725}.tool-activity-group{background:#302d2b;border-color:#ffffff14}.tool-activity-header{background:#3a3633}.tool-activity-header:hover{background:#43403c}.status-bar.info{background:#1e3a5f;color:#90caf9;border:1px solid #2C5282}.status-bar.success{background:#1b4d3e;color:#a5d6a7;border:1px solid #2E7D5E}.status-bar.error{background:#5c1a1a;color:#ef9a9a;border:1px solid #7C2D2D}.warning-box{background:#3e2723;border:1px solid #5D4037;border-left:4px solid #FF9800}.warning-box svg{color:#ffb74d}.warning-box strong{color:#ffcc80}.warning-box p{color:#bcaaa4}.warning-box.critical{background:#4a1a1a;border-color:#7c2d2d;border-left-color:#f44336}.warning-box.critical svg{color:#ef5350}.warning-box.critical strong{color:#ff8a80}.warning-box.critical p,.warning-box.critical li{color:#ffccbc}.form-checkbox,.batch-tool-checkbox input[type=checkbox]{color-scheme:dark}.primary-btn{background-color:#7a9cb8}.primary-btn:hover{background-color:#5b7c99}.secondary-btn{background-color:#3a3a3a;color:#f5f5f5}.secondary-btn:hover{background-color:#4a4a4a}.workspace-list-item:hover{background:#333}.workspace-list-item.active{background:var(--color-primary-light)}.workspace-list-item-delete:hover{background:var(--color-error);color:#fff}.conversation-tabs{background:#2a2a2a;border-bottom-color:#3a3a3a}.conversation-tab{background:#1a1a1a;border-color:#3a3a3a}.conversation-tab:hover{background:#333;border-color:#4a4a4a}.conversation-tab.active{background:#3a2f2a;border-color:var(--color-primary)}.tab-close:hover{background:#4a4a4a}.tab-notification{border-color:#2a2a2a}.new-tab-btn{background:#2a2a2a;border-color:#3a3a3a}.new-tab-btn:hover{background:#333;border-color:#4a4a4a}.tool-item-status.pending{background:#0b3a6e}.tool-item-status.completed{background:#1b5e20}.tool-item-args,.tool-item-result{background:#2a2725;color:#b0b0b0}.chat-privacy-notice{background:#333;border:1px solid #3A3A3A;color:#b0b0b0}.chat-privacy-notice svg{color:#ffb74d}.toast-error{background:#5c1a1a;border-color:#7c2d2d}.toast-success{background:#1b4d3e;border-color:#2e7d5e}.toast-info{background:#1e3a5f;border-color:#2c5282}.toast-warning{background:#5c4a1a;border-color:#7c632d}.toast-error .toast-message{color:#ef9a9a}.toast-success .toast-message{color:#a5d6a7}.toast-info .toast-message{color:#90caf9}.toast-warning .toast-message{color:#ffe082}}.warning-box.critical{background:#ffebee;border:1px solid #FFCDD2;border-left:4px solid #F44336}.warning-box.critical svg{color:#d32f2f}.warning-box.critical strong{color:#c62828}.warning-box.critical p{color:#5d4037}.warning-box.critical p+p{margin-top:.5rem}.warning-box.critical ul{margin:.5rem 0;padding-left:1.5rem}.warning-box.critical li{margin:.25rem 0;color:#5d4037}.warning-box.critical .warning-emphasis{margin-top:1rem}.primary-btn,.secondary-btn{padding:var(--spacing-sm) var(--spacing-lg);border:none;border-radius:var(--radius-md);cursor:pointer;font-size:.9375rem;font-weight:600;transition:all .2s ease}.primary-btn{background-color:var(--color-primary);color:#fff}.primary-btn:hover{background-color:var(--color-primary-hover);transform:translateY(-1px);box-shadow:var(--shadow-md)}.primary-btn:focus-visible{outline:2px solid var(--color-primary);outline-offset:2px}.secondary-btn{background-color:var(--color-border);color:var(--color-text-primary)}.secondary-btn:hover{background-color:var(--color-text-tertiary);color:#fff;transform:translateY(-1px)}.secondary-btn:focus-visible{outline:2px solid var(--color-text-tertiary);outline-offset:2px}.modal-buttons{margin-top:1.5rem;display:flex;gap:1rem;justify-content:flex-end}.chat-privacy-notice{display:flex;align-items:center;gap:var(--spacing-sm);padding:var(--spacing-sm) var(--spacing-md);margin-top:var(--spacing-sm);background:var(--color-bg);border:1px solid var(--color-border-light);border-radius:var(--radius-md);font-size:.8125rem;color:var(--color-text-secondary);line-height:1.4}.chat-privacy-notice svg{flex-shrink:0;color:var(--color-warning)}.chat-privacy-notice span{flex:1}.toast-container{position:fixed;top:calc(var(--header-height) + var(--spacing-md));right:var(--spacing-md);z-index:2000;display:flex;flex-direction:column;gap:var(--spacing-sm);pointer-events:none;max-width:400px}.toast{pointer-events:auto;background:var(--color-surface);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);padding:var(--spacing-md) var(--spacing-lg);display:flex;align-items:flex-start;gap:var(--spacing-md);min-width:300px;max-width:400px;border-left:4px solid;opacity:0;transform:translate(100%);transition:all .3s cubic-bezier(.4,0,.2,1)}.toast.show{opacity:1;transform:translate(0)}.toast.hiding{opacity:0;transform:translate(100%)}.toast-error{border-color:var(--color-error);background:#ffebee}.toast-success{border-color:var(--color-success);background:#e8f5e9}.toast-info{border-color:var(--color-info);background:#e3f2fd}.toast-warning{border-color:var(--color-warning);background:#fff3e0}.toast-message{flex:1;font-size:.9375rem;line-height:1.5;color:var(--color-text-primary);word-wrap:break-word}.toast-error .toast-message{color:#c62828}.toast-success .toast-message{color:#388e3c}.toast-info .toast-message{color:#1976d2}.toast-warning .toast-message{color:#f57c00}.toast-close{flex-shrink:0;width:24px;height:24px;border:none;background:transparent;color:currentColor;cursor:pointer;font-size:1.5rem;line-height:1;padding:0;opacity:.6;transition:opacity .2s ease;display:flex;align-items:center;justify-content:center}.toast-close:hover{opacity:1}@media(max-width:768px){.toast-container{top:calc(var(--header-height) + var(--spacing-sm));right:var(--spacing-sm);left:var(--spacing-sm);max-width:none}.toast{min-width:0;max-width:none}}.providers-section{display:flex;flex-direction:column;gap:var(--spacing-lg)}.providers-header{display:flex;justify-content:space-between;align-items:center}.providers-header h3{font-size:1.125rem;font-weight:600;color:var(--color-text-primary)}.providers-list{display:flex;flex-direction:column;gap:var(--spacing-md);max-height:400px;overflow-y:auto}.provider-card{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);padding:var(--spacing-lg);display:flex;flex-direction:column;gap:var(--spacing-md);transition:border-color .2s ease,box-shadow .2s ease}.provider-card.default{border-color:var(--color-primary);background:var(--color-primary-light)}.provider-card:hover{box-shadow:var(--shadow-sm)}.provider-card-header{display:flex;justify-content:space-between;align-items:start}.provider-card-info{flex:1}.provider-card-name{font-weight:600;color:var(--color-text-primary);font-size:1rem;display:flex;align-items:center;gap:var(--spacing-sm)}.provider-card-name .default-badge{display:inline-flex;align-items:center;padding:2px 8px;background:var(--color-primary);color:#fff;border-radius:var(--radius-sm);font-size:.75rem;font-weight:500;text-transform:uppercase;letter-spacing:.025em}.provider-card-details{display:flex;flex-direction:column;gap:var(--spacing-xs);margin-top:var(--spacing-xs);font-size:.875rem;color:var(--color-text-secondary)}.provider-card-detail{display:flex;align-items:center;gap:var(--spacing-xs)}.provider-card-detail strong{color:var(--color-text-primary);font-weight:500}.provider-card-actions{display:flex;gap:var(--spacing-sm)}.provider-card-btn{padding:var(--spacing-xs) var(--spacing-sm);border:1px solid var(--color-border);background:var(--color-surface);border-radius:var(--radius-sm);cursor:pointer;font-size:.875rem;transition:all .2s ease;display:flex;align-items:center;gap:var(--spacing-xs)}.provider-card-btn:hover{background:var(--color-bg);border-color:var(--color-text-secondary)}.provider-card-btn.set-default{color:var(--color-primary);border-color:var(--color-primary)}.provider-card-btn.set-default:hover{background:var(--color-primary-light)}.provider-card-btn.delete{color:var(--color-error);border-color:var(--color-error)}.provider-card-btn.delete:hover{background:#ffebee}.providers-empty{text-align:center;padding:var(--spacing-xl);color:var(--color-text-secondary)}.providers-empty p{margin-bottom:var(--spacing-md)}.skills-description{color:var(--color-text-secondary);font-size:.875rem;margin-bottom:var(--spacing-lg)}.skills-description code{background:var(--color-bg);padding:1px 4px;border-radius:var(--radius-sm);font-size:.8rem}.skills-list{display:flex;flex-direction:column;gap:var(--spacing-sm)}.skills-empty{text-align:center;padding:var(--spacing-xl) var(--spacing-lg);color:var(--color-text-secondary)}.skills-empty p{margin-bottom:var(--spacing-sm)}.skills-actions{margin-top:var(--spacing-lg);display:flex;gap:var(--spacing-sm)}.skill-list-item{display:flex;align-items:center;gap:var(--spacing-md);padding:var(--spacing-sm) var(--spacing-md);border:1px solid var(--color-border-light);border-radius:var(--radius-md);transition:background .15s,border-color .15s}.skill-list-item:hover{background:var(--color-bg);border-color:var(--color-border)}.skill-list-item-info{flex:1;min-width:0}.skill-list-item-header{display:flex;align-items:center;gap:var(--spacing-sm)}.skill-list-item-name{font-weight:600;font-size:.9rem;color:var(--color-text-primary);font-family:var(--font-mono, monospace)}.skill-list-item-description{color:var(--color-text-secondary);font-size:.8rem;margin:2px 0 0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.skill-list-item-hint{display:inline-block;margin-top:2px;font-size:.75rem;color:var(--color-text-tertiary);font-family:var(--font-mono, monospace)}.skill-badge{font-size:.65rem;padding:1px 5px;border-radius:var(--radius-sm);font-weight:500;text-transform:uppercase;letter-spacing:.03em}.skill-badge-readonly{background:var(--color-primary-light);color:var(--color-primary)}.skill-list-item-actions{display:flex;gap:var(--spacing-xs);flex-shrink:0}.skill-action-btn{display:flex;align-items:center;justify-content:center;width:28px;height:28px;border:none;border-radius:var(--radius-sm);background:none;color:var(--color-text-tertiary);cursor:pointer;transition:background .15s,color .15s}.skill-run-btn:hover{background:var(--color-primary-light);color:var(--color-primary)}.skill-delete-btn:hover{background:var(--color-error);color:#fff}.skill-action-btn:focus-visible{outline:2px solid var(--color-primary);outline-offset:1px}.skill-runner-content{max-width:480px}.skill-runner-info{margin-bottom:var(--spacing-lg)}.skill-runner-skill-name{font-family:var(--font-mono, monospace);font-size:1.1rem;font-weight:600;color:var(--color-text-primary);margin-bottom:var(--spacing-xs)}.skill-runner-skill-description{color:var(--color-text-secondary);font-size:.875rem}.notifications-section{border-top:1px solid var(--color-border);padding-top:var(--spacing-lg)}.notifications-section h3{font-size:1.125rem;font-weight:600;color:var(--color-text-primary);margin-bottom:var(--spacing-sm)}.notifications-description{color:var(--color-text-secondary);font-size:.875rem;margin-bottom:var(--spacing-md)}.notification-setting{display:flex;flex-direction:column;gap:var(--spacing-sm)}.notifications-status{font-size:.8125rem;color:var(--color-text-tertiary);margin:0}.notifications-status.denied{color:var(--color-error)}.checkbox-label{display:flex;align-items:center;gap:var(--spacing-sm);cursor:pointer;user-select:none}.form-checkbox{width:18px;height:18px;cursor:pointer;accent-color:var(--color-primary)}.modal-buttons{display:flex;justify-content:flex-end;gap:var(--spacing-md);margin-top:var(--spacing-lg);padding-top:var(--spacing-lg);border-top:1px solid var(--color-border)}.primary-btn{padding:var(--spacing-sm) var(--spacing-lg);background:var(--color-primary);color:#fff;border:none;border-radius:var(--radius-md);cursor:pointer;font-size:.9375rem;font-weight:500;transition:background-color .2s ease;display:flex;align-items:center;gap:var(--spacing-sm)}.primary-btn:hover{background:var(--color-primary-hover)}.primary-btn:disabled{background:var(--color-border);cursor:not-allowed;opacity:.6}.secondary-btn{padding:var(--spacing-sm) var(--spacing-lg);background:var(--color-surface);color:var(--color-text-primary);border:1px solid var(--color-border);border-radius:var(--radius-md);cursor:pointer;font-size:.9375rem;font-weight:500;transition:all .2s ease}.secondary-btn:hover{background:var(--color-bg);border-color:var(--color-text-secondary)}.update-notification{position:fixed;top:calc(var(--header-height) + var(--spacing-md));right:var(--spacing-md);z-index:1500;display:flex;align-items:center;gap:var(--spacing-sm);padding:var(--spacing-sm) var(--spacing-md);background:var(--color-surface);border:1px solid var(--color-info);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);opacity:0;transform:translateY(-10px);transition:opacity .3s ease,transform .3s ease}.update-notification[hidden]{display:none}.update-notification.show{opacity:1;transform:translateY(0)}.update-notification-text{font-size:.875rem;color:var(--color-text-primary);font-weight:500}.update-notification-link{font-size:.8125rem;color:var(--color-info);text-decoration:none;font-weight:500;transition:color .2s ease}.update-notification-link:hover{color:var(--color-info-hover);text-decoration:underline}.update-notification-link[hidden]{display:none}.update-notification-btn{padding:var(--spacing-xs) var(--spacing-md);background:var(--color-info);color:#fff;border:none;border-radius:var(--radius-sm);font-size:.8125rem;font-weight:600;cursor:pointer;transition:background-color .2s ease}.update-notification-btn:hover{background:var(--color-info-hover)}.update-notification-dismiss{display:flex;align-items:center;justify-content:center;width:24px;height:24px;padding:0;background:transparent;border:none;color:var(--color-text-tertiary);cursor:pointer;border-radius:var(--radius-sm);transition:color .2s ease,background-color .2s ease}.update-notification-dismiss:hover{color:var(--color-text-primary);background:var(--color-bg)}@media(prefers-color-scheme:dark){.update-notification{background:var(--color-notification-bg, #1E3A5F);border-color:var(--color-notification-border, #2C5282)}.update-notification-text{color:var(--color-info-bg)}.update-notification-link{color:var(--color-info-light)}.update-notification-link:hover{color:var(--color-info-lighter)}.update-notification-btn{background:var(--color-info-dark, #42A5F5)}.update-notification-btn:hover{background:var(--color-info-light)}.update-notification-dismiss{color:var(--color-info-lighter)}.update-notification-dismiss:hover{color:var(--color-info-bg);background:#ffffff1a}.skill-list-item{border-color:#333}.skill-list-item:hover{background:#333;border-color:#444}.skills-description code{background:#333}}@media(max-width:768px){.update-notification{top:calc(var(--header-height) + var(--spacing-sm));right:var(--spacing-sm);left:var(--spacing-sm)}}.file-list{view-transition-name:file-list}.folder-info{view-transition-name:folder-info}.chat-input-wrapper{view-transition-name:chat-input-wrapper}::view-transition-old(root){animation:none}::view-transition-new(root){animation:none}::view-transition-old(file-list){animation:vt-fade-out .15s ease-out}::view-transition-new(file-list){animation:vt-fade-in .15s ease-out}::view-transition-old(folder-info){animation:vt-slide-out-up .2s ease-out}::view-transition-new(folder-info){animation:vt-slide-in-down .2s ease-out}::view-transition-old(status-bar){animation:vt-fade-out .15s ease-out}::view-transition-new(status-bar){animation:vt-fade-in .15s ease-out}::view-transition-old(chat-input-wrapper),::view-transition-new(chat-input-wrapper){animation:none}::view-transition-old(*){animation:vt-fade-out .15s ease-out}::view-transition-new(*){animation:vt-message-in .2s cubic-bezier(.2,0,.2,1)}@keyframes vt-fade-out{0%{opacity:1}to{opacity:0}}@keyframes vt-fade-in{0%{opacity:0}to{opacity:1}}@keyframes vt-slide-out-up{0%{opacity:1;transform:translateY(0)}to{opacity:0;transform:translateY(-10px)}}@keyframes vt-slide-in-down{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}@keyframes vt-slide-out-right{0%{opacity:1;transform:translate(0)}to{opacity:0;transform:translate(10px)}}@keyframes vt-slide-in-left{0%{opacity:0;transform:translate(-10px)}to{opacity:1;transform:translate(0)}}@keyframes vt-message-in{0%{opacity:0;transform:translateY(20px) scale(.95)}to{opacity:1;transform:translateY(0) scale(1)}}@keyframes vt-expand-in{0%{opacity:0;transform:scaleY(.8);transform-origin:top}to{opacity:1;transform:scaleY(1);transform-origin:top}}@media(prefers-reduced-motion:reduce){::view-transition-group(*),::view-transition-old(*),::view-transition-new(*){animation:none!important}}
