:root{--blue-500: #3B82F6;--blue-600: #2563EB;--blue-700: #1D4ED8;--blue-50: #EFF6FF;--blue-100: #DBEAFE;--slate-50: #F8FAFC;--slate-100: #F1F5F9;--slate-200: #E2E8F0;--slate-300: #CBD5E1;--slate-400: #94A3B8;--slate-500: #64748B;--slate-600: #475569;--slate-700: #334155;--slate-800: #1E293B;--slate-900: #0F172A;--slate-950: #020617;--danger: #EF4444;--danger-bg: rgba(239,68,68,.08);--toolbar-bg: #0F172A;--toolbar-h: 52px;--sidebar-bg: #1E293B;--sidebar-w: 260px;--canvas-bg: #EEF2F7;--widget-bg: #FFFFFF;--widget-shadow: 0 1px 3px rgba(0,0,0,.08), 0 4px 12px rgba(0,0,0,.05);--widget-shadow-lift: 0 8px 30px rgba(0,0,0,.14), 0 2px 8px rgba(0,0,0,.08);--widget-header: #1E293B;--widget-radius: 10px;--modal-shadow: 0 20px 60px rgba(0,0,0,.3), 0 4px 16px rgba(0,0,0,.15);--border-light: #E2E8F0;--border-medium: #CBD5E1;--radius-sm: 5px;--radius-md: 8px;--radius-lg: 12px}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html,body,#root{height:100%}body{font-family:Inter,Segoe UI,system-ui,-apple-system,sans-serif;font-size:13px;color:var(--slate-900);background:var(--canvas-bg);overflow:hidden;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}.app{display:grid;grid-template-rows:var(--toolbar-h) 1fr;grid-template-columns:var(--sidebar-w) 1fr;height:100vh}.toolbar{grid-column:1 / -1;display:flex;align-items:center;gap:2px;padding:0 16px;background:var(--toolbar-bg);border-bottom:1px solid rgba(255,255,255,.06);position:relative;z-index:100}.toolbar-logo{display:flex;align-items:center;gap:8px;margin-right:14px;text-decoration:none;flex-shrink:0}.toolbar-logo-icon{width:26px;height:26px;background:linear-gradient(135deg,#3b82f6,#2563eb);border-radius:7px;display:flex;align-items:center;justify-content:center;flex-shrink:0;box-shadow:0 0 0 1px #3b82f666,0 2px 8px #2563eb59}.toolbar-logo-text{font-size:15px;font-weight:700;letter-spacing:-.4px;line-height:1}.toolbar-logo-text span:first-child{color:#fff}.toolbar-logo-text span:last-child{color:#60a5fa}.toolbar-sep{width:1px;height:20px;background:#ffffff1a;margin:0 6px;flex-shrink:0}.toolbar-dashboard-name{font-size:12px;font-weight:600;color:#ffffff8c;max-width:200px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;padding:3px 8px;background:#ffffff0d;border-radius:var(--radius-sm);border:1px solid rgba(255,255,255,.08);flex-shrink:0}.btn{display:inline-flex;align-items:center;gap:5px;padding:5px 11px;border:none;border-radius:var(--radius-sm);font-size:12px;font-weight:500;cursor:pointer;transition:background .12s,box-shadow .12s,opacity .12s;white-space:nowrap;flex-shrink:0;font-family:inherit;letter-spacing:-.1px}.btn:disabled{opacity:.38;cursor:not-allowed}.btn-ghost{background:#ffffff0d;color:#ffffffbf;border:1px solid rgba(255,255,255,.08)}.btn-ghost:hover:not(:disabled){background:#ffffff1a;color:#fff;border-color:#ffffff24}.btn-primary{background:linear-gradient(135deg,#3b82f6,#2563eb);color:#fff;font-weight:600;border:1px solid rgba(37,99,235,.3);box-shadow:0 1px 3px #2563eb59,inset 0 1px #ffffff1f}.btn-primary:hover:not(:disabled){background:linear-gradient(135deg,#60a5fa,#3b82f6);box-shadow:0 2px 8px #2563eb73,inset 0 1px #ffffff26}.btn-primary:active:not(:disabled){background:linear-gradient(135deg,#2563eb,#1d4ed8)}.btn-danger{background:var(--danger-bg);color:var(--danger);border:1px solid rgba(239,68,68,.15)}.btn-danger:hover:not(:disabled){background:#ef444426}.sidebar{background:var(--sidebar-bg);border-right:1px solid rgba(255,255,255,.05);display:flex;flex-direction:column;overflow:hidden}.sidebar-section{display:flex;flex-direction:column;overflow:hidden}.sidebar-section+.sidebar-section{border-top:1px solid rgba(255,255,255,.06)}.sidebar-header{display:flex;align-items:center;justify-content:space-between;padding:10px 14px 6px;font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.9px;color:#ffffff4d}.sidebar-list{flex:1;overflow-y:auto;padding:2px 6px 6px}.sidebar-item{display:flex;align-items:center;gap:8px;padding:7px 10px;cursor:pointer;font-size:12.5px;font-weight:500;color:#fff9;border-radius:var(--radius-sm);transition:background .1s,color .1s;margin-bottom:1px}.sidebar-item:hover{background:#ffffff0f;color:#ffffffe6}.sidebar-item.active{background:#3b82f626;color:#93c5fd}.sidebar-item.active .sidebar-item-icon{color:#60a5fa}.sidebar-item-icon{flex-shrink:0;color:#ffffff59;transition:color .1s}.sidebar-item:hover .sidebar-item-icon{color:#ffffffb3}.schema-conn-row{display:flex;align-items:center;gap:6px;padding:6px 10px 4px}.schema-conn-select{flex:1;background:#ffffff0d;border:1px solid rgba(255,255,255,.09);border-radius:var(--radius-sm);color:#ffffffbf;font-size:11.5px;font-family:inherit;padding:5px 8px;cursor:pointer;transition:border-color .12s}.schema-conn-select:focus{outline:none;border-color:#3b82f680;box-shadow:0 0 0 2px #3b82f61f}.schema-conn-select option{background:#1e293b}.schema-tree{flex:1;overflow-y:auto;padding:2px 6px 8px}.schema-table-node{-webkit-user-select:none;user-select:none;margin-bottom:1px}.schema-table-header{display:flex;align-items:center;gap:6px;padding:6px 8px;cursor:pointer;color:#ffffffa6;font-size:12px;font-weight:600;border-radius:var(--radius-sm);transition:background .1s,color .1s}.schema-table-header:hover{background:#ffffff0f;color:#fff}.schema-table-header[draggable]{cursor:grab}.schema-table-header[draggable]:active{cursor:grabbing}.schema-table-chevron{color:#ffffff4d;transition:transform .15s,color .1s;flex-shrink:0}.schema-table-chevron.open{transform:rotate(90deg);color:#ffffff80}.schema-table-icon{color:#fff6;flex-shrink:0}.schema-col-list{padding-left:20px}.schema-col-item{display:flex;align-items:center;gap:6px;padding:4px 8px;font-size:11.5px;color:#ffffff6b;cursor:grab;border-radius:4px;transition:color .1s,background .1s}.schema-col-item:hover{color:#ffffffb8;background:#ffffff0a}.schema-col-item:active{cursor:grabbing}.schema-col-icon{flex-shrink:0}.canvas-wrapper{overflow:auto;background:var(--canvas-bg);background-image:radial-gradient(circle at 1px 1px,rgba(148,163,184,.18) 1px,transparent 0);background-size:24px 24px}.canvas{position:relative;min-width:100%;min-height:100%;padding:16px}.canvas-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:14px;height:calc(100vh - var(--toolbar-h));color:var(--slate-400);pointer-events:none}.canvas-empty svg{opacity:.3}.canvas-empty p{font-size:14px;color:var(--slate-500);font-weight:500}.canvas-empty strong{font-weight:700;color:var(--slate-600)}.widget{position:absolute;background:var(--widget-bg);border-radius:var(--widget-radius);box-shadow:var(--widget-shadow);border:1px solid rgba(0,0,0,.06);overflow:hidden;transition:box-shadow .18s,border-color .18s}.widget:hover{box-shadow:var(--widget-shadow-lift);border-color:#00000014}.widget.dragging,.widget.resizing{box-shadow:var(--widget-shadow-lift);z-index:999;overflow:visible;opacity:.96}.widget-header{display:flex;align-items:center;justify-content:space-between;padding:0 12px;background:var(--widget-header);color:#ffffffd9;font-size:11.5px;font-weight:600;letter-spacing:.1px;cursor:move;-webkit-user-select:none;user-select:none;height:34px;gap:8px;flex-shrink:0}.widget-title{flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.widget-header-actions{display:flex;gap:3px;flex-shrink:0}.widget-header-btn{background:none;border:none;color:#ffffff4d;cursor:pointer;padding:4px;border-radius:4px;display:flex;align-items:center;justify-content:center;transition:color .12s,background .12s;line-height:1}.widget-header-btn:hover{color:#ffffffd9;background:#ffffff1a}.widget-header-btn.delete:hover{color:#fca5a5;background:#ef444426}.widget-body{position:absolute;top:34px;left:0;right:0;bottom:0;overflow:hidden}.widget-chart{width:100%;height:100%}.widget-kpi{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100%;gap:6px;padding:16px;background:linear-gradient(160deg,#fff 0%,var(--slate-50) 100%)}.kpi-value{font-size:clamp(30px,6vw,52px);font-weight:700;color:var(--slate-900);line-height:1;text-align:center;letter-spacing:-1px;background:linear-gradient(135deg,var(--slate-800) 0%,var(--blue-600) 100%);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.kpi-label{font-size:11px;color:var(--slate-400);text-transform:uppercase;letter-spacing:.8px;font-weight:600}.widget-table-wrap{width:100%;height:100%;overflow:auto}.widget-table{width:100%;border-collapse:collapse;font-size:12px}.widget-table th{background:var(--slate-50);padding:7px 12px;text-align:left;font-weight:600;color:var(--slate-600);font-size:11px;text-transform:uppercase;letter-spacing:.4px;position:sticky;top:0;border-bottom:1px solid var(--border-light);white-space:nowrap}.widget-table td{padding:6px 12px;border-bottom:1px solid #F1F5F9;white-space:nowrap;color:var(--slate-700)}.widget-table tr:last-child td{border-bottom:none}.widget-table tbody tr:hover td{background:var(--blue-50)}.widget-no-data{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100%;gap:8px;color:var(--slate-400);font-size:12px;font-weight:500;text-align:center;padding:20px;background:var(--slate-50)}.resize-handle{position:absolute;bottom:0;right:0;width:20px;height:20px;cursor:se-resize;z-index:10}.resize-handle:after{content:"";position:absolute;bottom:4px;right:4px;width:8px;height:8px;border-right:2px solid rgba(100,116,139,.3);border-bottom:2px solid rgba(100,116,139,.3);border-radius:1px;transition:border-color .15s}.widget:hover .resize-handle:after,.resize-handle:hover:after,.widget.resizing .resize-handle:after{border-color:var(--blue-500)}.widget-drop-zone{position:absolute;top:0;left:0;right:0;bottom:0;background:#3b82f614;border:2px dashed rgba(59,130,246,.4);border-radius:var(--widget-radius);z-index:20;display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:600;color:var(--blue-600);pointer-events:none;opacity:0;transition:opacity .12s,background .12s}.widget.schema-drag-active .widget-drop-zone{opacity:1}.widget.schema-drag-hover .widget-drop-zone{background:#3b82f62e;border-color:var(--blue-500);color:var(--blue-700)}.modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#0f172a99;backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px);z-index:1000;display:flex;align-items:center;justify-content:center;padding:16px}.modal{background:#fff;border-radius:var(--radius-lg);width:580px;max-width:calc(100vw - 32px);max-height:calc(100vh - 48px);display:flex;flex-direction:column;box-shadow:var(--modal-shadow);border:1px solid rgba(0,0,0,.06)}.modal-header{display:flex;align-items:center;justify-content:space-between;padding:18px 22px 16px;border-bottom:1px solid var(--border-light)}.modal-title{font-size:15px;font-weight:700;color:var(--slate-900);letter-spacing:-.2px}.modal-close{background:var(--slate-100);border:none;border-radius:var(--radius-sm);color:var(--slate-500);cursor:pointer;padding:5px;display:flex;align-items:center;justify-content:center;transition:background .12s,color .12s}.modal-close:hover{color:var(--slate-800);background:var(--slate-200)}.modal-body{padding:20px 22px;overflow-y:auto;display:flex;flex-direction:column;gap:16px}.modal-footer{padding:14px 22px;border-top:1px solid var(--border-light);display:flex;justify-content:flex-end;gap:8px;background:var(--slate-50);border-radius:0 0 var(--radius-lg) var(--radius-lg)}.form-row{display:flex;gap:12px}.form-group{display:flex;flex-direction:column;gap:5px;flex:1}.form-label{font-size:11px;font-weight:600;color:var(--slate-600);text-transform:uppercase;letter-spacing:.5px}.form-input,.form-select{padding:8px 11px;border:1px solid var(--border-medium);border-radius:var(--radius-sm);font-size:13px;font-family:inherit;background:#fff;color:var(--slate-900);transition:border-color .15s,box-shadow .15s}.form-input:focus,.form-select:focus{outline:none;border-color:var(--blue-500);box-shadow:0 0 0 3px #3b82f61f}.form-input::placeholder{color:var(--slate-400)}.form-row-3{display:grid;grid-template-columns:1fr 1fr 1fr;gap:10px}::-webkit-scrollbar{width:5px;height:5px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:#0000001f;border-radius:3px}.sidebar ::-webkit-scrollbar-thumb{background:#ffffff1f}.sr-only{position:absolute;width:1px;height:1px;overflow:hidden;clip:rect(0,0,0,0)}.sidebar-overlay{display:none;position:fixed;top:0;right:0;bottom:0;left:0;background:#00000080;z-index:490}.btn-hamburger{display:none}@media (max-width: 768px){:root{--toolbar-h: 52px}.app{grid-template-columns:1fr}.sidebar{position:fixed;top:var(--toolbar-h);left:0;width:min(280px,85vw);height:calc(100% - var(--toolbar-h));z-index:500;transform:translate(-100%);transition:transform .22s cubic-bezier(.4,0,.2,1);box-shadow:8px 0 32px #0006}.sidebar.mobile-open{transform:translate(0)}.sidebar-overlay.visible{display:block}.btn-hamburger{display:inline-flex;padding:6px 8px;flex-shrink:0}.toolbar{padding:0 8px;overflow-x:auto;-webkit-overflow-scrolling:touch;scrollbar-width:none}.toolbar::-webkit-scrollbar{display:none}.btn{min-height:38px;padding:7px 11px}.canvas-wrapper{-webkit-overflow-scrolling:touch}.modal-backdrop{align-items:flex-end;padding:0}.modal{width:100%!important;max-width:100%!important;border-radius:16px 16px 0 0!important;max-height:92vh}.modal-footer{border-radius:0}}
