:root{--color-primary: #6366f1;--color-primary-hover: #4f46e5;--color-primary-light: #e0e7ff;--color-success: #10b981;--color-warning: #f59e0b;--color-error: #ef4444;--color-text: #111827;--color-text-secondary: #4b5563;--color-text-muted: #9ca3af;--color-bg: #f8fafc;--color-bg-elevated: #ffffff;--color-border: #e2e8f0;--color-border-light: #f1f5f9;--shadow-sm: 0 1px 2px 0 rgba(0, 0, 0, .03);--shadow: 0 1px 3px 0 rgba(0, 0, 0, .06), 0 1px 2px -1px rgba(0, 0, 0, .06);--shadow-md: 0 4px 6px -1px rgba(0, 0, 0, .07), 0 2px 4px -2px rgba(0, 0, 0, .05);--shadow-lg: 0 10px 15px -3px rgba(0, 0, 0, .08), 0 4px 6px -4px rgba(0, 0, 0, .04);--radius-sm: 6px;--radius: 10px;--radius-lg: 16px;--radius-xl: 20px}*{box-sizing:border-box}.app-layout{min-height:100vh;background:var(--color-bg)}.app-sider{background:linear-gradient(180deg,#0f172a,#020617)!important;box-shadow:var(--shadow-lg);position:fixed!important;left:0;top:0;bottom:0;z-index:100;height:100vh!important;overflow-y:auto;border-right:1px solid rgba(255,255,255,.05)}.app-sider .ant-layout-sider-children{display:flex;flex-direction:column;height:100%}.app-sider .logo{height:72px;display:flex;align-items:center;padding:0 20px;gap:14px;border-bottom:1px solid rgba(255,255,255,.06)}.app-sider .logo .logo-icon{width:42px;height:42px;background:linear-gradient(135deg,#6366f1,#8b5cf6);border-radius:12px;display:flex;align-items:center;justify-content:center;color:#fff;font-size:22px;flex-shrink:0;box-shadow:0 4px 12px #6366f166}.app-sider .logo .logo-text{font-size:22px;font-weight:700;color:#fff;letter-spacing:.05em;white-space:nowrap}.app-sider .ant-menu{background:transparent!important;border:none;padding:16px 12px;flex:1}.app-sider .ant-menu .ant-menu-item{display:flex!important;align-items:center!important;height:46px!important;line-height:1!important;margin:3px 0!important;padding:0 14px!important;border-radius:10px;color:#fff9!important;font-weight:500;font-size:14px;gap:12px;transition:all .2s ease}.app-sider .ant-menu .ant-menu-item .anticon{font-size:18px;min-width:18px;line-height:1;margin:0!important;opacity:.8}.app-sider .ant-menu .ant-menu-item span:not(.anticon){line-height:1}.app-sider .ant-menu .ant-menu-item:hover{background:#ffffff0f!important;color:#ffffffe6!important}.app-sider .ant-menu .ant-menu-item:hover .anticon{opacity:1}.app-sider .ant-menu .ant-menu-item.ant-menu-item-selected{background:linear-gradient(135deg,#6366f1,#8b5cf6)!important;color:#fff!important;box-shadow:0 4px 15px #6366f159}.app-sider .ant-menu .ant-menu-item.ant-menu-item-selected .anticon{opacity:1}.app-sider .ant-menu .ant-menu-item.ant-menu-item-selected:after{display:none}.app-sider .ant-menu .ant-menu-item-divider{background:#ffffff0f;margin:14px}.app-sider .sider-trigger{height:48px;display:flex;align-items:center;justify-content:center;color:#ffffff80;cursor:pointer;border-top:1px solid rgba(255,255,255,.08);transition:all .2s}.app-sider .sider-trigger:hover{color:#fff;background:#ffffff0d}.app-sider .sider-trigger .anticon{font-size:16px}.app-sider.ant-layout-sider-collapsed .logo{padding:0;justify-content:center}.app-sider.ant-layout-sider-collapsed .ant-menu{padding:12px 4px}.app-sider.ant-layout-sider-collapsed .ant-menu .ant-menu-item{padding:0!important;justify-content:center;width:calc(100% - 8px);margin:4px auto!important}.app-sider.ant-layout-sider-collapsed .ant-menu .ant-menu-item .anticon{margin:0!important}.app-sider.ant-layout-sider-collapsed .ant-menu .ant-menu-item span:not(.anticon){display:none}.app-sider.ant-layout-sider-collapsed .ant-menu .ant-menu-item-divider{margin:12px 8px}.main-layout{background:var(--color-bg);margin-left:260px;transition:margin-left .2s;min-height:100vh}.main-layout.sidebar-collapsed{margin-left:80px}.main-layout.no-sidebar{margin-left:0}.app-header{position:sticky;top:0;z-index:10;background:linear-gradient(135deg,#0f172a,#1e293b);padding-inline:32px;max-height:72px;line-height:72px;display:flex;align-items:center;justify-content:space-between;border-bottom:1px solid rgba(255,255,255,.05)}.app-header .header-left{display:flex;flex-direction:column;gap:4px}.app-header .header-left .page-title{margin:0;font-size:18px;font-weight:600;color:#fff;letter-spacing:-.01em;line-height:1.3}.app-header .header-left .page-subtitle{font-size:12px;color:#ffffff80;line-height:1.4;font-weight:400}.app-header .header-right{display:flex;align-items:center;gap:12px}.app-header .header-right .lang-switch{color:#ffffffb3;font-weight:600;font-size:12px;letter-spacing:.05em;padding:4px 10px;height:32px;border-radius:8px;background:#ffffff14;border:1px solid rgba(255,255,255,.12);transition:all .2s}.app-header .header-right .lang-switch:hover{color:#fff;background:#ffffff24;border-color:#fff3}.app-header .header-right .user-button{display:flex;align-items:center;padding:6px 14px 6px 6px;height:42px;border-radius:10px;transition:all .2s;background:#ffffff0d}.app-header .header-right .user-button:hover{background:#ffffff1a}.app-header .header-right .user-button .ant-avatar{background:linear-gradient(135deg,#6366f1,#8b5cf6)!important}.app-header .header-right .user-button .user-name{color:#fff;font-weight:500;font-size:13px}.app-content{margin:20px;padding:28px;background:var(--color-bg-elevated);border-radius:var(--radius-xl);min-height:calc(100vh - 112px);box-shadow:var(--shadow);border:1px solid var(--color-border-light)}.app-content.embed-mode{margin:0;border-radius:0;min-height:100vh;border:none}.app-content.auth-mode{margin:0;padding:0;background:transparent;min-height:100vh;box-shadow:none;border:none}.fade-enter-active,.fade-leave-active{transition:opacity .2s ease}.fade-enter-from,.fade-leave-to{opacity:0}.ant-btn-primary{box-shadow:0 2px 4px #2563eb33}.ant-btn-primary:hover{box-shadow:0 4px 8px #2563eb4d}.ant-card{border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);border:1px solid var(--color-border)}.ant-input,.ant-select-selector,.ant-picker{border-radius:var(--radius)!important}.ant-table .ant-table-thead>tr>th{background:#f9fafb;font-weight:600;color:var(--color-text)}.ant-tag{border-radius:6px;font-weight:500}.ant-modal-content{border-radius:var(--radius-lg);overflow:hidden}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:#d1d5db;border-radius:4px}::-webkit-scrollbar-thumb:hover{background:#9ca3af}html,body{width:100%;height:100%}input::-ms-clear,input::-ms-reveal{display:none}*,*:before,*:after{box-sizing:border-box}html{font-family:sans-serif;line-height:1.15;-webkit-text-size-adjust:100%;-ms-text-size-adjust:100%;-ms-overflow-style:scrollbar;-webkit-tap-highlight-color:rgba(0,0,0,0)}@-ms-viewport{width:device-width}body{margin:0}[tabindex="-1"]:focus{outline:none}hr{box-sizing:content-box;height:0;overflow:visible}h1,h2,h3,h4,h5,h6{margin-top:0;margin-bottom:.5em;font-weight:500}p{margin-top:0;margin-bottom:1em}abbr[title],abbr[data-original-title]{-webkit-text-decoration:underline dotted;text-decoration:underline;text-decoration:underline dotted;border-bottom:0;cursor:help}address{margin-bottom:1em;font-style:normal;line-height:inherit}input[type=text],input[type=password],input[type=number],textarea{-webkit-appearance:none}ol,ul,dl{margin-top:0;margin-bottom:1em}ol ol,ul ul,ol ul,ul ol{margin-bottom:0}dt{font-weight:500}dd{margin-bottom:.5em;margin-left:0}blockquote{margin:0 0 1em}dfn{font-style:italic}b,strong{font-weight:bolder}small{font-size:80%}sub,sup{position:relative;font-size:75%;line-height:0;vertical-align:baseline}sub{bottom:-.25em}sup{top:-.5em}pre,code,kbd,samp{font-size:1em;font-family:SFMono-Regular,Consolas,Liberation Mono,Menlo,Courier,monospace}pre{margin-top:0;margin-bottom:1em;overflow:auto}figure{margin:0 0 1em}img{vertical-align:middle;border-style:none}a,area,button,[role=button],input:not([type=range]),label,select,summary,textarea{touch-action:manipulation}table{border-collapse:collapse}caption{padding-top:.75em;padding-bottom:.3em;text-align:left;caption-side:bottom}input,button,select,optgroup,textarea{margin:0;color:inherit;font-size:inherit;font-family:inherit;line-height:inherit}button,input{overflow:visible}button,select{text-transform:none}button,html [type=button],[type=reset],[type=submit]{-webkit-appearance:button}button::-moz-focus-inner,[type=button]::-moz-focus-inner,[type=reset]::-moz-focus-inner,[type=submit]::-moz-focus-inner{padding:0;border-style:none}input[type=radio],input[type=checkbox]{box-sizing:border-box;padding:0}input[type=date],input[type=time],input[type=datetime-local],input[type=month]{-webkit-appearance:listbox}textarea{overflow:auto;resize:vertical}fieldset{min-width:0;margin:0;padding:0;border:0}legend{display:block;width:100%;max-width:100%;margin-bottom:.5em;padding:0;color:inherit;font-size:1.5em;line-height:inherit;white-space:normal}progress{vertical-align:baseline}[type=number]::-webkit-inner-spin-button,[type=number]::-webkit-outer-spin-button{height:auto}[type=search]{outline-offset:-2px;-webkit-appearance:none}[type=search]::-webkit-search-cancel-button,[type=search]::-webkit-search-decoration{-webkit-appearance:none}::-webkit-file-upload-button{font:inherit;-webkit-appearance:button}output{display:inline-block}summary{display:list-item}template{display:none}[hidden]{display:none!important}mark{padding:.2em;background-color:#feffe6}*{margin:0;padding:0;box-sizing:border-box}html,body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica Neue,Arial,sans-serif;font-size:14px;line-height:1.5}.monaco-editor{font-family:Fira Code,Monaco,Menlo,monospace!important}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:#f1f1f1;border-radius:4px}::-webkit-scrollbar-thumb{background:#c1c1c1;border-radius:4px}::-webkit-scrollbar-thumb:hover{background:#a1a1a1}.flex{display:flex}.flex-1{flex:1}.items-center{align-items:center}.justify-between{justify-content:space-between}.gap-8{gap:8px}.gap-16{gap:16px}.mt-16{margin-top:16px}.mb-16{margin-bottom:16px}.text-muted{color:#00000073}.query-editor-container{display:flex;flex-direction:column;height:calc(100vh - 160px);min-height:600px}.editor-wrapper{flex:1;display:flex;gap:16px;min-height:0}.editor-panel{flex:1;display:flex;flex-direction:column;min-width:0}.schema-panel{flex-shrink:0;border-left:1px solid #f0f0f0;padding-left:16px;overflow:auto}.results-panel{margin-top:16px;border-top:1px solid #f0f0f0;padding-top:16px;max-height:400px;overflow:auto}.results-table{width:100%}.results-table .ant-table-thead>tr>th{background:#fafafa;font-weight:600}.sql-highlight{font-family:Fira Code,Monaco,monospace;font-size:13px;background:#f5f5f5;padding:12px;border-radius:6px;overflow-x:auto}.info-card{background:#f6f8fa;border-radius:8px;padding:16px;margin-bottom:16px}.info-card .info-card-title{font-weight:600;margin-bottom:8px;color:#000000a6}.info-card .info-card-content{color:#000000a6}.status-badge{display:inline-flex;align-items:center;gap:6px;padding:2px 8px;border-radius:4px;font-size:12px}.status-badge.success{background:#f6ffed;color:#52c41a}.status-badge.error{background:#fff2f0;color:#ff4d4f}.status-badge.warning{background:#fffbe6;color:#faad14}.status-badge.info{background:#e6f7ff;color:#1890ff}.empty-state{text-align:center;padding:48px 24px;color:#00000073}.empty-state .anticon{font-size:48px;margin-bottom:16px;opacity:.5}.empty-state h3{margin-bottom:8px;color:#000000a6}.loading-overlay{position:absolute;top:0;right:0;bottom:0;left:0;background:#fffc;display:flex;align-items:center;justify-content:center;z-index:10}
