:root{--paper: #f8f6f3;--paper-soft: #f3f1ed;--paper-accent: #eae7e1;--bg-primary: var(--paper);--bg-secondary: var(--paper-soft);--bg-tertiary: var(--paper-accent);--ink: #2c2825;--ink-soft: #5c5651;--ink-muted: #8a847d;--ink-whisper: #b8b2aa;--text-primary: var(--ink);--text-secondary: var(--ink-soft);--text-tertiary: var(--ink-muted);--text-muted: var(--ink-whisper);--accent: #7d8c5c;--accent-hover: #6a7a4d;--accent-soft: rgba(125, 140, 92, .12);--accent-light: var(--accent-soft);--olive: #7d8c5c;--olive-dark: #5c6b42;--olive-soft: rgba(125, 140, 92, .15);--olive-muted: #9ba87a;--line: rgba(120, 113, 108, .12);--line-emphasis: rgba(120, 113, 108, .25);--border-light: var(--line);--border: var(--line-emphasis);--border-dark: rgba(120, 113, 108, .35);--code-bg: #2a2725;--code-text: #e8e4df;--space-xs: .25rem;--space-sm: .5rem;--space-md: 1rem;--space-lg: 1.5rem;--space-xl: 2.5rem;--space-2xl: 4rem;--font-sans: "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif;--font-mono: "JetBrains Mono", "SF Mono", "Consolas", monospace;--text-xs: .75rem;--text-sm: .875rem;--text-base: 1rem;--text-lg: 1.125rem;--text-xl: 1.25rem;--text-2xl: 1.5rem;--text-3xl: 1.875rem;--weight-light: 300;--weight-normal: 400;--weight-medium: 500;--weight-semibold: 600;--transition-fast: .15s ease;--transition-base: .2s ease;--radius-sm: 4px;--radius-md: 6px;--radius-lg: 8px;--shadow-subtle: 0 1px 3px rgba(44, 40, 37, .04), 0 4px 12px rgba(44, 40, 37, .06);--shadow-elevated: 0 4px 6px rgba(44, 40, 37, .05), 0 12px 24px rgba(44, 40, 37, .1)}*{margin:0;padding:0;box-sizing:border-box}html,body,#root{height:100%;margin:0;padding:0}body{font-family:var(--font-sans);font-size:var(--text-base);line-height:1.65;color:var(--ink);background:var(--paper);padding:var(--space-sm) var(--space-lg);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;overflow-x:auto;overflow-y:hidden;min-width:800px}#root{height:100%}.container{max-width:1600px;margin:0 auto;height:100%;display:flex;flex-direction:column}.page-title-area{display:flex;flex-direction:column;align-items:center;padding:var(--space-xs) 0 var(--space-sm);flex-shrink:0}.page-title{font-size:var(--text-xl);font-weight:var(--weight-medium);color:var(--ink);margin:0;letter-spacing:-.02em}.page-title:after{content:"";display:block;width:40px;height:2px;background:var(--olive);margin:var(--space-xs) auto var(--space-xs);border-radius:1px}h1{font-size:var(--text-2xl);font-weight:var(--weight-medium);color:var(--ink);text-align:center;margin-bottom:var(--space-xl);letter-spacing:-.02em}h1:after{content:"";display:block;width:40px;height:2px;background:var(--olive);margin:var(--space-sm) auto 0;border-radius:1px}h2{font-size:var(--text-xl);font-weight:var(--weight-medium);color:var(--ink);letter-spacing:-.015em}h3{font-size:var(--text-lg);font-weight:var(--weight-medium);color:var(--ink)}.main-layout{display:grid;grid-template-columns:480px 1fr;gap:var(--space-lg);align-items:stretch;flex:1;min-height:0}.left-panel{display:flex;flex-direction:column;gap:var(--space-sm);height:100%;overflow:hidden;min-width:360px}.right-panel{min-width:0;display:flex;flex-direction:column;background:transparent;overflow:hidden;align-self:stretch}.show{display:block!important}.hide{display:none!important}button{font-family:inherit;cursor:pointer;transition:color var(--transition-fast),border-color var(--transition-fast)}button:disabled{opacity:.5;cursor:not-allowed}input,textarea{font-family:inherit;font-size:var(--text-sm)}@media(max-width:1200px){.main-layout{grid-template-columns:360px 1fr}}.auth-container{display:flex;align-items:center;justify-content:flex-end;gap:var(--space-sm);width:100%;padding:0;box-sizing:border-box;min-height:24px}.auth-btn{display:flex;align-items:center;gap:4px;padding:4px 8px;font-size:var(--text-xs);font-weight:var(--weight-medium);border-radius:var(--radius-sm);border:none;background:transparent;color:var(--ink-muted);transition:color var(--transition-fast);cursor:pointer}.auth-btn:hover{color:var(--ink)}.auth-btn svg{flex-shrink:0;width:14px;height:14px}.auth-btn-login{color:var(--ink-soft)}.auth-btn-login:hover{color:var(--olive)}.auth-btn-logout{color:var(--ink-muted)}.auth-btn-logout:hover{color:var(--ink-soft)}.auth-user-info{display:flex;align-items:center;gap:6px;font-size:var(--text-xs)}.auth-email{color:var(--ink-muted);max-width:120px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.auth-role-badge{padding:1px 6px;font-size:10px;font-weight:var(--weight-medium);border-radius:3px;text-transform:uppercase;letter-spacing:.3px}.auth-role-badge.role-root{background:transparent;color:#b45309;border:1px solid #d97706}.auth-role-badge.role-admin{background:transparent;color:#2563eb;border:1px solid #3b82f6}.auth-role-badge.role-user{background:transparent;color:var(--ink-muted);border:1px solid var(--line-emphasis)}.auth-btn-mypage{color:var(--ink-muted)}.auth-btn-mypage:hover{color:var(--olive)}.auth-loading{font-size:var(--text-sm);color:var(--ink-muted)}.page-title-area{position:relative}.permission-disabled{opacity:.4;cursor:not-allowed!important;pointer-events:none}button.permission-disabled:hover{background:inherit;color:inherit;border-color:inherit}.schema-tree{font-family:var(--font-sans);border:1px solid var(--line);border-radius:var(--radius-md);background:var(--paper);overflow:hidden;flex:1;display:flex;flex-direction:column;min-height:0}.schema-header{display:flex;justify-content:space-between;align-items:center;padding:var(--space-md) var(--space-lg);border-bottom:1px solid var(--line);position:relative}.schema-refresh-btn{position:absolute;left:var(--space-sm);top:50%;transform:translateY(-50%);width:28px;height:28px;padding:0;background:transparent;border:none;border-radius:var(--radius-sm);cursor:pointer;font-size:14px;display:flex;align-items:center;justify-content:center;transition:color var(--transition-fast);color:var(--ink-muted)}.schema-refresh-btn:hover{color:var(--accent)}.schema-refresh-btn:active{transform:translateY(-50%) scale(.95)}.schema-refresh-btn:disabled{cursor:not-allowed;opacity:.4}.schema-header h3{font-size:var(--text-base);font-weight:var(--weight-medium);color:var(--ink);flex:1;text-align:center;margin:0 0 0 30px;letter-spacing:-.01em}.schema-header h3:before{content:"";display:inline-block;width:8px;height:8px;background:var(--olive);border-radius:2px;margin-right:var(--space-sm);vertical-align:middle}.table-count{font-size:var(--text-sm);color:var(--ink-muted);font-weight:var(--weight-normal)}.tree-content{padding:var(--space-md);flex:1;overflow-y:auto;min-height:0}.schema-footer{padding:var(--space-md) var(--space-lg);border-top:1px solid var(--line)}.edit-metadata-btn{width:100%;padding:var(--space-sm) var(--space-md);background:transparent;color:var(--ink-soft);border:1px solid var(--line);border-radius:var(--radius-sm);cursor:pointer;font-size:var(--text-sm);font-weight:var(--weight-medium);transition:all var(--transition-fast)}.edit-metadata-btn:hover{border-color:var(--ink-muted);color:var(--ink)}.tree-node{margin:var(--space-xs) 0}.table-node{margin-bottom:var(--space-sm)}.table-comment-inline{font-size:.625rem;color:var(--ink-muted);font-style:italic;margin-left:var(--space-sm);margin-right:var(--space-sm)}.node-header{display:flex;align-items:center;padding:var(--space-sm) var(--space-md);background:transparent;border:none;border-radius:var(--radius-sm);cursor:pointer;transition:background var(--transition-fast)}.node-header:hover{background:var(--paper-soft)}.toggle-icon{margin-right:var(--space-sm);font-size:var(--text-xs);color:var(--ink-muted);transition:transform var(--transition-fast)}.table-icon{margin-right:var(--space-sm);font-size:var(--text-base);color:var(--olive-muted)}.column-icon{margin-right:var(--space-sm);font-size:var(--text-sm);color:var(--ink-whisper)}.node-label{font-weight:var(--weight-medium);color:var(--ink);margin-right:var(--space-sm);font-size:var(--text-sm)}.column-count{font-size:var(--text-xs);color:var(--ink-muted);margin-left:auto}.node-children{margin-left:var(--space-xl);margin-top:var(--space-xs);padding-left:var(--space-md);border-left:1px solid var(--line)}.column-node{display:flex;flex-direction:column;padding:var(--space-sm) var(--space-md);background:transparent;border:none;border-radius:var(--radius-sm);margin:0;cursor:pointer;transition:background var(--transition-fast)}.column-node:last-child{border-bottom:none}.column-info{display:flex;align-items:center}.column-node:hover{background:var(--paper-soft)}.column-node.selected{background:var(--accent-soft);box-shadow:inset 2px 0 0 var(--accent)}.column-type{font-size:var(--text-xs);color:var(--ink-muted);font-family:var(--font-mono);margin-left:auto;margin-right:var(--space-sm)}.column-nullable{font-size:var(--text-xs);color:var(--ink-whisper);margin-right:var(--space-sm)}.column-default{font-size:var(--text-xs);color:var(--ink-muted)}.node-comment{font-size:.625rem;color:var(--ink-muted);font-style:italic;margin-top:var(--space-xs);padding-left:22px;line-height:1.5}.table-node .node-comment{padding-left:34px;margin-top:var(--space-xs);margin-bottom:var(--space-xs)}.loading,.error,.empty{padding:var(--space-2xl) var(--space-lg);text-align:center;color:var(--ink-muted)}.error{color:#c45c5c}.tree-content::-webkit-scrollbar{width:5px}.tree-content::-webkit-scrollbar-track{background:transparent}.tree-content::-webkit-scrollbar-thumb{background:var(--ink-whisper);border-radius:3px}.tree-content::-webkit-scrollbar-thumb:hover{background:var(--ink-muted)}#sqlExamplesPanelContainer{flex-shrink:0}.metadata-editor-panel{font-family:var(--font-sans);border:1px solid var(--line);border-radius:var(--radius-md);background:var(--paper);overflow:hidden}.metadata-header{display:flex;justify-content:space-between;align-items:center;padding:var(--space-sm) var(--space-md);border-bottom:1px solid var(--line)}.metadata-header h3{margin:0;font-size:var(--text-sm);font-weight:var(--weight-medium);color:var(--ink);text-align:center;flex:1}.metadata-header h3:before{content:"";display:inline-block;width:6px;height:6px;background:var(--olive);border-radius:2px;margin-right:var(--space-xs);vertical-align:middle}.metadata-content{padding:var(--space-sm)}.metadata-buttons{display:flex;gap:var(--space-sm);justify-content:space-between}.metadata-btn{flex:1;padding:var(--space-xs) var(--space-sm);background:transparent;color:var(--ink-soft);border:1px solid var(--line);border-radius:var(--radius-sm);cursor:pointer;font-size:var(--text-xs);font-weight:var(--weight-medium);transition:all var(--transition-fast)}.metadata-btn:hover{border-color:var(--ink-muted);color:var(--ink)}.schema-header-right{display:flex;align-items:center;gap:var(--space-sm)}.history-toggle-btn{width:28px;height:28px;padding:0;background:transparent;border:none;border-radius:var(--radius-sm);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all var(--transition-fast);color:var(--olive)}.history-toggle-btn:hover{color:var(--accent);background:var(--paper-soft)}.history-toggle-btn:active{transform:scale(.95)}#schemaTreeContainer{position:relative;overflow:hidden;flex:1;display:flex;flex-direction:column;min-height:0}.history-panel{position:absolute;inset:0;background:var(--paper);border:1px solid var(--line);border-radius:var(--radius-md);transform:translate(100%);transition:transform .3s cubic-bezier(.4,0,.2,1);z-index:10;display:flex;flex-direction:column}.history-panel.active{transform:translate(0)}.history-panel-header{display:flex;justify-content:space-between;align-items:center;padding:var(--space-md) var(--space-lg);border-bottom:1px solid var(--line);position:relative}.history-back-btn{width:28px;height:28px;padding:0;background:transparent;border:none;border-radius:var(--radius-sm);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all var(--transition-fast);color:var(--ink-muted)}.history-back-btn:hover{color:var(--ink);background:var(--paper-soft)}.history-panel-header h3{margin:0;font-size:var(--text-base);font-weight:var(--weight-medium);color:var(--ink);flex:1;text-align:center;letter-spacing:-.01em}.history-panel-header h3:before{content:"";display:inline-block;width:8px;height:8px;background:var(--olive);border-radius:2px;margin-right:var(--space-sm);vertical-align:middle}.history-count{font-size:var(--text-sm);color:var(--ink-muted);font-weight:var(--weight-normal)}.history-header-spacer{width:28px}.history-content{flex:1;overflow-y:auto;padding:var(--space-md)}.history-loading,.history-empty,.history-error{padding:var(--space-2xl) var(--space-lg);text-align:center;color:var(--ink-muted)}.history-empty{display:flex;flex-direction:column;align-items:center;gap:var(--space-md)}.history-empty svg{stroke:var(--ink-whisper)}.history-error{color:#c45c5c}.history-item{display:flex;align-items:center;padding:var(--space-sm) var(--space-md);background:transparent;border-radius:var(--radius-sm);cursor:pointer;transition:background var(--transition-fast);margin-bottom:var(--space-xs)}.history-item:hover{background:var(--paper-soft)}.history-item:hover .history-item-delete{opacity:1}.history-item-content{flex:1;min-width:0}.history-item-title{font-size:var(--text-sm);font-weight:var(--weight-medium);color:var(--ink);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;margin-bottom:var(--space-xs)}.history-item-meta{display:flex;gap:var(--space-sm);font-size:var(--text-xs);color:var(--ink-muted)}.history-item-date{color:var(--ink-whisper)}.history-item-turns{color:var(--ink-muted)}.history-item-delete{width:28px;height:28px;padding:0;background:transparent;border:none;border-radius:var(--radius-sm);cursor:pointer;display:flex;align-items:center;justify-content:center;opacity:0;transition:all var(--transition-fast);color:var(--ink-muted);flex-shrink:0}.history-item-delete:hover{color:#c45c5c;background:#c45c5c1a}.history-content::-webkit-scrollbar{width:5px}.history-content::-webkit-scrollbar-track{background:transparent}.history-content::-webkit-scrollbar-thumb{background:var(--ink-whisper);border-radius:3px}.history-content::-webkit-scrollbar-thumb:hover{background:var(--ink-muted)}.column-header{display:flex;align-items:center;width:100%;cursor:pointer}.column-header *{pointer-events:none}.column-toggle-icon{font-size:8pt;color:var(--ink-muted);margin-right:var(--space-xs);transition:transform var(--transition-fast);flex-shrink:0;width:12px}.column-toggle-placeholder{width:12px;margin-right:var(--space-xs);flex-shrink:0}.column-node.has-samples{cursor:pointer}.column-node.has-samples .column-header:hover .column-toggle-icon{color:var(--accent)}.sample-values-container{margin-left:calc(12px + var(--space-xs) + 22px);margin-top:var(--space-xs);padding-left:var(--space-sm);border-left:1px solid var(--line)}.sample-values-list{display:flex;flex-direction:column;gap:2px}.sample-value-item{font-size:8pt;font-family:var(--font-mono);color:var(--ink-soft);padding:2px var(--space-xs);background:var(--paper-soft);border-radius:2px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:200px}.sample-value-item:hover{background:var(--accent-soft);color:var(--ink)}.sample-null{color:var(--ink-whisper);font-style:italic}.column-node.expanded{background:var(--paper-soft)}.column-node.expanded .column-toggle-icon{color:var(--accent)}.input-section{background:var(--bg-primary);padding:var(--space-xl);border:1px solid var(--border);border-radius:var(--radius-md);margin-bottom:var(--space-xl)}.prompt-input{width:100%;padding:var(--space-md);font-size:var(--text-base);border:1px solid var(--border);border-radius:var(--radius-sm);resize:vertical;font-family:inherit;background:var(--bg-primary);transition:border-color var(--transition-fast)}.prompt-input:focus{outline:none;border-color:var(--accent)}.prompt-input:disabled{background:var(--bg-secondary);color:var(--text-muted);cursor:not-allowed}.submit-btn{background:var(--olive);color:#fff;border:none;padding:var(--space-sm) var(--space-xl);font-size:var(--text-base);border-radius:var(--radius-sm);cursor:pointer;transition:background var(--transition-fast)}.submit-btn:hover{background:var(--olive-dark)}.submit-btn:active{transform:none}table{width:100%;border-collapse:collapse;margin-top:var(--space-sm)}th,td{padding:var(--space-sm) var(--space-md);text-align:left;border-bottom:1px solid var(--border-light)}th{font-size:var(--text-sm);font-weight:var(--weight-semibold);color:var(--text-primary);border-bottom:2px solid var(--border);background:transparent}td{font-size:var(--text-sm);color:var(--text-secondary)}tr:hover td{background:var(--bg-secondary)}.conversation-box{flex:1;display:flex;flex-direction:column;border:1px solid var(--line);border-radius:var(--radius-md);background:var(--paper);overflow:hidden;min-height:0}.conversation-header{display:flex;justify-content:space-between;align-items:center;padding:var(--space-sm) var(--space-md);border-bottom:1px solid var(--line)}.conversation-title{font-size:var(--text-sm);font-weight:var(--weight-medium);color:var(--ink);letter-spacing:-.01em;display:flex;align-items:center;gap:var(--space-sm)}.conversation-title:before{content:"";width:3px;height:14px;background:var(--olive);border-radius:2px}.new-chat-btn{background:transparent;border:1px solid var(--line);color:var(--ink-soft);cursor:pointer;padding:var(--space-xs) var(--space-sm);border-radius:var(--radius-sm);transition:all var(--transition-fast);display:flex;align-items:center;gap:var(--space-xs);font-size:var(--text-xs)}.new-chat-btn:hover{background:var(--paper-soft);border-color:var(--olive-muted);color:var(--olive)}.conversation-container{background:var(--paper);flex:1;overflow-y:auto;padding:var(--space-lg)}.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:var(--space-2xl) var(--space-lg);color:var(--ink-muted);text-align:center}.empty-state svg{margin-bottom:var(--space-lg);stroke:var(--ink-whisper);opacity:.6}.empty-state p{margin:var(--space-xs) 0}.empty-hint{font-size:var(--text-sm);color:var(--ink-whisper);font-style:italic}.chat-message{margin-bottom:var(--space-lg)}.chat-message:last-child{margin-bottom:0}.chat-message-inner{max-width:100%}.chat-message-user{padding:0}.chat-message-user .chat-role{font-size:var(--text-xs);font-weight:var(--weight-medium);color:var(--ink-soft);text-transform:uppercase;letter-spacing:.05em;margin-bottom:var(--space-xs)}.chat-message-user .chat-content{font-size:var(--text-sm);line-height:1.65;color:var(--ink)}.chat-message-assistant{padding:0}.chat-message-assistant .chat-message-inner{background:var(--paper-soft);border-radius:var(--radius-md);padding:var(--space-md) var(--space-lg);border-left:3px solid var(--accent)}.chat-message-assistant .chat-role{font-size:var(--text-xs);font-weight:var(--weight-medium);color:var(--accent);text-transform:uppercase;letter-spacing:.05em;margin-bottom:var(--space-sm);display:flex;align-items:center;gap:var(--space-sm)}.query-type-badge{display:inline-flex;align-items:center;padding:2px 8px;border-radius:var(--radius-sm);font-size:10px;font-weight:var(--weight-medium);text-transform:uppercase;letter-spacing:.05em;margin-left:var(--space-sm)}.query-type-badge--general{background:#6b8f711f;color:var(--olive);border:1px solid rgba(107,143,113,.25)}.query-type-badge--ambiguous{background:#c9a2271f;color:#c9a227;border:1px solid rgba(201,162,39,.25)}.query-type-badge--clear,.query-type-badge--search{background:#6b8f711f;color:var(--olive);border:1px solid rgba(107,143,113,.25)}.chat-message-assistant .chat-content{font-size:var(--text-sm);line-height:1.65;color:var(--ink)}.chat-message-clarification .chat-message-inner{border-left-color:#c9a227}.chat-message-clarification .chat-role{color:#c9a227}.chat-message-out-of-scope .chat-message-inner{border-left-color:#c45c5c}.chat-message-out-of-scope .chat-role{color:#c45c5c}.chat-message-loading .chat-message-inner{background:var(--paper-soft);border-radius:var(--radius-md);padding:var(--space-md) var(--space-lg);border-left:3px solid var(--ink-whisper)}.loading-indicator{display:flex;align-items:center;gap:var(--space-md);padding:var(--space-sm) 0}.loading-dots{display:flex;gap:5px}.loading-dots span{width:6px;height:6px;background:var(--ink-muted);border-radius:50%;animation:loadingDot 1.4s infinite ease-in-out both}.loading-dots span:nth-child(1){animation-delay:-.32s}.loading-dots span:nth-child(2){animation-delay:-.16s}.loading-dots span:nth-child(3){animation-delay:0}@keyframes loadingDot{0%,80%,to{transform:scale(.6);opacity:.4}40%{transform:scale(1);opacity:1}}.loading-text{font-size:var(--text-sm);color:var(--ink-muted);font-style:italic}.streaming-cursor{display:inline-block;width:2px;height:1em;background:var(--ink-soft);margin-left:2px;vertical-align:text-bottom;animation:cursorBlink 1s step-end infinite}@keyframes cursorBlink{0%,to{opacity:1}50%{opacity:0}}.chat-message-streaming .chat-content{min-height:1.5em}.sql-block{margin-top:var(--space-md)}.sql-query-dropdown{margin-bottom:var(--space-md)}.sql-query-toggle{display:inline-flex;align-items:center;gap:var(--space-xs);padding:var(--space-xs) var(--space-sm);background:transparent;border:1px solid var(--line);border-radius:var(--radius-sm);color:var(--ink-muted);font-size:var(--text-xs);font-family:inherit;cursor:pointer;transition:all .15s ease}.sql-query-toggle:hover{background:var(--paper-soft);border-color:var(--ink-whisper);color:var(--ink-soft)}.sql-toggle-icon{transition:transform .2s ease}.sql-query-dropdown.open .sql-toggle-icon{transform:rotate(180deg)}.sql-query-content{display:none;margin-top:var(--space-sm)}.sql-query-dropdown.open .sql-query-content{display:block}.sql-query-display{background:var(--code-bg);color:var(--code-text);padding:var(--space-md);border-radius:var(--radius-sm);font-family:var(--font-mono);font-size:var(--text-sm);overflow-x:auto;white-space:pre-wrap;word-break:break-all;line-height:1.5;margin:0}.chart-action-container{margin-top:var(--space-md);display:flex;justify-content:flex-start}.chart-generate-btn{display:inline-flex;align-items:center;gap:var(--space-xs);padding:var(--space-sm) var(--space-md);background:transparent;border:1px solid var(--line-emphasis);border-radius:var(--radius-sm);color:var(--ink-soft);font-size:var(--text-sm);cursor:pointer;transition:all var(--transition-fast)}.chart-generate-btn:hover{background:var(--paper-soft);border-color:var(--olive-muted);color:var(--olive)}.chart-generate-btn:disabled{cursor:wait;opacity:.7}.chart-generate-btn.chart-btn-disabled{cursor:not-allowed;opacity:.5;background:var(--paper-accent);border-color:var(--line);color:var(--ink-muted)}.chart-generate-btn.chart-btn-disabled:hover{background:var(--paper-accent);border-color:var(--line);color:var(--ink-muted)}.chart-generate-btn.chart-btn-not-suitable{cursor:default;opacity:.85;background:#6b8f7114;border-color:#6b8f7140;color:var(--olive)}.chart-generate-btn.chart-btn-not-suitable:hover{background:#6b8f7114;border-color:#6b8f7140;color:var(--olive)}.chart-generate-btn svg{flex-shrink:0}.loading-dots-small{display:inline-flex;gap:3px}.loading-dots-small span{width:4px;height:4px;background:currentColor;border-radius:50%;animation:loadingDot 1.4s infinite ease-in-out both}.loading-dots-small span:nth-child(1){animation-delay:-.32s}.loading-dots-small span:nth-child(2){animation-delay:-.16s}.loading-dots-small span:nth-child(3){animation-delay:0}.chart-container{margin-top:var(--space-md);background:var(--paper);border-radius:var(--radius-md);padding:var(--space-md);min-height:300px;max-width:100%;overflow:hidden;border:1px solid var(--line)}.chart-container .plotly-graph-div{width:100%!important;max-width:100%!important}.chart-container .modebar{background:transparent!important}.chart-container .modebar-btn{color:var(--ink-muted)!important;opacity:.6;transition:opacity .15s ease}.chart-container .modebar-btn:hover{color:var(--ink)!important;opacity:1}.turn-limit-notice{display:flex;align-items:flex-start;gap:var(--space-md);padding:var(--space-md) var(--space-lg);background:#c45c5c14;border-radius:var(--radius-md);border:1px solid rgba(196,92,92,.2);margin-top:var(--space-lg)}.turn-limit-notice svg{flex-shrink:0;color:#c45c5c;margin-top:2px}.turn-limit-text{flex:1}.turn-limit-text strong{display:block;font-size:var(--text-sm);color:#c45c5c;margin-bottom:var(--space-xs)}.turn-limit-text p{font-size:var(--text-sm);color:var(--ink-soft);margin:0}.query-input-section{background:var(--paper);padding:var(--space-md);border:1px solid var(--line);border-radius:var(--radius-md);flex-shrink:0}.query-input-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--space-sm)}.query-input-title{font-size:var(--text-sm);font-weight:var(--weight-medium);color:var(--ink);letter-spacing:-.01em}.recommend-btn{background:transparent;border:none;color:var(--ink-muted);cursor:pointer;padding:var(--space-xs);border-radius:var(--radius-sm);transition:color var(--transition-fast);display:flex;align-items:center;gap:var(--space-xs);font-size:var(--text-xs)}.recommend-btn:hover{color:var(--accent)}.query-input-wrapper{display:flex;gap:var(--space-sm);align-items:flex-end}.query-input-wrapper .prompt-input{flex:1;padding:var(--space-sm) var(--space-md);font-size:var(--text-sm);border:1px solid var(--line);border-radius:var(--radius-sm);resize:none;font-family:inherit;transition:border-color var(--transition-fast);min-height:60px;background:var(--paper);color:var(--ink);line-height:1.6}.query-input-wrapper .prompt-input::placeholder{color:var(--ink-whisper)}.query-input-wrapper .prompt-input:focus{outline:none;border-color:var(--olive-muted);box-shadow:0 0 0 2px var(--olive-soft)}.send-btn{background:var(--olive);color:var(--paper);border:none;width:42px;height:42px;border-radius:var(--radius-sm);cursor:pointer;transition:background var(--transition-fast);display:flex;align-items:center;justify-content:center;flex-shrink:0}.send-btn:hover{background:var(--olive-dark)}.send-btn:disabled{background:var(--ink-whisper);cursor:not-allowed}.send-btn.abort-mode{background:#c0392b}.send-btn.abort-mode:hover{background:#a93226}.send-btn.cooldown-mode{background:var(--ink-muted)}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.send-btn svg.spin{animation:spin 1s linear infinite}.conversation-container::-webkit-scrollbar{width:5px}.conversation-container::-webkit-scrollbar-track{background:transparent}.conversation-container::-webkit-scrollbar-thumb{background:var(--ink-whisper);border-radius:3px}.conversation-container::-webkit-scrollbar-thumb:hover{background:var(--ink-muted)}.loading{display:none;text-align:center;padding:var(--space-xl);color:var(--ink-muted)}.loading.show{display:block}.spinner{border:2px solid var(--line);border-top:2px solid var(--ink-muted);border-radius:50%;width:24px;height:24px;animation:spin 1s linear infinite;margin:0 auto var(--space-sm)}@media(max-width:1200px){.conversation-container{min-height:400px;max-height:calc(100vh - 250px)}}.markdown-content{line-height:1.65}.markdown-content h1{font-size:1.25rem;font-weight:600;color:var(--ink);margin:1.5rem 0 .75rem;padding-bottom:.5rem;border-bottom:1px solid var(--line)}.markdown-content h2{font-size:1.125rem;font-weight:600;color:var(--ink);margin:1.25rem 0 .5rem}.markdown-content h3{font-size:1rem;font-weight:600;color:var(--ink);margin:1rem 0 .5rem}.markdown-content h4,.markdown-content h5,.markdown-content h6{font-size:.9375rem;font-weight:600;color:var(--ink-soft);margin:.75rem 0 .5rem}.markdown-content>h1:first-child,.markdown-content>h2:first-child,.markdown-content>h3:first-child{margin-top:0}.markdown-content p{margin:0 0 .75rem;color:var(--ink-soft)}.markdown-content p:last-child{margin-bottom:0}.markdown-content strong{font-weight:600;color:var(--ink)}.markdown-content em{font-style:italic;color:var(--ink-soft)}.markdown-content ul,.markdown-content ol{margin:.5rem 0 .75rem;padding-left:1.5rem;color:var(--ink-soft)}.markdown-content li{margin:.25rem 0;line-height:1.6}.markdown-content li>ul,.markdown-content li>ol{margin:.25rem 0}.markdown-content code{font-family:SF Mono,Monaco,Consolas,monospace;font-size:.875em;background:var(--paper-soft);color:var(--olive);padding:.15em .4em;border-radius:3px}.markdown-content pre{background:var(--paper-soft);border:1px solid var(--line);border-radius:var(--radius-sm);padding:.875rem 1rem;margin:.75rem 0;overflow-x:auto}.markdown-content pre code{background:transparent;padding:0;color:var(--ink-soft);font-size:.8125rem;line-height:1.5}.markdown-content blockquote{margin:.75rem 0;padding:.5rem 0 .5rem 1rem;border-left:2px solid var(--olive-muted);color:var(--ink-muted);font-style:italic}.markdown-content blockquote p{margin:0;color:inherit}.markdown-content hr{border:none;border-top:1px solid var(--line);margin:1.25rem 0}.markdown-content a{color:var(--olive);text-decoration:none;border-bottom:1px solid transparent;transition:border-color .15s ease}.markdown-content a:hover{border-bottom-color:var(--olive-muted)}.markdown-content table{width:100%;border-collapse:collapse;margin:.75rem 0;font-size:.875rem}.markdown-content th,.markdown-content td{padding:.5rem .75rem;text-align:left;border-bottom:1px solid var(--line)}.markdown-content th{font-weight:600;color:var(--ink);background:var(--paper-soft)}.markdown-content td{color:var(--ink-soft)}.markdown-content tr:last-child td{border-bottom:none}.sql-result-display{margin-top:var(--space-md);max-width:100%;border-radius:var(--radius-sm);border:1px solid var(--line);overflow:hidden}.table-wrapper{position:relative}.table-scroll-container{max-height:400px;overflow:auto}.table-toolbar{position:absolute;top:0;right:6px;height:33px;display:flex;align-items:center;gap:2px;padding:0 var(--space-xs);opacity:0;visibility:hidden;transition:opacity .15s ease,visibility .15s ease;z-index:10;background:var(--paper);border-radius:var(--radius-sm)}.table-wrapper:hover .table-toolbar{opacity:1;visibility:visible}.table-toolbar-btn{display:inline-flex;align-items:center;justify-content:center;width:28px;height:28px;padding:0;background:transparent;border:none;border-radius:var(--radius-xs);color:var(--ink-muted);cursor:pointer;transition:all .15s ease}.table-toolbar-btn:hover{background:var(--paper-soft);color:var(--ink)}.table-toolbar-btn:active{transform:scale(.95)}.table-toolbar-btn svg{flex-shrink:0}.table-toolbar-btn-group{position:relative}.table-download-dropdown{position:absolute;top:100%;right:0;margin-top:4px;background:var(--paper);border:1px solid var(--line);border-radius:var(--radius-sm);box-shadow:0 4px 12px #0000001a;min-width:100px;z-index:100}.table-download-option{display:flex;align-items:center;gap:var(--space-sm);width:100%;padding:var(--space-sm) var(--space-md);background:transparent;border:none;font-size:var(--text-xs);font-family:inherit;color:var(--ink-soft);cursor:pointer;transition:all .15s ease;text-align:left}.table-download-option:hover{background:var(--paper-soft);color:var(--ink)}.table-download-option:first-child{border-radius:var(--radius-sm) var(--radius-sm) 0 0}.table-download-option:last-child{border-radius:0 0 var(--radius-sm) var(--radius-sm)}.table-download-option svg{opacity:.6}.sql-result-display table{width:max-content;min-width:100%;border-collapse:collapse;font-size:var(--text-sm);margin:0}.sql-result-display th{background:var(--paper);color:var(--ink);padding:var(--space-sm) var(--space-md);text-align:left;font-weight:var(--weight-medium);border-bottom:1px solid var(--line-emphasis);font-size:var(--text-xs);text-transform:uppercase;letter-spacing:.04em;position:sticky;top:0;z-index:1}.row-number-col{width:50px;min-width:50px;max-width:50px;text-align:center!important;color:var(--ink-muted)!important;background:var(--paper-soft)!important;font-size:var(--text-xs);-webkit-user-select:none;user-select:none}.col-numeric{text-align:right}.decimal-part{color:var(--olive)}.sql-result-display td{padding:var(--space-sm) var(--space-md);border-bottom:1px solid var(--line);color:var(--ink-soft)}.sql-result-display tr:last-child td{border-bottom:none}.sql-result-display tr:hover td{background:var(--paper-soft)}.no-result{color:var(--ink-muted);font-style:italic;padding:var(--space-lg);text-align:center}.table-scroll-container::-webkit-scrollbar{width:6px;height:6px}.table-scroll-container::-webkit-scrollbar-track{background:transparent}.table-scroll-container::-webkit-scrollbar-thumb{background:var(--ink-whisper);border-radius:3px}.table-scroll-container::-webkit-scrollbar-thumb:hover{background:var(--ink-muted)}.table-modal-overlay{position:fixed;inset:0;width:100vw;height:100vh;background:#2c2825b3;z-index:9999;display:flex;justify-content:center;align-items:center;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.table-modal-content{background:var(--paper);border-radius:12px;width:90vw;height:85vh;max-width:1200px;max-height:800px;display:flex;flex-direction:column;box-shadow:0 25px 50px -12px #00000040;overflow:hidden}.table-modal-header{padding:var(--space-md) var(--space-lg);border-bottom:1px solid var(--line);display:flex;justify-content:space-between;align-items:center;flex-shrink:0}.table-modal-title{font-size:var(--text-base);font-weight:var(--weight-medium);color:var(--ink);margin:0;display:flex;align-items:center;gap:var(--space-sm)}.table-modal-title:before{content:"";width:4px;height:16px;background:var(--olive);border-radius:2px}.table-modal-close{background:none;border:none;color:var(--ink-muted);font-size:28px;font-weight:300;cursor:pointer;width:40px;height:40px;display:flex;align-items:center;justify-content:center;border-radius:6px;transition:all .15s ease;line-height:1}.table-modal-close:hover{color:var(--ink);background:#0000000d}.table-modal-body{flex:1;display:flex;overflow:hidden;min-height:0}.table-modal-main{flex:1;display:flex;flex-direction:column;min-width:0;overflow:hidden}.table-modal-toolbar{padding:var(--space-sm) var(--space-lg);border-bottom:1px solid var(--line);display:flex;justify-content:space-between;align-items:center;flex-shrink:0;background:var(--paper-soft)}.table-modal-toolbar-group{display:flex;align-items:center;gap:var(--space-md)}.table-modal-toolbar-item{display:flex;align-items:center;gap:var(--space-xs);font-size:var(--text-sm);color:var(--ink)}.table-modal-toolbar-item input[type=checkbox]{width:14px;height:14px;accent-color:var(--olive)}.table-modal-toolbar-item select{padding:var(--space-xs) var(--space-sm);border:1px solid var(--line);border-radius:var(--radius-xs);font-size:var(--text-xs);font-family:inherit;background:var(--paper);color:var(--ink);cursor:pointer}.table-modal-toolbar-btn{display:inline-flex;align-items:center;gap:var(--space-xs);padding:var(--space-xs) var(--space-sm);background:var(--paper);border:1px solid var(--line);border-radius:var(--radius-sm);font-size:var(--text-xs);font-family:inherit;color:var(--ink-soft);cursor:pointer;transition:all .15s ease}.table-modal-toolbar-btn:hover{background:var(--paper);border-color:var(--olive-muted);color:var(--olive)}.table-modal-toolbar-btn svg{opacity:.7}.table-modal-toolbar-btn:hover svg{opacity:1}.download-dropdown-wrapper{position:relative}.download-dropdown-menu{position:absolute;top:100%;right:0;margin-top:4px;background:var(--paper);border:1px solid var(--line);border-radius:var(--radius-sm);box-shadow:0 4px 12px #0000001a;min-width:100px;z-index:100}.download-dropdown-menu button{display:block;width:100%;padding:var(--space-sm) var(--space-md);background:transparent;border:none;font-size:var(--text-sm);font-family:inherit;color:var(--ink-soft);text-align:left;cursor:pointer;transition:all .15s ease}.download-dropdown-menu button:hover{background:var(--paper-soft);color:var(--ink)}.table-format-toolbar{display:flex;flex-direction:column;background:var(--paper);border-bottom:1px solid var(--line);flex-shrink:0;transition:opacity .2s ease}.table-format-toolbar.disabled{opacity:.4;pointer-events:none}.format-toolbar-row{display:flex;align-items:center;gap:var(--space-md);padding:var(--space-sm) var(--space-lg)}.format-toolbar-main-row{border-bottom:none}.format-toolbar-currency-row{padding-top:var(--space-xs);padding-bottom:var(--space-sm);padding-left:var(--space-lg);gap:var(--space-md);margin-left:calc(100px + var(--space-md) + 1px + var(--space-xs)*2 + 50px + var(--space-md) + 1px + var(--space-xs)*2)}.format-toolbar-selected-col{font-size:var(--text-sm);font-weight:var(--weight-medium);color:var(--olive);min-width:100px;padding:var(--space-xs) var(--space-sm);background:transparent;border-left:2px solid var(--olive);border-radius:0}.table-format-toolbar.disabled .format-toolbar-selected-col{color:var(--ink-muted);border-left-color:var(--line)}.format-toolbar-group{display:flex;align-items:center;gap:var(--space-xs)}.format-toolbar-label{font-size:var(--text-xs);color:var(--ink-muted);margin-right:var(--space-xs)}.format-btn{display:flex;align-items:center;justify-content:center;padding:5px 8px;background:transparent;border:none;border-radius:4px;color:var(--ink-muted);cursor:pointer;transition:color .15s ease,background .15s ease;font-size:11px;font-weight:600;font-family:SF Mono,Monaco,Consolas,monospace}.format-btn:hover:not(:disabled){background:var(--surface-hover);color:var(--ink)}.format-btn.active{background:var(--olive-soft);color:var(--olive)}.format-btn:disabled{color:var(--ink-whisper);cursor:not-allowed}.format-currency-btn svg{width:14px;height:14px}.format-percent-btn span{font-size:14px;font-weight:500}.format-toolbar-select{padding:5px 8px;border:1px solid var(--line);border-radius:var(--radius-xs);font-size:var(--text-xs);font-family:inherit;background:var(--paper);color:var(--ink-soft);cursor:pointer;min-width:90px;transition:border-color .15s ease}.format-toolbar-select:focus{outline:none;border-color:var(--olive-muted)}.format-toolbar-select:disabled{background:var(--paper);color:var(--ink-whisper);cursor:not-allowed;border-color:var(--line)}.format-toolbar-divider{width:1px;height:18px;background:var(--line);margin:0 var(--space-xs)}.format-decimal-group{gap:2px}.format-decimal-btn span{font-size:11px}.table-modal-table-container{flex:1;overflow:auto;padding:var(--space-md) var(--space-lg);min-height:0}.table-modal-table{width:max-content;min-width:100%;border-collapse:collapse;font-size:var(--text-sm)}.table-modal-table th{background:var(--paper-soft);color:var(--ink);padding:var(--space-sm) var(--space-md);text-align:left;font-weight:var(--weight-medium);border-bottom:2px solid var(--line-emphasis);font-size:var(--text-xs);text-transform:uppercase;letter-spacing:.04em;position:sticky;top:0;z-index:1}.table-modal-table td{padding:var(--space-sm) var(--space-md);border-bottom:1px solid var(--line);color:var(--ink-soft)}.table-modal-table tr:last-child td{border-bottom:none}.table-modal-table tr:hover td{background:var(--paper-soft)}.table-modal-footer-info{padding:var(--space-sm) var(--space-lg);border-top:1px solid var(--line);font-size:var(--text-xs);color:var(--ink-muted);flex-shrink:0;background:var(--paper-soft)}.table-modal-table-container::-webkit-scrollbar{width:8px;height:8px}.table-modal-table-container::-webkit-scrollbar-track{background:var(--paper-soft)}.table-modal-table-container::-webkit-scrollbar-thumb{background:var(--ink-whisper);border-radius:4px}.table-modal-table-container::-webkit-scrollbar-thumb:hover{background:var(--ink-muted)}.table-modal-header-actions{display:flex;align-items:center;gap:var(--space-sm)}.table-col-header{position:relative;cursor:pointer;-webkit-user-select:none;user-select:none;transition:background .15s ease}.table-col-header:hover{background:var(--paper-soft)}.table-col-header.has-settings{color:var(--olive)}.table-col-header.has-settings:after{content:"";position:absolute;top:6px;right:6px;width:5px;height:5px;background:var(--olive);border-radius:50%}.table-col-header.selected{background:var(--olive-soft)}.table-col-header.selected:before{content:"";position:absolute;bottom:0;left:0;right:0;height:2px;background:var(--olive)}.table-col-header-content{display:flex;align-items:center;justify-content:space-between;gap:var(--space-xs)}.table-col-header-text{flex:1}.table-col-header.sort-asc .table-col-header-text:after,.table-col-header.sort-desc .table-col-header-text:after{content:"";display:inline-block;margin-left:6px;width:0;height:0;border-left:4px solid transparent;border-right:4px solid transparent;vertical-align:middle}.table-col-header.sort-asc .table-col-header-text:after{border-bottom:5px solid var(--olive)}.table-col-header.sort-desc .table-col-header-text:after{border-top:5px solid var(--olive)}.table-col-filter-btn{display:flex;align-items:center;justify-content:center;width:20px;height:20px;padding:0;background:transparent;border:none;border-radius:3px;color:var(--ink-muted);cursor:pointer;transition:all .15s ease;flex-shrink:0}.table-col-filter-btn svg{width:12px;height:12px}.table-col-filter-btn:hover{background:#7d8c5c1a;color:var(--olive)}.table-col-filter-btn.active,.table-col-header.sort-asc .table-col-filter-btn,.table-col-header.sort-desc .table-col-filter-btn{color:var(--olive);background:var(--olive-soft)}.filter-dropdown{position:absolute;top:100%;left:0;background:var(--paper);border:1px solid var(--line);border-radius:6px;box-shadow:0 4px 12px #2c282514,0 1px 3px #2c28250a;width:180px;min-width:180px;max-width:180px;overflow:hidden;z-index:1000}.filter-dropdown-header{display:flex;align-items:center;justify-content:space-between;padding:8px 12px;border-bottom:1px solid var(--line);font-size:var(--text-xs);font-weight:var(--weight-medium);color:var(--ink-soft);text-transform:uppercase;letter-spacing:.03em}.filter-dropdown-close{display:flex;align-items:center;justify-content:center;width:18px;height:18px;padding:0;background:transparent;border:none;border-radius:2px;color:var(--ink-muted);cursor:pointer;transition:color .15s ease}.filter-dropdown-close svg{width:10px;height:10px}.filter-dropdown-close:hover{color:var(--ink)}.filter-dropdown-body{padding:0}.filter-dropdown-input{width:100%;padding:8px 10px;border:1px solid var(--line);border-radius:4px;font-size:var(--text-sm);font-family:inherit;background:var(--paper);color:var(--ink);transition:border-color .15s ease}.filter-dropdown-input:focus{outline:none;border-color:var(--olive-muted)}.filter-dropdown-input::placeholder{color:var(--ink-whisper)}.filter-dropdown-footer{display:flex;justify-content:flex-end;gap:6px;padding:8px 12px;border-top:1px solid var(--line)}.filter-dropdown-btn{padding:5px 12px;border-radius:4px;font-size:var(--text-xs);font-family:inherit;font-weight:var(--weight-medium);cursor:pointer;transition:all .15s ease}.filter-clear-btn{background:transparent;border:1px solid var(--line);color:var(--ink-soft)}.filter-clear-btn:hover{border-color:var(--ink-whisper);color:var(--ink)}.filter-apply-btn{background:var(--olive);border:1px solid var(--olive);color:var(--paper)}.filter-apply-btn:hover{background:var(--olive-dark);border-color:var(--olive-dark)}.filter-dropdown-section{padding:10px 12px;border-bottom:1px solid var(--line)}.filter-dropdown-section:last-of-type{border-bottom:none}.filter-sort-section{display:flex;flex-direction:column;gap:4px}.filter-sort-section.disabled{opacity:.4;pointer-events:none}.filter-sort-btn{display:flex;align-items:center;gap:8px;width:100%;padding:8px 10px;background:transparent;border:none;border-radius:4px;color:var(--ink-soft);font-size:var(--text-sm);font-family:inherit;cursor:pointer;transition:all .15s ease;text-align:left}.filter-sort-btn:hover:not(:disabled){background:var(--paper-soft);color:var(--ink)}.filter-sort-btn.active{background:var(--olive-soft);color:var(--olive)}.filter-sort-btn:disabled{cursor:not-allowed;color:var(--ink-whisper)}.filter-sort-btn svg{flex-shrink:0;opacity:.7}.filter-sort-btn.active svg{opacity:1}.filter-search-section{display:flex;flex-direction:column;gap:8px}.filter-mode-toggle{display:flex;gap:4px;padding:3px;background:var(--paper-soft);border-radius:4px}.filter-mode-btn{flex:1;padding:5px 10px;background:transparent;border:none;border-radius:3px;color:var(--ink-muted);font-size:var(--text-xs);font-family:inherit;font-weight:var(--weight-medium);cursor:pointer;transition:all .15s ease}.filter-mode-btn:hover{color:var(--ink-soft)}.filter-mode-btn.active{background:var(--paper);color:var(--olive);box-shadow:0 1px 2px #2c28250f}@media(max-width:768px){.table-modal-toolbar{flex-direction:column;gap:var(--space-sm);align-items:flex-start}.table-modal-toolbar-group{flex-wrap:wrap}}.modal-overlay{display:none;position:fixed;top:0;left:0;width:100%;height:100%;background:#2c282580;z-index:1000;justify-content:center!important;align-items:center!important;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px)}.modal-overlay.show{display:flex!important}.modal-content{background:var(--paper);border-radius:var(--radius-lg);width:90%;max-width:900px;max-height:85vh;display:flex;flex-direction:column;box-shadow:var(--shadow-elevated);border:none}.modal-header{padding:var(--space-lg) var(--space-xl);border-bottom:1px solid var(--line);display:flex;justify-content:space-between;align-items:center}.modal-header h2{margin:0;font-size:var(--text-lg);font-weight:var(--weight-medium);color:var(--ink);letter-spacing:-.01em;display:flex;align-items:center;gap:var(--space-sm)}.modal-header h2:before{content:"";width:4px;height:18px;background:var(--olive);border-radius:2px}.modal-close{background:none;border:none;color:var(--ink-muted);font-size:24px;cursor:pointer;line-height:1;padding:0;width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:var(--radius-sm);transition:color var(--transition-fast)}.modal-close:hover{color:var(--ink)}.modal-body{padding:var(--space-xl);overflow-y:auto;flex:1}.comment-table{margin-bottom:var(--space-xl)}.comment-table-header{font-size:var(--text-sm);font-weight:var(--weight-medium);color:var(--ink);margin-bottom:var(--space-md);display:flex;align-items:center;padding-bottom:var(--space-sm);border-bottom:1px solid var(--line)}.comment-input-group{margin-bottom:var(--space-lg);padding:0}.comment-input-group:last-child{margin-bottom:0}.comment-input-label{display:block;font-size:var(--text-xs);font-weight:var(--weight-medium);color:var(--ink-muted);margin-bottom:var(--space-xs);text-transform:uppercase;letter-spacing:.04em}.comment-input{width:100%;padding:var(--space-sm) var(--space-md);border:1px solid var(--line);border-radius:var(--radius-sm);font-size:var(--text-sm);font-family:inherit;background:var(--paper);color:var(--ink);transition:border-color var(--transition-fast)}.comment-input:focus{outline:none;border-color:var(--ink-muted)}.column-comment{margin-left:var(--space-lg);padding-left:var(--space-md);border-left:1px solid var(--line)}.column-comment-item{margin-bottom:var(--space-sm)}.modal-footer{padding:var(--space-lg) var(--space-xl);border-top:1px solid var(--line);display:flex;justify-content:flex-end;gap:var(--space-sm)}.modal-btn{padding:var(--space-sm) var(--space-lg);border:1px solid var(--line-emphasis);border-radius:var(--radius-sm);cursor:pointer;font-size:var(--text-sm);font-weight:var(--weight-medium);transition:all var(--transition-fast);background:transparent}.modal-btn-cancel{color:var(--ink-soft)}.modal-btn-cancel:hover{border-color:var(--ink-muted);color:var(--ink)}.modal-btn-save{background:var(--olive);color:var(--paper);border-color:var(--olive)}.modal-btn-save:hover{background:var(--olive-dark);border-color:var(--olive-dark)}.modal-btn-save:disabled{background:var(--ink-whisper);border-color:var(--ink-whisper);color:var(--paper);cursor:not-allowed;opacity:.6}.examples-section{margin-bottom:var(--space-xl)}.examples-section:last-child{margin-bottom:0}.new-example-section{border-top:1px solid var(--line);padding-top:var(--space-xl)}.example-count{font-size:var(--text-sm);color:var(--ink-muted)}.sql-examples-container{width:100%;overflow-x:auto;border-radius:var(--radius-sm)}.example-text{padding:var(--space-sm);font-size:var(--text-sm);color:var(--ink);line-height:1.6;word-break:break-word}.example-query-text{font-family:var(--font-mono);background:var(--paper-soft);border-radius:var(--radius-sm);padding:var(--space-sm)}.sql-examples-table{width:100%;border-collapse:collapse;margin:0}.sql-examples-table thead th{background:var(--paper);color:var(--ink);padding:var(--space-sm) var(--space-md);text-align:left;font-weight:var(--weight-medium);font-size:var(--text-xs);text-transform:uppercase;letter-spacing:.04em;border-bottom:1px solid var(--line-emphasis);position:sticky;top:0;z-index:10}.sql-examples-table tbody tr.example-row{border-bottom:1px solid var(--line)}.sql-examples-table tbody tr.example-row:hover{background:var(--paper-soft)}.sql-examples-table td{padding:var(--space-sm) var(--space-md);vertical-align:middle;border:none}.example-input{width:100%;padding:var(--space-sm) var(--space-md);border:1px solid var(--line);border-radius:var(--radius-sm);font-size:var(--text-sm);font-family:inherit;resize:vertical;min-height:60px;background:var(--paper);color:var(--ink);transition:border-color var(--transition-fast)}.example-query{font-family:var(--font-mono)}.example-input:focus{outline:none;border-color:var(--ink-muted)}.example-input::placeholder{color:var(--ink-whisper);font-style:italic}.validate-row-btn{background:transparent;color:var(--ink-muted);border:none;padding:var(--space-xs) var(--space-sm);border-radius:var(--radius-sm);cursor:pointer;font-size:var(--text-xs);font-weight:var(--weight-medium);transition:color var(--transition-fast);white-space:nowrap}.validate-row-btn:hover{color:var(--accent)}.validate-row-btn:disabled{color:var(--ink-whisper);cursor:not-allowed}.delete-row-btn{background:transparent;color:var(--ink-whisper);border:none;padding:var(--space-xs) var(--space-sm);border-radius:var(--radius-sm);cursor:pointer;font-size:var(--text-xs);font-weight:var(--weight-medium);transition:color var(--transition-fast);white-space:nowrap}.delete-row-btn:hover{color:#c45c5c}.add-row{background:transparent}.add-row-cell{padding:var(--space-md);text-align:center}.add-row-btn{background:transparent;border:1px dashed var(--line-emphasis);color:var(--ink-muted);padding:var(--space-sm) var(--space-lg);border-radius:var(--radius-sm);cursor:pointer;font-size:var(--text-sm);font-weight:var(--weight-medium);display:inline-flex;align-items:center;gap:var(--space-sm);transition:all var(--transition-fast)}.add-row-btn:hover{border-color:var(--ink-muted);color:var(--ink)}.add-icon{font-size:var(--text-lg);line-height:1}.modal-btn-validate{background:transparent;color:var(--ink-soft);border:1px solid var(--line-emphasis)}.modal-btn-validate:hover{border-color:var(--ink-muted);color:var(--ink)}.modal-btn-validate:disabled{color:var(--ink-whisper);border-color:var(--line);cursor:not-allowed}.knowledge-section{margin-bottom:var(--space-xl)}.knowledge-section:last-child{margin-bottom:0}.new-knowledge-section{border-top:1px solid var(--line);padding-top:var(--space-xl)}.section-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--space-md);padding-bottom:var(--space-sm)}.section-header h3{margin:0;font-size:var(--text-sm);font-weight:var(--weight-medium);color:var(--ink)}.knowledge-count{font-size:var(--text-sm);color:var(--ink-muted)}.knowledge-container{width:100%;overflow-x:auto;max-height:400px;overflow-y:auto;border-radius:var(--radius-sm)}.knowledge-table{width:100%;border-collapse:collapse;margin:0}.knowledge-table thead th{background:var(--paper);color:var(--ink);padding:var(--space-sm) var(--space-md);text-align:left;font-weight:var(--weight-medium);font-size:var(--text-xs);text-transform:uppercase;letter-spacing:.04em;border-bottom:1px solid var(--line-emphasis);position:sticky;top:0;z-index:10}.knowledge-table tbody tr.knowledge-row{border-bottom:1px solid var(--line)}.knowledge-table tbody tr.knowledge-row:hover{background:var(--paper-soft)}.knowledge-table td{padding:var(--space-sm) var(--space-md);vertical-align:middle;border:none}.row-number{text-align:center;font-weight:var(--weight-normal);color:var(--ink-muted);font-size:var(--text-sm)}.knowledge-text{padding:var(--space-sm);font-size:var(--text-sm);color:var(--ink);line-height:1.6;word-break:break-word}.knowledge-title{font-weight:var(--weight-medium);color:var(--ink)}.knowledge-content{background:var(--paper-soft);border-radius:var(--radius-sm);max-height:100px;overflow-y:auto;padding:var(--space-sm)}.empty-row{background:transparent}.empty-message{text-align:center;padding:var(--space-xl);color:var(--ink-muted);font-style:italic}.knowledge-form{background:var(--paper-soft);padding:var(--space-lg);border-radius:var(--radius-sm)}.form-group{margin-bottom:var(--space-md)}.form-group:last-child{margin-bottom:0}.form-group label{display:block;margin-bottom:var(--space-xs);font-size:var(--text-xs);font-weight:var(--weight-medium);color:var(--ink-muted);text-transform:uppercase;letter-spacing:.04em}.knowledge-input{width:100%;padding:var(--space-sm) var(--space-md);border:1px solid var(--line);border-radius:var(--radius-sm);font-size:var(--text-sm);font-family:inherit;resize:vertical;background:var(--paper);color:var(--ink);transition:border-color var(--transition-fast)}.knowledge-input:focus{outline:none;border-color:var(--ink-muted)}.knowledge-input::placeholder{color:var(--ink-whisper);font-style:italic}.form-actions{display:flex;gap:var(--space-sm);justify-content:flex-end;margin-top:var(--space-md)}.cancel-btn,.save-btn{padding:var(--space-sm) var(--space-lg);border:1px solid var(--line-emphasis);border-radius:var(--radius-sm);cursor:pointer;font-size:var(--text-sm);font-weight:var(--weight-medium);transition:all var(--transition-fast);background:transparent}.cancel-btn{color:var(--ink-soft)}.cancel-btn:hover{border-color:var(--ink-muted);color:var(--ink)}.save-btn{background:var(--olive);color:var(--paper);border-color:var(--olive)}.save-btn:hover{background:var(--olive-dark);border-color:var(--olive-dark)}.save-btn:disabled{background:var(--ink-whisper);border-color:var(--ink-whisper);color:var(--paper);cursor:not-allowed;opacity:.6}.action-buttons{display:flex;gap:var(--space-xs);align-items:center;justify-content:center;flex-wrap:wrap}.edit-btn,.delete-btn{border:none;padding:var(--space-xs) var(--space-sm);border-radius:var(--radius-sm);cursor:pointer;font-size:var(--text-xs);font-weight:var(--weight-medium);transition:color var(--transition-fast);white-space:nowrap;background:transparent}.edit-btn{color:var(--ink-muted)}.edit-btn:hover{color:var(--ink)}.delete-btn{color:var(--ink-whisper)}.delete-btn:hover{color:#c45c5c}.knowledge-container::-webkit-scrollbar{width:5px;height:5px}.knowledge-container::-webkit-scrollbar-track{background:transparent}.knowledge-container::-webkit-scrollbar-thumb{background:var(--ink-whisper);border-radius:3px}.knowledge-container::-webkit-scrollbar-thumb:hover{background:var(--ink-muted)}.knowledge-content::-webkit-scrollbar{width:4px}.knowledge-content::-webkit-scrollbar-track{background:transparent}.knowledge-content::-webkit-scrollbar-thumb{background:var(--ink-whisper);border-radius:2px}.chart-modal-overlay{display:flex;position:fixed;inset:0;width:100vw;height:100vh;background:#2c2825b3;z-index:9999;justify-content:center;align-items:center;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.chart-modal-content{background:var(--paper, #f8f6f3);border-radius:12px;width:90vw;height:85vh;max-width:1400px;max-height:900px;display:flex;flex-direction:column;box-shadow:0 25px 50px -12px #00000040;overflow:hidden;position:relative}.chart-modal-header{padding:var(--space-md) var(--space-lg);border-bottom:1px solid var(--line);display:flex;justify-content:space-between;align-items:center;flex-shrink:0}.chart-modal-title{font-size:var(--text-base);font-weight:var(--weight-medium);color:var(--ink);display:flex;align-items:center;gap:var(--space-sm)}.chart-modal-title:before{content:"";width:4px;height:16px;background:var(--olive);border-radius:2px}.chart-modal-close{background:none;border:none;color:#8a847d;font-size:28px;font-weight:300;cursor:pointer;width:40px;height:40px;display:flex;align-items:center;justify-content:center;border-radius:6px;transition:all .15s ease;line-height:1;z-index:10}.chart-modal-close:hover{color:#2c2825;background:#0000000d}.chart-modal-body{flex:1;display:flex;overflow:hidden;min-height:0}.chart-modal-chart-area{flex:1;display:flex;flex-direction:column;min-width:0;overflow:hidden;background:#f3f1ed}.chart-modal-chart-container{flex:1;width:100%;height:100%;padding:16px;background:#f3f1ed;overflow:hidden;position:relative}.chart-modal-settings{width:280px;border-left:1px solid var(--line);background:var(--paper);display:flex;flex-direction:column;flex-shrink:0;overflow-y:auto}.chart-settings-header{padding:var(--space-md) var(--space-lg);border-bottom:1px solid var(--line);font-size:var(--text-sm);font-weight:var(--weight-medium);color:var(--ink);display:flex;align-items:center;gap:var(--space-xs)}.chart-settings-header svg{color:var(--ink-muted)}.chart-settings-body{padding:var(--space-lg);display:flex;flex-direction:column;gap:var(--space-lg)}.chart-setting-group{display:flex;flex-direction:column;gap:var(--space-xs)}.chart-setting-label{font-size:var(--text-xs);font-weight:var(--weight-medium);color:var(--ink-muted);text-transform:uppercase;letter-spacing:.04em}.chart-setting-select{width:100%;padding:var(--space-sm) var(--space-md);border:1px solid var(--line);border-radius:var(--radius-sm);font-size:var(--text-sm);font-family:inherit;background:var(--paper);color:var(--ink);cursor:pointer;transition:border-color var(--transition-fast);appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%238a847d' stroke-width='2'%3E%3Cpolyline points='6 9 12 15 18 9'%3E%3C/polyline%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 12px center;padding-right:36px}.chart-setting-select:hover{border-color:var(--ink-muted)}.chart-setting-select:focus{outline:none;border-color:var(--olive)}.chart-type-option{display:flex;align-items:center;gap:var(--space-sm)}.chart-settings-divider{height:1px;background:var(--line);margin:var(--space-sm) 0}.chart-settings-info{font-size:var(--text-xs);color:var(--ink-muted);line-height:1.5;padding:var(--space-sm);background:var(--paper-soft);border-radius:var(--radius-sm)}.chart-tabs{display:flex;border-bottom:1px solid var(--line);padding:0 var(--space-md)}.chart-tab{flex:1;padding:var(--space-sm) var(--space-md);background:none;border:none;border-bottom:2px solid transparent;font-size:var(--text-sm);font-family:inherit;color:var(--ink-muted);cursor:pointer;transition:all .15s ease}.chart-tab:hover{color:var(--ink)}.chart-tab.active{color:var(--ink);border-bottom-color:var(--olive)}.chart-tab-content{display:none}.chart-tab-content.active{display:flex}.chart-series-list{display:flex;flex-direction:column;gap:var(--space-xs);max-height:240px;overflow-y:auto}.chart-series-item{display:flex;align-items:center;gap:var(--space-xs);padding:var(--space-xs);background:var(--paper-soft);border-radius:var(--radius-sm);border:1px solid var(--line)}.chart-series-item .series-column{flex:1;min-width:0}.chart-series-item .series-column select{width:100%;padding:var(--space-xs) var(--space-sm);border:1px solid var(--line);border-radius:var(--radius-xs);font-size:var(--text-xs);font-family:inherit;background:var(--paper);color:var(--ink);cursor:pointer}.chart-series-item .series-type{width:70px;flex-shrink:0}.chart-series-item .series-type select{width:100%;padding:var(--space-xs) var(--space-sm);border:1px solid var(--line);border-radius:var(--radius-xs);font-size:var(--text-xs);font-family:inherit;background:var(--paper);color:var(--ink);cursor:pointer}.chart-series-item .series-remove{width:24px;height:24px;padding:0;background:none;border:none;color:var(--ink-muted);cursor:pointer;display:flex;align-items:center;justify-content:center;border-radius:var(--radius-xs);flex-shrink:0;transition:all .15s ease}.chart-series-item .series-remove:hover{background:#0000000d;color:#c53030}.chart-add-series-btn{display:flex;align-items:center;justify-content:center;gap:var(--space-xs);width:100%;padding:var(--space-sm);margin-top:var(--space-xs);background:none;border:1px dashed var(--line);border-radius:var(--radius-sm);font-size:var(--text-xs);font-family:inherit;color:var(--ink-muted);cursor:pointer;transition:all .15s ease}.chart-add-series-btn:hover{border-color:var(--ink-muted);color:var(--ink);background:var(--paper-soft)}.chart-series-list::-webkit-scrollbar{width:4px}.chart-series-list::-webkit-scrollbar-track{background:transparent}.chart-series-list::-webkit-scrollbar-thumb{background:var(--ink-whisper);border-radius:2px}.chart-modal-settings::-webkit-scrollbar{width:4px}.chart-modal-settings::-webkit-scrollbar-track{background:transparent}.chart-modal-settings::-webkit-scrollbar-thumb{background:var(--ink-whisper);border-radius:2px}@media(max-width:900px){.chart-modal-body{flex-direction:column}.chart-modal-settings{width:100%;border-left:none;border-top:1px solid var(--line);max-height:200px}.chart-settings-body{flex-direction:row;flex-wrap:wrap}.chart-setting-group{flex:1;min-width:150px}}.erd-panel{position:absolute;inset:0;background:var(--paper);border:1px solid var(--line);transform:translate(-100%);transition:transform var(--transition-base);z-index:10;display:flex;flex-direction:column;border-radius:var(--radius-md)}.erd-panel.active{transform:translate(0)}.erd-panel-header{display:flex;align-items:center;justify-content:space-between;padding:var(--space-sm) var(--space-md);border-bottom:1px solid var(--line);flex-shrink:0}.erd-panel-header h3{font-size:var(--text-sm);font-weight:var(--weight-medium);color:var(--ink);margin:0;flex:1;text-align:center}.erd-header-actions{display:flex;align-items:center;gap:var(--space-xs)}.erd-back-btn,.erd-expand-btn,.erd-download-btn{display:flex;align-items:center;justify-content:center;width:28px;height:28px;background:transparent;border:none;border-radius:var(--radius-sm);color:var(--ink-soft);cursor:pointer;transition:color var(--transition-fast),background var(--transition-fast)}.erd-back-btn:hover,.erd-expand-btn:hover,.erd-download-btn:hover{color:var(--ink);background:var(--paper-accent)}.erd-panel-content{flex:1;min-height:0;overflow:hidden}.erd-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100%;color:var(--ink-muted);gap:var(--space-sm)}.erd-empty svg{opacity:.5}.erd-empty p{font-size:var(--text-sm);margin:0}.erd-modal-overlay{z-index:1000}.erd-modal-content{width:95vw;height:90vh;max-width:none;display:flex;flex-direction:column}.erd-modal-header{display:flex;align-items:center;justify-content:space-between;padding:var(--space-md) var(--space-lg);border-bottom:1px solid var(--line);flex-shrink:0}.erd-modal-header h2{font-size:var(--text-lg);font-weight:var(--weight-medium);color:var(--ink);margin:0}.erd-modal-header h2:after{display:none}.erd-modal-body{flex:1;min-height:0;overflow:hidden}.erd-modal-footer{display:flex;align-items:center;justify-content:space-between;padding:var(--space-sm) var(--space-lg);border-top:1px solid var(--line);flex-shrink:0}.erd-legend{display:flex;gap:var(--space-lg)}.erd-legend-item{display:flex;align-items:center;gap:var(--space-xs);font-size:var(--text-xs);color:var(--ink-soft)}.erd-stats{font-size:var(--text-xs);color:var(--ink-muted)}.erd-table-node{background:var(--paper);border:1px solid var(--line-emphasis);border-radius:var(--radius-md);min-width:200px;max-width:300px;box-shadow:var(--shadow-subtle);font-size:var(--text-xs)}.erd-table-header{background:var(--paper-accent);padding:var(--space-sm) var(--space-md);border-bottom:1px solid var(--line);border-radius:var(--radius-md) var(--radius-md) 0 0}.erd-table-name{font-weight:var(--weight-semibold);color:var(--ink);font-size:var(--text-sm)}.erd-table-columns{padding:var(--space-xs) 0}.erd-column-row{display:flex;align-items:center;padding:var(--space-xs) var(--space-md);position:relative;transition:background var(--transition-fast)}.erd-column-row:hover{background:var(--paper-soft)}.erd-column-info{display:flex;align-items:center;gap:var(--space-sm);flex:1;min-width:0}.erd-column-icons{display:flex;gap:2px;flex-shrink:0;min-width:36px}.erd-icon{display:inline-flex;align-items:center;justify-content:center;padding:1px 3px;border-radius:2px;font-size:9px;font-weight:var(--weight-semibold);letter-spacing:.02em}.erd-icon-pk{background:var(--olive-soft);color:var(--olive-dark)}.erd-icon-fk{background:#6482b426;color:#4a6a9a}.erd-column-name{color:var(--ink);font-weight:var(--weight-medium);flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.erd-column-type{color:var(--ink-muted);font-size:10px;flex-shrink:0}.erd-handle{width:8px!important;height:8px!important;background:var(--paper)!important;border:2px solid var(--ink-muted)!important;opacity:0;transition:opacity var(--transition-fast)}.erd-column-row:hover .erd-handle{opacity:1}.erd-handle-left{left:-4px!important}.erd-handle-right{right:-4px!important}.react-flow__controls{box-shadow:var(--shadow-subtle)!important;border-radius:var(--radius-md)!important;border:1px solid var(--line)!important;overflow:hidden}.react-flow__controls-button{background:var(--paper)!important;border-bottom:1px solid var(--line)!important;fill:var(--ink-soft)!important;transition:background var(--transition-fast),fill var(--transition-fast)!important}.react-flow__controls-button:hover{background:var(--paper-soft)!important;fill:var(--ink)!important}.react-flow__controls-button:last-child{border-bottom:none!important}.react-flow__minimap{background:var(--paper-soft)!important;border-radius:var(--radius-md)!important;border:1px solid var(--line)!important;box-shadow:var(--shadow-subtle)!important}.react-flow__edge-path{stroke:var(--ink-muted)!important;stroke-width:1.5!important}.react-flow__edge.selected .react-flow__edge-path,.react-flow__edge:hover .react-flow__edge-path{stroke:var(--olive)!important;stroke-width:2!important}.erd-toggle-btn{display:flex;align-items:center;justify-content:center;width:28px;height:28px;background:transparent;border:none;border-radius:var(--radius-sm);color:var(--ink-soft);cursor:pointer;transition:color var(--transition-fast),background var(--transition-fast)}.erd-toggle-btn:hover,.erd-toggle-btn.active{color:var(--olive);background:var(--olive-soft)}.react-flow{direction:ltr;--xy-edge-stroke-default: #b1b1b7;--xy-edge-stroke-width-default: 1;--xy-edge-stroke-selected-default: #555;--xy-connectionline-stroke-default: #b1b1b7;--xy-connectionline-stroke-width-default: 1;--xy-attribution-background-color-default: rgba(255, 255, 255, .5);--xy-minimap-background-color-default: #fff;--xy-minimap-mask-background-color-default: rgba(240, 240, 240, .6);--xy-minimap-mask-stroke-color-default: transparent;--xy-minimap-mask-stroke-width-default: 1;--xy-minimap-node-background-color-default: #e2e2e2;--xy-minimap-node-stroke-color-default: transparent;--xy-minimap-node-stroke-width-default: 2;--xy-background-color-default: transparent;--xy-background-pattern-dots-color-default: #91919a;--xy-background-pattern-lines-color-default: #eee;--xy-background-pattern-cross-color-default: #e2e2e2;background-color:var(--xy-background-color, var(--xy-background-color-default));--xy-node-color-default: inherit;--xy-node-border-default: 1px solid #1a192b;--xy-node-background-color-default: #fff;--xy-node-group-background-color-default: rgba(240, 240, 240, .25);--xy-node-boxshadow-hover-default: 0 1px 4px 1px rgba(0, 0, 0, .08);--xy-node-boxshadow-selected-default: 0 0 0 .5px #1a192b;--xy-node-border-radius-default: 3px;--xy-handle-background-color-default: #1a192b;--xy-handle-border-color-default: #fff;--xy-selection-background-color-default: rgba(0, 89, 220, .08);--xy-selection-border-default: 1px dotted rgba(0, 89, 220, .8);--xy-controls-button-background-color-default: #fefefe;--xy-controls-button-background-color-hover-default: #f4f4f4;--xy-controls-button-color-default: inherit;--xy-controls-button-color-hover-default: inherit;--xy-controls-button-border-color-default: #eee;--xy-controls-box-shadow-default: 0 0 2px 1px rgba(0, 0, 0, .08);--xy-edge-label-background-color-default: #ffffff;--xy-edge-label-color-default: inherit;--xy-resize-background-color-default: #3367d9}.react-flow.dark{--xy-edge-stroke-default: #3e3e3e;--xy-edge-stroke-width-default: 1;--xy-edge-stroke-selected-default: #727272;--xy-connectionline-stroke-default: #b1b1b7;--xy-connectionline-stroke-width-default: 1;--xy-attribution-background-color-default: rgba(150, 150, 150, .25);--xy-minimap-background-color-default: #141414;--xy-minimap-mask-background-color-default: rgba(60, 60, 60, .6);--xy-minimap-mask-stroke-color-default: transparent;--xy-minimap-mask-stroke-width-default: 1;--xy-minimap-node-background-color-default: #2b2b2b;--xy-minimap-node-stroke-color-default: transparent;--xy-minimap-node-stroke-width-default: 2;--xy-background-color-default: #141414;--xy-background-pattern-dots-color-default: #777;--xy-background-pattern-lines-color-default: #777;--xy-background-pattern-cross-color-default: #777;--xy-node-color-default: #f8f8f8;--xy-node-border-default: 1px solid #3c3c3c;--xy-node-background-color-default: #1e1e1e;--xy-node-group-background-color-default: rgba(240, 240, 240, .25);--xy-node-boxshadow-hover-default: 0 1px 4px 1px rgba(255, 255, 255, .08);--xy-node-boxshadow-selected-default: 0 0 0 .5px #999;--xy-handle-background-color-default: #bebebe;--xy-handle-border-color-default: #1e1e1e;--xy-selection-background-color-default: rgba(200, 200, 220, .08);--xy-selection-border-default: 1px dotted rgba(200, 200, 220, .8);--xy-controls-button-background-color-default: #2b2b2b;--xy-controls-button-background-color-hover-default: #3e3e3e;--xy-controls-button-color-default: #f8f8f8;--xy-controls-button-color-hover-default: #fff;--xy-controls-button-border-color-default: #5b5b5b;--xy-controls-box-shadow-default: 0 0 2px 1px rgba(0, 0, 0, .08);--xy-edge-label-background-color-default: #141414;--xy-edge-label-color-default: #f8f8f8}.react-flow__background{background-color:var(--xy-background-color-props, var(--xy-background-color, var(--xy-background-color-default)));pointer-events:none;z-index:-1}.react-flow__container{position:absolute;width:100%;height:100%;top:0;left:0}.react-flow__pane{z-index:1}.react-flow__pane.draggable{cursor:grab}.react-flow__pane.dragging{cursor:grabbing}.react-flow__pane.selection{cursor:pointer}.react-flow__viewport{transform-origin:0 0;z-index:2;pointer-events:none}.react-flow__renderer{z-index:4}.react-flow__selection{z-index:6}.react-flow__nodesselection-rect:focus,.react-flow__nodesselection-rect:focus-visible{outline:none}.react-flow__edge-path{stroke:var(--xy-edge-stroke, var(--xy-edge-stroke-default));stroke-width:var(--xy-edge-stroke-width, var(--xy-edge-stroke-width-default));fill:none}.react-flow__connection-path{stroke:var(--xy-connectionline-stroke, var(--xy-connectionline-stroke-default));stroke-width:var(--xy-connectionline-stroke-width, var(--xy-connectionline-stroke-width-default));fill:none}.react-flow .react-flow__edges{position:absolute}.react-flow .react-flow__edges svg{overflow:visible;position:absolute;pointer-events:none}.react-flow__edge{pointer-events:visibleStroke}.react-flow__edge.selectable{cursor:pointer}.react-flow__edge.animated path{stroke-dasharray:5;animation:dashdraw .5s linear infinite}.react-flow__edge.animated path.react-flow__edge-interaction{stroke-dasharray:none;animation:none}.react-flow__edge.inactive{pointer-events:none}.react-flow__edge.selected,.react-flow__edge:focus,.react-flow__edge:focus-visible{outline:none}.react-flow__edge.selected .react-flow__edge-path,.react-flow__edge.selectable:focus .react-flow__edge-path,.react-flow__edge.selectable:focus-visible .react-flow__edge-path{stroke:var(--xy-edge-stroke-selected, var(--xy-edge-stroke-selected-default))}.react-flow__edge-textwrapper{pointer-events:all}.react-flow__edge .react-flow__edge-text{pointer-events:none;-webkit-user-select:none;-moz-user-select:none;user-select:none}.react-flow__arrowhead polyline{stroke:var(--xy-edge-stroke, var(--xy-edge-stroke-default))}.react-flow__arrowhead polyline.arrowclosed{fill:var(--xy-edge-stroke, var(--xy-edge-stroke-default))}.react-flow__connection{pointer-events:none}.react-flow__connection .animated{stroke-dasharray:5;animation:dashdraw .5s linear infinite}svg.react-flow__connectionline{z-index:1001;overflow:visible;position:absolute}.react-flow__nodes{pointer-events:none;transform-origin:0 0}.react-flow__node{position:absolute;-webkit-user-select:none;-moz-user-select:none;user-select:none;pointer-events:all;transform-origin:0 0;box-sizing:border-box;cursor:default}.react-flow__node.selectable{cursor:pointer}.react-flow__node.draggable{cursor:grab;pointer-events:all}.react-flow__node.draggable.dragging{cursor:grabbing}.react-flow__nodesselection{z-index:3;transform-origin:left top;pointer-events:none}.react-flow__nodesselection-rect{position:absolute;pointer-events:all;cursor:grab}.react-flow__handle{position:absolute;pointer-events:none;min-width:5px;min-height:5px;width:6px;height:6px;background-color:var(--xy-handle-background-color, var(--xy-handle-background-color-default));border:1px solid var(--xy-handle-border-color, var(--xy-handle-border-color-default));border-radius:100%}.react-flow__handle.connectingfrom{pointer-events:all}.react-flow__handle.connectionindicator{pointer-events:all;cursor:crosshair}.react-flow__handle-bottom{top:auto;left:50%;bottom:0;transform:translate(-50%,50%)}.react-flow__handle-top{top:0;left:50%;transform:translate(-50%,-50%)}.react-flow__handle-left{top:50%;left:0;transform:translate(-50%,-50%)}.react-flow__handle-right{top:50%;right:0;transform:translate(50%,-50%)}.react-flow__edgeupdater{cursor:move;pointer-events:all}.react-flow__pane.selection .react-flow__panel{pointer-events:none}.react-flow__panel{position:absolute;z-index:5;margin:15px}.react-flow__panel.top{top:0}.react-flow__panel.bottom{bottom:0}.react-flow__panel.top.center,.react-flow__panel.bottom.center{left:50%;transform:translate(-15px) translate(-50%)}.react-flow__panel.left{left:0}.react-flow__panel.right{right:0}.react-flow__panel.left.center,.react-flow__panel.right.center{top:50%;transform:translateY(-15px) translateY(-50%)}.react-flow__attribution{font-size:10px;background:var(--xy-attribution-background-color, var(--xy-attribution-background-color-default));padding:2px 3px;margin:0}.react-flow__attribution a{text-decoration:none;color:#999}@keyframes dashdraw{0%{stroke-dashoffset:10}}.react-flow__edgelabel-renderer{position:absolute;width:100%;height:100%;pointer-events:none;-webkit-user-select:none;-moz-user-select:none;user-select:none;left:0;top:0}.react-flow__viewport-portal{position:absolute;width:100%;height:100%;left:0;top:0;-webkit-user-select:none;-moz-user-select:none;user-select:none}.react-flow__minimap{background:var( --xy-minimap-background-color-props, var(--xy-minimap-background-color, var(--xy-minimap-background-color-default)) )}.react-flow__minimap-svg{display:block}.react-flow__minimap-mask{fill:var( --xy-minimap-mask-background-color-props, var(--xy-minimap-mask-background-color, var(--xy-minimap-mask-background-color-default)) );stroke:var( --xy-minimap-mask-stroke-color-props, var(--xy-minimap-mask-stroke-color, var(--xy-minimap-mask-stroke-color-default)) );stroke-width:var( --xy-minimap-mask-stroke-width-props, var(--xy-minimap-mask-stroke-width, var(--xy-minimap-mask-stroke-width-default)) )}.react-flow__minimap-node{fill:var( --xy-minimap-node-background-color-props, var(--xy-minimap-node-background-color, var(--xy-minimap-node-background-color-default)) );stroke:var( --xy-minimap-node-stroke-color-props, var(--xy-minimap-node-stroke-color, var(--xy-minimap-node-stroke-color-default)) );stroke-width:var( --xy-minimap-node-stroke-width-props, var(--xy-minimap-node-stroke-width, var(--xy-minimap-node-stroke-width-default)) )}.react-flow__background-pattern.dots{fill:var( --xy-background-pattern-color-props, var(--xy-background-pattern-color, var(--xy-background-pattern-dots-color-default)) )}.react-flow__background-pattern.lines{stroke:var( --xy-background-pattern-color-props, var(--xy-background-pattern-color, var(--xy-background-pattern-lines-color-default)) )}.react-flow__background-pattern.cross{stroke:var( --xy-background-pattern-color-props, var(--xy-background-pattern-color, var(--xy-background-pattern-cross-color-default)) )}.react-flow__controls{display:flex;flex-direction:column;box-shadow:var(--xy-controls-box-shadow, var(--xy-controls-box-shadow-default))}.react-flow__controls.horizontal{flex-direction:row}.react-flow__controls-button{display:flex;justify-content:center;align-items:center;height:26px;width:26px;padding:4px;border:none;background:var(--xy-controls-button-background-color, var(--xy-controls-button-background-color-default));border-bottom:1px solid var( --xy-controls-button-border-color-props, var(--xy-controls-button-border-color, var(--xy-controls-button-border-color-default)) );color:var( --xy-controls-button-color-props, var(--xy-controls-button-color, var(--xy-controls-button-color-default)) );cursor:pointer;-webkit-user-select:none;-moz-user-select:none;user-select:none}.react-flow__controls-button svg{width:100%;max-width:12px;max-height:12px;fill:currentColor}.react-flow__edge.updating .react-flow__edge-path{stroke:#777}.react-flow__edge-text{font-size:10px}.react-flow__node.selectable:focus,.react-flow__node.selectable:focus-visible{outline:none}.react-flow__node-input,.react-flow__node-default,.react-flow__node-output,.react-flow__node-group{padding:10px;border-radius:var(--xy-node-border-radius, var(--xy-node-border-radius-default));width:150px;font-size:12px;color:var(--xy-node-color, var(--xy-node-color-default));text-align:center;border:var(--xy-node-border, var(--xy-node-border-default));background-color:var(--xy-node-background-color, var(--xy-node-background-color-default))}.react-flow__node-input.selectable:hover,.react-flow__node-default.selectable:hover,.react-flow__node-output.selectable:hover,.react-flow__node-group.selectable:hover{box-shadow:var(--xy-node-boxshadow-hover, var(--xy-node-boxshadow-hover-default))}.react-flow__node-input.selectable.selected,.react-flow__node-input.selectable:focus,.react-flow__node-input.selectable:focus-visible,.react-flow__node-default.selectable.selected,.react-flow__node-default.selectable:focus,.react-flow__node-default.selectable:focus-visible,.react-flow__node-output.selectable.selected,.react-flow__node-output.selectable:focus,.react-flow__node-output.selectable:focus-visible,.react-flow__node-group.selectable.selected,.react-flow__node-group.selectable:focus,.react-flow__node-group.selectable:focus-visible{box-shadow:var(--xy-node-boxshadow-selected, var(--xy-node-boxshadow-selected-default))}.react-flow__node-group{background-color:var(--xy-node-group-background-color, var(--xy-node-group-background-color-default))}.react-flow__nodesselection-rect,.react-flow__selection{background:var(--xy-selection-background-color, var(--xy-selection-background-color-default));border:var(--xy-selection-border, var(--xy-selection-border-default))}.react-flow__nodesselection-rect:focus,.react-flow__nodesselection-rect:focus-visible,.react-flow__selection:focus,.react-flow__selection:focus-visible{outline:none}.react-flow__controls-button:hover{background:var( --xy-controls-button-background-color-hover-props, var(--xy-controls-button-background-color-hover, var(--xy-controls-button-background-color-hover-default)) );color:var( --xy-controls-button-color-hover-props, var(--xy-controls-button-color-hover, var(--xy-controls-button-color-hover-default)) )}.react-flow__controls-button:disabled{pointer-events:none}.react-flow__controls-button:disabled svg{fill-opacity:.4}.react-flow__controls-button:last-child{border-bottom:none}.react-flow__controls.horizontal .react-flow__controls-button{border-bottom:none;border-right:1px solid var( --xy-controls-button-border-color-props, var(--xy-controls-button-border-color, var(--xy-controls-button-border-color-default)) )}.react-flow__controls.horizontal .react-flow__controls-button:last-child{border-right:none}.react-flow__resize-control{position:absolute}.react-flow__resize-control.left,.react-flow__resize-control.right{cursor:ew-resize}.react-flow__resize-control.top,.react-flow__resize-control.bottom{cursor:ns-resize}.react-flow__resize-control.top.left,.react-flow__resize-control.bottom.right{cursor:nwse-resize}.react-flow__resize-control.bottom.left,.react-flow__resize-control.top.right{cursor:nesw-resize}.react-flow__resize-control.handle{width:5px;height:5px;border:1px solid #fff;border-radius:1px;background-color:var(--xy-resize-background-color, var(--xy-resize-background-color-default));translate:-50% -50%}.react-flow__resize-control.handle.left{left:0;top:50%}.react-flow__resize-control.handle.right{left:100%;top:50%}.react-flow__resize-control.handle.top{left:50%;top:0}.react-flow__resize-control.handle.bottom{left:50%;top:100%}.react-flow__resize-control.handle.top.left,.react-flow__resize-control.handle.bottom.left{left:0}.react-flow__resize-control.handle.top.right,.react-flow__resize-control.handle.bottom.right{left:100%}.react-flow__resize-control.line{border-color:var(--xy-resize-background-color, var(--xy-resize-background-color-default));border-width:0;border-style:solid}.react-flow__resize-control.line.left,.react-flow__resize-control.line.right{width:1px;transform:translate(-50%);top:0;height:100%}.react-flow__resize-control.line.left{left:0;border-left-width:1px}.react-flow__resize-control.line.right{left:100%;border-right-width:1px}.react-flow__resize-control.line.top,.react-flow__resize-control.line.bottom{height:1px;transform:translateY(-50%);left:0;width:100%}.react-flow__resize-control.line.top{top:0;border-top-width:1px}.react-flow__resize-control.line.bottom{border-bottom-width:1px;top:100%}.react-flow__edge-textbg{fill:var(--xy-edge-label-background-color, var(--xy-edge-label-background-color-default))}.react-flow__edge-text{fill:var(--xy-edge-label-color, var(--xy-edge-label-color-default))}.admin-login-container{min-height:100vh;display:flex;align-items:center;justify-content:center;background:var(--paper)}.admin-login-box{background:var(--paper);padding:var(--space-xl);width:100%;max-width:360px}.admin-login-box h1{text-align:center;margin-bottom:var(--space-xl);color:var(--ink);font-size:1.5rem;font-weight:500;letter-spacing:-.01em}.admin-form-group{margin-bottom:var(--space-lg)}.admin-form-group label{display:block;margin-bottom:var(--space-sm);color:var(--ink-muted);font-size:.75rem;font-weight:500;letter-spacing:.05em;text-transform:uppercase}.admin-form-group input{width:100%;padding:.75rem 1rem;background:var(--paper);border:1px solid var(--line);border-radius:4px;font-size:1rem;color:var(--ink);transition:border-color .15s ease}.admin-form-group input:focus{outline:none;border-color:var(--olive-muted);box-shadow:0 0 0 2px var(--olive-soft)}.admin-form-group input::placeholder{color:var(--ink-whisper)}.admin-btn-primary{width:100%;padding:.75rem 1.25rem;background:var(--olive);color:var(--paper);border:none;border-radius:4px;font-size:1rem;font-weight:500;cursor:pointer;transition:background-color .15s ease}.admin-btn-primary:hover{background:var(--olive-dark)}.admin-btn-back{width:100%;margin-top:var(--space-md);padding:.75rem 1.25rem;background:transparent;color:var(--ink-muted);border:1px solid var(--line);border-radius:4px;font-size:.875rem;cursor:pointer;transition:all .15s ease}.admin-btn-back:hover{border-color:var(--ink-muted);color:var(--ink)}.admin-btn-secondary{padding:.5rem 1rem;background:transparent;color:var(--ink-soft);border:1px solid var(--line);border-radius:4px;font-size:.875rem;cursor:pointer;transition:all .15s ease}.admin-btn-secondary:hover{border-color:var(--ink-muted);color:var(--ink)}.admin-btn-logout{padding:.5rem 1rem;background:transparent;color:var(--ink-muted);border:1px solid var(--line);border-radius:4px;font-size:.875rem;cursor:pointer;transition:all .15s ease}.admin-btn-logout:hover{border-color:var(--ink-muted);color:var(--ink)}.admin-error{color:#a65d57;font-size:.875rem;margin-bottom:var(--space-md);text-align:center;padding:var(--space-sm);background:#a65d571a;border-radius:4px}.admin-container{background:var(--paper);padding:var(--space-xl);max-width:1000px;width:100%;min-height:100vh;margin:0 auto}.admin-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--space-xl);padding-bottom:var(--space-lg);border-bottom:1px solid var(--line)}.admin-header h1{color:var(--ink);font-size:1.5rem;font-weight:500;letter-spacing:-.01em}.admin-header-actions{display:flex;align-items:center;gap:var(--space-md)}.admin-user-email{color:var(--ink-soft);font-size:.875rem}.admin-section{margin-bottom:var(--space-xl)}.admin-section h2{color:var(--ink);font-size:1.125rem;font-weight:500;margin-bottom:var(--space-lg)}.admin-loading,.admin-empty{text-align:center;padding:var(--space-xl);color:var(--ink-muted)}.admin-user-table{width:100%;border-collapse:collapse}.admin-user-table th,.admin-user-table td{padding:var(--space-md);text-align:left;border-bottom:1px solid var(--line)}.admin-user-table th{color:var(--ink-muted);font-size:.75rem;font-weight:500;letter-spacing:.05em;text-transform:uppercase}.admin-user-table td{color:var(--ink-soft);font-size:.875rem}.admin-user-table tr:hover{background:var(--paper-soft)}.admin-oauth-sub{font-family:JetBrains Mono,SF Mono,Monaco,monospace;font-size:.75rem;color:var(--ink-muted)}.admin-role-select{padding:.375rem .5rem;background:var(--paper);border:1px solid var(--line);border-radius:4px;font-size:.875rem;color:var(--ink);cursor:pointer}.admin-role-select:focus{outline:none;border-color:var(--olive-muted)}.admin-role-badge-root{display:inline-block;padding:.25rem .5rem;background:var(--olive-soft);color:var(--olive-dark);border-radius:4px;font-size:.75rem;font-weight:500;text-transform:uppercase}
