:root{--primary-color: #2563eb;--primary-hover: #1d4ed8;--bg-color: #f3f4f6;--card-bg: #ffffff;--text-main: #111827;--text-secondary: #6b7280;--text-inverse: #ffffff;--border-color: #e5e7eb;--border-focus: #2563eb;--radius-sm: 8px;--radius-lg: 16px;--error-color: #dc2626;--error-bg: #fef2f2;--success-color: #10b981;--shadow-sm: 0 1px 2px 0 rgba(0, 0, 0, .05);--shadow-md: 0 4px 6px -1px rgba(0, 0, 0, .1), 0 2px 4px -1px rgba(0, 0, 0, .06);--shadow-lg: 0 10px 15px -3px rgba(0, 0, 0, .1), 0 4px 6px -2px rgba(0, 0, 0, .05);--transition: all .2s ease-in-out}body{margin:0;font-family:Inter,system-ui,-apple-system,sans-serif;background-color:var(--bg-color);color:var(--text-main);-webkit-font-smoothing:antialiased}a{color:var(--primary-color);text-decoration:none;font-weight:500;transition:var(--transition)}a:hover{color:var(--primary-hover);text-decoration:underline}.loader{width:20px;height:20px;border:2px solid var(--text-inverse);border-bottom-color:transparent;border-radius:50%;display:inline-block;box-sizing:border-box;animation:rotation 1s linear infinite}:root{--primary-color: #2563eb;--primary-hover: #1d4ed8;--bg-color: #f3f4f6;--card-bg: #ffffff;--text-main: #111827;--text-secondary: #6b7280;--border-color: #e5e7eb;--border-focus: #2563eb;--error-color: #dc2626;--error-bg: #fef2f2;--radius: 8px;--shadow: 0 4px 6px -1px rgba(0, 0, 0, .1), 0 2px 4px -1px rgba(0, 0, 0, .06)}.login-page{min-height:100vh;width:100%;display:flex;align-items:center;justify-content:center;background-color:var(--bg-color);font-family:Inter,system-ui,-apple-system,sans-serif;padding:20px;box-sizing:border-box}.login-card{background:var(--card-bg);width:100%;max-width:420px;padding:40px;border-radius:16px;box-shadow:var(--shadow);animation:fadeIn .5s ease-out}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.login-header{text-align:center;margin-bottom:32px}.login-header h1{font-size:24px;font-weight:700;color:var(--text-main);margin:0 0 8px}.login-header p{color:var(--text-secondary);font-size:14px;margin:0}.login-form{display:flex;flex-direction:column;gap:20px}.form-group input{padding:12px 16px;font-size:16px;border:1px solid var(--border-color);border-radius:var(--radius);outline:none;transition:all .2s ease;background:#f9fafb}.api-error-alert{background-color:var(--error-bg);color:var(--error-color);padding:12px;border-radius:var(--radius);font-size:14px;display:flex;align-items:center;gap:10px}.submit-btn{margin-top:10px;padding:12px;background-color:var(--primary-color);color:#fff;border:none;border-radius:var(--radius);font-size:16px;font-weight:600;cursor:pointer;transition:background-color .2s;display:flex;justify-content:center;align-items:center}.login-footer{margin-top:24px;text-align:center;font-size:14px;color:var(--text-secondary)}.login-footer a{color:var(--primary-color);font-weight:600;text-decoration:none}.login-footer a:hover{text-decoration:underline}.loader{width:20px;height:20px;border:2px solid #fff;border-bottom-color:transparent;border-radius:50%;display:inline-block;box-sizing:border-box;animation:rotation 1s linear infinite}@keyframes rotation{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@media(max-width:480px){.login-card{box-shadow:none;background:transparent;padding:20px 0}}.schema_modal_overlay{position:fixed;inset:0;background-color:#0f172a66;z-index:10000;display:flex;align-items:center;justify-content:center;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px)}.schema_modal_content{background-color:#fff;padding:24px;border-radius:12px;width:400px;border:1px solid #e2e8f0;color:#0f172a;box-shadow:0 20px 25px -5px #0000001a,0 10px 10px -5px #0000000a}.schema_modal_title{margin:0 0 20px;font-size:18px;display:flex;align-items:center;gap:8px;font-weight:600}.schema_modal_form_group{display:flex;flex-direction:column;gap:6px;margin-bottom:24px}.schema_modal_label{font-size:13px;font-weight:600;color:#475569}.schema_modal_input{width:100%;padding:8px 12px;border-radius:6px;border:1px solid #cbd5e1;background-color:#f8fafc;color:#0f172a;font-size:14px;box-sizing:border-box;transition:border-color .2s ease,background-color .2s ease;outline:none;font-family:inherit}.schema_modal_input:focus{border-color:#3b82f6;background-color:#fff}.schema_modal_error{color:#ef4444;font-size:12px;margin-top:4px}.schema_modal_actions{display:flex;gap:12px;justify-content:flex-end}.schema_modal_btn{padding:8px 16px;border-radius:6px;border:none;cursor:pointer;font-size:14px;font-weight:500;transition:all .2s ease;font-family:inherit}.schema_modal_btn_cancel{background-color:#f1f5f9;color:#475569;border:1px solid #cbd5e1}.schema_modal_btn_cancel:hover{background-color:#e2e8f0}.schema_modal_btn_create{background-color:#3b82f6;color:#fff}.schema_modal_btn_create:hover{background-color:#2563eb}.overlay-spinner-container{position:absolute;inset:0;background-color:#0f172abf;display:flex;justify-content:center;align-items:center;z-index:50;border-radius:inherit;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px)}.overlay-spinner-content{display:flex;flex-direction:column;align-items:center;gap:12px}.overlay-spinner{width:40px;height:40px;border:4px solid #334155;border-top-color:#3b82f6;border-radius:50%;animation:overlay-spin 1s linear infinite}.overlay-spinner-text{color:#cbd5e1;font-size:14px;font-weight:500}@keyframes overlay-spin{to{transform:rotate(360deg)}}.home-page{width:100%;min-height:100vh;background-color:var(--bg-color);padding:40px 20px;box-sizing:border-box}.home-container{max-width:1200px;margin:0 auto}.dashboard-header{display:flex;flex-direction:column;gap:24px;margin-bottom:40px}@media(min-width:768px){.dashboard-header{flex-direction:row;align-items:end;justify-content:space-between}}.title-section h1{font-size:32px;font-weight:700;color:var(--text-main);margin:0 0 8px}.title-section .subtitle{color:var(--text-secondary);font-size:16px;margin:0}.controls-section{display:flex;flex-direction:column;gap:16px;width:100%;max-width:500px}@media(min-width:768px){.controls-section{align-items:flex-end}}.search-bar{display:flex;align-items:center;background:var(--card-bg);border:1px solid var(--border-color);border-radius:var(--radius-sm);padding:4px 4px 4px 12px;width:100%;transition:var(--transition);box-shadow:var(--shadow-sm)}.search-bar:focus-within{border-color:var(--border-focus);box-shadow:0 0 0 3px #2563eb1a}.search-icon{color:var(--text-secondary);margin-right:8px}.search-bar input{border:none;background:transparent;outline:none;font-size:15px;flex:1;padding:8px 0;color:var(--text-main)}.search-btn{background-color:var(--primary-color);color:#fff;border:none;border-radius:6px;padding:8px 16px;font-weight:500;cursor:pointer;transition:background-color .2s}.search-btn:hover{background-color:var(--primary-hover)}.filter-toggle{display:flex;align-items:center;cursor:pointer;-webkit-user-select:none;user-select:none}.filter-toggle input{display:none}.toggle-slider{width:40px;height:22px;background-color:#e5e7eb;border-radius:22px;position:relative;transition:background-color .2s;margin-right:10px}.toggle-slider:after{content:"";position:absolute;top:2px;left:2px;width:18px;height:18px;background-color:#fff;border-radius:50%;transition:transform .2s;box-shadow:0 1px 2px #0003}.filter-toggle input:checked+.toggle-slider{background-color:var(--primary-color)}.filter-toggle input:checked+.toggle-slider:after{transform:translate(18px)}.toggle-label{font-size:14px;color:var(--text-secondary);font-weight:500}.schema-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:24px}.schema-card{background:var(--card-bg);border-radius:var(--radius-lg);border:1px solid var(--border-color);overflow:hidden;cursor:pointer;transition:all .2s ease;display:flex;flex-direction:column}.schema-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg);border-color:var(--primary-color)}.card-preview{height:140px;background-color:#f9fafb;display:flex;align-items:center;justify-content:center;border-bottom:1px solid var(--border-color)}.schema-icon{color:#d1d5db}.card-content{padding:16px}.schema-name{font-size:18px;font-weight:600;margin:0 0 12px;color:var(--text-main);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.schema-meta{display:flex;justify-content:space-between;align-items:center}.author-info{display:flex;align-items:center;gap:8px;width:100%}.avatar-mini{width:24px;height:24px;border-radius:50%;object-fit:cover}.author-email{font-size:13px;color:var(--text-secondary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:180px}.loader-container{display:flex;justify-content:center;padding:40px}.empty-state{text-align:center;padding:60px 20px;color:var(--text-secondary)}.empty-icon{font-size:48px;margin-bottom:16px;opacity:.5}.btn_create_holder{width:100%;display:flex;flex-direction:row;justify-content:flex-end}.btn_create{background-color:var(--primary-color);color:#fff;padding:10px 16px;border-radius:8px;border:none;cursor:pointer;font-weight:700;display:flex;align-items:center;gap:8px}.btn_create:hover{background-color:var(--primary-hover)}.header_container{display:flex;justify-content:space-between;align-items:center;padding:0 24px;height:60px;background-color:#fff}.logo__container{display:flex;align-items:center;gap:12px;cursor:pointer}#logo__image{height:32px;width:auto}#logo__text{margin:0;color:#0f172a;font-size:18px;font-weight:700}.profile_wrapper{position:relative;display:flex;align-items:center}.profile_avatar{width:36px;height:36px;border-radius:50%;background-color:#f1f5f9;color:#64748b;display:flex;align-items:center;justify-content:center;cursor:pointer;border:1px solid #cbd5e1;transition:all .2s ease}.profile_avatar:hover{background-color:#e2e8f0;color:#0f172a;border-color:#94a3b8}.profile_dropdown{position:absolute;top:calc(100% + 8px);right:0;width:200px;background-color:#fff;border:1px solid #cbd5e1;border-radius:8px;z-index:1000;overflow:hidden}.profile_dropdown_item{display:flex;align-items:center;gap:10px;padding:12px 16px;cursor:pointer;font-size:14px;font-weight:500;transition:background-color .2s}.profile_dropdown_item.logout{color:#ef4444}.profile_dropdown_item.logout:hover{background-color:#fef2f2}.er_toast_container{position:fixed;bottom:72px;right:24px;display:flex;flex-direction:column;gap:12px;z-index:999999;pointer-events:none}.er_toast_item{pointer-events:auto;background-color:#1e293b;border-left:4px solid transparent;border-radius:6px;padding:12px 16px;min-width:250px;max-width:400px;box-shadow:0 10px 15px -3px #0000004d;display:flex;align-items:center;gap:12px;color:#fff;animation:slideInRight .3s ease-out forwards}.er_toast_item--error{border-left-color:#ef4444}.er_toast_item--warning{border-left-color:#f59e0b}.er_toast_item--info{border-left-color:#3b82f6}.er_toast_icon{font-size:18px}.er_toast_text{flex:1;font-size:14px;line-height:1.4;word-wrap:break-word}.er_toast_close{background:none;border:none;color:#94a3b8;cursor:pointer;font-size:16px;padding:4px;display:flex;align-items:center;justify-content:center;transition:color .2s}.er_toast_close:hover{color:#fff}@keyframes slideInRight{0%{transform:translate(100%);opacity:0}to{transform:translate(0);opacity:1}}.register-page{min-height:100vh;width:100%;display:flex;align-items:center;justify-content:center;background-color:var(--bg-color);padding:20px;box-sizing:border-box}.register-card{background:var(--card-bg);width:100%;max-width:480px;padding:40px;border-radius:var(--radius-lg);box-shadow:var(--shadow-md);animation:slideUp .4s ease-out}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.auth-header{text-align:center;margin-bottom:32px}.auth-header h1{font-size:26px;font-weight:700;color:var(--text-main);margin:0 0 8px}.auth-header p{color:var(--text-secondary);font-size:14px;margin:0}.auth-form{display:flex;flex-direction:column;gap:20px}.form-group{display:flex;flex-direction:column;gap:6px}.form-group label{font-size:14px;font-weight:500;color:var(--text-main)}.form-group input{padding:12px 16px;font-size:16px;border:1px solid var(--border-color);border-radius:var(--radius-sm);outline:none;transition:var(--transition);background:#f9fafb;color:var(--text-main)}.form-group input:focus{border-color:var(--border-focus);background:#fff;box-shadow:0 0 0 3px #2563eb1a}.form-group.has-error input{border-color:var(--error-color);background-color:var(--error-bg)}.error-message{font-size:12px;color:var(--error-color);margin-top:2px}.password-input-wrapper{position:relative;display:flex;align-items:center}.password-input-wrapper input{width:100%;padding-right:40px}.password-toggle{position:absolute;right:10px;background:none;border:none;cursor:pointer;color:var(--text-secondary);padding:4px;display:flex;align-items:center;transition:color .2s}.password-toggle:hover{color:var(--text-main)}.api-error-alert{background-color:var(--error-bg);color:var(--error-color);padding:12px;border-radius:var(--radius-sm);font-size:14px;display:flex;align-items:center;gap:10px}.submit-btn{margin-top:10px;padding:12px;background-color:var(--primary-color);color:var(--text-inverse);border:none;border-radius:var(--radius-sm);font-size:16px;font-weight:600;cursor:pointer;transition:background-color .2s;display:flex;justify-content:center;align-items:center}.submit-btn:hover:not(:disabled){background-color:var(--primary-hover)}.submit-btn:disabled{opacity:.7;cursor:not-allowed}.auth-footer{margin-top:24px;text-align:center;font-size:14px;color:var(--text-secondary)}.auth-footer a{color:var(--primary-color);font-weight:600}@media(max-width:480px){.register-card{box-shadow:none;background:transparent;padding:20px 0}}.confirmation_page__container{width:100%;min-height:100vh;display:flex;flex:1;justify-content:center;align-items:center;background-color:#f1f5f9;font-family:inherit}.otp-container{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:24px;padding:40px;background-color:#fff;border:1px solid #e2e8f0;min-width:320px;max-width:450px;border-radius:12px;box-shadow:0 20px 25px -5px #0000001a,0 10px 10px -5px #0000000a}.otp-title{margin:0;font-size:24px;font-weight:600;color:#0f172a}.otp-subtitle{margin:0;color:#64748b;font-size:14px;text-align:center;line-height:1.5}.otp-inputs{display:flex;gap:12px}.otp-input{width:48px;height:56px;text-align:center;font-size:24px;font-weight:600;border:1px solid #cbd5e1;border-radius:8px;outline:none;transition:all .2s ease;background-color:#f8fafc;color:#0f172a;font-family:inherit}.otp-input:focus{border-color:#3b82f6;background-color:#fff;box-shadow:0 0 0 3px #3b82f626;transform:translateY(-2px)}.otp-input::-webkit-outer-spin-button,.otp-input::-webkit-inner-spin-button{-webkit-appearance:none;margin:0}.otp-link{color:#3b82f6;cursor:pointer;font-weight:500;text-decoration:none;transition:color .2s ease}.otp-link:hover{color:#2563eb;text-decoration:underline}.otp-error{font-size:14px;color:#ef4444;text-align:center;margin-top:-8px;min-height:20px}.otp-input--error{border-color:#ef4444}.otp-input--error:focus{border-color:#ef4444;box-shadow:0 0 0 3px #ef444426}.tree-version-item{display:flex;align-items:center;padding:10px;border-bottom:1px solid var(--border-color, #ccc);cursor:pointer;transition:background-color .3s}.tree-version-item:hover{background-color:var(--bg-color, #f5f5f5)}.tree-version-working{border-left:3px solid blue;background-color:#adff2f1a}.tree-version-working:hover{background-color:#adff2f4d}.tree-toggle-wrapper{width:24px;display:flex;justify-content:center;align-items:center;margin-right:8px;flex-shrink:0}.tree-toggle-btn{width:20px;height:20px;display:flex;justify-content:center;align-items:center;background:var(--bg-color, #fff);border:1px solid var(--border-color, #ccc);border-radius:4px;cursor:pointer;font-size:14px;line-height:1;padding:0;color:var(--text-main, #333);transition:all .2s}.tree-toggle-btn:hover:not(.disabled){background:#e0e0e0}.tree-toggle-btn.disabled{cursor:not-allowed;opacity:.5;background:#eee}.tree-toggle-placeholder{width:20px;height:20px;display:inline-block}.tree-version-info{display:flex;flex-direction:column}.tree-version-name{display:block;font-weight:500;font-size:16px}.tree-version-date{font-size:12px;color:var(--text-secondary, #666)}.custom-context-menu{position:fixed;z-index:9999;background-color:var(--card-bg, #ffffff);border:1px solid var(--border-color, #d1d5db);border-radius:6px;box-shadow:0 4px 12px #00000026;padding:4px 0;min-width:220px;font-size:14px;color:var(--text-main, #333333)}.menu-item{padding:8px 16px;cursor:pointer;display:flex;justify-content:space-between;align-items:center;position:relative;transition:background-color .2s}.menu-item:hover{background-color:var(--bg-color, #f3f4f6)}.menu-item.item-danger{color:#dc2626}.menu-item.item-danger:hover{background-color:#fef2f2}.menu-divider{height:1px;background-color:var(--border-color, #e5e7eb);margin:4px 0}.has-submenu{padding-right:12px}.submenu-arrow{font-size:10px;color:var(--text-secondary, #9ca3af)}.submenu{position:absolute;top:-5px;left:100%;background-color:var(--card-bg, #ffffff);border:1px solid var(--border-color, #d1d5db);border-radius:6px;box-shadow:0 4px 12px #00000026;padding:4px 0;min-width:140px;z-index:10000}.versions-content-wrapper{display:flex;flex-direction:column;flex-grow:1}.versions-header-controls{display:flex;justify-content:space-between;padding:10px 20px;border-bottom:1px solid var(--border-color, #ccc)}.mode-switchers button{background:none;border:1px solid var(--border-color, #ccc);padding:4px 8px;cursor:pointer;font-size:12px;color:var(--text-main, #333)}.mode-switchers button:first-child{border-radius:4px 0 0 4px;border-right:none}.mode-switchers button:last-child{border-radius:0 4px 4px 0}.mode-switchers button.active{background:#eee;font-weight:700}.versions-list-container{flex-grow:1;padding-top:10px}.list-version-item{padding:10px 20px;border-bottom:1px solid var(--border-color, #ccc);cursor:pointer;transition:background-color;display:flex;flex-direction:column}.list-version-item:hover{background-color:var(--bg-color, #f5f5f5)}.list-version-name{font-weight:500;font-size:16px;color:var(--text-main, #333)}.list-version-date{font-size:12px;color:var(--text-secondary, #666)}.list-version-working{border-left:3px solid blue;margin-left:25px}.list-version-working:hover{background-color:#adff2f4d}.schema-sidebar{position:relative;width:0;height:100%;background:var(--card-bg, #ffffff);border-right:1px solid var(--border-color, #ccc);transition:.3s ease;display:flex;flex-direction:column;z-index:20;box-shadow:2px 0 8px #0000001a}.schema-sidebar.open{width:380px}.sidebar-toggle{position:absolute;right:-24px;top:20px;width:24px;height:40px;background:var(--card-bg, #ffffff);border:1px solid var(--border-color, #ccc);border-left:none;border-radius:0 4px 4px 0;display:flex;align-items:center;justify-content:center;cursor:pointer;color:var(--text-secondary, #666);box-shadow:2px 0 4px #0000000d;z-index:21}.sidebar-main-content{width:380px;flex:1;display:flex;flex-direction:column;opacity:0;pointer-events:none;transition:opacity .1s;min-height:0}.schema-sidebar.open .sidebar-main-content{opacity:1;pointer-events:auto}.sidebar-top-bar{padding:16px 20px;border-bottom:1px solid var(--border-color, #ccc)}.sidebar-select{width:100%;padding:8px 12px;background:var(--bg-color, #f9f9f9);border:1px solid var(--border-color, #ccc);border-radius:4px;color:var(--text-main, #333);font-size:15px;font-weight:500;outline:none;cursor:pointer;transition:border-color .2s}.sidebar-select:focus{border-color:#3b82f6}.sidebar-dynamic-area{flex:1;overflow-y:auto;overflow-x:hidden;display:block;min-height:0}.sidebar-placeholder{padding:24px 20px;color:var(--text-secondary, #666);text-align:center}.sidebar-dynamic-area::-webkit-scrollbar{width:6px}.sidebar-dynamic-area::-webkit-scrollbar-thumb{background-color:var(--border-color, #ccc);border-radius:3px}.sidebar-dynamic-area::-webkit-scrollbar-track{background:transparent}.index_modal_overlay{position:fixed;top:0;left:0;width:100vw;height:100vh;display:flex;align-items:center;justify-content:center;z-index:9999;background-color:#0f172a99;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px)}.index_modal_content{background-color:#fff;border-radius:8px;width:320px;padding:20px;box-shadow:0 10px 25px -5px #0000001a,0 8px 10px -6px #0000001a;display:flex;flex-direction:column;gap:16px}.index_modal_title{margin:0;color:#0f172a;font-size:16px;font-weight:600}.index_modal_input{padding:8px 12px;border-radius:6px;border:1px solid #cbd5e1;outline:none;font-size:14px;color:#0f172a;transition:border-color .2s}.index_modal_input:focus{border-color:#3b82f6}.index_modal_columns{display:flex;flex-direction:column;gap:8px;max-height:200px;overflow-y:auto;border:1px solid #e2e8f0;border-radius:6px;padding:8px;background-color:#f8fafc}.index_col_label{display:flex;align-items:center;gap:8px;cursor:pointer;padding:4px 0}.index_col_name{font-size:13px;color:#334155;flex:1;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.index_col_badges{display:flex;gap:4px}.index_badge{font-size:10px;font-weight:700;padding:2px 4px;border-radius:4px;color:#fff}.index_badge.uq{background-color:#10b981}.index_badge.nn{background-color:#64748b}.index_modal_actions{display:flex;gap:8px;margin-top:4px}.index_modal_btn{flex:1;padding:8px;border:none;border-radius:6px;font-size:14px;font-weight:500;cursor:pointer;transition:background-color .2s}.index_modal_btn.submit{background-color:#3b82f6;color:#fff}.index_modal_btn.submit:hover:not(:disabled){background-color:#2563eb}.index_modal_btn.submit:disabled{background-color:#94a3b8;cursor:not-allowed}.index_modal_btn.cancel{background-color:#f1f5f9;color:#475569;border:1px solid #cbd5e1}.index_modal_btn.cancel:hover{background-color:#e2e8f0}.tree-node-subgroup-wrapper{display:flex;align-items:center;justify-content:space-between;padding-right:20px}.tree-node-add-btn{background:transparent;border:none;font-size:16px;color:#3b82f6;cursor:pointer;display:flex;align-items:center;justify-content:center;width:20px;height:20px;border-radius:4px}.tree-node-add-btn:hover{background-color:#e2e8f0}.index_modal_checkbox_wrapper{display:flex;align-items:center;gap:8px;font-size:14px;color:#0f172a;cursor:pointer;padding:4px 0}.index_modal_checkbox_wrapper input[type=checkbox]{cursor:pointer}.schema-details-wrapper{display:block;padding:10px 0 100px}.schema-group{margin-bottom:8px}.schema-group-header{display:flex;align-items:center;justify-content:space-between;padding:8px 16px;background-color:var(--bg-color, #f9f9f9);border-bottom:1px solid var(--border-color, #eee);cursor:pointer;-webkit-user-select:none;user-select:none;transition:background-color .2s}.schema-group-header:hover{background-color:#f1f5f9}.chevron{position:static!important;margin:0!important;display:flex;align-items:center;justify-content:center;width:16px;height:16px;font-size:20px;line-height:1;color:#94a3b8;transition:transform .2s ease}.group_title{font-weight:600;font-size:14px;color:var(--text-main, #333);white-space:nowrap}.schema-group-title{display:flex;align-items:center;justify-content:flex-start;gap:8px}.group_title{display:block}.schema-group-content{padding:4px 0}.schema-empty-text{padding:8px 20px 8px 44px;font-size:13px;color:var(--text-secondary, #94a3b8);font-style:italic}.schema-context-menu{position:fixed;background:#fff;border:1px solid #ccc;box-shadow:0 4px 6px #0000001a;border-radius:6px;padding:4px;z-index:1000;min-width:150px}.schema-ctx-item{padding:8px 12px;font-size:13px;cursor:pointer;border-radius:4px;transition:background-color .2s}.schema-ctx-item:hover{background-color:#f1f5f9}.schema-ctx-item.danger{color:#ef4444}.schema-ctx-item.danger:hover{background-color:#fef2f2}.tree-node-container{display:flex;flex-direction:column}.tree-node-header{display:flex;align-items:center;padding:6px 20px 6px 36px;cursor:pointer;transition:background-color .2s;-webkit-user-select:none;user-select:none;position:relative}.tree-node-header:hover{background-color:var(--bg-color, #f1f5f9)}.chevron{display:inline-block;width:16px;text-align:center;transition:transform .2s;color:#94a3b8;position:absolute;left:16px;font-size:18px;line-height:1}.chevron.expanded{transform:rotate(90deg)}.tree-node-icon{margin-right:8px;font-size:14px;color:#64748b}.tree-node-title{font-size:14px;color:var(--text-main, #333);font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;flex-grow:1}.schema-add-btn.small{width:20px;height:20px;font-size:16px;opacity:0}.tree-node-header:hover .schema-add-btn.small{opacity:1}.tree-node-children{display:flex;flex-direction:column}.tree-node-subgroup{padding:4px 20px 4px 56px;font-size:11px;text-transform:uppercase;color:#94a3b8;font-weight:600;margin-top:4px}.tree-node-leaf{display:flex;align-items:center;justify-content:space-between;padding:4px 20px 4px 56px;cursor:context-menu;transition:background-color .2s;cursor:pointer}.tree-node-leaf:hover{background-color:#f8fafc}.tree-node-leaf.ref-leaf{padding-left:44px}.leaf-main-info{display:flex;align-items:center;gap:6px;flex-grow:1;overflow:hidden}.tree-node-type{font-size:12px;color:#64748b;font-family:monospace;white-space:nowrap}.leaf-badges{display:flex;gap:4px}.badge{font-size:10px;font-weight:700;padding:2px 4px;border-radius:4px;color:#fff}.badge.pk{background-color:#eab308}.badge.ai{background-color:#3b82f6}.badge.unique{background-color:#10b981}.badge.constraint{background-color:#94a3b8}.ref-details{display:flex;align-items:center;gap:6px;font-size:13px;color:var(--text-main, #333)}.inline-edit-input{background:var(--bg-color, #ffffff);border:1px solid #3b82f6;color:var(--text-main, #333);font-family:inherit;font-size:13px;padding:2px 6px;border-radius:4px;outline:none;width:140px;box-shadow:0 0 0 2px #3b82f633}.ref-arrow{color:#94a3b8}.users-overlay{position:absolute;top:20px;right:20px;width:240px;background:var(--card-bg);border-radius:var(--radius-sm);box-shadow:var(--shadow-md);border:1px solid var(--border-color);z-index:50;overflow:hidden;transition:all .3s ease;display:flex;flex-direction:column;max-height:400px}.users-overlay.collapsed{max-height:46px}.users-header{padding:12px 16px;background:var(--bg-color);border-bottom:1px solid var(--border-color);font-size:14px;font-weight:600;display:flex;justify-content:space-between;align-items:center;cursor:pointer;-webkit-user-select:none;user-select:none}.toggle-users-btn{background:none;border:none;cursor:pointer;color:var(--text-secondary);padding:0;display:flex}.users-list{padding:8px 0;overflow-y:auto}.user-item{display:flex;align-items:center;padding:8px 16px;gap:10px;transition:background .2s}.user-item:hover{background-color:#f9fafb}.user-avatar{width:28px;height:28px;border-radius:50%;object-fit:cover;border:1px solid var(--border-color)}.user-email{font-size:13px;color:var(--text-main);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.er_add_column_menu__container{position:absolute;top:50%;margin-top:8px;width:260px;background-color:#fff;border:1px solid #cbd5e1;border-radius:8px;padding:16px;z-index:1000;box-shadow:0 10px 25px -5px #0000001a,0 8px 10px -6px #0000000a}.add_column_title{margin:0 0 12px;color:#0f172a;font-size:16px;font-weight:600;padding-bottom:10px;border-bottom:1px solid #e2e8f0}.er_add_column_menu{display:flex;flex-direction:column;gap:10px}.col_input,.col_type_select,.col_length_input,.col_description_input,.col_default_input,.col_precision_input,.col_scale_input,.min-max-input{padding:8px 12px;border-radius:6px;border:1px solid #cbd5e1;background-color:#f8fafc;color:#0f172a;font-size:13px;outline:none;transition:all .2s ease;box-sizing:border-box;font-family:inherit}.col_input:focus,.col_type_select:focus,.col_length_input:focus,.col_description_input:focus,.col_default_input:focus,.col_precision_input:focus,.col_scale_input:focus,.min-max-input:focus{border-color:#3b82f6;background-color:#fff}.col_decimal_input{display:flex;gap:8px}.col_precision_input,.col_scale_input{width:50%}.col_default_container{display:flex;gap:8px}.col_default_input{flex:1}.col_default_container button{background-color:#f8fafc;border:1px solid #cbd5e1;border-radius:6px;cursor:pointer;transition:all .2s ease;display:flex;align-items:center;justify-content:center;color:#475569}.col_default_container button:hover{background-color:#e2e8f0;border-color:#94a3b8}.add_col_constraint_container{display:flex;flex-wrap:wrap;gap:12px;color:#334155;font-size:13px;font-weight:500;margin-top:4px}.add_col_constraint_label{display:flex;align-items:center;gap:6px;white-space:nowrap;cursor:pointer}.add_col_constraint_label input[type=checkbox]{cursor:pointer;accent-color:#3b82f6}.add_col_constraint_label input[type=checkbox]:disabled{cursor:not-allowed;opacity:.5}.add_col_btn_container{display:flex;gap:8px;margin-top:12px}.add_col_btn{flex:1;padding:8px 12px;color:#fff;border:none;border-radius:6px;font-size:13px;font-weight:500;cursor:pointer;transition:filter .2s ease,background-color .2s ease}.add_col_btn:hover{filter:brightness(.9)}.add_col_min_max_container{display:flex;justify-content:space-between;gap:8px}.min_max_container{display:flex;flex-direction:column;gap:4px;flex:1}.min-max-label{color:#475569;font-size:12px;font-weight:600}.input-wrapper{position:relative;width:100%}.min-max-input{width:100%;padding-right:28px}.clear-icon{position:absolute;right:8px;top:50%;transform:translateY(-50%);cursor:pointer;color:#94a3b8;transition:color .2s ease}.clear-icon:hover{color:#ef4444}.er_column_row{position:relative;height:32px;display:flex;align-items:center;justify-content:center;border-bottom:1px solid #f3f4f6;box-sizing:border-box}.er_port{position:absolute;top:50%;transform:translateY(-50%);width:12px;height:12px;background:#d1d5db;border-radius:50%;cursor:pointer;border:2px solid white;box-shadow:0 0 2px #0003;transition:all .2s;z-index:20}.er_port:hover{transform:translateY(-50%) scale(1.2)}.port_left{left:-6px}.port_right{right:-6px}.port_source_active{background:#2563eb;transform:translateY(-50%) scale(1.4);box-shadow:0 0 0 3px #2563eb33;z-index:25}.port_target_active{background:#f59e0b;transform:translateY(-50%) scale(1.4);box-shadow:0 0 0 3px #f59e0b33;z-index:25}.port_badge{position:absolute;top:-14px;color:#fff;font-size:9px;font-weight:700;width:14px;height:14px;border-radius:50%;display:flex;align-items:center;justify-content:center;pointer-events:none;z-index:30}.badge_right{right:-8px;background:#2563eb}.badge_left{left:-8px;background:#f59e0b}.col_name{font-size:13px;color:#374151;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.col_info_wrapper{display:flex;align-items:center;width:85%;gap:6px;overflow:hidden}.col_type{font-size:11px;color:#94a3b8}.col_constraint_container{display:flex;gap:3px;margin-left:auto;font-size:9px;font-weight:700;color:#64748b}.col_constraint{padding:2px;border:1px solid #334155;border-radius:3px}.er_table_card{position:absolute;background:#fff;border-radius:8px;box-shadow:0 4px 6px -1px #0000001a,0 2px 4px -1px #0000000f;border:1px solid #e5e7eb;display:flex;flex-direction:column;z-index:10}.er_table_header{background:#2563eb;padding:13px;border-radius:7px 7px 0 0;cursor:grab;color:#fff;font-weight:600;font-size:14px;outline:none;text-align:center}.er_table_header:active{cursor:grabbing}.er_table_separator{height:2px;background:#1e40af;width:100%}.er_column_list{background:#fff;padding:4px 0;min-height:20px}.er_add_col_btn{width:100%;border:none;background:#f9fafb;color:#2563eb;font-size:12px;font-weight:600;padding:8px;cursor:pointer;border-radius:0 0 7px 7px;border-top:1px solid #e5e7eb}.er_add_col_btn:hover{background:#eff6ff}.er_add_reference_menu__container{position:absolute;top:0;left:0;width:350px;background-color:#fff;border:1px solid #1e40af;border-radius:8px;z-index:1000;box-shadow:0 10px 15px -3px #0000001a,0 4px 6px -2px #0000000d;display:flex;flex-direction:column;will-change:transform;transform-origin:top left}.add_reference_header{padding:12px 16px;background-color:#2563eb;border-bottom:1px solid #e2e8f0;border-top-left-radius:8px;border-top-right-radius:8px;cursor:grab;-webkit-user-select:none;user-select:none}.add_reference_header:active{cursor:grabbing}.add_reference_title{margin:0;font-size:15px;color:#fff;font-weight:600}.er_add_reference_menu{padding:16px;display:flex;flex-direction:column;gap:16px}.ref_controls_group{display:flex;flex-direction:column;gap:12px}.ref_actions_row{display:flex;gap:12px}.ref_action_col{flex:1;display:flex;flex-direction:column;gap:4px}.ref_label{font-size:12px;color:#64748b;font-weight:500}.ref_select{width:100%;padding:6px 8px;border-radius:6px;border:1px solid #cbd5e1;background-color:#fff;color:#0f172a;font-size:13px;outline:none;transition:border-color .2s}.ref_select:focus{border-color:#3b82f6}.ref_mapping_box{border:1px solid #e2e8f0;border-radius:6px;padding:12px;background-color:#f8fafc}.ref_mapping_header{display:flex;border-bottom:1px solid #cbd5e1;padding-bottom:6px;margin-bottom:12px;font-size:12px;font-weight:600;color:#475569}.ref_mapping_col{flex:1}.ref_mapping_row{display:flex;align-items:center;gap:8px;margin-bottom:6px}.ref_mapping_row:last-child{margin-bottom:0}.ref_col_item{flex:1;background-color:#fff;border:1px solid #e2e8f0;padding:6px 8px;border-radius:4px;font-size:13px;color:#0f172a;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;box-shadow:0 1px 2px #0000000d}.target_item{display:flex;align-items:center;gap:6px}.ref_col_text{flex:1;overflow:hidden;text-overflow:ellipsis}.ref_arrow_icon{color:#94a3b8;font-size:14px}.ref_col_controls{display:flex;flex-direction:column;gap:2px}.ref_ctrl_btn{font-size:8px;padding:2px 4px;background:transparent;border:none;cursor:pointer;color:#64748b;border-radius:2px}.ref_ctrl_btn:hover:not(:disabled){background-color:#e2e8f0;color:#0f172a}.ref_ctrl_btn:disabled{opacity:.3;cursor:not-allowed}.ref_btn_container{display:flex;gap:8px}.ref_btn{flex:1;padding:8px;border-radius:6px;border:none;font-size:14px;font-weight:500;cursor:pointer;transition:all .2s}.submit_btn{background-color:#2563eb;color:#fff}.submit_btn:hover:not(:disabled){background-color:#2563eb}.submit_btn:disabled{background-color:#94a3b8;cursor:not-allowed}.cancel_btn{background-color:#f1f5f9;color:#475569;border:1px solid #cbd5e1}.cancel_btn:hover{background-color:#e2e8f0}.modal__overlay{position:fixed;inset:0;background-color:#0f172a66;z-index:10000;display:flex;align-items:center;justify-content:center;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px)}.modal__container{background-color:#fff;padding:24px;border-radius:12px;width:400px;border:1px solid #e2e8f0;color:#0f172a;box-shadow:0 20px 25px -5px #0000001a,0 10px 10px -5px #0000000a}.delete_table_header{margin:0 0 12px;font-size:18px;font-weight:600;display:flex;align-items:center;gap:8px;color:#0f172a}.delete_table_message{margin:0 0 24px;color:#475569;font-size:14px;line-height:1.5}.delete_table_btn_container{display:flex;gap:12px;justify-content:flex-end}.delete_table_btn_cancel{padding:8px 16px;border-radius:6px;border:1px solid #cbd5e1;background-color:#f1f5f9;color:#475569;cursor:pointer;font-family:inherit;font-size:14px;font-weight:500;transition:all .2s ease}.delete_table_btn_cancel:hover{background-color:#e2e8f0}.delete_table_btn_confirm{padding:8px 16px;border-radius:6px;border:none;background-color:#ef4444;color:#fff;cursor:pointer;font-family:inherit;font-size:14px;font-weight:600;transition:all .2s ease}.delete_table_btn_confirm:hover{background-color:#dc2626}.er_modal_overlay{position:fixed;inset:0;background-color:#0f172a66;z-index:10000;display:flex;align-items:center;justify-content:center;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px)}.er_modal_content{background-color:#fff;padding:24px;border-radius:12px;width:400px;border:1px solid #e2e8f0;color:#0f172a;box-shadow:0 20px 25px -5px #0000001a,0 10px 10px -5px #0000000a}.er_modal_title{margin:0 0 12px;font-size:18px;font-weight:600;display:flex;align-items:center;gap:8px}.er_modal_icon{font-size:24px}.er_modal_text{margin:0 0 24px;color:#475569;font-size:14px;line-height:1.5}.er_modal_highlight{color:#0f172a;font-weight:600}.er_modal_actions{display:flex;gap:12px;justify-content:flex-end}.er_modal_btn{padding:8px 16px;border-radius:6px;border:none;cursor:pointer;font-family:inherit;font-size:14px;font-weight:500;transition:all .2s ease}.er_modal_btn_cancel{background-color:#f1f5f9;color:#475569;border:1px solid #cbd5e1}.er_modal_btn_cancel:hover{background-color:#e2e8f0}.er_modal_btn_delete{background-color:#ef4444;color:#fff}.er_modal_btn_delete:hover{background-color:#dc2626}.er_edit_modal_overlay{position:fixed;inset:0;background-color:#0f172a66;z-index:10000;display:flex;align-items:center;justify-content:center;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px)}.er_edit_modal_content{background-color:#fff;padding:24px;border-radius:12px;width:400px;border:1px solid #e2e8f0;color:#0f172a;box-shadow:0 20px 25px -5px #0000001a,0 10px 10px -5px #0000000a}.er_edit_modal_title{margin:0 0 20px;font-size:18px;font-weight:600;display:flex;align-items:center;gap:8px;color:#0f172a}.er_edit_modal_form{display:flex;flex-direction:column;gap:16px;margin-bottom:24px}.er_edit_modal_group{display:flex;flex-direction:column;gap:6px}.er_edit_modal_label{font-size:13px;font-weight:600;color:#475569}.er_edit_modal_input,.er_edit_modal_textarea{width:100%;padding:8px 12px;border-radius:6px;border:1px solid #cbd5e1;background-color:#f8fafc;color:#0f172a;font-size:14px;box-sizing:border-box;transition:all .2s ease;font-family:inherit;outline:none}.er_edit_modal_textarea{resize:vertical;min-height:80px}.er_edit_modal_input:focus,.er_edit_modal_textarea:focus{border-color:#3b82f6;background-color:#fff}.er_edit_modal_actions{display:flex;gap:12px;justify-content:flex-end}.er_edit_modal_btn{padding:8px 16px;border-radius:6px;border:none;cursor:pointer;font-size:14px;font-weight:500;font-family:inherit;transition:all .2s ease}.er_edit_modal_btn_cancel{background-color:#f1f5f9;color:#475569;border:1px solid #cbd5e1}.er_edit_modal_btn_cancel:hover{background-color:#e2e8f0}.er_edit_modal_btn_save{background-color:#3b82f6;color:#fff}.er_edit_modal_btn_save:hover{background-color:#2563eb}.er_zoom_controls{position:absolute;bottom:24px;right:24px;display:flex;align-items:center;background-color:#fff;border:1px solid #e2e8f0;border-radius:8px;box-shadow:0 4px 6px -1px #0000001a,0 2px 4px -1px #0000000f;z-index:100;padding:4px;gap:4px}.er_zoom_btn{display:flex;align-items:center;justify-content:center;width:32px;height:32px;background:transparent;border:none;border-radius:6px;color:#64748b;cursor:pointer;transition:background-color .2s,color .2s}.er_zoom_btn:hover{background-color:#f1f5f9;color:#0f172a}.er_zoom_btn:active{background-color:#e2e8f0}.er_zoom_input_wrapper{display:flex;align-items:center;justify-content:center;padding:0 2px;color:#475569}.er_zoom_input{width:28px;background:transparent;border:none;color:#0f172a;font-size:13px;font-weight:500;text-align:right;padding:0;outline:none;font-family:inherit;transition:color .2s}.er_zoom_input:focus{color:#2563eb;box-shadow:0 1px #3b82f6}.er_zoom_percent{font-size:13px;font-weight:500;margin-left:2px;-webkit-user-select:none;user-select:none}.er_diagram_wrapper{width:100%;height:100%;position:relative;background-color:#f3f4f6;background-image:linear-gradient(#e5e7eb 1px,transparent 1px),linear-gradient(90deg,#e5e7eb 1px,transparent 1px);background-size:20px 20px;overflow:hidden;-webkit-user-select:none;user-select:none}.er_viewport{width:100%;height:100%;position:absolute;transform-origin:0 0}.er_svg_layer{position:absolute;top:0;left:0;width:100%;height:100%;pointer-events:none;overflow:visible}.er_line{fill:none;stroke:#64748b;stroke-width:2px;stroke-linejoin:round;transition:stroke .2s;pointer-events:auto}.er_line:hover{stroke:#2563eb;stroke-width:3px;cursor:pointer;z-index:50}.er_relation_label,.er_line,.er_relation_point{transition:fill .2s ease,stroke .2s ease}.er_relation_group:hover .er_relation_label{fill:#2563eb;padding:2px}.er_relation_group:hover .er_relation_point{fill:#2563eb}.er_relation_group:hover .er_line{stroke:#2563eb}.er_ctx_menu{position:absolute;background:#fff;border:1px solid #e5e7eb;box-shadow:0 4px 6px -1px #0000001a;border-radius:6px;padding:4px;z-index:100;min-width:140px}.er_ctx_item{padding:8px 12px;font-size:13px;cursor:pointer;color:#374151;border-radius:4px}.er_ctx_item:hover{background:#f3f4f6}.er_selection_marquee{position:absolute;border:1px solid #2563eb;background-color:#3b82f61a;pointer-events:none;z-index:9999}.er_table_card.selected{outline:3px solid #3b82f6;outline-offset:1px;box-shadow:0 0 0 4px #3b82f633}.er_relation_group.selected .er_line{stroke:#3b82f6!important;filter:drop-shadow(0 0 3px rgba(59,130,246,.6))}.er_relation_group.selected text{fill:#2563eb!important}.er_relation_group.selected circle{fill:#2563eb!important}.er_cursor_controls{position:absolute;bottom:24px;left:50%;transform:translate(-50%);display:flex;align-items:center;background-color:#fff;border:1px solid #cbd5e1;border-radius:8px;box-shadow:0 4px 6px -1px #0000001a,0 2px 4px -1px #0000000f;z-index:100;padding:4px;gap:4px}.er_cursor_btn{display:flex;align-items:center;justify-content:center;width:36px;height:36px;background:transparent;border:none;border-radius:6px;color:#64748b;cursor:pointer;transition:all .2s}.er_cursor_btn:hover{background-color:#f1f5f9;color:#0f172a}.er_cursor_btn.active{background-color:#eff6ff;color:#2563eb;box-shadow:inset 0 0 0 1px #bfdbfe}.version_modal_overlay{position:fixed;inset:0;background-color:#0f172a66;z-index:10000;display:flex;align-items:center;justify-content:center}.version_modal_content{background-color:#fff;padding:24px;border-radius:12px;width:400px;border:1px solid #e2e8f0;color:#0f172a;box-shadow:0 20px 25px -5px #0000001a,0 10px 10px -5px #0000000a}.version_modal_title{margin:0 0 8px;font-size:18px;font-weight:600;display:flex;align-items:center;gap:8px}.version_modal_description{margin:0 0 20px;color:#64748b;font-size:14px;line-height:1.5}.version_modal_form_group{display:flex;flex-direction:column;gap:6px;margin-bottom:24px}.version_modal_label{font-size:13px;font-weight:600;color:#475569}.version_modal_input{width:100%;padding:8px 12px;border-radius:6px;border:1px solid #cbd5e1;background-color:#f8fafc;color:#0f172a;font-size:14px;box-sizing:border-box;transition:border-color .2s ease,background-color .2s ease;outline:none}.version_modal_input:focus{border-color:#3b82f6;background-color:#fff}.version_modal_error{color:#ef4444;font-size:12px;margin-top:4px}.version_modal_actions{display:flex;gap:12px;justify-content:flex-end}.version_modal_btn{padding:8px 16px;border-radius:6px;border:none;cursor:pointer;font-size:14px;font-weight:500;transition:all .2s ease}.version_modal_btn_cancel{background-color:#f1f5f9;color:#475569;border:1px solid #cbd5e1}.version_modal_btn_cancel:hover{background-color:#e2e8f0}.version_modal_btn_save{background-color:#3b82f6;color:#fff}.version_modal_btn_save:hover{background-color:#2563eb}.participation_list__overlay{position:fixed;inset:0;background-color:#0f172a66;z-index:10000;display:flex;align-items:center;justify-content:center;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px)}.participation_list__container{display:flex;flex-direction:column;background-color:#fff;width:400px;min-height:500px;max-height:80vh;border-radius:12px;box-shadow:0 20px 25px -5px #0000001a,0 10px 10px -5px #0000000a;border:1px solid #e2e8f0;overflow:hidden}.participation_list__header{position:relative;display:flex;align-items:center;justify-content:center;padding:16px 20px;border-bottom:1px solid #e2e8f0;background-color:#f8fafc;flex-shrink:0}.participation_list__header>h3{margin:0;font-size:18px;font-weight:600;color:#0f172a}.participation_list__header>img{position:absolute;width:24px;height:24px;right:16px;cursor:pointer;padding:4px;border-radius:6px;transition:background-color .2s ease}.participation_list__header>img:hover{background-color:#e2e8f0}.participation_list__content{flex:1;overflow-y:auto;padding:16px;display:flex;flex-direction:column;gap:8px}.participation_info{padding:10px 12px;border:1px solid #e2e8f0;border-radius:8px;display:flex;align-items:center;transition:all .2s ease;cursor:pointer;background-color:#fff}.participation_info>img{width:32px;height:32px;border-radius:50%;object-fit:cover}.participation_info__email{color:#334155;margin-left:12px;font-size:14px;font-weight:500}.participation_info:hover{background-color:#eff6ff;border-color:#bfdbfe}.invite_btn_holder{padding:16px;border-top:1px solid #e2e8f0;background-color:#f8fafc;display:flex;justify-content:center;flex-shrink:0;margin-top:auto}.invite_btn{padding:10px 20px;color:#fff;background-color:#3b82f6;font-size:14px;font-weight:600;cursor:pointer;border-radius:6px;transition:background-color .2s ease;width:100%;text-align:center}.invite_btn:hover{background-color:#2563eb}.participation_info_tooltip__container{position:fixed;background-color:#fff;width:300px;padding:16px;z-index:100000;border-radius:12px;border:1px solid #e2e8f0;display:flex;flex-direction:column;gap:12px;animation:fadeInSlide .2s ease-out forwards;box-shadow:0 10px 25px -5px #0000001a,0 8px 10px -6px #0000000a}.tooltip_authority_label{color:#334155;font-size:14px;font-weight:500}.tooltip_authority_container input[type=checkbox]{cursor:pointer;accent-color:#3b82f6}.tooltip_authority_container input[type=checkbox]:disabled{cursor:not-allowed}.btn_holders{margin-top:8px;width:100%;display:flex;gap:8px}.save_btn{flex:1;padding:8px 12px;color:#fff;background-color:#3b82f6;font-size:13px;font-weight:600;cursor:pointer;border:none;border-radius:6px;transition:background-color .2s ease}.save_btn:hover:not(:disabled){background-color:#2563eb}.save_btn:disabled{background-color:#94a3b8;cursor:not-allowed}.kick_user_btn{flex:1;padding:8px 12px;color:#fff;background-color:#ef4444;font-size:13px;font-weight:600;cursor:pointer;border:none;border-radius:6px;transition:background-color .2s ease}.kick_user_btn:hover:not(:disabled){background-color:#dc2626}.kick_user_btn:disabled{background-color:#fca5a5;cursor:not-allowed}.tooltip_header{margin:0;font-size:15px;font-weight:600;width:100%;text-align:center;color:#0f172a}.tooltip_header_separator{height:1px;width:100%;background-color:#e2e8f0;border:none;margin:0}.tooltip_user_creator_text{color:#64748b;font-size:13px;text-align:center;display:block;padding:8px 0}@keyframes fadeInSlide{0%{opacity:0;transform:translate(-10px,5px)}to{opacity:1;transform:translate(0)}}.invite_modal__overlay{position:fixed;top:0;left:0;width:100vw;height:100vh;background-color:#0f172a66;display:flex;justify-content:center;align-items:center;z-index:1000;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px)}.invite_modal__container{background-color:#fff;border-radius:12px;width:400px;max-width:90%;color:#0f172a;box-shadow:0 20px 25px -5px #0000001a,0 10px 10px -5px #0000000a;border:1px solid #e2e8f0;display:flex;flex-direction:column;overflow:hidden}.invite_modal__header{display:flex;justify-content:space-between;align-items:center;padding:16px 20px;border-bottom:1px solid #e2e8f0;background-color:#f8fafc}.invite_modal__header h3{margin:0;font-size:18px;font-weight:600;color:#0f172a}.invite_modal__header img{cursor:pointer;width:24px;height:24px;padding:4px;border-radius:6px;transition:background-color .2s ease}.invite_modal__header img:hover{background-color:#e2e8f0}.invite_modal__body{padding:20px;display:flex;flex-direction:column;gap:20px}.invite_modal__field_group{display:flex;flex-direction:column;gap:8px}.invite_modal__label{font-size:13px;font-weight:600;color:#475569}.invite_modal__input{padding:10px 12px;border-radius:6px;border:1px solid #cbd5e1;background-color:#f8fafc;color:#0f172a;outline:none;font-size:14px;font-family:inherit;transition:all .2s ease}.invite_modal__input:focus{border-color:#3b82f6;background-color:#fff}.invite_modal__input--error{border-color:#ef4444}.invite_modal__error_text{color:#ef4444;font-size:12px;margin-top:-4px}.invite_modal__empty_text{font-size:13px;color:#64748b}.invite_modal__checkbox_list{display:flex;flex-direction:column;gap:10px}.invite_modal__checkbox_item{display:flex;align-items:center;gap:8px;cursor:pointer}.invite_modal__checkbox_item input[type=checkbox]{cursor:pointer;accent-color:#3b82f6}.invite_modal__checkbox_label{font-size:14px;color:#334155}.invite_modal__footer{display:flex;justify-content:flex-end;gap:12px;margin-top:10px}.invite_modal__btn_cancel{padding:8px 16px;border-radius:6px;border:1px solid #cbd5e1;background-color:#f1f5f9;color:#475569;cursor:pointer;font-family:inherit;font-size:14px;font-weight:500;transition:all .2s ease}.invite_modal__btn_cancel:hover{background-color:#e2e8f0}.invite_modal__btn_submit{padding:8px 16px;border-radius:6px;border:none;background-color:#3b82f6;color:#fff;cursor:pointer;font-family:inherit;font-size:14px;font-weight:500;transition:all .2s ease}.invite_modal__btn_submit:hover:not(:disabled){background-color:#2563eb}.invite_modal__btn_submit:disabled{background-color:#94a3b8;cursor:not-allowed}:root{--primary: #2563eb;--primary-hover: #1d4ed8;--bg-page: #f3f4f6;--white: #ffffff;--text-dark: #111827;--text-gray: #6b7280;--border: #e5e7eb;--shadow-sm: 0 1px 3px rgba(0,0,0,.1);--shadow-md: 0 4px 12px rgba(0,0,0,.08);--radius: 12px}.schema_page__container{height:100vh;display:flex;flex-direction:column;background-color:var(--bg-page);font-family:Inter,sans-serif}.schema_page__header{width:100%;height:64px;background:var(--white);border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between;z-index:10}.header_left{display:flex;align-items:center;gap:16px;padding-left:24px}.schema_page__name{font-size:18px;font-weight:700;color:var(--text-dark)}.schema_controls{display:flex;gap:12px;padding-right:24px}.btn_primary{background:var(--primary);color:#fff;border:none;padding:8px 16px;border-radius:8px;font-weight:600;cursor:pointer}.btn_secondary{background:#fff;border:1px solid var(--border);padding:8px 16px;border-radius:8px;color:var(--text-dark);cursor:pointer}.schema_page__workspace{flex:1;display:flex;overflow:hidden;position:relative}.schema_canvas_area{flex:1;position:relative;overflow:hidden}.btn_leave{background:red;border:1px solid var(--border);padding:8px 16px;border-radius:8px;color:#fff;cursor:pointer}.scripts_modal_overlay{position:fixed;top:0;left:0;width:100vw;height:100vh;display:flex;align-items:center;justify-content:center;z-index:9999;background-color:#0f172a99;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px)}.scripts_modal_container{width:80%;max-width:1200px;min-width:600px;max-height:85vh;background-color:#fff;border-radius:12px;box-shadow:0 20px 25px -5px #0000001a,0 10px 10px -5px #0000000a;display:flex;flex-direction:column;overflow:hidden}.scripts_modal_header{display:flex;align-items:center;justify-content:space-between;padding:16px 24px;background-color:#f8fafc;border-bottom:1px solid #e2e8f0}.scripts_header_left{display:flex;align-items:center;gap:16px}.scripts_modal_title{margin:0;font-size:20px;font-weight:600;color:#0f172a}.scripts_create_btn{background-color:#e0f2fe;color:#0284c7;border:1px solid #bae6fd;padding:6px 12px;border-radius:6px;font-size:13px;font-weight:600;cursor:pointer;transition:all .2s}.scripts_create_btn:hover{background-color:#bae6fd;color:#0369a1}.scripts_modal_close{background:transparent;border:none;color:#64748b;cursor:pointer;display:flex;align-items:center;justify-content:center;padding:4px;border-radius:6px;transition:all .2s ease}.scripts_modal_close:hover{background-color:#e2e8f0;color:#ef4444}.scripts_modal_content{padding:0;overflow-y:auto;flex:1}.scripts_empty_state{padding:40px;text-align:center;color:#64748b;font-size:15px}.scripts_table{width:100%;border-collapse:collapse;text-align:left}.scripts_table th{background-color:#fff;color:#475569;font-weight:600;font-size:13px;padding:12px 24px;border-bottom:2px solid #e2e8f0;position:sticky;top:0;z-index:10}.scripts_table td{padding:12px 24px;border-bottom:1px solid #f1f5f9;color:#334155;font-size:14px;vertical-align:middle}.scripts_table_row:hover td{background-color:#f8fafc}.scripts_group_header td{background-color:#eff6ff;color:#1e3a8a;font-weight:600;font-size:14px;padding:8px 24px;border-bottom:1px solid #bfdbfe;border-top:1px solid #bfdbfe}.scripts_icon_cell{display:flex;align-items:center;justify-content:center}.scripts_download_link{display:inline-flex;align-items:center;gap:8px;color:#3b82f6;text-decoration:none;font-weight:500;transition:color .2s;cursor:pointer}.scripts_download_link:hover{color:#2563eb;text-decoration:underline}.download_icon{opacity:0;transform:translateY(-2px);transition:all .2s ease}.scripts_download_link:hover .download_icon{opacity:1;transform:translateY(0)}.badge{display:inline-block;padding:4px 10px;border-radius:6px;font-size:11px;font-weight:700;letter-spacing:.5px}.badge_mysql{background-color:#e0f2fe;color:#0369a1;border:1px solid #bfdbfe}.badge_postgres{background-color:#ede9fe;color:#075985;border:1px solid #bae6fd}.badge_liquibase{background-color:#dcfce7;color:#065f46;border:1px solid #a7f3d0}.badge_full{background-color:#f1f5f9;color:#475569;border:1px solid #e2e8f0}.badge_migration{background-color:#fef9c3;color:#b45309;border:1px solid #fde047}.scripts_details_cell{font-size:13px}.migration_text{color:#64748b}.migration_text strong{color:#0f172a}.full_text{color:#cbd5e1}.create_script_overlay{position:absolute;top:0;left:0;width:100%;height:100%;background-color:#0f172a99;display:flex;align-items:center;justify-content:center;z-index:9999;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px)}.create_script_content{width:400px;background-color:#fff;border-radius:12px;padding:24px;box-shadow:0 20px 25px -5px #0000001a,0 10px 10px -5px #0000000a;border:1px solid #e2e8f0;display:flex;flex-direction:column;gap:16px}.create_script_title{margin:0 0 8px;color:#0f172a;font-size:18px;font-weight:600}.create_form_group{display:flex;flex-direction:column;gap:6px}.create_label{font-size:13px;font-weight:600;color:#475569}.create_select{padding:8px 12px;border-radius:6px;border:1px solid #cbd5e1;background-color:#f8fafc;color:#0f172a;font-size:14px;outline:none;transition:border-color .2s}.create_select:focus{border-color:#3b82f6;background-color:#fff}.create_radio_group{display:flex;gap:8px}.create_radio_label{flex:1;display:flex;align-items:center;justify-content:center;gap:6px;padding:8px;border:1px solid #cbd5e1;border-radius:6px;font-size:13px;font-weight:500;color:#475569;cursor:pointer;transition:all .2s;background-color:#f8fafc}.create_radio_label input{display:none}.create_radio_label.active{background-color:#eff6ff;border-color:#3b82f6;color:#1d4ed8}.create_radio_label.disabled{opacity:.5;cursor:not-allowed;background-color:#f1f5f9}.create_script_actions{display:flex;gap:8px;margin-top:8px}.create_script_btn{flex:1;padding:10px;border-radius:6px;border:none;font-size:14px;font-weight:600;cursor:pointer;transition:all .2s}.create_script_btn.submit{background-color:#3b82f6;color:#fff}.create_script_btn.submit:hover:not(:disabled){background-color:#2563eb}.create_script_btn.submit:disabled{background-color:#94a3b8;cursor:not-allowed}.create_script_btn.cancel{background-color:#f1f5f9;color:#475569;border:1px solid #cbd5e1}.create_script_btn.cancel:hover{background-color:#e2e8f0}
