.db-home{height:calc(100vh - 72px);display:flex;flex-direction:column;overflow:hidden;padding:28px 32px 20px;gap:20px}.db-home-header{display:flex;align-items:center;gap:16px;flex-shrink:0}.db-home-title{display:flex;align-items:center;gap:14px;flex:1;color:#7c3aed}.db-home-title h1{font-size:22px;font-weight:700;color:#1e1b4b;margin:0;line-height:1.2}.db-home-title p{font-size:13px;color:#6b7280;margin:2px 0 0}.db-btn-new{display:flex;align-items:center;gap:6px;padding:9px 18px;background:#7c3aed;color:#fff;border:none;border-radius:8px;font-size:13px;font-weight:600;cursor:pointer;white-space:nowrap;flex-shrink:0;transition:background .15s,transform .1s}.db-btn-new:hover{background:#6d28d9;transform:translateY(-1px)}.db-processing-bar{display:flex;gap:12px;flex-wrap:wrap;flex-shrink:0}.db-processing-item{display:flex;align-items:center;gap:8px;padding:6px 14px;background:#f5f3ff;border:1px solid #ddd6fe;border-radius:20px;font-size:12px;font-weight:500;color:#7c3aed}.db-processing-pct{color:#9ca3af}.spin{animation:db-spin 1s linear infinite}@keyframes db-spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.db-empty{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:14px;color:#9ca3af;text-align:center}.db-empty h2{font-size:20px;font-weight:700;color:#1e1b4b;margin:0}.db-empty p{font-size:14px;margin:0}.db-grid{flex:1;display:flex;flex-wrap:wrap;gap:18px;align-content:flex-start;overflow:hidden}.db-card{width:200px;height:170px;background:#fff;border:1.5px solid #e5e7eb;border-radius:14px;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:12px;padding:20px 16px;cursor:pointer;position:relative;overflow:hidden;transition:border-color .2s,box-shadow .2s,transform .15s;-webkit-user-select:none;user-select:none}.db-card:hover{border-color:#a78bfa;box-shadow:0 6px 24px #7c3aed1f;transform:translateY(-3px)}.db-card:active{transform:translateY(0)}.db-card--failed{border-color:#fca5a5}.db-card--failed:hover{border-color:#f87171}.db-card-icon-wrap{width:56px;height:56px;border-radius:14px;background:#f5f3ff;color:#7c3aed;display:flex;align-items:center;justify-content:center;transition:background .2s}.db-card:hover .db-card-icon-wrap{background:#ede9fe}.db-card-body{display:flex;flex-direction:column;align-items:center;gap:4px;width:100%}.db-card-name{font-size:13px;font-weight:700;color:#1e1b4b;text-align:center;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:160px}.db-card-meta{display:flex;align-items:center;gap:8px}.db-card-tables{font-size:11px;color:#6b7280}.db-card-badge{font-size:10px;font-weight:700;padding:2px 8px;border-radius:10px}.badge--ok{background:#d1fae5;color:#065f46}.badge--failed{background:#fee2e2;color:#991b1b}.db-card-date{font-size:11px;color:#9ca3af}.db-card-cta{position:absolute;bottom:0;left:0;right:0;background:linear-gradient(to top,#7c3aede6,#7c3aed00);color:#fff;font-size:12px;font-weight:600;display:flex;align-items:center;justify-content:center;gap:4px;padding:10px;opacity:0;transition:opacity .2s}.db-card:hover .db-card-cta{opacity:1}.db-card--add{border-style:dashed;border-color:#d1d5db;background:#fafafa}.db-card--add:hover{border-color:#7c3aed;background:#f5f3ff;box-shadow:none;transform:translateY(-2px)}.db-card-add-inner{display:flex;flex-direction:column;align-items:center;gap:8px;color:#9ca3af;font-size:13px;font-weight:500}.db-card--add:hover .db-card-add-inner{color:#7c3aed}.infinite-canvas{position:relative;width:100%;height:100%;min-height:0;overflow:hidden;background:#f8f7ff;cursor:grab;-webkit-user-select:none;user-select:none;border-radius:12px}.infinite-canvas.is-panning{cursor:grabbing}.canvas-grid{position:absolute;inset:0;width:100%;height:100%;background-image:radial-gradient(circle,#c4b5fd 1px,transparent 1px);background-size:40px 40px;pointer-events:none}.canvas-viewport{position:absolute;top:0;left:0;transform-origin:0 0;will-change:transform}.canvas-node{position:absolute;cursor:default;filter:drop-shadow(0 4px 16px rgba(124,58,237,.1));transition:filter .2s}.canvas-node:hover{filter:drop-shadow(0 6px 20px rgba(124,58,237,.22));z-index:10}.canvas-controls{position:absolute;bottom:16px;right:16px;display:flex;align-items:center;gap:4px;background:#ffffffeb;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);border:1px solid #e5e7eb;border-radius:8px;padding:4px 8px;box-shadow:0 2px 8px #0000001a;z-index:100}.canvas-ctrl-btn{width:28px;height:28px;border:none;border-radius:6px;background:transparent;cursor:pointer;font-size:16px;color:#4b5563;display:flex;align-items:center;justify-content:center;transition:background .15s}.canvas-ctrl-btn:hover{background:#f3f0ff;color:#7c3aed}.canvas-zoom-label{font-size:12px;color:#6b7280;min-width:36px;text-align:center;font-weight:500}.canvas-empty{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center;pointer-events:none;text-align:center;gap:12px;color:#6b7280}.canvas-empty-icon{opacity:.55}.canvas-empty h3{font-size:20px;font-weight:700;color:#1e1b4b;margin:0}.canvas-empty p{font-size:14px;line-height:1.6;max-width:340px;margin:0}.canvas-empty-hints{display:flex;gap:20px;margin-top:8px}.canvas-empty-hints span{font-size:12px;background:#7c3aed14;color:#7c3aed;padding:4px 12px;border-radius:20px;font-weight:500}.bi-node{width:380px;background:#fff;border-radius:12px;border:1.5px solid #e5e7eb;overflow:hidden;font-family:inherit}.bi-node-header{display:flex;align-items:center;gap:8px;padding:10px 14px;border-bottom:1px solid #f3f4f6;background:#fafafa}.bi-node-icon{font-size:16px}.bi-node-title{flex:1;font-size:13px;font-weight:600;color:#1e293b;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.bi-node-type-badge{font-size:10px;font-weight:600;text-transform:uppercase;letter-spacing:.05em;padding:2px 7px;border-radius:10px;background:#ede9fe;color:#7c3aed;flex-shrink:0}.bi-chart-node{width:400px}.bi-chart-body{padding:12px;height:260px}.bi-chart-loading-body{display:flex;flex-direction:column;align-items:center;justify-content:center;height:200px;gap:14px;color:#6b7280}.bi-chart-spinner{width:36px;height:36px;border:3px solid #ede9fe;border-top-color:#7c3aed;border-radius:50%;animation:bi-spin .8s linear infinite}.bi-chart-loading-text{font-size:13px;font-weight:500;color:#7c3aed}@keyframes bi-spin{to{transform:rotate(360deg)}}.bi-table-node{width:480px}.bi-table-body{padding:0}.bi-table-scroll{overflow-x:auto;max-height:280px;overflow-y:auto}.bi-table{width:100%;border-collapse:collapse;font-size:12px}.bi-table th{padding:8px 10px;background:#f8fafc;text-align:left;font-weight:600;color:#374151;border-bottom:1px solid #e5e7eb;white-space:nowrap}.bi-table td{padding:7px 10px;border-bottom:1px solid #f3f4f6;color:#4b5563}.bi-table tr:last-child td{border-bottom:none}.bi-table tr:hover td{background:#fdf4ff}.bi-table-empty{padding:20px;text-align:center;color:#9ca3af;font-size:13px}.bi-table-more{padding:8px 10px;font-size:11px;color:#7c3aed;text-align:center;background:#faf5ff}.bi-insight-node{width:360px;border-color:#bfdbfe;background:#eff6ff}.bi-insight-body{padding:12px 14px}.bi-insight-body p{margin:0;font-size:13px;line-height:1.65;color:#1e293b;white-space:pre-wrap}.bi-metric-node{width:200px;border-color:#ddd6fe}.bi-metric-body{padding:14px 16px 16px;text-align:center}.bi-metric-value{font-size:36px;font-weight:800;color:#1e1b4b;line-height:1.1}.bi-metric-unit{font-size:14px;color:#6b7280;margin-top:2px}.bi-metric-change{margin-top:6px;font-size:13px;font-weight:600}.bi-metric-period{font-weight:400;color:#9ca3af}.bi-metric-desc{margin-top:6px;font-size:11px;color:#9ca3af}.cp-root{width:100%;height:100%;display:flex;flex-direction:column;background:#f1f0fb;overflow:hidden;font-family:inherit;min-height:0}.cp-topbar{height:48px;min-height:48px;flex-shrink:0;background:#fff;border-bottom:1px solid #e5e7eb;display:flex;align-items:center;gap:12px;padding:0 16px;z-index:50;box-shadow:0 1px 4px #0000000f}.cp-back{display:flex;align-items:center;gap:6px;background:none;border:1px solid #e5e7eb;border-radius:6px;padding:5px 12px;font-size:13px;font-weight:500;color:#374151;cursor:pointer;transition:all .15s;white-space:nowrap}.cp-back:hover{background:#f5f3ff;border-color:#7c3aed;color:#7c3aed}.cp-breadcrumb{display:flex;align-items:center;gap:6px;font-size:13px;color:#6b7280}.cp-db-name{font-weight:700;color:#1e1b4b;max-width:200px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.cp-bc-sep{color:#d1d5db}.cp-bc-page{color:#9ca3af}.cp-topbar-info{flex:1;display:flex;align-items:center;gap:12px}.cp-topbar-badge{background:#ede9fe;color:#7c3aed;font-size:11px;font-weight:600;padding:3px 10px;border-radius:20px}.cp-topbar-loading{display:flex;align-items:center;gap:6px;font-size:12px;color:#7c3aed;font-weight:500}.cp-sidebar-toggle{background:none;border:1px solid #e5e7eb;border-radius:6px;width:30px;height:30px;display:flex;align-items:center;justify-content:center;cursor:pointer;color:#6b7280;transition:all .15s}.cp-sidebar-toggle:hover{background:#f5f3ff;color:#7c3aed}.cp-body{flex:1;display:flex;overflow:hidden;min-height:0;height:0}.cp-sidebar{width:300px;min-width:300px;background:#fff;border-right:1px solid #e5e7eb;display:flex;flex-direction:column;overflow:hidden;transition:width .22s ease,min-width .22s ease,opacity .18s;z-index:10}.cp-sidebar--closed{width:0;min-width:0;opacity:0;pointer-events:none}.cp-section{padding:14px 16px}.cp-section-title{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:#9ca3af;margin-bottom:10px;display:flex;align-items:center;gap:6px}.cp-presets{display:flex;flex-direction:column;gap:6px}.cp-preset-btn{display:flex;align-items:center;gap:8px;padding:9px 12px;background:#fafafa;border:1px solid #e5e7eb;border-radius:8px;font-size:13px;font-weight:500;color:#374151;cursor:pointer;text-align:left;transition:all .15s;width:100%}.cp-preset-btn:hover:not(:disabled){background:#f5f3ff;border-color:#c4b5fd;color:#7c3aed}.cp-preset-btn:disabled{opacity:.5;cursor:not-allowed}.cp-divider{height:1px;background:#f3f4f6;margin:0 16px;flex-shrink:0}.cp-chat-section{flex:1;display:flex;flex-direction:column;min-height:0;overflow:hidden;padding-bottom:0}.cp-messages{flex:1;overflow-y:auto;padding:8px 0;display:flex;flex-direction:column;gap:10px;min-height:0;scrollbar-width:thin;scrollbar-color:#e5e7eb transparent}.cp-welcome{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:10px;padding:24px 8px;text-align:center;color:#9ca3af;flex:1}.cp-welcome svg{opacity:.4}.cp-welcome p{font-size:13px;line-height:1.6;margin:0}.cp-quick-qs{display:flex;flex-direction:column;gap:6px;width:100%;margin-top:8px}.cp-quick-q{padding:7px 10px;background:#f5f3ff;border:1px solid #ddd6fe;border-radius:8px;font-size:12px;color:#7c3aed;cursor:pointer;text-align:left;transition:all .15s}.cp-quick-q:hover{background:#ede9fe}.cp-msg{display:flex;gap:8px;padding:0 4px}.cp-msg--user{flex-direction:row-reverse}.cp-msg-avatar{width:24px;height:24px;border-radius:50%;background:#ede9fe;color:#7c3aed;display:flex;align-items:center;justify-content:center;flex-shrink:0;margin-top:2px}.cp-msg--user .cp-msg-avatar{background:#dbeafe;color:#2563eb}.cp-msg-body{max-width:220px;background:#f9fafb;border:1px solid #f3f4f6;border-radius:10px;padding:8px 10px;font-size:13px;color:#1e293b;line-height:1.55}.cp-msg--user .cp-msg-body{background:#ede9fe;border-color:#c4b5fd;color:#1e1b4b}.cp-msg--error .cp-msg-body{background:#fef2f2;border-color:#fecaca;color:#ef4444}.cp-msg-meta{font-size:11px;color:#7c3aed;margin-top:4px;font-weight:500}.cp-typing{display:flex;gap:4px;padding:2px 0}.cp-typing span{width:6px;height:6px;border-radius:50%;background:#7c3aed;opacity:.4;animation:cp-bounce 1.2s infinite}.cp-typing span:nth-child(2){animation-delay:.2s}.cp-typing span:nth-child(3){animation-delay:.4s}@keyframes cp-bounce{0%,80%,to{transform:scale(.8);opacity:.4}40%{transform:scale(1.2);opacity:1}}.cp-input-row{display:flex;gap:6px;padding:12px 16px;border-top:1px solid #f3f4f6;background:#fff;flex-shrink:0;align-items:flex-end}.cp-input{flex:1;border:1px solid #e5e7eb;border-radius:8px;padding:8px 12px;font-size:13px;outline:none;transition:border-color .15s;background:#fafafa;color:#1e293b;resize:none;overflow:hidden;min-height:36px;max-height:120px;line-height:1.5;font-family:inherit;display:block}.cp-input:focus{border-color:#7c3aed;background:#fff}.cp-input::placeholder{color:#9ca3af}.cp-send{width:36px;height:36px;border-radius:8px;background:#7c3aed;border:none;color:#fff;cursor:pointer;display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:background .15s}.cp-send:hover:not(:disabled){background:#6d28d9}.cp-send:disabled{opacity:.5;cursor:not-allowed}.cp-canvas-area{flex:1;min-width:0;overflow:hidden;position:relative}.spin{animation:canvas-spin 1s linear infinite}@keyframes canvas-spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.ai-dashboard{padding:24px;background:#f8f9fa;min-height:100vh}.dashboard-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:24px;padding:20px;background:#fff;border-radius:8px;box-shadow:0 2px 4px #0000001a}.dashboard-header h2{margin:0;font-size:24px;color:#333}.health-indicators{display:flex;gap:16px}.health-indicator{display:flex;align-items:center;gap:8px;padding:8px 12px;background:#f8f9fa;border-radius:6px}.indicator-dot{width:10px;height:10px;border-radius:50%;animation:pulse 2s infinite}.status-healthy .indicator-dot{background:#28a745}.status-unhealthy .indicator-dot{background:#ffc107}.status-offline .indicator-dot{background:#dc3545}.status-unknown .indicator-dot{background:#6c757d}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}.indicator-label{font-size:14px;font-weight:500;color:#495057}.dashboard-tabs{display:flex;gap:8px;margin-bottom:24px}.dashboard-tabs button{padding:12px 24px;border:none;background:#fff;border-radius:8px;font-size:14px;font-weight:500;color:#495057;cursor:pointer;transition:all .3s}.dashboard-tabs button:hover{background:#e9ecef}.dashboard-tabs button.active{background:#007bff;color:#fff}.dashboard-content{background:#fff;border-radius:8px;padding:24px;box-shadow:0 2px 4px #0000001a}.realtime-panel{min-height:500px}.panel-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px}.panel-header h3{margin:0;font-size:20px;color:#333}.alert{padding:12px 16px;border-radius:6px;margin-bottom:16px}.alert-danger{background:#f8d7da;color:#721c24;border:1px solid #f5c6cb}.alert-warning{background:#fff3cd;color:#856404;border:1px solid #ffeeba}.alert-info{background:#d1ecf1;color:#0c5460;border:1px solid #bee5eb}.predictions-list{display:flex;flex-direction:column;gap:12px;max-height:600px;overflow-y:auto}.empty-state{text-align:center;padding:60px 20px;color:#6c757d;font-size:16px}.prediction-card{padding:16px;border:1px solid #dee2e6;border-radius:6px;background:#f8f9fa;transition:transform .2s}.prediction-card:hover{transform:translate(4px);border-color:#007bff}.prediction-time{font-size:12px;color:#6c757d;margin-bottom:8px}.prediction-value{font-size:16px;color:#333;margin-bottom:4px}.prediction-value strong{color:#007bff;font-size:20px}.prediction-confidence{font-size:14px;color:#28a745}.connection-panel{max-width:600px}.form-group label{display:block;margin-bottom:8px;font-weight:500;color:#333}.form-group input,.form-group select{width:100%;padding:10px 12px;border:1px solid #ced4da;border-radius:6px;font-size:14px;transition:border-color .3s}.form-group input:focus,.form-group select:focus{outline:none;border-color:#007bff}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:16px}.button-group{display:flex;gap:12px;margin-top:24px}.btn-primary,.btn-secondary{padding:12px 24px;border:none;border-radius:6px;font-size:14px;font-weight:500;cursor:pointer;transition:all .3s}.btn-primary{background:#007bff;color:#fff}.btn-primary:hover{background:#0056b3}.btn-primary:disabled{background:#6c757d;cursor:not-allowed}.btn-secondary{background:#6c757d;color:#fff}.btn-secondary:hover{background:#5a6268}.schema-panel.empty{text-align:center;padding:60px 20px;color:#6c757d}.schema-summary{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:16px;margin-bottom:24px}.summary-card{padding:20px;background:linear-gradient(135deg,#667eea,#764ba2);border-radius:8px;color:#fff;text-align:center}.summary-card h4{font-size:32px;margin:0 0 8px}.summary-card p{margin:0;opacity:.9}.tables-list{display:flex;flex-direction:column;gap:16px}.table-card{padding:20px;border:1px solid #dee2e6;border-radius:8px;background:#f8f9fa}.table-card h4{margin:0 0 8px;color:#007bff}.table-description{color:#6c757d;font-size:14px;margin-bottom:16px}.columns-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(250px,1fr));gap:12px}.column-item{padding:12px;background:#fff;border-radius:6px;border:1px solid #dee2e6}.column-item strong{display:block;color:#333;margin-bottom:4px}.column-type{display:inline-block;padding:2px 8px;background:#e9ecef;border-radius:4px;font-size:12px;color:#495057}.column-description{margin:8px 0 0;font-size:12px;color:#6c757d}.training-panel{max-width:800px}.training-status{padding:20px;background:#f8f9fa;border-radius:8px;margin-bottom:24px}.training-status h4{margin:0 0 12px;color:#333}.training-status p{color:#6c757d;margin-bottom:16px}.metrics{margin-top:16px}.metrics h5{margin:0 0 8px;color:#333}.metrics pre{background:#fff;padding:12px;border-radius:6px;overflow-x:auto;font-size:12px;border:1px solid #dee2e6}.connection-form-container{background:linear-gradient(135deg,#667eea,#764ba2);border-radius:16px;padding:32px;box-shadow:0 10px 30px #0003;max-width:800px;margin:0 auto}.connection-form-header{text-align:center;margin-bottom:32px;color:#fff}.connection-form-header h2{font-size:28px;font-weight:700;margin-bottom:8px}.connection-form-header p{font-size:16px;opacity:.9}.connection-form{background:#fff;padding:32px;border-radius:12px}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:20px;margin-bottom:20px}.port-group{max-width:150px}.checkbox-group label{display:flex;align-items:center;gap:12px;cursor:pointer;font-weight:500}.checkbox-group input[type=checkbox]{width:20px;height:20px;cursor:pointer;accent-color:#667eea}.alert{padding:16px;border-radius:8px;margin-bottom:20px;font-weight:500;display:flex;align-items:center;gap:8px}.form-actions{display:flex;gap:12px;justify-content:flex-end;margin-top:24px}.btn{padding:12px 24px;border:none;border-radius:8px;font-size:15px;font-weight:600;cursor:pointer;display:flex;align-items:center;gap:8px;transition:all .3s ease}.btn:disabled{opacity:.6;cursor:not-allowed}.btn-primary:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 8px 20px #667eea66}.btn-secondary:hover:not(:disabled){background:#e5e7eb}@media (max-width: 768px){.form-row{grid-template-columns:1fr}.port-group{max-width:100%}.connection-form-container,.connection-form{padding:20px}}.table-list-container{background:#fff;border-radius:16px;padding:24px;box-shadow:0 4px 20px #00000014;margin-top:24px}.table-list-header{display:flex;align-items:center;gap:16px;margin-bottom:24px;padding-bottom:16px;border-bottom:2px solid #f3f4f6}.header-info{flex:1}.header-info h3{font-size:22px;font-weight:700;color:#1f2937;margin-bottom:4px}.table-count{font-size:14px;color:#6b7280;font-weight:500}.search-box{position:relative;flex:1;max-width:300px}.search-box i{position:absolute;left:12px;top:50%;transform:translateY(-50%);color:#9ca3af;font-size:18px}.search-box input{width:100%;padding:10px 12px 10px 40px;border:2px solid #e5e7eb;border-radius:8px;font-size:14px;transition:all .3s ease}.search-box input:focus{outline:none;border-color:#667eea;box-shadow:0 0 0 3px #667eea1a}.btn-refresh{background:#f3f4f6;color:#374151;padding:10px 16px;border:none;border-radius:8px;cursor:pointer;transition:all .3s ease}.btn-refresh:hover{background:#e5e7eb;transform:rotate(180deg)}.tables-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:16px}.table-card{background:linear-gradient(135deg,#f9fafb,#f3f4f6);border:2px solid #e5e7eb;border-radius:12px;padding:20px;cursor:pointer;transition:all .3s ease;display:flex;align-items:center;gap:16px}.table-card:hover{transform:translateY(-4px);box-shadow:0 8px 20px #0000001a;border-color:#667eea}.table-card.selected{background:linear-gradient(135deg,#667eea,#764ba2);border-color:#667eea;color:#fff}.table-icon{width:48px;height:48px;background:#667eea1a;border-radius:12px;display:flex;align-items:center;justify-content:center;font-size:24px;color:#667eea;flex-shrink:0}.table-card.selected .table-icon{background:#fff3;color:#fff}.table-info{flex:1}.table-info h4{font-size:16px;font-weight:700;color:#1f2937;margin-bottom:6px}.table-card.selected .table-info h4{color:#fff}.schema-badge{display:inline-block;padding:4px 12px;background:#e0e7ff;color:#4f46e5;border-radius:6px;font-size:12px;font-weight:600}.table-card.selected .schema-badge{background:#fff3;color:#fff}.table-arrow{font-size:20px;color:#9ca3af;transition:transform .3s ease}.table-card:hover .table-arrow{transform:translate(4px)}.table-card.selected .table-arrow{color:#fff}.table-checkbox{position:absolute;top:12px;left:12px;z-index:10}.table-checkbox input[type=checkbox]{width:20px;height:20px;cursor:pointer;accent-color:#667eea}.table-card.checked{border-color:#667eea;background:linear-gradient(135deg,#667eea0d,#764ba20d)}.table-card.checked .table-icon{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff}.loading-state,.error-state,.empty-state{text-align:center;padding:60px 20px}.spinner-large{width:48px;height:48px;border:4px solid #e5e7eb;border-top-color:#667eea;border-radius:50%;animation:spin .8s linear infinite;margin:0 auto 16px}.loading-state p,.error-state p,.empty-state p{font-size:16px;color:#6b7280;margin-top:8px}.error-state i,.empty-state i{font-size:64px;color:#e5e7eb;margin-bottom:16px}@media (max-width: 768px){.table-list-header{flex-direction:column;align-items:stretch}.search-box{max-width:100%}.tables-grid{grid-template-columns:1fr}}.table-schema-container{background:#fff;border-radius:16px;padding:24px;box-shadow:0 4px 20px #00000014;margin-top:24px}.schema-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:24px;padding-bottom:16px;border-bottom:2px solid #f3f4f6}.schema-title{display:flex;align-items:center;gap:16px}.schema-title>i{font-size:48px;color:#667eea}.schema-title h3{font-size:24px;font-weight:700;color:#1f2937;margin-bottom:4px}.row-count{display:flex;align-items:center;gap:6px;font-size:14px;color:#6b7280;font-weight:500}.btn-ai{background:linear-gradient(135deg,#f59e0b,#d97706);color:#fff;padding:12px 24px;border:none;border-radius:8px;font-size:15px;font-weight:600;cursor:pointer;display:flex;align-items:center;gap:8px;transition:all .3s ease}.btn-ai:hover{transform:translateY(-2px);box-shadow:0 8px 20px #f59e0b66}.columns-table-wrapper{overflow-x:auto;border-radius:12px;border:2px solid #f3f4f6}.columns-table{width:100%;border-collapse:collapse}.columns-table thead{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff}.columns-table th{padding:16px;text-align:left;font-weight:600;font-size:14px;text-transform:uppercase;letter-spacing:.5px}.columns-table tbody tr{border-bottom:1px solid #f3f4f6;transition:background .2s ease}.columns-table tbody tr:hover{background:#f9fafb}.columns-table tbody tr:last-child{border-bottom:none}.columns-table td{padding:16px;font-size:14px;color:#374151}.column-index{color:#9ca3af;font-weight:600;width:60px}.column-name{display:flex;align-items:center;gap:8px;font-weight:600;color:#1f2937}.column-name i{color:#667eea;font-size:16px}.data-type{display:inline-block;padding:6px 12px;border-radius:6px;font-weight:600;font-size:12px;text-transform:uppercase;letter-spacing:.5px}.type-number{background:#dbeafe;color:#1e40af}.type-string{background:#fef3c7;color:#92400e}.type-date{background:#e0e7ff;color:#4338ca}.type-boolean{background:#d1fae5;color:#065f46}.type-other{background:#f3f4f6;color:#6b7280}.nullable-cell{text-align:center}.badge{padding:6px 12px;border-radius:6px;font-weight:600;font-size:12px}.badge-yes{background:#d1fae5;color:#065f46}.badge-no{background:#fee2e2;color:#991b1b}.max-length{text-align:center;color:#6b7280;font-weight:500}.schema-footer{margin-top:24px;padding-top:16px;border-top:2px solid #f3f4f6}.schema-stats{display:flex;gap:32px;justify-content:center}.stat-item{display:flex;align-items:center;gap:8px;color:#6b7280;font-weight:600}.stat-item i{font-size:20px;color:#667eea}@media (max-width: 768px){.schema-header{flex-direction:column;align-items:flex-start;gap:16px}.schema-stats{flex-direction:column;gap:12px}.columns-table{font-size:12px}.columns-table th,.columns-table td{padding:12px 8px}}.ai-analysis-container{background:#fff;border-radius:16px;padding:24px;box-shadow:0 4px 20px #00000014;margin-top:24px}.ai-header{text-align:center;margin-bottom:32px}.ai-header h3{font-size:24px;font-weight:700;color:#1f2937;margin-bottom:8px}.ai-header p{font-size:16px;color:#6b7280}.ai-services-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(320px,1fr));gap:20px;margin-bottom:24px}.ai-service-card{background:linear-gradient(135deg,#f9fafb,#fff);border:3px solid #e5e7eb;border-radius:16px;padding:24px;transition:all .3s ease}.ai-service-card:hover{transform:translateY(-4px);box-shadow:0 12px 30px #00000026;border-color:var(--service-color)}.ai-service-card.active{border-color:var(--service-color);background:linear-gradient(135deg,#667eea0d,#764ba20d)}.service-header{margin-bottom:20px}.service-icon{width:64px;height:64px;background:var(--service-color);border-radius:16px;display:flex;align-items:center;justify-content:center;font-size:32px;color:#fff;margin-bottom:16px;box-shadow:0 8px 20px #00000026}.service-info h4{font-size:20px;font-weight:700;color:#1f2937;margin-bottom:8px}.service-info p{font-size:14px;color:#6b7280;line-height:1.6;margin-bottom:8px}.service-port{display:inline-block;padding:4px 12px;background:#f3f4f6;color:#374151;border-radius:6px;font-size:12px;font-weight:600}.btn-analyze{width:100%;padding:12px 24px;background:var(--service-color);color:#fff;border:none;border-radius:8px;font-size:15px;font-weight:600;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:8px;transition:all .3s ease}.btn-analyze:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 8px 20px #0003}.btn-analyze:disabled{opacity:.6;cursor:not-allowed}.analysis-error{background:#fee2e2;border:2px solid #ef4444;border-radius:12px;padding:20px;display:flex;align-items:center;gap:12px;color:#991b1b;margin-bottom:24px}.analysis-error i{font-size:24px}.analysis-results{background:#f9fafb;border:2px solid #e5e7eb;border-radius:12px;padding:24px;margin-top:24px}.results-header{display:flex;align-items:center;gap:12px;margin-bottom:16px;color:#10b981}.results-header i{font-size:32px}.results-header h4{font-size:20px;font-weight:700}.analysis-results pre{background:#fff;border:1px solid #e5e7eb;border-radius:8px;padding:16px;overflow-x:auto;font-size:13px;line-height:1.6;color:#374151}.no-data-warning{background:#fef3c7;border:2px solid #f59e0b;border-radius:12px;padding:20px;display:flex;align-items:center;gap:12px;color:#92400e;margin-top:24px}.no-data-warning i{font-size:24px}@media (max-width: 768px){.ai-services-grid{grid-template-columns:1fr}}.data-analysis-page{min-height:100vh;background:linear-gradient(135deg,#667eea,#764ba2);padding:32px}.page-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:32px}.header-content h1{font-size:36px;font-weight:700;color:#fff;margin-bottom:8px}.header-content p{font-size:18px;color:#ffffffe6}.btn-reset{background:#fff3;color:#fff;border:2px solid white;padding:12px 24px;border-radius:8px;font-size:15px;font-weight:600;cursor:pointer;display:flex;align-items:center;gap:8px;transition:all .3s ease;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.btn-reset:hover{background:#fff;color:#667eea;transform:translateY(-2px);box-shadow:0 8px 20px #ffffff4d}.progress-steps{display:flex;align-items:center;justify-content:center;margin-bottom:48px;background:#ffffff1a;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);padding:24px;border-radius:16px}.step{display:flex;flex-direction:column;align-items:center;gap:8px;opacity:.5;transition:all .3s ease}.step.active{opacity:1}.step.completed .step-number{background:#10b981;color:#fff}.step-number{width:48px;height:48px;background:#fff3;border:3px solid white;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:20px;font-weight:700;color:#fff;transition:all .3s ease}.step.active .step-number{background:#fff;color:#667eea;transform:scale(1.1);box-shadow:0 8px 20px #fff6}.step-label{font-size:14px;font-weight:600;color:#fff;text-align:center}.step-line{width:80px;height:3px;background:#ffffff4d;margin:0 16px}.page-content{max-width:1400px;margin:0 auto}.connection-info-banner{background:#10b98133;border:2px solid rgba(16,185,129,.5);padding:16px 24px;border-radius:12px;display:flex;align-items:center;gap:12px;color:#fff;font-weight:600;margin-bottom:24px;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);animation:slideInDown .5s ease}.connection-info-banner i{font-size:24px;color:#10b981}@keyframes slideInDown{0%{opacity:0;transform:translateY(-20px)}to{opacity:1;transform:translateY(0)}}.page-footer{margin-top:48px;padding:24px;background:#ffffff1a;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-radius:16px;max-width:1400px;margin-left:auto;margin-right:auto}.footer-info{display:flex;justify-content:center;gap:48px}.info-item{display:flex;align-items:center;gap:12px;color:#fff;font-weight:600}.info-item i{font-size:24px}.status-dot{width:12px;height:12px;border-radius:50%;animation:pulse 2s ease-in-out infinite}.status-dot.online{background:#10b981;box-shadow:0 0 12px #10b981}@keyframes pulse{0%,to{opacity:1;transform:scale(1)}50%{opacity:.7;transform:scale(1.2)}}@media (max-width: 768px){.data-analysis-page{padding:16px}.page-header{flex-direction:column;align-items:flex-start;gap:16px}.header-content h1{font-size:24px}.header-content p{font-size:14px}.progress-steps{flex-wrap:wrap;padding:16px}.step-line{width:40px;margin:0 8px}.step-label{font-size:12px}.footer-info{flex-direction:column;gap:16px}}.agent-query-page{display:flex;flex-direction:column;height:100vh;background:#f8f9fa}.agent-header{background:#fff;border-bottom:1px solid #e5e7eb;padding:16px 24px;flex-shrink:0}.agent-header-content{display:flex;justify-content:space-between;align-items:center;gap:20px;max-width:1600px;margin:0 auto}.agent-title{display:flex;align-items:center;gap:12px}.agent-title svg{color:#6366f1;flex-shrink:0}.agent-title h1{font-size:1.5rem;font-weight:700;margin:0;color:#1a1a2e}.agent-title p{font-size:.85rem;color:#6b7280;margin:2px 0 0}.header-connection-selector{display:flex;align-items:center;gap:8px}.connection-select-compact{padding:8px 14px;border:1.5px solid #e5e7eb;border-radius:8px;font-size:.9rem;color:#374151;background:#fff;cursor:pointer;transition:border-color .2s,background .2s;min-width:250px}.connection-select-compact:focus{outline:none;border-color:#6366f1;background:#f9fafb}.btn-analyze-compact{display:flex;align-items:center;justify-content:center;padding:8px 12px;background:linear-gradient(135deg,#6366f1,#8b5cf6);color:#fff;border:none;border-radius:8px;cursor:pointer;transition:transform .2s,box-shadow .2s}.btn-analyze-compact:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 4px 12px #6366f14d}.btn-analyze-compact:disabled{opacity:.6;cursor:not-allowed}.config-status-bar{margin-top:12px;max-width:1600px;margin-left:auto;margin-right:auto}.status-msg{display:inline-flex;align-items:center;gap:8px;padding:8px 14px;border-radius:6px;font-size:.85rem;font-weight:500}.status-msg.analyzing{background:#eff6ff;color:#2563eb}.status-msg.ready{background:#ecfdf5;color:#059669}.status-msg.failed{background:#fef2f2;color:#dc2626}.retry-btn{display:inline-flex;align-items:center;gap:4px;padding:4px 8px;background:transparent;border:1px solid currentColor;border-radius:4px;color:inherit;cursor:pointer;font-size:.75rem;margin-left:8px}.agent-error-banner{display:flex;align-items:center;gap:10px;padding:12px 24px;background:#fef2f2;border-bottom:1px solid #fecaca;color:#dc2626;flex-shrink:0}.agent-error-banner button{margin-left:auto;background:none;border:none;cursor:pointer;color:#dc2626;font-size:1.1rem}.agent-workspace{display:grid;grid-template-columns:450px 1fr;gap:0;flex:1;overflow:hidden;max-width:1600px;margin:0 auto;width:100%}.chat-panel{display:flex;flex-direction:column;background:#fff;border-right:1px solid #e5e7eb;height:100%}.chat-messages{flex:1;overflow-y:auto;padding:20px;display:flex;flex-direction:column;gap:16px}.chat-messages::-webkit-scrollbar{width:6px}.chat-messages::-webkit-scrollbar-thumb{background:#d1d5db;border-radius:3px}.chat-welcome{display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;padding:40px 20px;color:#6b7280;height:100%}.chat-welcome svg{color:#9ca3af;margin-bottom:16px}.chat-welcome h3{font-size:1.2rem;color:#374151;margin:0 0 8px}.chat-welcome p{font-size:.9rem;margin:0}.welcome-suggestions{margin-top:24px;width:100%;max-width:350px}.suggestion-label{font-size:.8rem;color:#9ca3af;font-weight:600;display:block;margin-bottom:8px}.suggestion-btn{display:block;width:100%;padding:10px 14px;margin-bottom:8px;background:#f3f4f6;border:1px solid #e5e7eb;border-radius:8px;font-size:.85rem;color:#374151;text-align:left;cursor:pointer;transition:all .2s}.suggestion-btn:hover{background:#ede9fe;border-color:#c4b5fd;color:#6366f1}.chat-message{display:flex;gap:12px;padding:12px;border-radius:8px;transition:background .2s;cursor:pointer}.chat-message:hover{background:#f9fafb}.chat-message.user{flex-direction:row}.chat-message.ai{flex-direction:row;background:#f0f9ff}.chat-message.ai:hover{background:#e0f2fe}.message-avatar{width:36px;height:36px;border-radius:50%;display:flex;align-items:center;justify-content:center;flex-shrink:0;font-size:1.1rem}.chat-message.user .message-avatar{background:#dbeafe;color:#2563eb}.chat-message.ai .message-avatar{background:#ede9fe;color:#7c3aed}.message-content{flex:1}.message-text{font-size:.9rem;color:#1f2937;line-height:1.5;word-wrap:break-word}.message-meta{display:flex;align-items:center;gap:6px;margin-top:6px;font-size:.75rem;color:#6b7280}.typing-indicator{display:flex;gap:4px;padding:4px 0}.typing-indicator span{width:8px;height:8px;border-radius:50%;background:#9ca3af;animation:typingDot 1.4s infinite ease-in-out}.typing-indicator span:nth-child(2){animation-delay:.2s}.typing-indicator span:nth-child(3){animation-delay:.4s}@keyframes typingDot{0%,80%,to{transform:scale(.7);opacity:.4}40%{transform:scale(1);opacity:1}}.chat-input-form{padding:16px;border-top:1px solid #e5e7eb;background:#fff;flex-shrink:0}.chat-input-wrapper{display:flex;gap:0;background:#f9fafb;border:2px solid #e5e7eb;border-radius:10px;overflow:hidden;transition:border-color .2s,box-shadow .2s}.chat-input-wrapper:focus-within{border-color:#6366f1;box-shadow:0 0 0 3px #6366f11a;background:#fff}.chat-input{flex:1;padding:12px 16px;border:none;background:transparent;font-size:.95rem;color:#1f2937}.chat-input:focus{outline:none}.chat-input::placeholder{color:#9ca3af}.chat-submit-btn{display:flex;align-items:center;justify-content:center;padding:12px 16px;background:linear-gradient(135deg,#6366f1,#8b5cf6);color:#fff;border:none;cursor:pointer;transition:background .2s}.chat-submit-btn:hover:not(:disabled){background:linear-gradient(135deg,#4f46e5,#7c3aed)}.chat-submit-btn:disabled{opacity:.5;cursor:not-allowed}.results-panel{display:flex;flex-direction:column;background:#fafafa;overflow-y:auto;padding:24px}.results-panel::-webkit-scrollbar{width:8px}.results-panel::-webkit-scrollbar-thumb{background:#d1d5db;border-radius:4px}.results-header{margin-bottom:20px}.results-header h3{font-size:1.3rem;color:#1f2937;margin:0 0 6px}.result-question{font-size:.9rem;color:#6b7280;font-style:italic}.result-summary{padding:16px;background:#f0fdf4;border:1px solid #bbf7d0;border-radius:8px;margin-bottom:20px;font-size:.95rem;color:#15803d;line-height:1.6}.charts-container{display:flex;flex-direction:column;gap:20px;margin-bottom:24px}.agent-chart-card{background:#fff;border:1px solid #e5e7eb;border-radius:10px;padding:20px;box-shadow:0 1px 3px #0000000d}.chart-wrapper{height:350px;position:relative}.insights-section{margin-top:20px}.insights-section h4{font-size:1.1rem;color:#1f2937;margin:0 0 12px}.insights-list{display:flex;flex-direction:column;gap:10px}.insight-item{display:flex;gap:12px;padding:14px;border-radius:8px;border:1px solid #e5e7eb;background:#fff}.insight-item.insight-success{background:#f0fdf4;border-color:#bbf7d0}.insight-item.insight-warning{background:#fffbeb;border-color:#fde68a}.insight-item.insight-info{background:#eff6ff;border-color:#bfdbfe}.insight-item.insight-metric{background:#faf5ff;border-color:#e9d5ff}.insight-icon{font-size:1.2rem;flex-shrink:0}.insight-item strong{display:block;font-size:.9rem;color:#1f2937;margin-bottom:4px}.insight-item p{font-size:.85rem;color:#6b7280;margin:0;line-height:1.4}.results-placeholder{display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;height:100%;color:#9ca3af;padding:40px 20px}.results-placeholder svg{margin-bottom:16px}.results-placeholder h3{font-size:1.2rem;color:#6b7280;margin:0 0 8px}.results-placeholder p{font-size:.9rem;margin:0}.agent-placeholder{display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;height:calc(100vh - 120px);color:#9ca3af;padding:40px 20px}.agent-placeholder svg{color:#d1d5db;margin-bottom:20px}.agent-placeholder h3{font-size:1.3rem;color:#6b7280;margin:0 0 8px}.agent-placeholder p{font-size:.95rem;margin:0}.spin{animation:spin 1s linear infinite}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@media (max-width: 1024px){.agent-workspace{grid-template-columns:1fr;grid-template-rows:60vh 1fr}.chat-panel{border-right:none;border-bottom:1px solid #e5e7eb}.results-panel{border-top:1px solid #e5e7eb}}@media (max-width: 768px){.agent-header-content{flex-direction:column;align-items:flex-start;gap:12px}.header-connection-selector{width:100%}.connection-select-compact{min-width:0;flex:1}.agent-workspace{grid-template-rows:50vh 1fr}.chart-wrapper{height:280px}}.sql-connection-settings{padding:24px 0}.settings-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:32px;padding-bottom:24px;border-bottom:2px solid #e5e7eb}.page-title{display:flex;align-items:center;gap:12px;font-size:28px;font-weight:700;color:#1f2937;margin-bottom:8px}.page-title i{color:#667eea}.text-muted{color:#6b7280;font-size:16px}.btn{padding:10px 20px;border:none;border-radius:8px;font-size:14px;font-weight:600;cursor:pointer;display:inline-flex;align-items:center;gap:8px;transition:all .3s ease}.btn-primary{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff}.btn-primary:hover{transform:translateY(-2px);box-shadow:0 8px 20px #667eea66}.btn-secondary{background:#f3f4f6;color:#374151}.btn-secondary:hover{background:#e5e7eb}.btn-outline-primary{background:#fff;color:#667eea;border:2px solid #667eea}.btn-outline-primary:hover{background:#667eea;color:#fff}.btn-outline-danger{background:#fff;color:#ef4444;border:2px solid #ef4444}.btn-outline-danger:hover{background:#ef4444;color:#fff}.btn-sm{padding:6px 12px;font-size:13px}.btn-group{display:flex;gap:12px}.alert{padding:16px;border-radius:8px;margin-bottom:24px;font-weight:500;display:flex;align-items:center;gap:8px}.alert-success{background-color:#d1fae5;color:#065f46;border:2px solid #10b981}.alert-error{background-color:#fee2e2;color:#991b1b;border:2px solid #ef4444}.connection-form-card{background:#fff;border:2px solid #e5e7eb;border-radius:12px;margin-bottom:32px;box-shadow:0 4px 20px #00000014}.card-header{padding:20px 24px;border-bottom:2px solid #f3f4f6}.card-header h3{font-size:20px;font-weight:700;color:#1f2937;margin:0}.card-body{padding:24px}.card-footer{padding:20px 24px;border-top:2px solid #f3f4f6;display:flex;justify-content:space-between;align-items:center}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:20px}.form-group{margin-bottom:20px}.form-group-small{max-width:150px}.form-group label{display:flex;align-items:center;gap:8px;font-weight:600;color:#374151;margin-bottom:8px;font-size:14px}.form-group label i{font-size:18px;color:#667eea}.form-group input[type=text],.form-group input[type=password],.form-group input[type=number]{width:100%;padding:12px 16px;border:2px solid #e5e7eb;border-radius:8px;font-size:15px;transition:all .3s ease}.form-group input:focus{outline:none;border-color:#667eea;box-shadow:0 0 0 3px #667eea1a}.checkbox-label{display:flex;align-items:center;gap:12px;cursor:pointer;font-weight:500}.checkbox-label input[type=checkbox]{width:20px;height:20px;cursor:pointer;accent-color:#667eea}.spinner{width:16px;height:16px;border:2px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:spin .6s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.connections-list{margin-top:32px}.empty-state{text-align:center;padding:80px 20px;background:#fff;border:2px dashed #e5e7eb;border-radius:12px}.empty-state i{font-size:64px;color:#e5e7eb;margin-bottom:16px}.empty-state h3{font-size:20px;font-weight:700;color:#6b7280;margin-bottom:8px}.empty-state p{font-size:14px;color:#9ca3af}.connections-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(350px,1fr));gap:20px}.connection-card{background:#fff;border:2px solid #e5e7eb;border-radius:12px;padding:20px;transition:all .3s ease}.connection-card:hover{transform:translateY(-4px);box-shadow:0 8px 20px #0000001a;border-color:#667eea}.connection-header{display:flex;align-items:flex-start;gap:16px;margin-bottom:16px;padding-bottom:16px;border-bottom:2px solid #f3f4f6}.connection-icon{width:48px;height:48px;background:linear-gradient(135deg,#667eea,#764ba2);border-radius:12px;display:flex;align-items:center;justify-content:center;font-size:24px;color:#fff;flex-shrink:0}.connection-info{flex:1;min-width:0}.connection-info h4{font-size:18px;font-weight:700;color:#1f2937;margin-bottom:4px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.connection-database{display:inline-block;padding:4px 12px;background:#e0e7ff;color:#4f46e5;border-radius:6px;font-size:12px;font-weight:600}.connection-details{margin-bottom:16px}.detail-item{display:flex;align-items:center;gap:8px;margin-bottom:8px;color:#6b7280;font-size:14px}.detail-item i{color:#667eea;font-size:16px}.connection-actions{display:flex;gap:8px;padding-top:16px;border-top:2px solid #f3f4f6}.connection-actions .btn{flex:1}@media (max-width: 768px){.settings-header{flex-direction:column;align-items:flex-start;gap:16px}.form-row{grid-template-columns:1fr}.form-group-small{max-width:100%}.connections-grid{grid-template-columns:1fr}.card-footer{flex-direction:column;gap:12px}.btn-group{width:100%;flex-direction:column}}.modal-overlay{position:fixed;inset:0;background:#000000b3;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:9999;padding:24px;animation:fadeIn .3s ease}.modal-container{background:#fff;border-radius:16px;max-width:1400px;width:100%;max-height:90vh;display:flex;flex-direction:column;box-shadow:0 20px 60px #0000004d;animation:slideUp .3s ease}@keyframes slideUp{0%{opacity:0;transform:translateY(40px)}to{opacity:1;transform:translateY(0)}}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:24px 32px;border-bottom:2px solid #e5e7eb}.modal-header h2{display:flex;align-items:center;gap:12px;font-size:24px;font-weight:700;color:#1f2937;margin:0}.modal-header h2 i{color:#667eea}.modal-close{background:none;border:none;width:40px;height:40px;border-radius:50%;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .3s ease;color:#6b7280;font-size:24px}.modal-close:hover{background:#f3f4f6;color:#1f2937}.modal-body{flex:1;overflow-y:auto;padding:32px}.modal-footer{display:flex;justify-content:flex-end;gap:12px;padding:24px 32px;border-top:2px solid #e5e7eb;background:#f9fafb;border-radius:0 0 16px 16px}.btn-success{background:linear-gradient(135deg,#10b981,#059669);color:#fff}.btn-success:hover{background:linear-gradient(135deg,#059669,#047857);transform:translateY(-2px);box-shadow:0 8px 20px #10b9814d}.modal-info-banner{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;padding:16px 24px;border-radius:12px;display:flex;align-items:center;gap:12px;margin-bottom:24px;font-weight:600}.modal-info-banner i{font-size:24px}.selected-count{margin-left:auto;background:#fff3;padding:6px 16px;border-radius:20px;font-weight:700}.badge-success{background:linear-gradient(135deg,#10b981,#059669);color:#fff;padding:4px 12px;border-radius:12px;font-size:12px;font-weight:700}.detail-item.highlight{background:#f0fdf4;padding:8px 12px;border-radius:8px;margin-top:8px}.analysis-panel-overlay{position:fixed;top:0;right:0;bottom:0;width:100%;background:#00000080;z-index:9998;animation:fadeIn .3s ease}.analysis-panel{position:fixed;top:0;right:0;bottom:0;width:800px;background:#fff;box-shadow:-4px 0 24px #0003;display:flex;flex-direction:column;animation:slideInRight .3s ease;z-index:9999}@keyframes slideInRight{0%{transform:translate(100%)}to{transform:translate(0)}}.analysis-panel-header{display:flex;justify-content:space-between;align-items:flex-start;padding:24px 32px;border-bottom:2px solid #e5e7eb;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff}.analysis-header-info h2{display:flex;align-items:center;gap:12px;font-size:24px;font-weight:700;margin:0 0 8px}.analysis-connection-name{font-size:14px;opacity:.9;margin:0}.btn-close-panel{background:#fff3;border:none;width:40px;height:40px;border-radius:50%;display:flex;align-items:center;justify-content:center;cursor:pointer;color:#fff;font-size:24px;transition:all .3s ease}.btn-close-panel:hover{background:#ffffff4d;transform:rotate(90deg)}.analysis-panel-body{flex:1;overflow-y:auto;padding:24px 32px}.analysis-section{margin-bottom:32px}.analysis-section h3{display:flex;align-items:center;gap:12px;font-size:18px;font-weight:700;color:#1f2937;margin-bottom:16px;padding-bottom:12px;border-bottom:2px solid #f3f4f6}.analysis-section h3 i{color:#667eea}.selected-tables-list{display:flex;flex-direction:column;gap:8px}.selected-table-item{display:flex;align-items:center;gap:12px;padding:14px 18px;background:#f9fafb;border:2px solid #e5e7eb;border-radius:8px;font-weight:600;font-size:15px;color:#374151;transition:all .3s ease}.selected-table-item:hover{background:#f3f4f6;border-color:#667eea}.selected-table-item i{color:#667eea;font-size:20px}.analysis-actions-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:12px}.analysis-action-btn{display:flex;flex-direction:column;align-items:flex-start;gap:4px;padding:16px;background:#fff;border:2px solid #e5e7eb;border-radius:12px;cursor:pointer;transition:all .3s ease;text-align:left}.analysis-action-btn:hover{border-color:#667eea;background:linear-gradient(135deg,#667eea0d,#764ba20d);transform:translateY(-2px);box-shadow:0 4px 12px #667eea33}.analysis-action-btn i{font-size:28px;color:#667eea;margin-bottom:8px}.analysis-action-btn span{font-size:15px;font-weight:700;color:#1f2937}.analysis-action-btn small{font-size:12px;color:#6b7280}.analysis-action-btn:disabled{opacity:.5;cursor:not-allowed}.analysis-action-btn.active{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border-color:#667eea}.analysis-action-btn.active i,.analysis-action-btn.active small{color:#fff}.analysis-loading{text-align:center;padding:30px;margin-top:20px}.spinner-large{border:4px solid #f3f4f6;border-top:4px solid #667eea;border-radius:50%;width:50px;height:50px;animation:spinLarge 1s linear infinite;margin:0 auto 15px}@keyframes spinLarge{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.analysis-results-container{margin-top:25px;animation:fadeInUp .4s ease}.quality-results h4,.statistics-results h4,.relationships-results h4,.missing-results h4{font-size:18px;font-weight:600;margin-bottom:15px;color:#1e293b}.result-card{background:#fff;border:1px solid #e2e8f0;border-radius:12px;padding:20px;margin-bottom:15px}.result-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:15px;padding-bottom:15px;border-bottom:1px solid #e2e8f0}.result-header .table-name{font-size:16px;font-weight:600;color:#667eea}.quality-badge{padding:6px 16px;border-radius:20px;font-weight:600;font-size:14px}.quality-badge.good{background:#d1fae5;color:#065f46}.quality-badge.medium{background:#fed7aa;color:#92400e}.quality-badge.poor{background:#fecaca;color:#991b1b}.result-stats{display:grid;grid-template-columns:repeat(3,1fr);gap:15px}.stat{display:flex;flex-direction:column;gap:5px}.stat span{font-size:13px;color:#64748b}.stat strong{font-size:18px;color:#1e293b}.numeric-stats{margin-top:15px;padding-top:15px;border-top:1px solid #e2e8f0}.numeric-stats h5{font-size:14px;font-weight:600;margin-bottom:10px;color:#475569}.numeric-col{display:flex;flex-direction:column;gap:5px;padding:8px 0;border-bottom:1px solid #f1f5f9}.numeric-col strong{font-size:14px;color:#1e293b}.numeric-col span{font-size:12px;color:#64748b}.relationship-card{background:#fff;border:1px solid #e2e8f0;border-radius:12px;padding:15px 20px;margin-bottom:10px}.rel-arrow{display:flex;align-items:center;gap:12px;font-weight:600;color:#1e293b;margin-bottom:5px}.rel-arrow i{color:#667eea;font-size:18px}.relationship-card small{color:#64748b;font-size:12px}.missing-badge{padding:6px 16px;border-radius:20px;font-weight:600;font-size:14px;background:#fef3c7;color:#92400e}.missing-columns{display:flex;flex-direction:column;gap:10px}.missing-col{display:flex;justify-content:space-between;align-items:center;padding:10px;background:#f8fafc;border-radius:8px}.missing-col span:first-child{font-weight:500;color:#1e293b}.missing-count{font-size:13px;color:#dc2626;font-weight:600}.no-data{text-align:center;padding:30px;color:#64748b;font-style:italic}.error-result{text-align:center;padding:30px;background:#fef2f2;border-radius:12px;color:#991b1b}.error-result i{font-size:48px;margin-bottom:15px}@keyframes fadeInUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.analysis-settings{display:flex;flex-direction:column;gap:16px}.setting-item{display:flex;flex-direction:column;gap:8px}.setting-item label{display:flex;align-items:center;gap:8px;font-size:14px;font-weight:600;color:#374151}.setting-item label i{color:#667eea;font-size:18px}.setting-select{padding:10px 14px;border:2px solid #e5e7eb;border-radius:8px;font-size:14px;font-weight:500;color:#374151;background:#fff;cursor:pointer;transition:all .3s ease}.setting-select:hover{border-color:#667eea}.setting-select:focus{outline:none;border-color:#667eea;box-shadow:0 0 0 3px #667eea1a}.analysis-panel-footer{display:flex;justify-content:flex-end;gap:12px;padding:24px 32px;border-top:2px solid #e5e7eb;background:#f9fafb}.btn-ai-gradient{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;padding:12px 24px;border:none;border-radius:8px;font-size:15px;font-weight:700;cursor:pointer;display:flex;align-items:center;gap:8px;transition:all .3s ease}.btn-ai-gradient:hover{transform:translateY(-2px);box-shadow:0 8px 20px #667eea66}.btn-ai-gradient i{font-size:20px}@media (max-width: 768px){.analysis-panel{width:100%}.analysis-actions-grid{grid-template-columns:1fr}}.modal-overlay{padding:0}.modal-container{max-width:100%;max-height:100vh;border-radius:0}.modal-header,.modal-body,.modal-footer{padding:16px}} .notification-overlay{position:fixed;inset:0;background:#0009;display:flex;align-items:center;justify-content:center;z-index:10000;animation:fadeIn .2s ease;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.notification-modal{background:#fff;border-radius:16px;box-shadow:0 20px 60px #0000004d;max-width:500px;width:90%;animation:slideUp .3s ease;overflow:hidden}.notification-header{padding:20px 24px;display:flex;align-items:center;justify-content:space-between;border-bottom:2px solid #e5e7eb}.notification-header.notification-success{background:linear-gradient(135deg,#10b981,#059669);color:#fff}.notification-header.notification-error{background:linear-gradient(135deg,#ef4444,#dc2626);color:#fff}.notification-header.notification-warning{background:linear-gradient(135deg,#f59e0b,#d97706);color:#fff}.notification-header h3{margin:0;font-size:20px;font-weight:700;display:flex;align-items:center;gap:8px}.notification-close{background:#fff3;border:none;border-radius:8px;width:32px;height:32px;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .2s ease;color:#fff}.notification-close:hover{background:#ffffff4d;transform:scale(1.1)}.notification-body{padding:24px}.notification-message{font-size:16px;line-height:1.6;color:#374151;margin:0 0 16px}.notification-details{background:#f9fafb;border:1px solid #e5e7eb;border-radius:8px;padding:16px;font-size:13px;line-height:1.5;color:#6b7280;white-space:pre-wrap;word-wrap:break-word;max-height:200px;overflow-y:auto;margin:0;font-family:Courier New,monospace}.notification-footer{padding:16px 24px;background:#f9fafb;border-top:1px solid #e5e7eb;display:flex;justify-content:flex-end;gap:12px}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{transform:translateY(20px);opacity:0}to{transform:translateY(0);opacity:1}}
