.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}.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}.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:5000;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}
