.react-flow{direction:ltr}.react-flow__container{position:absolute;width:100%;height:100%;top:0;left:0}.react-flow__pane{z-index:1;cursor:-webkit-grab;cursor:grab}.react-flow__pane.selection{cursor:pointer}.react-flow__pane.dragging{cursor:-webkit-grabbing;cursor:grabbing}.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 .react-flow__edges{pointer-events:none;overflow:visible}.react-flow__edge-path,.react-flow__connection-path{stroke:#b1b1b7;stroke-width:1;fill:none}.react-flow__edge{pointer-events:visibleStroke;cursor:pointer}.react-flow__edge.animated path{stroke-dasharray:5;-webkit-animation:dashdraw .5s linear infinite;animation:dashdraw .5s linear infinite}.react-flow__edge.animated path.react-flow__edge-interaction{stroke-dasharray:none;-webkit-animation: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:focus .react-flow__edge-path,.react-flow__edge:focus-visible .react-flow__edge-path{stroke:#555}.react-flow__edge-textwrapper{pointer-events:all}.react-flow__edge-textbg{fill:#fff}.react-flow__edge .react-flow__edge-text{pointer-events:none;-webkit-user-select:none;-moz-user-select:none;user-select:none}.react-flow__connection{pointer-events:none}.react-flow__connection .animated{stroke-dasharray:5;-webkit-animation:dashdraw .5s linear infinite;animation:dashdraw .5s linear infinite}.react-flow__connectionline{z-index:1001}.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:-webkit-grab;cursor:grab}.react-flow__node.dragging{cursor:-webkit-grabbing;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:-webkit-grab;cursor:grab}.react-flow__handle{position:absolute;pointer-events:none;min-width:5px;min-height:5px;width:6px;height:6px;background:#1a192b;border:1px solid white;border-radius:100%}.react-flow__handle.connectionindicator{pointer-events:all;cursor:crosshair}.react-flow__handle-bottom{top:auto;left:50%;bottom:-4px;transform:translate(-50%)}.react-flow__handle-top{left:50%;top:-4px;transform:translate(-50%)}.react-flow__handle-left{top:50%;left:-4px;transform:translateY(-50%)}.react-flow__handle-right{right:-4px;top:50%;transform:translateY(-50%)}.react-flow__edgeupdater{cursor:move;pointer-events:all}.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.left{left:0}.react-flow__panel.right{right:0}.react-flow__panel.center{left:50%;transform:translate(-50%)}.react-flow__attribution{font-size:10px;background:#ffffff80;padding:2px 3px;margin:0}.react-flow__attribution a{text-decoration:none;color:#999}@-webkit-keyframes dashdraw{0%{stroke-dashoffset:10}}@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}.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-default,.react-flow__node-input,.react-flow__node-output,.react-flow__node-group{padding:10px;border-radius:3px;width:150px;font-size:12px;color:#222;text-align:center;border-width:1px;border-style:solid;border-color:#1a192b;background-color:#fff}.react-flow__node-default.selectable:hover,.react-flow__node-input.selectable:hover,.react-flow__node-output.selectable:hover,.react-flow__node-group.selectable:hover{box-shadow:0 1px 4px 1px #00000014}.react-flow__node-default.selectable.selected,.react-flow__node-default.selectable:focus,.react-flow__node-default.selectable:focus-visible,.react-flow__node-input.selectable.selected,.react-flow__node-input.selectable:focus,.react-flow__node-input.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:0 0 0 .5px #1a192b}.react-flow__node-group{background-color:#f0f0f040}.react-flow__nodesselection-rect,.react-flow__selection{background:#0059dc14;border:1px dotted rgba(0,89,220,.8)}.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{box-shadow:0 0 2px 1px #00000014}.react-flow__controls-button{border:none;background:#fefefe;border-bottom:1px solid #eee;box-sizing:content-box;display:flex;justify-content:center;align-items:center;width:16px;height:16px;cursor:pointer;-webkit-user-select:none;-moz-user-select:none;user-select:none;padding:5px}.react-flow__controls-button:hover{background:#f4f4f4}.react-flow__controls-button svg{width:100%;max-width:12px;max-height:12px}.react-flow__controls-button:disabled{pointer-events:none}.react-flow__controls-button:disabled svg{fill-opacity:.4}.react-flow__minimap{background-color:#fff}.react-flow__minimap svg{display:block}.table-node{background:#fff;border:2px solid #667eea;border-radius:8px;min-width:250px;box-shadow:0 4px 12px #0000001a;overflow:hidden;pointer-events:all!important;position:relative;display:flex;flex-direction:column}.table-header{background:#667eea;color:#fff;padding:12px 16px;font-weight:600;font-size:16px;cursor:grab!important;-webkit-user-select:none;user-select:none;position:relative;z-index:1;flex-shrink:0}.table-header:active{cursor:grabbing!important}.table-name{margin:0;-webkit-user-select:none;user-select:none;pointer-events:none}.table-note{margin-top:4px;font-size:12px;font-weight:400;opacity:.9;font-style:italic;-webkit-user-select:none;user-select:none;pointer-events:none;line-height:1.3}.table-body{padding:8px 0;-webkit-user-select:none;user-select:none;position:relative;background:#fff;flex:1}.field-row{padding:8px 16px;display:flex;align-items:center;gap:8px;border-bottom:1px solid #f0f0f0;font-size:13px;-webkit-user-select:none;user-select:none;position:relative;cursor:default}.field-row[title]:not([title=""]){cursor:help}.field-row[title]:not([title=""]):hover{background-color:#f8f9fa}.field-row:last-child{border-bottom:none}.field-name{font-weight:500;color:#333;flex:1;font-family:Courier New,monospace;-webkit-user-select:none;user-select:none;pointer-events:none}.field-type{color:#666;font-size:12px;font-family:Courier New,monospace;-webkit-user-select:none;user-select:none;pointer-events:none}.field-badge{padding:2px 6px;border-radius:3px;font-size:10px;font-weight:600;text-transform:uppercase;-webkit-user-select:none;user-select:none;pointer-events:none}.field-badge.pk{background:#ffc107;color:#333}.field-badge.unique{background:#2196f3;color:#fff}.field-badge.not-null{background:#f44336;color:#fff}.table-node .react-flow__handle{width:8px;height:8px;background:#667eea;pointer-events:all;position:absolute}.field-note-indicator{font-size:12px;margin-left:auto;opacity:.6;-webkit-user-select:none;user-select:none;pointer-events: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:4px;height:4px;border:1px solid #fff;border-radius:1px;background-color:#3367d9;transform: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:#3367d9;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%}.group-node-wrapper{pointer-events:none!important}.group-node{width:100%;height:100%;border:3px solid;border-radius:12px;padding:50px 20px 20px;position:absolute;top:0;left:0;box-sizing:border-box;pointer-events:none!important}.group-header{position:absolute;top:12px;left:15px;font-size:13px;font-weight:700;text-transform:uppercase;letter-spacing:1.2px;color:#fff;padding:6px 14px;border-radius:6px;box-shadow:0 2px 4px #00000026;pointer-events:all!important;-webkit-user-select:none;user-select:none;cursor:grab!important;z-index:1000}.group-header:active{cursor:grabbing!important}.react-flow__resize-control{pointer-events:all!important;z-index:1001!important}.project-panel-node{background:#fffffffa;border:3px solid #667eea;border-radius:10px;box-shadow:0 4px 16px #0003;padding:16px 20px;width:100%;height:100%;box-sizing:border-box;transition:box-shadow .2s;overflow:hidden}.project-panel-node:hover{box-shadow:0 6px 20px #0000004d}.project-panel-node .drag-handle{position:absolute;top:8px;left:8px;font-size:20px;color:#999;cursor:move;line-height:1;padding:4px;z-index:10}.project-content{color:#333;width:100%;height:100%;display:flex;flex-direction:column}.project-header{display:flex;align-items:center;justify-content:center;gap:12px;margin-bottom:12px;font-size:24px;font-weight:700;color:#667eea;flex-shrink:0;line-height:1.2}.project-db-badge{font-size:16px;font-weight:700;padding:4px 10px;background:#667eea;color:#fff;border-radius:5px;text-transform:uppercase;letter-spacing:.5px;white-space:nowrap}.project-note{font-size:18px;line-height:1.5;color:#555;font-weight:500;white-space:pre-wrap;word-break:break-word;overflow-y:auto;flex:1;text-align:left;padding:0 8px}.dbml-viewer{width:100%;height:100%;position:relative;background-color:#fff}.dbml-viewer.dark{background-color:#1a192b}.react-flow__node{cursor:grab!important;pointer-events:all!important}.react-flow__node.dragging{cursor:grabbing!important}.react-flow__node.selectable:hover{cursor:grab!important}.react-flow__node[data-type=table]{pointer-events:all!important;cursor:grab!important}.react-flow__node-group{pointer-events:none!important}.react-flow__node-table{pointer-events:all!important}.empty-state,.error-state{width:100%;height:100%;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#667eea,#764ba2)}.empty-content,.error-content{text-align:center;color:#fff;padding:40px;max-width:500px}.empty-content h2,.error-content h2{font-size:36px;margin:0 0 20px;font-weight:600}.empty-content p,.error-content p{font-size:18px;margin:15px 0;line-height:1.6;opacity:.95}.empty-content .hint{font-size:16px;opacity:.8;font-style:italic;margin-top:20px}.error-state{background:linear-gradient(135deg,#ff6b6b,#ee5a6f)}.error-content h2{font-size:32px}.color-picker-bar{position:absolute;bottom:20px;right:20px;z-index:6000;background:#fff;border-radius:8px;padding:12px 20px;box-shadow:0 4px 12px #00000026;border:2px solid #667eea;display:flex;flex-direction:column;gap:10px}.color-picker-header{display:flex;align-items:center;justify-content:space-between}.color-picker-label{font-weight:600;color:#333;font-size:14px}.color-picker-colors{display:flex;align-items:center;gap:12px}.color-input{width:50px;height:32px;border:2px solid #e5e7eb;border-radius:4px;cursor:pointer}.preset-colors{display:flex;gap:8px}.preset-color{width:28px;height:28px;border:2px solid #e5e7eb;border-radius:4px;cursor:pointer;transition:all .2s}.preset-color:hover{transform:scale(1.1);border-color:#667eea;box-shadow:0 2px 8px #0003}.export-buttons{position:absolute;top:20px;right:20px;z-index:1000;display:flex;gap:10px}.export-btn{padding:8px 16px;background:#667eea;color:#fff;border:none;border-radius:4px;cursor:pointer;font-size:14px;font-weight:500;transition:all .2s}.export-btn:hover{background:#5568d3}.dbml-editor{height:100%;display:flex;flex-direction:column;background:#282c34}.editor-header{display:flex;justify-content:space-between;align-items:center;padding:15px 20px;background:#21252b;border-bottom:1px solid #181a1f}.editor-header h2{margin:0;color:#abb2bf;font-size:18px;font-weight:600}.editor-actions{display:flex;gap:10px}.load-example-btn,.clear-btn,.format-btn{padding:8px 16px;color:#fff;border:none;border-radius:4px;cursor:pointer;font-size:14px;font-weight:500;transition:all .2s}.load-example-btn{background:#667eea}.load-example-btn:hover{background:#5568d3}.clear-btn{background:#e74c3c}.clear-btn:hover{background:#c0392b}.format-btn{background:#2196f3}.format-btn:hover{background:#0b7dda}.load-example-btn:active,.clear-btn:active,.format-btn:active{transform:translateY(1px)}.error-banner{background:#ff6b6b;color:#fff;padding:12px 20px;font-size:14px;border-bottom:1px solid #ff5252;animation:slideDown .3s ease-out}.error-banner strong{font-weight:600;margin-right:8px}@keyframes slideDown{0%{max-height:0;opacity:0}to{max-height:100px;opacity:1}}.editor-container{flex:1;overflow:auto;background:#282c34}.editor-container .cm-editor{height:100%;font-size:14px}.editor-container .cm-scroller{font-family:Consolas,Monaco,Courier New,monospace}.editor-footer{padding:10px 20px;background:#21252b;border-top:1px solid #181a1f;color:#5c6370;font-size:13px}.hint{display:flex;align-items:center;gap:8px}.hint:before{content:"u24d8";font-size:16px}.auth-modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#0009;display:flex;align-items:center;justify-content:center;z-index:1000;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.auth-modal{background:#fff;border-radius:12px;width:90%;max-width:440px;max-height:90vh;overflow-y:auto;box-shadow:0 20px 60px #0000004d}.auth-modal-header{display:flex;justify-content:space-between;align-items:center;padding:24px 24px 16px;border-bottom:1px solid #e5e7eb}.auth-modal-header h2{margin:0;font-size:24px;font-weight:600;color:#111827}.close-btn{background:none;border:none;font-size:28px;color:#6b7280;cursor:pointer;width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:6px;transition:all .2s}.close-btn:hover{background:#f3f4f6;color:#111827}.auth-modal-body{padding:24px}.auth-error{background:#fee2e2;color:#dc2626;padding:12px;border-radius:8px;margin-bottom:20px;font-size:14px}.form-group{margin-bottom:16px}.form-group label{display:block;margin-bottom:6px;font-weight:500;color:#374151;font-size:14px}.form-group input{width:100%;padding:10px 12px;border:1px solid #d1d5db;border-radius:8px;font-size:14px;transition:all .2s;box-sizing:border-box}.form-group input:focus{outline:none;border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a}.form-group small{display:block;margin-top:4px;font-size:12px;color:#6b7280}.btn{padding:10px 16px;border:none;border-radius:8px;font-size:14px;font-weight:500;cursor:pointer;transition:all .2s;display:inline-flex;align-items:center;justify-content:center;gap:8px}.btn:disabled{opacity:.6;cursor:not-allowed}.btn-primary{background:#3b82f6;color:#fff}.btn-primary:hover:not(:disabled){background:#2563eb}.btn-block{width:100%;margin-top:8px}.auth-divider{text-align:center;margin:24px 0;position:relative}.auth-divider:before{content:"";position:absolute;top:50%;left:0;right:0;height:1px;background:#e5e7eb}.auth-divider span{background:#fff;padding:0 12px;position:relative;color:#6b7280;font-size:14px}.social-login-buttons{display:flex;gap:12px}.btn-social{flex:1;background:#fff;border:1px solid #d1d5db;color:#374151}.btn-social:hover:not(:disabled){background:#f9fafb;border-color:#9ca3af}.btn-google svg{flex-shrink:0}.btn-github svg{flex-shrink:0}.auth-footer{margin-top:24px;text-align:center}.auth-footer p{margin:0;color:#6b7280;font-size:14px}.link-btn{background:none;border:none;color:#3b82f6;font-weight:500;cursor:pointer;padding:0;font-size:14px}.link-btn:hover{text-decoration:underline}.library-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#0009;display:flex;align-items:center;justify-content:center;z-index:1000;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.library-modal{background:#fff;border-radius:12px;width:90%;max-width:900px;max-height:90vh;display:flex;flex-direction:column;box-shadow:0 20px 60px #0000004d}.library-header{display:flex;justify-content:space-between;align-items:center;padding:24px 24px 16px;border-bottom:1px solid #e5e7eb}.library-header h2{margin:0;font-size:24px;font-weight:600;color:#111827}.library-header-actions{display:flex;align-items:center;gap:12px}.library-body{padding:24px;overflow-y:auto;flex:1}.library-error{background:#fee2e2;color:#dc2626;padding:12px;border-radius:8px;margin-bottom:20px;font-size:14px}.library-loading{text-align:center;padding:40px;color:#6b7280}.library-empty{text-align:center;padding:60px 20px;color:#6b7280}.library-empty p{margin:0;font-size:18px}.library-empty-hint{margin-top:8px!important;font-size:14px!important;color:#9ca3af}.diagrams-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:16px}.diagram-card{background:#f9fafb;border:1px solid #e5e7eb;border-radius:8px;padding:16px;transition:all .2s}.diagram-card:hover{border-color:#3b82f6;box-shadow:0 4px 12px #0000001a}.diagram-card-header{display:flex;align-items:flex-start;justify-content:space-between;gap:8px;margin-bottom:8px}.diagram-card h3{margin:0;font-size:16px;font-weight:600;color:#111827;flex:1;word-break:break-word}.badge-public{background:#dcfce7;color:#166534;font-size:11px;font-weight:600;padding:2px 8px;border-radius:12px;text-transform:uppercase;flex-shrink:0}.diagram-description{margin:8px 0;font-size:14px;color:#6b7280;line-height:1.4;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.diagram-meta{margin:12px 0;padding-top:12px;border-top:1px solid #e5e7eb}.diagram-meta small{color:#9ca3af;font-size:12px}.diagram-actions{display:flex;gap:8px;margin-top:12px}.btn-sm{padding:6px 12px;font-size:13px}.btn-danger{background:#dc2626;color:#fff}.btn-danger:hover:not(:disabled){background:#b91c1c}.save-dialog-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#0009;display:flex;align-items:center;justify-content:center;z-index:1000;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.save-dialog{background:#fff;border-radius:12px;width:90%;max-width:500px;max-height:90vh;overflow-y:auto;box-shadow:0 20px 60px #0000004d}.save-dialog-header{display:flex;justify-content:space-between;align-items:center;padding:24px 24px 16px;border-bottom:1px solid #e5e7eb}.save-dialog-header h2{margin:0;font-size:24px;font-weight:600;color:#111827}.save-dialog-body{padding:24px}.save-error{background:#fee2e2;color:#dc2626;padding:12px;border-radius:8px;margin-bottom:20px;font-size:14px}textarea{width:100%;padding:10px 12px;border:1px solid #d1d5db;border-radius:8px;font-size:14px;font-family:inherit;resize:vertical;box-sizing:border-box;transition:all .2s}textarea:focus{outline:none;border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a}.checkbox-group{margin:20px 0}.checkbox-label{display:flex;align-items:center;gap:8px;cursor:pointer;font-weight:500;color:#374151}.checkbox-label input[type=checkbox]{width:18px;height:18px;cursor:pointer}.checkbox-group small{display:block;margin-top:6px;margin-left:26px;font-size:12px;color:#6b7280}.save-dialog-actions{display:flex;gap:12px;justify-content:flex-end;margin-top:24px;padding-top:20px;border-top:1px solid #e5e7eb}.btn-secondary{background:#fff;color:#374151;border:1px solid #d1d5db}.btn-secondary:hover:not(:disabled){background:#f9fafb;border-color:#9ca3af}.user-menu{position:relative}.user-menu-trigger{width:36px;height:36px;border-radius:50%;border:2px solid #e5e7eb;background:#fff;cursor:pointer;display:flex;align-items:center;justify-content:center;overflow:hidden;transition:all .2s}.user-menu-trigger:hover{border-color:#3b82f6;box-shadow:0 2px 8px #0000001a}.user-menu-trigger img{width:100%;height:100%;object-fit:cover}.user-initials{font-size:14px;font-weight:600;color:#3b82f6}.user-menu-dropdown{position:absolute;top:calc(100% + 8px);right:0;background:#fff;border-radius:8px;box-shadow:0 10px 40px #00000026;min-width:220px;z-index:10000;overflow:hidden;border:1px solid #e5e7eb}.user-menu-header{padding:16px;border-bottom:1px solid #e5e7eb;background:#f9fafb}.user-info{display:flex;flex-direction:column;gap:2px}.user-name{font-weight:600;color:#111827;font-size:14px}.user-email{font-size:12px;color:#6b7280;word-break:break-word}.user-menu-items{padding:8px 0}.user-menu-item{width:100%;padding:10px 16px;border:none;background:none;text-align:left;font-size:14px;color:#374151;cursor:pointer;display:flex;align-items:center;gap:10px;transition:background .2s}.user-menu-item:hover{background:#f3f4f6}.user-menu-item svg{flex-shrink:0}.user-menu-footer{border-top:1px solid #e5e7eb;padding:8px 0}.user-menu-logout{color:#dc2626}.user-menu-logout:hover{background:#fee2e2}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#0009;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:9999;animation:fadeIn .2s ease;padding:20px}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.modal-content{background:#fff;border-radius:16px;box-shadow:0 20px 60px #0000004d;max-width:90vw;max-height:90vh;overflow:hidden;display:flex;flex-direction:column;animation:slideUp .3s ease}@keyframes slideUp{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}.modal-header{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;padding:20px 24px;display:flex;align-items:center;justify-content:space-between;border-bottom:1px solid rgba(255,255,255,.1);flex-shrink:0}.modal-header h2{margin:0;font-size:20px;font-weight:600;letter-spacing:.3px}.modal-close{background:#fff3;border:none;color:#fff;font-size:28px;width:36px;height:36px;border-radius:50%;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s ease;padding:0;line-height:1}.modal-close:hover{background:#ffffff4d;transform:rotate(90deg)}.modal-close:active{transform:rotate(90deg) scale(.95)}.modal-body{padding:24px;overflow-y:auto;flex:1}.modal-content .btn{padding:10px 20px;border-radius:8px;font-size:14px;font-weight:600;border:none;cursor:pointer;transition:all .2s ease;box-shadow:0 2px 4px #0000001a}.modal-content .btn:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 4px 12px #00000026}.modal-content .btn:active:not(:disabled){transform:translateY(0)}.modal-content .btn:disabled{opacity:.6;cursor:not-allowed;transform:none}.modal-content .btn-primary{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff}.modal-content .btn-primary:hover:not(:disabled){background:linear-gradient(135deg,#5568d3,#6a4190)}.modal-content .btn-secondary{background:#95a5a6;color:#fff}.modal-content .btn-secondary:hover:not(:disabled){background:#7f8c8d}.modal-content ::-webkit-scrollbar{width:8px}.modal-content ::-webkit-scrollbar-track{background:#f1f1f1;border-radius:10px}.modal-content ::-webkit-scrollbar-thumb{background:#ccc;border-radius:10px}.modal-content ::-webkit-scrollbar-thumb:hover{background:#999}.databricks-modal{max-width:650px;width:100%;max-height:90vh;overflow-y:auto}.databricks-form{display:flex;flex-direction:column;gap:24px;padding:8px}.form-group{display:flex;flex-direction:column;gap:8px}.form-group label{font-weight:600;font-size:13px;color:#2c3e50;letter-spacing:.3px;display:flex;align-items:center;gap:6px}.form-group label:before{content:"●";color:#667eea;font-size:8px}.form-group .required{color:#e74c3c;font-weight:700}.form-group input,.form-group select{padding:12px 16px;border:2px solid #e0e6ed;border-radius:8px;font-size:14px;font-family:inherit;transition:all .2s ease;background:#f8f9fa;color:#2c3e50}.form-group input:hover,.form-group select:hover{border-color:#c8d0d8;background:#fff}.form-group input:focus,.form-group select:focus{outline:none;border-color:#667eea;background:#fff;box-shadow:0 0 0 3px #667eea1a}.form-group input::placeholder{color:#95a5a6}.form-group small{font-size:12px;color:#7f8c8d;line-height:1.4;display:flex;align-items:flex-start;gap:6px}.form-group small:before{content:"ℹ️";font-size:11px;margin-top:1px}.error-message{padding:14px 16px;background:linear-gradient(135deg,#ffebee,#ffcdd2);border-left:4px solid #e74c3c;border-radius:8px;color:#c62828;font-size:13px;line-height:1.5;box-shadow:0 2px 8px #e74c3c1a}.error-message:before{content:"⚠️ ";font-size:16px}.test-result{padding:14px 16px;border-radius:8px;font-size:14px;font-weight:500;display:flex;align-items:center;gap:10px;box-shadow:0 2px 8px #00000014;animation:slideIn .3s ease}.test-result.success{background:linear-gradient(135deg,#d4edda,#c3e6cb);border-left:4px solid #28a745;color:#155724}.test-result.success:before{content:"✓";font-size:20px;font-weight:700;color:#28a745}.test-result.error{background:linear-gradient(135deg,#f8d7da,#f5c6cb);border-left:4px solid #dc3545;color:#721c24}.test-result.error:before{content:"✗";font-size:20px;font-weight:700;color:#dc3545}.modal-actions{display:flex;gap:12px;justify-content:flex-end;margin-top:20px;padding-top:20px;border-top:2px solid #f0f0f0}.databricks-form .btn{padding:11px 24px;font-size:14px;font-weight:600;border-radius:8px;transition:all .2s ease;cursor:pointer;border:none;box-shadow:0 2px 4px #0000001a}.databricks-form .btn:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 4px 12px #00000026}.databricks-form .btn:active:not(:disabled){transform:translateY(0)}.databricks-form .btn-secondary{background:linear-gradient(135deg,#95a5a6,#7f8c8d);color:#fff}.databricks-form .btn-secondary:hover:not(:disabled){background:linear-gradient(135deg,#7f8c8d,#6c7a7b)}.databricks-form .btn-primary{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff}.databricks-form .btn-primary:hover:not(:disabled){background:linear-gradient(135deg,#5568d3,#6a4190)}.btn-danger{background:linear-gradient(135deg,#e74c3c,#c0392b);color:#fff;margin-right:auto}.btn-danger:hover:not(:disabled){background:linear-gradient(135deg,#c0392b,#a93226)}.databricks-form .btn:disabled{background:#bdc3c7;color:#ecf0f1;cursor:not-allowed;box-shadow:none;transform:none}.databricks-deploy-modal{max-width:800px;width:100%;max-height:90vh;overflow-y:auto}.no-connection-message{padding:40px 20px;text-align:center;color:#666}.no-connection-message p{margin:10px 0}.deploy-form{display:flex;flex-direction:column;gap:24px}.form-section{display:flex;flex-direction:column;gap:16px}.form-section h3{margin:0;font-size:16px;font-weight:600;color:#333}.section-header{display:flex;justify-content:space-between;align-items:center}.btn-link{background:none;border:none;color:#667eea;cursor:pointer;font-size:14px;padding:0;text-decoration:underline}.btn-link:hover{color:#5568d3}.btn-link:disabled{color:#ccc;cursor:not-allowed;text-decoration:none}.table-list{display:flex;flex-direction:column;gap:8px;max-height:300px;overflow-y:auto;padding:12px;border:1px solid #e0e0e0;border-radius:6px;background:#fafafa}.table-checkbox{display:flex;align-items:center;gap:10px;padding:10px;background:#fff;border:1px solid #e0e0e0;border-radius:4px;cursor:pointer;transition:all .2s}.table-checkbox:hover{background:#f5f5f5;border-color:#667eea}.table-checkbox input[type=checkbox]{cursor:pointer;width:18px;height:18px}.table-checkbox span{font-family:Courier New,monospace;font-size:14px;color:#333}.no-tables{text-align:center;color:#999;padding:20px}.deploy-result{background:#f9f9f9;border:1px solid #e0e0e0;border-radius:6px;padding:16px}.deploy-result h4{margin:0 0 16px;font-size:15px;font-weight:600;color:#333}.result-summary{display:grid;grid-template-columns:repeat(auto-fit,minmax(120px,1fr));gap:12px;margin-bottom:16px}.summary-item{display:flex;flex-direction:column;gap:4px;padding:12px;background:#fff;border:2px solid #e0e0e0;border-radius:6px}.summary-item.success{border-color:#4caf50;background:#f1f8f4}.summary-item.warning{border-color:#ff9800;background:#fff8f1}.summary-item.error{border-color:#f44336;background:#fef5f5}.summary-item .label{font-size:12px;color:#666;font-weight:500}.summary-item .value{font-size:24px;font-weight:700;color:#333}.result-details,.result-errors{display:flex;flex-direction:column;gap:8px}.result-item,.error-item{padding:10px 12px;border-radius:4px;font-size:13px}.result-item.created{background:#e8f5e9;border-left:3px solid #4caf50;color:#2e7d32}.result-item.skipped{background:#fff3e0;border-left:3px solid #ff9800;color:#e65100}.error-item{background:#ffebee;border-left:3px solid #f44336;color:#c62828}.result-item strong,.error-item strong{font-family:Courier New,monospace}.section-header.collapsible{display:flex;justify-content:space-between;align-items:center;cursor:pointer;padding:12px;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border-radius:8px;transition:all .3s ease;margin-bottom:0}.section-header.collapsible:hover{transform:translateY(-2px);box-shadow:0 4px 12px #667eea4d}.section-title{display:flex;align-items:center;gap:12px;flex:1}.section-icon{font-size:20px}.label-icon{font-size:16px;margin-right:4px}.badge{background:#fff3;padding:4px 12px;border-radius:12px;font-size:12px;font-weight:600}.collapse-btn{background:none;border:none;color:#fff;font-size:16px;cursor:pointer;padding:4px 8px;transition:transform .3s ease}.section-content{padding:16px;background:#fafafa;border:1px solid #e0e0e0;border-top:none;border-radius:0 0 8px 8px;margin-bottom:8px}.section-actions{display:flex;align-items:center;gap:12px}.naming-global{display:flex;flex-direction:column;gap:16px}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:16px}.naming-example{padding:12px;background:#e3f2fd;border-left:4px solid #2196f3;border-radius:4px;font-size:14px;color:#1565c0}.table-list-container{max-height:400px;overflow-y:auto;background:#fafafa;padding:8px}.table-item{display:flex;flex-direction:column;gap:8px;padding:12px;background:#fff;border:2px solid #e0e0e0;border-radius:8px;margin-bottom:8px;transition:all .2s ease}.table-item.selected{border-color:#667eea;background:#f5f7ff}.table-item:hover{box-shadow:0 2px 8px #0000001a}.table-source-name{font-family:Courier New,monospace;font-size:14px;font-weight:600;color:#333}.table-rename{display:flex;align-items:center;gap:8px;padding-left:28px;animation:slideIn .3s ease}@keyframes slideIn{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.rename-arrow{color:#667eea;font-size:18px;font-weight:700}.rename-input{flex:1;padding:8px 12px;border:2px solid #e0e0e0;border-radius:6px;font-family:Courier New,monospace;font-size:13px;transition:all .2s ease}.rename-input:focus{outline:none;border-color:#667eea;box-shadow:0 0 0 3px #667eea1a}.rename-input::placeholder{color:#999;font-style:italic}.final-name-preview{padding:8px 12px;background:#e8f5e9;border:2px solid #4caf50;border-radius:6px;font-family:Courier New,monospace;font-size:13px;font-weight:600;color:#2e7d32;min-width:150px;text-align:center}.mapping-preview{background:#fff;border:1px solid #e0e0e0;border-radius:8px;overflow:hidden}.preview-header{display:grid;grid-template-columns:1fr auto 2fr;gap:16px;padding:12px 16px;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;font-weight:600;font-size:13px;text-transform:uppercase}.mapping-row{display:grid;grid-template-columns:1fr auto 2fr;gap:16px;padding:12px 16px;border-bottom:1px solid #f0f0f0;align-items:center}.mapping-row:last-child{border-bottom:none}.mapping-row:hover{background:#fafafa}.source-name{font-family:Courier New,monospace;color:#666;font-size:13px}.arrow{color:#667eea;font-size:16px;font-weight:700}.dest-name{font-family:Courier New,monospace;font-weight:600;color:#2e7d32;font-size:13px;background:#f1f8f4;padding:6px 12px;border-radius:4px;border-left:3px solid #4caf50}.location-preview{padding:12px;background:#f3e5f5;border-left:4px solid #9c27b0;border-radius:4px;font-size:14px;color:#6a1b9a;margin-top:12px}.location-preview strong{font-weight:600}.existing-tables-list{display:flex;flex-direction:column;gap:8px;max-height:300px;overflow-y:auto}.existing-table-item{display:flex;align-items:center;gap:10px;padding:10px 12px;background:#fff;border:1px solid #e0e0e0;border-radius:6px;font-family:Courier New,monospace;font-size:14px;color:#555;transition:all .2s ease}.existing-table-item:hover{background:#f5f5f5;border-color:#667eea}.table-icon{font-size:16px}.existing-table-name{flex:1;color:#333;font-weight:500}.loading-message{text-align:center;color:#666;padding:20px;font-style:italic}.error-message{padding:16px 20px;background:linear-gradient(135deg,#ffebee,#ffcdd2);border:2px solid #e74c3c;border-radius:8px;color:#c62828;font-size:14px;font-weight:500;line-height:1.6;box-shadow:0 4px 12px #e74c3c33;margin:16px 0;animation:errorSlideIn .3s ease-out}.error-message:before{content:"⚠️ ";font-size:18px;margin-right:8px}@keyframes errorSlideIn{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.app{width:100%;height:100%;overflow:hidden;display:flex;flex-direction:column}.app-header{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;padding:12px 24px;display:flex;align-items:center;justify-content:space-between;box-shadow:0 2px 8px #00000026;flex-shrink:0}.app-title{margin:0;font-size:20px;font-weight:600;letter-spacing:.5px}.app-header-actions{display:flex;align-items:center;gap:12px}.app-header .btn-primary{background:#fff;color:#667eea;border:none;padding:8px 16px;border-radius:6px;font-weight:500;cursor:pointer;transition:all .2s}.app-header .btn-primary:hover{transform:translateY(-1px);box-shadow:0 4px 12px #0003}.app-header .btn-databricks{background:#ff3621;color:#fff;border:none;padding:8px 16px;border-radius:6px;font-weight:500;cursor:pointer;transition:all .2s}.app-header .btn-databricks:hover{background:#e0301d;transform:translateY(-1px);box-shadow:0 4px 12px #ff36214d}.app-header .btn-secondary{background:#fff3;color:#fff;border:1px solid rgba(255,255,255,.3);padding:8px 16px;border-radius:6px;font-weight:500;cursor:pointer;transition:all .2s}.app-header .btn-secondary:hover{background:#ffffff4d;transform:translateY(-1px)}.split-panel{display:flex;width:100%;flex:1;overflow:hidden}.panel{height:100%;overflow:hidden}.panel-left{flex:0 0 45%;min-width:400px;display:flex;flex-direction:column}.panel-divider{flex:0 0 3px;background:linear-gradient(to right,#21252b,#667eea,#21252b);cursor:col-resize;transition:background .2s}.panel-divider:hover{background:linear-gradient(to right,#667eea,#764ba2,#667eea)}.panel-right{flex:1;min-width:400px;position:relative}.split-panel.fullscreen .panel-right{flex:1;min-width:100%}.toggle-editor-btn{position:absolute;top:20px;left:20px;z-index:500;width:40px;height:40px;background:#667eea;color:#fff;border:none;border-radius:8px;cursor:pointer;font-size:18px;font-weight:700;box-shadow:0 2px 8px #0003;transition:all .3s ease;display:flex;align-items:center;justify-content:center}.toggle-editor-btn:hover{background:#5568d3;box-shadow:0 4px 12px #0000004d;transform:scale(1.05)}.toggle-editor-btn:active{transform:scale(.95)}*{margin:0;padding:0;box-sizing:border-box}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}#root{width:100vw;height:100vh}
