.auth-container{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#667eea,#764ba2);padding:20px}.auth-card{background:#fff;border-radius:12px;box-shadow:0 20px 60px #0000004d;padding:40px;width:100%;max-width:420px}.auth-header{text-align:center;margin-bottom:32px}.auth-title{font-size:24px;font-weight:600;color:#1a1a2e;margin:0 0 8px}.auth-subtitle{font-size:14px;color:#666;margin:0}.auth-form{margin-bottom:24px}.auth-error{background:#fee;color:#c33;padding:12px;border-radius:6px;margin-bottom:16px;font-size:13px}.auth-success{background:#efe;color:#3c3;padding:12px;border-radius:6px;margin-bottom:16px;font-size:13px}.auth-hint{font-size:12px;color:#666;margin-bottom:16px;line-height:1.5}.auth-footer{text-align:center;font-size:13px;color:#666}.auth-debug{background:#f0f0f0;padding:12px;border-radius:6px;margin-top:16px;font-size:12px}.auth-debug a{color:#667eea;word-break:break-all}.link-btn{background:none;border:none;color:#667eea;cursor:pointer;font-size:inherit;text-decoration:underline;padding:0}.link-btn:hover{color:#764ba2}.btn-block{width:100%;padding:12px;font-size:15px;font-weight:500}.form-group{margin-bottom:16px}.form-label{display:block;font-size:13px;font-weight:500;color:#333;margin-bottom:6px}.form-input{width:100%;padding:10px 12px;border:1px solid #ddd;border-radius:6px;font-size:14px;transition:border-color .2s;box-sizing:border-box}.form-input:focus{outline:none;border-color:#667eea}.form-input:disabled{background:#f5f5f5;cursor:not-allowed}.btn{padding:10px 20px;border:none;border-radius:6px;font-size:14px;font-weight:500;cursor:pointer;transition:all .2s;background:#f0f0f0;color:#333}.btn:hover{background:#e0e0e0}.btn:disabled{opacity:.6;cursor:not-allowed}.btn-primary{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff}.btn-primary:hover{background:linear-gradient(135deg,#764ba2,#667eea)}.btn-primary:disabled{opacity:.6}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{--bg1: #ffffff;--bg2: #f8f7f3;--bg3: #f0ede6;--border: rgba(0,0,0,.1);--border2: rgba(0,0,0,.2);--txt1: #1a1a18;--txt2: #6b6b67;--txt3: #9b9b97;--radius: 8px;--radius-lg: 12px;--accent: #534AB7;--accent-hover: #3C3489;--font-mono: "Consolas", "Courier New", monospace}body{font-family:system-ui,-apple-system,Segoe UI,sans-serif;background:var(--bg3);color:var(--txt1);font-size:13px;height:100vh;overflow:hidden}.app{display:flex;height:100vh;overflow:hidden}.sidebar{width:210px;min-width:210px;background:var(--bg1);border-right:.5px solid var(--border);display:flex;flex-direction:column;overflow:hidden}.sidebar-logo{padding:18px 16px 14px;border-bottom:.5px solid var(--border)}.logo-title{font-size:14px;font-weight:600;color:var(--txt1)}.logo-sub{font-size:11px;color:var(--txt3);margin-top:3px}.sidebar-nav{flex:1;overflow-y:auto;padding:8px 0}.nav-group{margin-bottom:2px}.nav-group-label{font-size:10px;font-weight:600;color:var(--txt3);padding:10px 16px 4px;letter-spacing:.07em;text-transform:uppercase}.nav-item{display:flex;align-items:center;gap:9px;padding:8px 16px;cursor:pointer;font-size:12.5px;color:var(--txt2);border-left:2px solid transparent;transition:background .12s,color .12s}.nav-item:hover{background:var(--bg2);color:var(--txt1)}.nav-item.active{background:var(--bg2);color:var(--txt1);border-left-color:var(--accent);font-weight:500}.nav-dot{width:7px;height:7px;border-radius:50%;flex-shrink:0}.main{flex:1;display:flex;flex-direction:column;overflow:hidden}.topbar{height:50px;background:var(--bg1);border-bottom:.5px solid var(--border);display:flex;align-items:center;padding:0 20px;gap:12px;flex-shrink:0}.topbar-title{font-size:14px;font-weight:500;flex:1}.content{flex:1;overflow:auto;padding:20px;position:relative}.btn{display:inline-flex;align-items:center;gap:5px;padding:6px 13px;border-radius:var(--radius);font-size:12px;font-weight:500;cursor:pointer;border:.5px solid var(--border2);background:var(--bg1);color:var(--txt1);transition:background .12s,border-color .12s;white-space:nowrap}.btn:hover{background:var(--bg2)}.btn-primary{background:var(--accent);color:#fff;border-color:var(--accent)}.btn-primary:hover{background:var(--accent-hover);border-color:var(--accent-hover)}.btn-danger{background:#e24b4a;color:#fff;border-color:#e24b4a}.btn-danger:hover{background:#a32d2d}.btn-sm{padding:4px 10px;font-size:11px}.card{background:var(--bg1);border:.5px solid var(--border);border-radius:var(--radius-lg);overflow:hidden;margin-bottom:16px}.card-header{padding:12px 16px;border-bottom:.5px solid var(--border);display:flex;align-items:center;justify-content:space-between}.card-header-title{font-size:13px;font-weight:500}.card-body{padding:16px}.table-wrap{overflow-x:auto}table{width:100%;border-collapse:collapse;font-size:12px}th{padding:8px 12px;text-align:left;font-weight:500;color:var(--txt2);border-bottom:.5px solid var(--border);background:var(--bg2);font-size:11px;white-space:nowrap}td{padding:8px 12px;border-bottom:.5px solid var(--border);color:var(--txt1);vertical-align:middle}tr:last-child td{border-bottom:none}tr:hover td{background:var(--bg2)}.badge{display:inline-flex;align-items:center;padding:2px 8px;border-radius:20px;font-size:10px;font-weight:500;border:.5px solid;white-space:nowrap}.badge-purple{background:#eeedfe;color:#3c3489;border-color:#afa9ec}.badge-teal{background:#e1f5ee;color:#085041;border-color:#5dcaa5}.badge-coral{background:#faece7;color:#712b13;border-color:#f0997b}.badge-amber{background:#faeeda;color:#633806;border-color:#ef9f27}.badge-blue{background:#e6f1fb;color:#0c447c;border-color:#85b7eb}.badge-gray{background:#f1efe8;color:#444441;border-color:#b4b2a9}.badge-green{background:#eaf3de;color:#27500a;border-color:#97c459}.badge-red{background:#fcebeb;color:#791f1f;border-color:#f09595}.tag-pk{display:inline-block;padding:1px 5px;border-radius:3px;font-size:10px;font-weight:700;background:#faeeda;color:#633806;border:.5px solid #EF9F27;margin-right:3px}.tag-fk{display:inline-block;padding:1px 5px;border-radius:3px;font-size:10px;font-weight:700;background:#e6f1fb;color:#0c447c;border:.5px solid #85B7EB;margin-right:3px}.form-row{display:flex;gap:12px;margin-bottom:12px;flex-wrap:wrap}.form-group{display:flex;flex-direction:column;gap:4px;flex:1;min-width:120px}.form-label{font-size:11px;font-weight:500;color:var(--txt2)}.form-input{padding:7px 10px;border:.5px solid var(--border2);border-radius:var(--radius);font-size:12px;background:var(--bg1);color:var(--txt1);outline:none;transition:border-color .12s;width:100%;font-family:inherit}.form-input:focus{border-color:var(--accent)}select.form-input{cursor:pointer}textarea.form-input{resize:vertical;min-height:80px}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000052;display:flex;align-items:center;justify-content:center;z-index:200}.modal{background:var(--bg1);border-radius:var(--radius-lg);border:.5px solid var(--border);width:540px;max-width:96%;max-height:88vh;overflow-y:auto;box-shadow:0 8px 40px #00000024}.modal-header{padding:16px 20px;border-bottom:.5px solid var(--border);display:flex;align-items:center;justify-content:space-between;position:sticky;top:0;background:var(--bg1);z-index:1}.modal-title{font-size:14px;font-weight:500}.modal-close{cursor:pointer;color:var(--txt3);font-size:20px;line-height:1;padding:2px 7px;border-radius:4px;border:none;background:none}.modal-close:hover{background:var(--bg2);color:var(--txt1)}.modal-body{padding:20px}.modal-footer{padding:12px 20px;border-top:.5px solid var(--border);display:flex;justify-content:flex-end;gap:8px;position:sticky;bottom:0;background:var(--bg1)}.tabs{display:flex;gap:2px;border-bottom:.5px solid var(--border);margin-bottom:16px}.tab{padding:8px 16px;font-size:12px;cursor:pointer;color:var(--txt2);border-bottom:2px solid transparent;transition:all .12s;margin-bottom:-.5px}.tab:hover{color:var(--txt1)}.tab.active{color:var(--accent);border-bottom-color:var(--accent);font-weight:500}.search-bar{display:flex;align-items:center;gap:8px;padding:7px 12px;border:.5px solid var(--border2);border-radius:var(--radius);background:var(--bg1)}.search-bar input{border:none;background:none;outline:none;font-size:12px;color:var(--txt1);flex:1;min-width:0}.search-bar input::placeholder{color:var(--txt3)}.chip{padding:3px 10px;border-radius:14px;font-size:11px;background:var(--bg2);border:.5px solid var(--border);color:var(--txt2);cursor:pointer;white-space:nowrap;transition:all .12s}.chip:hover,.chip.active{background:#eeedfe;border-color:#7f77dd;color:#3c3489}.stats-row{display:grid;grid-template-columns:repeat(4,1fr);gap:10px;margin-bottom:16px}.stat-card{background:var(--bg1);border:.5px solid var(--border);border-radius:var(--radius-lg);padding:16px;cursor:pointer;transition:border-color .12s,box-shadow .12s}.stat-card:hover{border-color:#afa9ec;box-shadow:0 2px 12px #534ab71a}.stat-num{font-size:24px;font-weight:500;color:var(--txt1)}.stat-label{font-size:11px;color:var(--txt3);margin-top:3px}.graph-canvas{position:relative;overflow:hidden;background:var(--bg2);border-radius:var(--radius);cursor:grab;-webkit-user-select:none;user-select:none}.graph-canvas:active{cursor:grabbing}.graph-hint{position:absolute;bottom:8px;left:10px;font-size:10px;color:var(--txt3);pointer-events:none}.er-node{position:absolute;background:var(--bg1);border:1.5px solid var(--border2);border-radius:var(--radius);min-width:188px;cursor:move;-webkit-user-select:none;user-select:none;box-shadow:0 2px 8px #00000012;transition:box-shadow .15s,border-color .15s}.er-node:hover,.er-node.selected{box-shadow:0 4px 20px #534ab729;border-color:#7f77dd}.er-node-header{padding:8px 12px;background:#eeedfe;border-radius:calc(var(--radius) - 1.5px) calc(var(--radius) - 1.5px) 0 0;border-bottom:1px solid #AFA9EC;display:flex;align-items:center;justify-content:space-between}.er-node-title{font-size:12px;font-weight:600;color:#3c3489}.er-node-schema{font-size:10px;color:#7f77dd}.er-field{display:flex;align-items:center;gap:6px;padding:4px 12px;border-bottom:.5px solid var(--border);font-size:11px}.er-field:last-child{border-bottom:none}.er-field-name{flex:1;color:var(--txt1);font-weight:500;font-family:var(--font-mono)}.er-field-type{color:var(--txt3);font-size:10px;font-family:var(--font-mono)}.er-node-footer{padding:4px 12px;border-top:.5px solid var(--border);font-size:10px;color:var(--txt3)}.ln-node{position:absolute;padding:9px 16px;background:var(--bg1);border:1.5px solid var(--border2);border-radius:var(--radius);font-size:12px;font-weight:500;cursor:move;-webkit-user-select:none;user-select:none;text-align:center;transition:all .15s;min-width:130px}.ln-node:hover{box-shadow:0 2px 12px #1d9e752e}.ln-node.source{border-color:#7f77dd;background:#eeedfe;color:#3c3489}.ln-node.transform{border-color:#ba7517;background:#faeeda;color:#633806}.ln-node.target{border-color:#1d9e75;background:#e1f5ee;color:#085041}.ln-node-sub{font-size:10px;font-weight:400;color:var(--txt3);margin-top:2px}.sql-editor{font-family:var(--font-mono);font-size:12.5px;line-height:1.65;background:#1e1e2e;color:#cdd6f4;border:.5px solid var(--border);border-radius:var(--radius);padding:14px;resize:vertical;min-height:160px;width:100%;outline:none}.toast{position:fixed;bottom:20px;right:20px;background:#1d9e75;color:#fff;padding:10px 18px;border-radius:var(--radius);font-size:12px;z-index:999;animation:fadeUp .2s ease}@keyframes fadeUp{0%{opacity:0;transform:translateY(6px)}to{opacity:1;transform:none}}.side-list{width:210px;flex-shrink:0}.side-list-item{padding:9px 12px;cursor:pointer;border-bottom:.5px solid var(--border);border-left:2px solid transparent;transition:background .1s}.side-list-item:hover{background:var(--bg2)}.side-list-item.active{background:var(--bg2);border-left-color:var(--accent)}.side-list-item-title{font-size:12px;font-weight:500}.side-list-item-sub{font-size:11px;color:var(--txt3);margin-top:1px}
