@import"https://cdn.jsdelivr.net/gh/orioncactus/pretendard/dist/web/variable/pretendardvariable.min.css";@import"https://fonts.googleapis.com/css2?family=Plus+Jakarta+Sans:wght@400;500;600;700;800&family=JetBrains+Mono:wght@400;500&display=swap";:root{--primary-900: #0d1b3e;--primary-800: #132952;--primary-700: #1a3a6b;--primary-600: #234b85;--primary-500: #2d5da0;--primary-400: #4a7cc4;--primary-300: #6e9be0;--primary-200: #a3c4f3;--primary-100: #d1e2fa;--primary-50: #eef5fc;--white: #ffffff;--neutral-50: #f8fafc;--neutral-100: #f1f5f9;--neutral-200: #e2e8f0;--neutral-300: #cbd5e1;--neutral-400: #94a3b8;--neutral-500: #64748b;--neutral-600: #475569;--neutral-700: #334155;--neutral-800: #1e293b;--neutral-900: #0f172a;--accent-600: #e55a28;--accent-500: #ff6b35;--accent-400: #ff8255;--accent-100: #fff4f0;--warning: #d97706;--error: #dc2626;--info: var(--primary-500);--paper: var(--white);--paper-soft: var(--neutral-50);--paper-accent: var(--neutral-100);--ink: var(--neutral-800);--ink-soft: var(--neutral-600);--ink-muted: var(--neutral-500);--ink-whisper: var(--neutral-400);--olive: var(--primary-700);--olive-dark: var(--primary-800);--olive-soft: var(--primary-100);--olive-muted: var(--primary-400);--accent: var(--primary-700);--accent-hover: var(--primary-600);--accent-soft: var(--primary-100);--accent-light: var(--primary-50);--bg-primary: var(--white);--bg-secondary: var(--neutral-50);--bg-tertiary: var(--neutral-100);--text-primary: var(--neutral-800);--text-secondary: var(--neutral-600);--text-tertiary: var(--neutral-500);--text-muted: var(--neutral-400);--line: var(--neutral-200);--line-emphasis: var(--neutral-300);--border-light: var(--neutral-200);--border: var(--neutral-300);--border-dark: var(--neutral-400);--code-bg: var(--neutral-900);--code-text: var(--neutral-100);--space-1: .25rem;--space-2: .5rem;--space-3: .75rem;--space-4: 1rem;--space-6: 1.5rem;--space-8: 2rem;--space-12: 3rem;--space-16: 4rem;--space-20: 5rem;--space-xs: .25rem;--space-sm: .5rem;--space-md: 1rem;--space-lg: 1.5rem;--space-xl: 2.5rem;--space-2xl: 4rem;--font-display: "Plus Jakarta Sans", system-ui, sans-serif;--font-body: "Pretendard Variable", "Pretendard", system-ui, sans-serif;--font-mono: "JetBrains Mono", "Fira Code", monospace;--font-sans: var(--font-body);--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;--weight-bold: 700;--weight-extrabold: 800;--ease-out: cubic-bezier(0, 0, .2, 1);--ease-in-out: cubic-bezier(.4, 0, .2, 1);--duration-fast: .15s;--duration-normal: .2s;--duration-slow: .3s;--transition-fast: .15s ease;--transition-base: .2s ease;--radius-sm: 4px;--radius-md: 8px;--radius-lg: 12px;--radius-xs: 4px;--radius-full: 9999px;--shadow-sm: 0 1px 2px 0 rgb(15 23 42 / .05);--shadow-md: 0 4px 6px -1px rgb(15 23 42 / .07), 0 2px 4px -2px rgb(15 23 42 / .05);--shadow-lg: 0 10px 15px -3px rgb(15 23 42 / .08), 0 4px 6px -4px rgb(15 23 42 / .04);--shadow-xl: 0 20px 25px -5px rgb(15 23 42 / .1), 0 8px 10px -6px rgb(15 23 42 / .04);--shadow-subtle: var(--shadow-sm);--shadow-elevated: var(--shadow-lg);--ring-primary: 0 0 0 3px rgb(45 93 160 / .25);--ring-accent: 0 0 0 3px rgb(255 107 53 / .25)}*{margin:0;padding:0;box-sizing:border-box}html,body,#root{height:100%;margin:0;padding:0}body{font-family:var(--font-body);font-size:var(--text-base);line-height:1.65;color:var(--neutral-800);background:var(--white);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-family:var(--font-display);font-size:var(--text-xl);font-weight:var(--weight-bold);color:var(--neutral-800);margin:0;letter-spacing:-.02em}.page-title:after{display:none}h1{font-family:var(--font-display);font-size:var(--text-2xl);font-weight:var(--weight-bold);color:var(--neutral-800);text-align:center;margin-bottom:var(--space-xl);letter-spacing:-.02em}h1:after{content:"";display:block;width:40px;height:2px;background:var(--primary-700);margin:var(--space-sm) auto 0;border-radius:1px}h2{font-family:var(--font-display);font-size:var(--text-xl);font-weight:var(--weight-bold);color:var(--neutral-800);letter-spacing:-.015em}h3{font-family:var(--font-display);font-size:var(--text-lg);font-weight:var(--weight-semibold);color:var(--neutral-800)}.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:all var(--duration-fast) var(--ease-out)}button:disabled{opacity:.5;cursor:not-allowed}input,textarea{font-family:inherit;font-size:var(--text-sm)}.btn-primary{background:var(--primary-700);color:var(--white);padding:.75rem 1.5rem;border-radius:8px;font-weight:600;border:none;transition:all var(--duration-fast) var(--ease-out)}.btn-primary:hover{background:var(--primary-600);transform:translateY(-1px)}.btn-primary:focus-visible{outline:none;box-shadow:var(--ring-primary)}.btn-secondary{background:transparent;color:var(--primary-700);border:1.5px solid var(--primary-300);padding:.75rem 1.5rem;border-radius:8px;font-weight:600}.btn-secondary:hover{background:var(--primary-50)}.card{background:var(--white);border-radius:8px;border:1px solid var(--neutral-200);padding:1.5rem;box-shadow:var(--shadow-sm);transition:all var(--duration-normal) var(--ease-out)}.card:hover{box-shadow:var(--shadow-md);border-color:var(--primary-200)}.input{width:100%;padding:.75rem 1rem;border:1.5px solid var(--neutral-300);border-radius:8px;font-size:1rem;transition:all var(--duration-fast)}.input:focus{outline:none;border-color:var(--primary-500);box-shadow:var(--ring-primary)}.input::placeholder{color:var(--neutral-400)}.badge{display:inline-flex;padding:.25rem .625rem;border-radius:4px;font-size:.75rem;font-weight:600}.badge-default{background:var(--primary-100);color:var(--primary-700)}.badge-accent{background:var(--accent-500);color:var(--white)}.highlight-accent{color:var(--accent-500);position:relative;display:inline-block}.highlight-accent:after{content:"";position:absolute;left:0;bottom:-6px;width:100%;height:2px;background:var(--primary-700);border-radius:1px}@keyframes fade-up{0%{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}.animate-in{animation:fade-up .4s var(--ease-out) forwards;opacity:0}.delay-1{animation-delay:80ms}.delay-2{animation-delay:.16s}.delay-3{animation-delay:.24s}.hover-lift{transition:transform var(--duration-normal) var(--ease-out),box-shadow var(--duration-normal) var(--ease-out)}.hover-lift:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg)}@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-md);border:none;background:transparent;color:var(--neutral-500);transition:color var(--transition-fast);cursor:pointer}.auth-btn:hover{color:var(--neutral-800)}.auth-btn svg{flex-shrink:0;width:14px;height:14px}.auth-btn-login{color:var(--neutral-600)}.auth-btn-login:hover{color:var(--primary-700)}.auth-btn-logout{color:var(--neutral-500)}.auth-btn-logout:hover{color:var(--neutral-600)}.auth-user-info{display:flex;align-items:center;gap:6px;font-size:var(--text-xs)}.auth-email{color:var(--neutral-500);max-width:120px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.auth-role-badge{padding:1px 6px;font-size:10px;font-weight:var(--weight-semibold);border-radius:3px;text-transform:uppercase;letter-spacing:.3px}.auth-role-badge.role-root{background:var(--accent-100);color:var(--accent-600);border:1px solid var(--accent-500)}.auth-role-badge.role-admin{background:var(--primary-50);color:var(--primary-700);border:1px solid var(--primary-400)}.auth-role-badge.role-user{background:transparent;color:var(--neutral-500);border:1px solid var(--neutral-300)}.auth-btn-mypage{color:var(--neutral-500)}.auth-btn-mypage:hover{color:var(--primary-700)}.auth-loading{font-size:var(--text-sm);color:var(--neutral-500)}.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-body);border:1px solid var(--neutral-200);border-radius:var(--radius-md);background:var(--white);overflow:hidden;flex:1;display:flex;flex-direction:column;min-height:0;box-shadow:var(--shadow-sm)}.schema-header{display:flex;justify-content:space-between;align-items:center;padding:.5rem var(--space-lg);border-bottom:1px solid var(--primary-800);position:relative;background:var(--primary-900)}.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-md);cursor:pointer;font-size:14px;display:flex;align-items:center;justify-content:center;transition:all var(--transition-fast);color:var(--neutral-400)}.schema-refresh-btn:hover{color:var(--white);background:var(--primary-800)}.schema-refresh-btn:active{transform:translateY(-50%) scale(.95)}.schema-refresh-btn:disabled{cursor:not-allowed;opacity:.4}.schema-header h3{font-family:var(--font-display);font-size:var(--text-base);font-weight:var(--weight-semibold);color:var(--white);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(--accent-500);border-radius:2px;margin-right:var(--space-sm);vertical-align:middle}.table-count{font-size:var(--text-sm);color:var(--neutral-400);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(--neutral-200);background:var(--neutral-50)}.edit-metadata-btn{width:100%;padding:var(--space-sm) var(--space-md);background:transparent;color:var(--neutral-600);border:1px solid var(--neutral-200);border-radius:var(--radius-md);cursor:pointer;font-size:var(--text-sm);font-weight:var(--weight-medium);transition:all var(--transition-fast)}.edit-metadata-btn:hover{border-color:var(--primary-300);color:var(--primary-700);background:var(--primary-50)}.tree-node{margin:var(--space-xs) 0}.table-node{margin-bottom:var(--space-sm)}.table-comment-inline{font-size:.625rem;color:var(--neutral-500);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-md);cursor:pointer;transition:background var(--transition-fast)}.node-header:hover{background:var(--neutral-50)}.toggle-icon{margin-right:var(--space-sm);font-size:var(--text-xs);color:var(--neutral-500);transition:transform var(--transition-fast)}.table-icon{margin-right:var(--space-sm);font-size:var(--text-xs);color:var(--primary-400)}.column-icon{margin-right:var(--space-sm);font-size:var(--text-xs);color:var(--neutral-400)}.node-label{font-weight:var(--weight-medium);color:var(--neutral-800);margin-right:var(--space-sm);font-size:var(--text-sm)}.column-count{font-size:var(--text-xs);color:var(--neutral-500);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(--neutral-200)}.column-node{display:flex;flex-direction:column;padding:var(--space-sm) var(--space-md);background:transparent;border:none;border-radius:var(--radius-md);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(--neutral-50)}.column-node.selected{background:var(--primary-50);box-shadow:inset 2px 0 0 var(--primary-700)}.column-type{font-size:var(--text-xs);color:var(--neutral-500);font-family:var(--font-mono);margin-left:auto;margin-right:var(--space-sm)}.column-nullable{font-size:var(--text-xs);color:var(--neutral-400);margin-right:var(--space-sm)}.column-default{font-size:var(--text-xs);color:var(--neutral-500)}.node-comment{font-size:.625rem;color:var(--neutral-500);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(--neutral-500)}.error{color:var(--error)}.tree-content::-webkit-scrollbar{width:5px;height:5px}.tree-content::-webkit-scrollbar-track{background:transparent}.tree-content::-webkit-scrollbar-thumb{background:var(--neutral-400);border-radius:3px}.tree-content::-webkit-scrollbar-thumb:hover{background:var(--neutral-500)}#sqlExamplesPanelContainer{flex-shrink:0}.metadata-editor-panel{font-family:var(--font-body);border:1px solid var(--neutral-200);border-radius:var(--radius-md);background:var(--white);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(--primary-800);background:var(--primary-900)}.metadata-header h3{margin:0;font-family:var(--font-display);font-size:var(--text-sm);font-weight:var(--weight-semibold);color:var(--white);text-align:center;flex:1}.metadata-header h3:before{content:"";display:inline-block;width:6px;height:6px;background:var(--accent-500);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(--neutral-600);border:1px solid var(--neutral-200);border-radius:var(--radius-md);cursor:pointer;font-size:var(--text-xs);font-weight:var(--weight-medium);transition:all var(--transition-fast)}.metadata-btn:hover{border-color:var(--primary-300);color:var(--primary-700);background:var(--primary-50)}.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-md);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all var(--transition-fast);color:var(--neutral-400)}.history-toggle-btn:hover{color:var(--white);background:var(--primary-800)}.history-toggle-btn:active{transform:scale(.95)}.new-chat-toggle-btn{width:28px;height:28px;padding:0;background:transparent;border:none;border-radius:var(--radius-md);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all var(--transition-fast);color:var(--neutral-400)}.new-chat-toggle-btn:hover{color:var(--white);background:var(--primary-800)}.new-chat-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(--white);border:1px solid var(--neutral-200);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:.5rem var(--space-lg);border-bottom:1px solid var(--primary-800);position:relative;background:var(--primary-900);border-radius:var(--radius-md) var(--radius-md) 0 0}.history-back-btn{width:28px;height:28px;padding:0;background:transparent;border:none;border-radius:var(--radius-md);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all var(--transition-fast);color:var(--neutral-400)}.history-back-btn:hover{color:var(--white);background:var(--primary-800)}.history-panel-header h3{margin:0;font-family:var(--font-display);font-size:var(--text-base);font-weight:var(--weight-semibold);color:var(--white);flex:1;text-align:center;letter-spacing:-.01em}.history-panel-header h3:before{content:"";display:inline-block;width:8px;height:8px;background:var(--accent-500);border-radius:2px;margin-right:var(--space-sm);vertical-align:middle}.history-count{font-size:var(--text-sm);color:var(--neutral-400);font-weight:var(--weight-normal)}.history-new-chat-btn{width:28px;height:28px;padding:0;background:transparent;border:none;border-radius:var(--radius-md);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all var(--transition-fast);color:var(--neutral-400)}.history-new-chat-btn:hover{color:var(--white);background:var(--primary-800)}.history-new-chat-btn:active{transform:scale(.95)}.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(--neutral-500)}.history-empty{display:flex;flex-direction:column;align-items:center;gap:var(--space-md)}.history-empty svg{stroke:var(--neutral-400)}.history-error{color:var(--error)}.history-item{display:flex;align-items:center;padding:var(--space-sm) var(--space-md);background:transparent;border-radius:var(--radius-md);cursor:pointer;transition:background var(--transition-fast);margin-bottom:var(--space-xs)}.history-item:hover{background:var(--neutral-50)}.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(--neutral-800);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(--neutral-500)}.history-item-date{color:var(--neutral-400)}.history-item-turns{color:var(--neutral-500)}.history-item-delete{width:28px;height:28px;padding:0;background:transparent;border:none;border-radius:var(--radius-md);cursor:pointer;display:flex;align-items:center;justify-content:center;opacity:0;transition:all var(--transition-fast);color:var(--neutral-500);flex-shrink:0}.history-item-delete:hover{color:var(--error);background:#dc26261a}.history-content::-webkit-scrollbar{width:5px}.history-content::-webkit-scrollbar-track{background:transparent}.history-content::-webkit-scrollbar-thumb{background:var(--neutral-400);border-radius:3px}.history-content::-webkit-scrollbar-thumb:hover{background:var(--neutral-500)}.column-header{display:flex;align-items:center;width:100%;cursor:pointer}.column-header *{pointer-events:none}.column-toggle-icon{font-size:8pt;color:var(--neutral-500);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(--primary-700)}.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(--neutral-200)}.sample-values-list{display:flex;flex-direction:column;gap:2px}.sample-value-item{font-size:8pt;font-family:var(--font-mono);color:var(--neutral-600);padding:2px var(--space-xs);background:var(--neutral-50);border-radius:2px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:200px}.sample-value-item:hover{background:var(--primary-50);color:var(--neutral-800)}.sample-null{color:var(--neutral-400);font-style:italic}.column-node.expanded{background:var(--neutral-50)}.column-node.expanded .column-toggle-icon{color:var(--primary-700)}.input-section{background:var(--white);padding:var(--space-xl);border:1px solid var(--neutral-200);border-radius:var(--radius-md);margin-bottom:var(--space-xl)}.prompt-input{width:100%;padding:var(--space-md);font-size:var(--text-base);border:1.5px solid var(--neutral-300);border-radius:var(--radius-md);resize:vertical;font-family:inherit;background:var(--white);transition:border-color var(--transition-fast),box-shadow var(--transition-fast)}.prompt-input:focus{outline:none;border-color:var(--primary-500);box-shadow:var(--ring-primary)}.prompt-input:disabled{background:var(--neutral-50);color:var(--neutral-500);cursor:not-allowed}.submit-btn{background:var(--primary-700);color:#fff;border:none;padding:var(--space-sm) var(--space-xl);font-size:var(--text-base);border-radius:var(--radius-md);cursor:pointer;transition:background var(--transition-fast),transform var(--transition-fast)}.submit-btn:hover{background:var(--primary-600);transform:translateY(-1px)}.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(--neutral-200)}th{font-size:var(--text-sm);font-weight:var(--weight-semibold);color:var(--white);border-bottom:2px solid var(--primary-700);background:var(--primary-800)}td{font-size:var(--text-sm);color:var(--neutral-600)}tr:hover td{background:var(--neutral-50)}.conversation-box{flex:1;display:flex;flex-direction:column;border:1px solid var(--neutral-200);border-radius:var(--radius-md);background:var(--white);overflow:hidden;min-height:0;box-shadow:var(--shadow-sm)}.conversation-header{display:flex;justify-content:space-between;align-items:center;padding:.5rem var(--space-md);border-bottom:1px solid var(--primary-800);background:var(--primary-900)}.conversation-title{font-family:var(--font-display);font-size:var(--text-sm);font-weight:var(--weight-semibold);color:var(--white);letter-spacing:-.01em;display:flex;align-items:center;gap:var(--space-sm)}.conversation-title:before{content:"";width:3px;height:14px;background:var(--accent-500);border-radius:2px}.new-chat-btn{background:transparent;border:1px solid var(--primary-600);color:var(--neutral-300);cursor:pointer;padding:var(--space-xs) var(--space-sm);border-radius:var(--radius-md);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(--primary-800);border-color:var(--primary-500);color:var(--white)}.conversation-container{background:var(--white);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(--neutral-500);text-align:center}.empty-state svg{margin-bottom:var(--space-lg);stroke:var(--neutral-400);opacity:.6}.empty-state p{margin:var(--space-xs) 0}.empty-hint{font-size:var(--text-sm);color:var(--neutral-400);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-semibold);color:var(--neutral-600);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(--neutral-800)}.chat-message-assistant{padding:0}.chat-message-assistant .chat-message-inner{background:var(--neutral-50);border-radius:var(--radius-md);padding:var(--space-md) var(--space-lg);border-left:3px solid var(--primary-700)}.chat-message-assistant .chat-role{font-size:var(--text-xs);font-weight:var(--weight-semibold);color:var(--primary-700);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-semibold);text-transform:uppercase;letter-spacing:.05em;margin-left:var(--space-sm)}.query-type-badge--general{background:var(--primary-100);color:var(--primary-700);border:1px solid var(--primary-200)}.query-type-badge--ambiguous{background:var(--accent-100);color:var(--accent-600);border:1px solid rgba(255,107,53,.25)}.query-type-badge--clear,.query-type-badge--search{background:var(--primary-100);color:var(--primary-700);border:1px solid var(--primary-200)}.chat-message-assistant .chat-content{font-size:var(--text-sm);line-height:1.65;color:var(--neutral-800)}.chat-message-clarification .chat-message-inner{border-left-color:var(--accent-500)}.chat-message-clarification .chat-role{color:var(--accent-600)}.chat-message-out-of-scope .chat-message-inner{border-left-color:var(--error)}.chat-message-out-of-scope .chat-role{color:var(--error)}.chat-message-loading .chat-message-inner{background:var(--neutral-50);border-radius:var(--radius-md);padding:var(--space-md) var(--space-lg);border-left:3px solid var(--neutral-400)}.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(--neutral-500);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(--neutral-500);font-style:italic}.streaming-cursor{display:inline-block;width:2px;height:1em;background:var(--neutral-600);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(--neutral-200);border-radius:var(--radius-md);color:var(--neutral-500);font-size:var(--text-xs);font-family:inherit;cursor:pointer;transition:all .15s ease}.sql-query-toggle:hover{background:var(--neutral-50);border-color:var(--neutral-300);color:var(--neutral-600)}.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);position:relative}.sql-query-dropdown.open .sql-query-content{display:block}.sql-copy-btn{position:absolute;top:8px;right:8px;display:flex;align-items:center;justify-content:center;width:28px;height:28px;background:transparent;border:none;border-radius:var(--radius-sm);color:var(--white);cursor:pointer;transition:all .15s ease;z-index:1;opacity:0}.sql-query-content:hover .sql-copy-btn{opacity:1}.sql-copy-btn:hover{transform:scale(1.1)}.sql-copy-btn:active{transform:scale(.95)}.sql-query-display{background:var(--neutral-900);color:var(--neutral-100);padding:var(--space-md);border-radius:var(--radius-md);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(--neutral-300);border-radius:var(--radius-md);color:var(--neutral-600);font-size:var(--text-sm);cursor:pointer;transition:all var(--transition-fast)}.chart-generate-btn:hover{background:var(--primary-50);border-color:var(--primary-300);color:var(--primary-700)}.chart-generate-btn:disabled{cursor:wait;opacity:.7}.chart-generate-btn.chart-btn-disabled{cursor:not-allowed;opacity:.5;background:var(--neutral-100);border-color:var(--neutral-200);color:var(--neutral-500)}.chart-generate-btn.chart-btn-disabled:hover{background:var(--neutral-100);border-color:var(--neutral-200);color:var(--neutral-500)}.chart-generate-btn.chart-btn-not-suitable{cursor:default;opacity:.85;background:var(--primary-50);border-color:var(--primary-200);color:var(--primary-700)}.chart-generate-btn.chart-btn-not-suitable:hover{background:var(--primary-50);border-color:var(--primary-200);color:var(--primary-700)}.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-wrapper{margin-top:var(--space-md)}.chart-container{background:var(--white);border-radius:var(--radius-md);padding:var(--space-md);min-height:300px;overflow:hidden;border:1px solid var(--neutral-200);box-sizing:border-box}.chart-container .plotly-graph-div{width:100%!important;max-width:calc(100% - 1px)!important;box-sizing:border-box}.chart-container .modebar{background:transparent!important}.chart-container .modebar-btn{color:var(--neutral-500)!important;opacity:.6;transition:opacity .15s ease}.chart-container .modebar-btn:hover{color:var(--neutral-800)!important;opacity:1}.turn-limit-notice{display:flex;align-items:flex-start;gap:var(--space-md);padding:var(--space-md) var(--space-lg);background:#dc262614;border-radius:var(--radius-md);border:1px solid rgba(220,38,38,.2);margin-top:var(--space-lg)}.turn-limit-notice svg{flex-shrink:0;color:var(--error);margin-top:2px}.turn-limit-text{flex:1}.turn-limit-text strong{display:block;font-size:var(--text-sm);color:var(--error);margin-bottom:var(--space-xs)}.turn-limit-text p{font-size:var(--text-sm);color:var(--neutral-600);margin:0}.query-input-section{background:var(--white);padding:var(--space-md);border:1px solid var(--neutral-200);border-radius:var(--radius-md);flex-shrink:0;box-shadow:var(--shadow-sm)}.query-input-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--space-sm)}.query-input-title{font-family:var(--font-display);font-size:var(--text-sm);font-weight:var(--weight-semibold);color:var(--neutral-800);letter-spacing:-.01em}.recommend-btn{background:transparent;border:none;color:var(--neutral-500);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(--primary-700)}.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:1.5px solid var(--neutral-300);border-radius:var(--radius-md);resize:none;font-family:inherit;transition:border-color var(--transition-fast),box-shadow var(--transition-fast);min-height:60px;background:var(--white);color:var(--neutral-800);line-height:1.6}.query-input-wrapper .prompt-input::placeholder{color:var(--neutral-400)}.query-input-wrapper .prompt-input:focus{outline:none;border-color:var(--primary-500);box-shadow:var(--ring-primary)}.send-btn{background:var(--primary-700);color:var(--white);border:none;width:42px;height:42px;border-radius:var(--radius-md);cursor:pointer;transition:background var(--transition-fast),transform var(--transition-fast);display:flex;align-items:center;justify-content:center;flex-shrink:0}.send-btn:hover{background:var(--primary-600);transform:translateY(-1px)}.send-btn:disabled{background:var(--neutral-400);cursor:not-allowed;transform:none}.send-btn.abort-mode{background:var(--error)}.send-btn.abort-mode:hover{background:#b91c1c}.send-btn.cooldown-mode{background:var(--neutral-500)}@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(--neutral-400);border-radius:3px}.conversation-container::-webkit-scrollbar-thumb:hover{background:var(--neutral-500)}.loading{display:none;text-align:center;padding:var(--space-xl);color:var(--neutral-500)}.loading.show{display:block}.spinner{border:2px solid var(--neutral-200);border-top:2px solid var(--neutral-500);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-family:var(--font-display);font-size:1.25rem;font-weight:700;color:var(--neutral-800);margin:1.5rem 0 .75rem;padding-bottom:.5rem;border-bottom:1px solid var(--neutral-200)}.markdown-content h2{font-family:var(--font-display);font-size:1.125rem;font-weight:700;color:var(--neutral-800);margin:1.25rem 0 .5rem}.markdown-content h3{font-family:var(--font-display);font-size:1rem;font-weight:600;color:var(--neutral-800);margin:1rem 0 .5rem}.markdown-content h4,.markdown-content h5,.markdown-content h6{font-family:var(--font-display);font-size:.9375rem;font-weight:600;color:var(--neutral-600);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(--neutral-600)}.markdown-content p:last-child{margin-bottom:0}.markdown-content strong{font-weight:600;color:var(--neutral-800)}.markdown-content em{font-style:italic;color:var(--neutral-600)}.markdown-content ul,.markdown-content ol{margin:.5rem 0 .75rem;padding-left:1.5rem;color:var(--neutral-600)}.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:var(--font-mono);font-size:.875em;background:var(--primary-50);color:var(--primary-700);padding:.15em .4em;border-radius:3px}.markdown-content pre{background:var(--neutral-100);border:1px solid var(--neutral-200);border-radius:var(--radius-md);padding:.875rem 1rem;margin:.75rem 0;overflow-x:auto}.markdown-content pre code{background:transparent;padding:0;color:var(--neutral-600);font-size:.8125rem;line-height:1.5}.markdown-content blockquote{margin:.75rem 0;padding:.5rem 0 .5rem 1rem;border-left:2px solid var(--primary-400);color:var(--neutral-500);font-style:italic}.markdown-content blockquote p{margin:0;color:inherit}.markdown-content hr{border:none;border-top:1px solid var(--neutral-200);margin:1.25rem 0}.markdown-content a{color:var(--primary-700);text-decoration:none;border-bottom:1px solid transparent;transition:border-color .15s ease}.markdown-content a:hover{border-bottom-color:var(--primary-400)}.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(--neutral-200)}.markdown-content th{font-weight:600;color:var(--neutral-800);background:var(--neutral-50)}.markdown-content td{color:var(--neutral-600)}.markdown-content tr:last-child td{border-bottom:none}.sql-result-display{margin-top:var(--space-md);max-width:100%;border-radius:var(--radius-md);border:1px solid var(--neutral-200);overflow:hidden}.table-wrapper{position:relative}.table-scroll-container{max-height:400px;overflow:auto}.table-toolbar{position:absolute;top:4px;right:8px;height:32px;display:flex;align-items:center;gap:2px;padding:2px 6px;opacity:0;visibility:hidden;transform:translateY(-4px);transition:all .2s ease;z-index:10;background:#ffffffbf;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border:1px solid rgba(255,255,255,.5);border-radius:20px;box-shadow:0 4px 16px #00000014,0 1px 3px #0000000d}.table-wrapper:hover .table-toolbar{opacity:1;visibility:visible;transform:translateY(0)}.table-toolbar-btn{display:inline-flex;align-items:center;justify-content:center;width:28px;height:28px;padding:0;background:transparent;border:none;border-radius:50%;color:var(--neutral-500);cursor:pointer;transition:all .18s ease}.table-toolbar-btn:hover{background:#fffc;color:var(--primary-600);transform:scale(1.1);box-shadow:0 2px 8px #0000001a}.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(--white);border:1px solid var(--neutral-200);border-radius:var(--radius-md);box-shadow:var(--shadow-lg);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(--neutral-600);cursor:pointer;transition:all .15s ease;text-align:left}.table-download-option:hover{background:var(--neutral-50);color:var(--neutral-800)}.table-download-option:first-child{border-radius:var(--radius-md) var(--radius-md) 0 0}.table-download-option:last-child{border-radius:0 0 var(--radius-md) var(--radius-md)}.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(--primary-800);color:var(--white);padding:var(--space-sm) var(--space-md);text-align:center;font-weight:var(--weight-semibold);border-bottom:2px solid var(--primary-700);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(--neutral-500);font-size:var(--text-xs);-webkit-user-select:none;user-select:none}th.row-number-col{background:var(--primary-800)!important;color:var(--white)!important}td.col-numeric{text-align:right}th.col-numeric,.sql-result-display th.col-numeric,.table-modal-table th.col-numeric{text-align:center}.decimal-part{color:var(--primary-700)}.sql-result-display td{padding:var(--space-sm) var(--space-md);border-bottom:1px solid var(--neutral-200);color:var(--neutral-600)}.sql-result-display tr:last-child td{border-bottom:none}.sql-result-display tbody tr:nth-child(odd) td{background:var(--white)}.sql-result-display tbody tr:nth-child(2n) td{background:var(--neutral-100)}.sql-result-display tbody tr:hover td{background:var(--primary-100)}.no-result{color:var(--neutral-500);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(--neutral-400);border-radius:3px}.table-scroll-container::-webkit-scrollbar-thumb:hover{background:var(--neutral-500)}.table-modal-overlay{position:fixed;inset:0;width:100vw;height:100vh;background:#0f172ab3;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(--white);border-radius:var(--radius-lg);width:90vw;height:85vh;max-width:1200px;max-height:800px;display:flex;flex-direction:column;box-shadow:var(--shadow-xl);overflow:hidden;border:none}.table-modal-header{padding:var(--space-md) var(--space-lg);border-bottom:1px solid var(--primary-800);display:flex;justify-content:space-between;align-items:center;flex-shrink:0;background:var(--primary-900)}.table-modal-title{font-family:var(--font-display);font-size:var(--text-base);font-weight:var(--weight-semibold);color:var(--white);margin:0;display:flex;align-items:center;gap:var(--space-sm)}.table-modal-title:before{content:"";width:4px;height:16px;background:var(--accent-500);border-radius:2px}.table-modal-close{background:none;border:none;color:var(--neutral-400);font-size:28px;font-weight:300;cursor:pointer;width:40px;height:40px;display:flex;align-items:center;justify-content:center;border-radius:var(--radius-md);transition:all .15s ease;line-height:1}.table-modal-close:hover{color:var(--white);background:var(--primary-800)}.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(--neutral-200);display:flex;justify-content:space-between;align-items:center;flex-shrink:0;background:var(--neutral-50)}.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(--neutral-800)}.table-modal-toolbar-item input[type=checkbox]{width:14px;height:14px;accent-color:var(--primary-700)}.table-modal-toolbar-item select{padding:var(--space-xs) var(--space-sm);border:1px solid var(--neutral-200);border-radius:var(--radius-sm);font-size:var(--text-xs);font-family:inherit;background:var(--white);color:var(--neutral-800);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(--white);border:1px solid var(--neutral-200);border-radius:var(--radius-md);font-size:var(--text-xs);font-family:inherit;color:var(--neutral-600);cursor:pointer;transition:all .15s ease}.table-modal-toolbar-btn:hover{background:var(--primary-50);border-color:var(--primary-300);color:var(--primary-700)}.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(--white);border:1px solid var(--neutral-200);border-radius:var(--radius-md);box-shadow:var(--shadow-lg);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(--neutral-600);text-align:left;cursor:pointer;transition:all .15s ease}.download-dropdown-menu button:hover{background:var(--neutral-50);color:var(--neutral-800)}.table-format-toolbar{display:flex;flex-direction:column;background:var(--white);border-bottom:1px solid var(--neutral-200);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(--primary-700);min-width:100px;padding:var(--space-xs) var(--space-sm);background:transparent;border-left:2px solid var(--primary-700);border-radius:0}.table-format-toolbar.disabled .format-toolbar-selected-col{color:var(--neutral-500);border-left-color:var(--neutral-200)}.format-toolbar-group{display:flex;align-items:center;gap:var(--space-xs)}.format-toolbar-label{font-size:var(--text-xs);color:var(--neutral-500);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(--neutral-500);cursor:pointer;transition:color .15s ease,background .15s ease;font-size:11px;font-weight:600;font-family:var(--font-mono)}.format-btn:hover:not(:disabled){background:var(--neutral-100);color:var(--neutral-800)}.format-btn.active{background:var(--primary-50);color:var(--primary-700)}.format-btn:disabled{color:var(--neutral-400);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(--neutral-200);border-radius:var(--radius-sm);font-size:var(--text-xs);font-family:inherit;background:var(--white);color:var(--neutral-600);cursor:pointer;min-width:90px;transition:border-color .15s ease}.format-toolbar-select:focus{outline:none;border-color:var(--primary-400)}.format-toolbar-select:disabled{background:var(--white);color:var(--neutral-400);cursor:not-allowed;border-color:var(--neutral-200)}.format-toolbar-divider{width:1px;height:18px;background:var(--neutral-200);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:0 var(--space-lg) var(--space-md);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(--primary-800);color:var(--white);padding:var(--space-sm) var(--space-md);text-align:center;font-weight:var(--weight-semibold);border-bottom:2px solid var(--primary-700);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(--neutral-200);color:var(--neutral-600)}.table-modal-table tr:last-child td{border-bottom:none}.table-modal-table tbody tr:nth-child(odd) td{background:var(--white)}.table-modal-table tbody tr:nth-child(2n) td{background:var(--neutral-100)}.table-modal-table tbody tr:hover td{background:var(--primary-100)}.table-modal-footer-info{padding:var(--space-sm) var(--space-lg);border-top:1px solid var(--neutral-200);font-size:var(--text-xs);color:var(--neutral-500);flex-shrink:0;background:var(--neutral-50)}.table-modal-table-container::-webkit-scrollbar{width:8px;height:8px}.table-modal-table-container::-webkit-scrollbar-track{background:var(--neutral-50)}.table-modal-table-container::-webkit-scrollbar-thumb{background:var(--neutral-400);border-radius:4px}.table-modal-table-container::-webkit-scrollbar-thumb:hover{background:var(--neutral-500)}.table-modal-header-actions{display:flex;align-items:center;gap:var(--space-xs)}.table-modal-header-actions .table-modal-toolbar-btn{width:32px;height:32px;padding:0;background:transparent;border:none;border-radius:var(--radius-md);color:var(--neutral-400);display:flex;align-items:center;justify-content:center}.table-modal-header-actions .table-modal-toolbar-btn:hover{background:var(--primary-800);color:var(--white)}.table-modal-header-actions .table-modal-toolbar-btn svg{opacity:1}.table-col-header{position:relative;cursor:pointer;-webkit-user-select:none;user-select:none;transition:background .15s ease}.table-col-header:hover{background:var(--primary-700)}.table-col-header.has-settings{color:var(--accent-400)}.table-col-header.has-settings:after{content:"";position:absolute;top:6px;right:6px;width:5px;height:5px;background:var(--accent-500);border-radius:50%}.table-col-header.selected{background:var(--primary-700)}.table-col-header.selected:before{content:"";position:absolute;bottom:0;left:0;right:0;height:2px;background:var(--accent-500)}.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(--accent-500)}.table-col-header.sort-desc .table-col-header-text:after{border-top:5px solid var(--accent-500)}.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(--neutral-400);cursor:pointer;transition:all .15s ease;flex-shrink:0}.table-col-filter-btn svg{width:12px;height:12px}.table-col-filter-btn:hover{background:var(--primary-700);color:var(--white)}.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(--accent-500);background:var(--primary-700)}.filter-dropdown{position:absolute;top:100%;left:0;background:var(--white);border:1px solid var(--neutral-200);border-radius:var(--radius-md);box-shadow:var(--shadow-lg);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(--neutral-200);font-size:var(--text-xs);font-weight:var(--weight-semibold);color:var(--neutral-600);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(--neutral-500);cursor:pointer;transition:color .15s ease}.filter-dropdown-close svg{width:10px;height:10px}.filter-dropdown-close:hover{color:var(--neutral-800)}.filter-dropdown-body{padding:0}.filter-dropdown-input{width:100%;padding:8px 10px;border:1px solid var(--neutral-200);border-radius:4px;font-size:var(--text-sm);font-family:inherit;background:var(--white);color:var(--neutral-800);transition:border-color .15s ease}.filter-dropdown-input:focus{outline:none;border-color:var(--primary-400)}.filter-dropdown-input::placeholder{color:var(--neutral-400)}.filter-dropdown-footer{display:flex;justify-content:flex-end;gap:6px;padding:8px 12px;border-top:1px solid var(--neutral-200)}.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(--neutral-200);color:var(--neutral-600)}.filter-clear-btn:hover{border-color:var(--neutral-300);color:var(--neutral-800)}.filter-apply-btn{background:var(--primary-700);border:1px solid var(--primary-700);color:var(--white)}.filter-apply-btn:hover{background:var(--primary-600);border-color:var(--primary-600)}.filter-dropdown-section{padding:10px 12px;border-bottom:1px solid var(--neutral-200)}.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(--neutral-600);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(--neutral-50);color:var(--neutral-800)}.filter-sort-btn.active{background:var(--primary-50);color:var(--primary-700)}.filter-sort-btn:disabled{cursor:not-allowed;color:var(--neutral-400)}.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(--neutral-50);border-radius:4px}.filter-mode-btn{flex:1;padding:5px 10px;background:transparent;border:none;border-radius:3px;color:var(--neutral-500);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(--neutral-600)}.filter-mode-btn.active{background:var(--white);color:var(--primary-700);box-shadow:var(--shadow-sm)}@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:#0f172a80;z-index:1000;justify-content:center!important;align-items:center!important;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.modal-overlay.show{display:flex!important}.modal-content{background:var(--white);border-radius:var(--radius-lg);width:90%;max-width:900px;max-height:85vh;display:flex;flex-direction:column;box-shadow:var(--shadow-xl);border:none;overflow:hidden}.modal-header{padding:var(--space-lg) var(--space-xl);border-bottom:1px solid var(--primary-800);display:flex;justify-content:space-between;align-items:center;background:var(--primary-900);border-radius:var(--radius-lg) var(--radius-lg) 0 0}.modal-header h2{margin:0;font-family:var(--font-display);font-size:var(--text-lg);font-weight:var(--weight-semibold);color:var(--white);letter-spacing:-.01em;display:flex;align-items:center;gap:var(--space-sm)}.modal-header h2:before{content:"";width:4px;height:18px;background:var(--accent-500);border-radius:2px}.modal-close{background:none;border:none;color:var(--neutral-400);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-md);transition:all var(--transition-fast)}.modal-close:hover{color:var(--white);background:var(--primary-800)}.modal-body{padding:var(--space-xl);overflow-y:auto;flex:1}.comment-table{margin-bottom:var(--space-xl)}.comment-table-header{font-family:var(--font-display);font-size:var(--text-sm);font-weight:var(--weight-semibold);color:var(--neutral-800);margin-bottom:var(--space-md);display:flex;align-items:center;padding-bottom:var(--space-sm);border-bottom:1px solid var(--neutral-200)}.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-semibold);color:var(--neutral-500);margin-bottom:var(--space-xs);text-transform:uppercase;letter-spacing:.04em}.comment-input{width:100%;padding:var(--space-sm) var(--space-md);border:1.5px solid var(--neutral-300);border-radius:var(--radius-md);font-size:var(--text-sm);font-family:inherit;background:var(--white);color:var(--neutral-800);transition:border-color var(--transition-fast),box-shadow var(--transition-fast)}.comment-input:focus{outline:none;border-color:var(--primary-500);box-shadow:var(--ring-primary)}.column-comment{margin-left:var(--space-lg);padding-left:var(--space-md);border-left:1px solid var(--neutral-200)}.column-comment-item{margin-bottom:var(--space-sm)}.modal-footer{padding:var(--space-lg) var(--space-xl);border-top:1px solid var(--neutral-200);display:flex;justify-content:flex-end;gap:var(--space-sm);background:var(--neutral-50);border-radius:0 0 var(--radius-lg) var(--radius-lg)}.modal-btn{padding:var(--space-sm) var(--space-lg);border:1.5px solid var(--neutral-300);border-radius:var(--radius-md);cursor:pointer;font-size:var(--text-sm);font-weight:var(--weight-semibold);transition:all var(--transition-fast);background:transparent}.modal-btn-cancel{color:var(--neutral-600)}.modal-btn-cancel:hover{border-color:var(--neutral-400);color:var(--neutral-800);background:var(--neutral-50)}.modal-btn-save{background:var(--primary-700);color:var(--white);border-color:var(--primary-700)}.modal-btn-save:hover{background:var(--primary-600);border-color:var(--primary-600);transform:translateY(-1px)}.modal-btn-save:disabled{background:var(--neutral-400);border-color:var(--neutral-400);color:var(--white);cursor:not-allowed;opacity:.6;transform:none}.examples-section{margin-bottom:var(--space-xl)}.examples-section:last-child{margin-bottom:0}.new-example-section{border-top:1px solid var(--neutral-200);padding-top:var(--space-xl)}.example-count{font-size:var(--text-sm);color:var(--neutral-500)}.sql-examples-container{width:100%;overflow-x:auto;border-radius:var(--radius-md)}.example-text{padding:var(--space-sm);font-size:var(--text-sm);color:var(--neutral-800);line-height:1.6;word-break:break-word}.example-query-text{font-family:var(--font-mono);background:var(--neutral-50);border-radius:var(--radius-md);padding:var(--space-sm)}.sql-examples-table{width:100%;border-collapse:collapse;margin:0}.sql-examples-table thead th{background:var(--primary-800);color:var(--white);padding:var(--space-sm) var(--space-md);text-align:left;font-weight:var(--weight-semibold);font-size:var(--text-xs);text-transform:uppercase;letter-spacing:.04em;border-bottom:2px solid var(--primary-700);position:sticky;top:0;z-index:10}.sql-examples-table tbody tr.example-row{border-bottom:1px solid var(--neutral-200)}.sql-examples-table tbody tr.example-row:hover{background:var(--neutral-50)}.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:1.5px solid var(--neutral-300);border-radius:var(--radius-md);font-size:var(--text-sm);font-family:inherit;resize:vertical;min-height:60px;background:var(--white);color:var(--neutral-800);transition:border-color var(--transition-fast),box-shadow var(--transition-fast)}.example-query{font-family:var(--font-mono)}.example-input:focus{outline:none;border-color:var(--primary-500);box-shadow:var(--ring-primary)}.example-input::placeholder{color:var(--neutral-400);font-style:italic}.validate-row-btn{background:transparent;color:var(--neutral-500);border:none;padding:var(--space-xs) var(--space-sm);border-radius:var(--radius-md);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(--primary-700)}.validate-row-btn:disabled{color:var(--neutral-400);cursor:not-allowed}.delete-row-btn{background:transparent;color:var(--neutral-400);border:none;padding:var(--space-xs) var(--space-sm);border-radius:var(--radius-md);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:var(--error)}.add-row{background:transparent}.add-row-cell{padding:var(--space-md);text-align:center}.add-row-btn{background:transparent;border:1px dashed var(--neutral-300);color:var(--neutral-500);padding:var(--space-sm) var(--space-lg);border-radius:var(--radius-md);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(--primary-400);color:var(--primary-700);background:var(--primary-50)}.add-icon{font-size:var(--text-lg);line-height:1}.modal-btn-validate{background:transparent;color:var(--neutral-600);border:1.5px solid var(--neutral-300)}.modal-btn-validate:hover{border-color:var(--neutral-400);color:var(--neutral-800)}.modal-btn-validate:disabled{color:var(--neutral-400);border-color:var(--neutral-200);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(--neutral-200);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-family:var(--font-display);font-size:var(--text-sm);font-weight:var(--weight-semibold);color:var(--neutral-800)}.knowledge-count{font-size:var(--text-sm);color:var(--neutral-500)}.knowledge-container{width:100%;overflow-x:auto;max-height:400px;overflow-y:auto;border-radius:var(--radius-md)}.knowledge-table{width:100%;border-collapse:collapse;margin:0}.knowledge-table thead th{background:var(--primary-800);color:var(--white);padding:var(--space-sm) var(--space-md);text-align:left;font-weight:var(--weight-semibold);font-size:var(--text-xs);text-transform:uppercase;letter-spacing:.04em;border-bottom:2px solid var(--primary-700);position:sticky;top:0;z-index:10}.knowledge-table tbody tr.knowledge-row{border-bottom:1px solid var(--neutral-200)}.knowledge-table tbody tr.knowledge-row:hover{background:var(--neutral-50)}.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(--neutral-500);font-size:var(--text-sm)}.knowledge-text{padding:var(--space-sm);font-size:var(--text-sm);color:var(--neutral-800);line-height:1.6;word-break:break-word}.knowledge-title{font-weight:var(--weight-medium);color:var(--neutral-800)}.knowledge-content{background:var(--neutral-50);border-radius:var(--radius-md);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(--neutral-500);font-style:italic}.knowledge-form{background:var(--neutral-50);padding:var(--space-lg);border-radius:var(--radius-md)}.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-semibold);color:var(--neutral-500);text-transform:uppercase;letter-spacing:.04em}.knowledge-input{width:100%;padding:var(--space-sm) var(--space-md);border:1.5px solid var(--neutral-300);border-radius:var(--radius-md);font-size:var(--text-sm);font-family:inherit;resize:vertical;background:var(--white);color:var(--neutral-800);transition:border-color var(--transition-fast),box-shadow var(--transition-fast)}.knowledge-input:focus{outline:none;border-color:var(--primary-500);box-shadow:var(--ring-primary)}.knowledge-input::placeholder{color:var(--neutral-400);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:1.5px solid var(--neutral-300);border-radius:var(--radius-md);cursor:pointer;font-size:var(--text-sm);font-weight:var(--weight-semibold);transition:all var(--transition-fast);background:transparent}.cancel-btn{color:var(--neutral-600)}.cancel-btn:hover{border-color:var(--neutral-400);color:var(--neutral-800)}.save-btn{background:var(--primary-700);color:var(--white);border-color:var(--primary-700)}.save-btn:hover{background:var(--primary-600);border-color:var(--primary-600)}.save-btn:disabled{background:var(--neutral-400);border-color:var(--neutral-400);color:var(--white);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-md);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(--neutral-500)}.edit-btn:hover{color:var(--neutral-800)}.delete-btn{color:var(--neutral-400)}.delete-btn:hover{color:var(--error)}.knowledge-container::-webkit-scrollbar{width:5px;height:5px}.knowledge-container::-webkit-scrollbar-track{background:transparent}.knowledge-container::-webkit-scrollbar-thumb{background:var(--neutral-400);border-radius:3px}.knowledge-container::-webkit-scrollbar-thumb:hover{background:var(--neutral-500)}.knowledge-content::-webkit-scrollbar{width:4px}.knowledge-content::-webkit-scrollbar-track{background:transparent}.knowledge-content::-webkit-scrollbar-thumb{background:var(--neutral-400);border-radius:2px}.chart-modal-overlay{display:flex;position:fixed;inset:0;width:100vw;height:100vh;background:#0f172ab3;z-index:9999;justify-content:center;align-items:center;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.chart-modal-content{background:var(--white);border-radius:var(--radius-lg);width:90vw;height:85vh;max-width:1400px;max-height:900px;display:flex;flex-direction:column;box-shadow:var(--shadow-xl);overflow:hidden;position:relative;border:none}.chart-modal-header{padding:var(--space-md) var(--space-lg);border-bottom:1px solid var(--primary-800);display:flex;justify-content:space-between;align-items:center;flex-shrink:0;background:var(--primary-900)}.chart-modal-title{font-family:var(--font-display);font-size:var(--text-base);font-weight:var(--weight-semibold);color:var(--white);display:flex;align-items:center;gap:var(--space-sm)}.chart-modal-title:before{content:"";width:4px;height:16px;background:var(--accent-500);border-radius:2px}.chart-modal-close{background:none;border:none;color:var(--neutral-400);font-size:28px;font-weight:300;cursor:pointer;width:40px;height:40px;display:flex;align-items:center;justify-content:center;border-radius:var(--radius-md);transition:all .15s ease;line-height:1;z-index:10}.chart-modal-close:hover{color:var(--white);background:var(--primary-800)}.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:var(--neutral-50)}.chart-modal-chart-container{flex:1;width:100%;height:100%;padding:16px;background:var(--neutral-50);overflow:hidden;position:relative}.chart-modal-settings{width:280px;border-left:1px solid var(--neutral-200);background:var(--white);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(--primary-800);font-family:var(--font-display);font-size:var(--text-sm);font-weight:var(--weight-semibold);color:var(--white);display:flex;align-items:center;gap:var(--space-xs);background:var(--primary-900)}.chart-settings-header svg{color:var(--neutral-400)}.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-semibold);color:var(--neutral-500);text-transform:uppercase;letter-spacing:.04em}.chart-setting-select{width:100%;padding:var(--space-sm) var(--space-md);border:1.5px solid var(--neutral-300);border-radius:var(--radius-md);font-size:var(--text-sm);font-family:inherit;background:var(--white);color:var(--neutral-800);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='%2364748b' 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(--neutral-400)}.chart-setting-select:focus{outline:none;border-color:var(--primary-500);box-shadow:var(--ring-primary)}.chart-type-option{display:flex;align-items:center;gap:var(--space-sm)}.chart-settings-divider{height:1px;background:var(--neutral-200);margin:var(--space-sm) 0}.chart-settings-info{font-size:var(--text-xs);color:var(--neutral-500);line-height:1.5;padding:var(--space-sm);background:var(--neutral-50);border-radius:var(--radius-md)}.chart-tabs{display:flex;border-bottom:1px solid var(--neutral-200);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(--neutral-500);cursor:pointer;transition:all .15s ease}.chart-tab:hover{color:var(--neutral-800)}.chart-tab.active{color:var(--neutral-800);border-bottom-color:var(--primary-700)}.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(--neutral-50);border-radius:var(--radius-md);border:1px solid var(--neutral-200)}.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(--neutral-200);border-radius:var(--radius-sm);font-size:var(--text-xs);font-family:inherit;background:var(--white);color:var(--neutral-800);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(--neutral-200);border-radius:var(--radius-sm);font-size:var(--text-xs);font-family:inherit;background:var(--white);color:var(--neutral-800);cursor:pointer}.chart-series-item .series-remove{width:24px;height:24px;padding:0;background:none;border:none;color:var(--neutral-500);cursor:pointer;display:flex;align-items:center;justify-content:center;border-radius:var(--radius-sm);flex-shrink:0;transition:all .15s ease}.chart-series-item .series-remove:hover{background:#dc26261a;color:var(--error)}.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(--neutral-300);border-radius:var(--radius-md);font-size:var(--text-xs);font-family:inherit;color:var(--neutral-500);cursor:pointer;transition:all .15s ease}.chart-add-series-btn:hover{border-color:var(--primary-400);color:var(--primary-700);background:var(--primary-50)}.chart-series-list::-webkit-scrollbar{width:4px}.chart-series-list::-webkit-scrollbar-track{background:transparent}.chart-series-list::-webkit-scrollbar-thumb{background:var(--neutral-400);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(--neutral-400);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(--neutral-200);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(--white);border:1px solid var(--neutral-200);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:.5rem var(--space-lg);border-bottom:1px solid var(--primary-800);flex-shrink:0;background:var(--primary-900);border-radius:var(--radius-md) var(--radius-md) 0 0}.erd-panel-header h3{font-family:var(--font-display);font-size:var(--text-base);font-weight:var(--weight-semibold);color:var(--white);margin:0;flex:1;text-align:center;letter-spacing:-.01em}.erd-panel-header h3:before{content:"";display:inline-block;width:8px;height:8px;background:var(--accent-500);border-radius:2px;margin-right:var(--space-sm);vertical-align:middle}.erd-back-btn,.erd-new-chat-btn{display:flex;align-items:center;justify-content:center;width:28px;height:28px;background:transparent;border:none;border-radius:var(--radius-md);color:var(--neutral-400);cursor:pointer;transition:all var(--transition-fast)}.erd-back-btn:hover,.erd-new-chat-btn:hover{color:var(--white);background:var(--primary-800)}.erd-back-btn:active,.erd-new-chat-btn:active{transform:scale(.95)}.erd-panel-content{flex:1;min-height:0;overflow:hidden;position:relative}.erd-toolbar{position:absolute;top:8px;right:8px;height:32px;display:flex;align-items:center;gap:2px;padding:2px 6px;opacity:0;visibility:hidden;transform:translateY(-4px);transition:all .2s ease;z-index:10;background:#ffffffbf;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border:1px solid rgba(255,255,255,.5);border-radius:20px;box-shadow:0 4px 16px #00000014,0 1px 3px #0000000d}.erd-panel-content:hover .erd-toolbar{opacity:1;visibility:visible;transform:translateY(0)}.erd-toolbar-btn{display:inline-flex;align-items:center;justify-content:center;width:28px;height:28px;padding:0;background:transparent;border:none;border-radius:50%;color:var(--neutral-500);cursor:pointer;transition:all .18s ease}.erd-toolbar-btn:hover{background:#fffc;color:var(--primary-600);transform:scale(1.1);box-shadow:0 2px 8px #0000001a}.erd-toolbar-btn:active{transform:scale(.95)}.erd-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100%;color:var(--neutral-500);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(--neutral-200);flex-shrink:0;background:var(--neutral-50)}.erd-modal-header h2{font-family:var(--font-display);font-size:var(--text-lg);font-weight:var(--weight-semibold);color:var(--neutral-800);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(--neutral-200);flex-shrink:0;background:var(--neutral-50)}.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(--neutral-600)}.erd-stats{font-size:var(--text-xs);color:var(--neutral-500)}.erd-table-node{background:var(--white);border:1px solid var(--neutral-300);border-radius:var(--radius-md);min-width:200px;max-width:300px;box-shadow:var(--shadow-sm);font-size:var(--text-xs)}.erd-table-header{background:var(--primary-800);padding:var(--space-sm) var(--space-md);border-bottom:1px solid var(--primary-700);border-radius:var(--radius-md) var(--radius-md) 0 0}.erd-table-name{font-family:var(--font-display);font-weight:var(--weight-semibold);color:var(--white);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(--neutral-50)}.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(--primary-100);color:var(--primary-800)}.erd-icon-fk{background:var(--accent-100);color:var(--accent-600)}.erd-column-name{color:var(--neutral-800);font-weight:var(--weight-medium);flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.erd-column-type{color:var(--neutral-500);font-size:10px;flex-shrink:0}.erd-handle{width:1px!important;height:1px!important;background:transparent!important;border:none!important;opacity:0!important;pointer-events:none!important}.erd-handle-left{left:0!important}.erd-handle-right{right:0!important}.react-flow__controls{box-shadow:var(--shadow-md)!important;border-radius:var(--radius-md)!important;border:1px solid var(--neutral-200)!important;overflow:hidden}.react-flow__controls-button{background:var(--white)!important;border-bottom:1px solid var(--neutral-200)!important;fill:var(--neutral-600)!important;transition:background var(--transition-fast),fill var(--transition-fast)!important}.react-flow__controls-button:hover{background:var(--neutral-50)!important;fill:var(--neutral-800)!important}.react-flow__controls-button:last-child{border-bottom:none!important}.react-flow__minimap{background:var(--neutral-50)!important;border-radius:var(--radius-md)!important;border:1px solid var(--neutral-200)!important;box-shadow:var(--shadow-sm)!important}.react-flow__edge-path{stroke:var(--neutral-500)!important;stroke-width:1.5!important}.react-flow__edge.selected .react-flow__edge-path,.react-flow__edge:hover .react-flow__edge-path{stroke:var(--primary-700)!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-md);color:var(--neutral-600);cursor:pointer;transition:all var(--transition-fast)}.erd-toggle-btn:hover,.erd-toggle-btn.active{color:var(--primary-700);background:var(--primary-50)}.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(--white)}.admin-login-box{background:var(--white);padding:var(--space-xl);width:100%;max-width:360px}.admin-login-box h1{font-family:var(--font-display);text-align:center;margin-bottom:var(--space-xl);color:var(--neutral-800);font-size:1.5rem;font-weight:700;letter-spacing:-.01em}.admin-form-group{margin-bottom:var(--space-lg)}.admin-form-group label{display:block;margin-bottom:var(--space-sm);color:var(--neutral-500);font-size:.75rem;font-weight:600;letter-spacing:.05em;text-transform:uppercase}.admin-form-group input{width:100%;padding:.75rem 1rem;background:var(--white);border:1.5px solid var(--neutral-300);border-radius:var(--radius-md);font-size:1rem;color:var(--neutral-800);transition:border-color .15s ease,box-shadow .15s ease}.admin-form-group input:focus{outline:none;border-color:var(--primary-500);box-shadow:var(--ring-primary)}.admin-form-group input::placeholder{color:var(--neutral-400)}.admin-btn-primary{width:100%;padding:.75rem 1.25rem;background:var(--primary-700);color:var(--white);border:none;border-radius:var(--radius-md);font-size:1rem;font-weight:600;cursor:pointer;transition:background-color .15s ease,transform .15s ease}.admin-btn-primary:hover{background:var(--primary-600);transform:translateY(-1px)}.admin-btn-back{width:100%;margin-top:var(--space-md);padding:.75rem 1.25rem;background:transparent;color:var(--neutral-500);border:1.5px solid var(--neutral-300);border-radius:var(--radius-md);font-size:.875rem;cursor:pointer;transition:all .15s ease}.admin-btn-back:hover{border-color:var(--neutral-400);color:var(--neutral-800)}.admin-btn-secondary{padding:.5rem 1rem;background:transparent;color:var(--neutral-600);border:1.5px solid var(--neutral-300);border-radius:var(--radius-md);font-size:.875rem;cursor:pointer;transition:all .15s ease}.admin-btn-secondary:hover{border-color:var(--neutral-400);color:var(--neutral-800)}.admin-btn-logout{padding:.5rem 1rem;background:transparent;color:var(--neutral-500);border:1.5px solid var(--neutral-300);border-radius:var(--radius-md);font-size:.875rem;cursor:pointer;transition:all .15s ease}.admin-btn-logout:hover{border-color:var(--neutral-400);color:var(--neutral-800)}.admin-error{color:var(--error);font-size:.875rem;margin-bottom:var(--space-md);text-align:center;padding:var(--space-sm);background:#dc26261a;border-radius:var(--radius-md)}.admin-container{background:var(--white);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(--neutral-200)}.admin-header h1{font-family:var(--font-display);color:var(--neutral-800);font-size:1.5rem;font-weight:700;letter-spacing:-.01em;text-align:left;margin-bottom:0}.admin-header h1:after{display:none}.admin-header-actions{display:flex;align-items:center;gap:var(--space-md)}.admin-user-email{color:var(--neutral-600);font-size:.875rem}.admin-section{margin-bottom:var(--space-xl)}.admin-section h2{font-family:var(--font-display);color:var(--neutral-800);font-size:1.125rem;font-weight:600;margin-bottom:var(--space-lg)}.admin-loading,.admin-empty{text-align:center;padding:var(--space-xl);color:var(--neutral-500)}.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(--neutral-200)}.admin-user-table th{color:var(--white);font-size:.75rem;font-weight:600;letter-spacing:.05em;text-transform:uppercase;background:var(--primary-800)}.admin-user-table td{color:var(--neutral-600);font-size:.875rem}.admin-user-table tr:hover{background:var(--neutral-50)}.admin-oauth-sub{font-family:var(--font-mono);font-size:.75rem;color:var(--neutral-500)}.admin-role-select{padding:.375rem .5rem;background:var(--white);border:1.5px solid var(--neutral-300);border-radius:var(--radius-md);font-size:.875rem;color:var(--neutral-800);cursor:pointer}.admin-role-select:focus{outline:none;border-color:var(--primary-500)}.admin-role-badge-root{display:inline-block;padding:.25rem .5rem;background:var(--accent-100);color:var(--accent-600);border-radius:var(--radius-sm);font-size:.75rem;font-weight:600;text-transform:uppercase}
