:root{--bg: #080a0f;--surface: #0f1117;--surface-2: #161b24;--surface-3: #1e2535;--border: #232b3e;--border-2: #2e3a54;--accent: #3b82f6;--accent-dim: rgba(59, 130, 246, .12);--accent-hover: #2563eb;--accent-2: #7c6af5;--text: #dce6f0;--text-muted: #5a6a85;--text-dim: #323c52;--pk: #f5c542;--fk: #5b9cf5;--nn: #8494a8;--unique: #c084fc;--identity: #6ee7b7;--default: #fb923c;--danger: #f87171;--radius: 8px;--radius-lg: 12px}*{margin:0;padding:0;box-sizing:border-box}html{font-size:14px;-webkit-font-smoothing:antialiased}body{background:var(--bg);color:var(--text);font-family:JetBrains Mono,monospace;min-height:100vh}::-webkit-scrollbar{width:5px;height:5px}::-webkit-scrollbar-track{background:var(--bg)}::-webkit-scrollbar-thumb{background:var(--border-2);border-radius:3px}.tip{position:relative;display:inline-flex;align-items:center;cursor:help}.tip-icon{width:14px;height:14px;border-radius:50%;background:var(--surface-3);border:1px solid var(--border-2);color:var(--text-muted);font-size:.6rem;font-style:normal;display:inline-flex;align-items:center;justify-content:center;margin-left:4px;flex-shrink:0;transition:all .15s}.tip:hover .tip-icon{background:var(--accent-dim);border-color:var(--accent);color:var(--accent)}.tip-box{position:fixed;background:#1a2235;border:1px solid var(--border-2);border-radius:var(--radius);padding:8px 11px;width:240px;font-size:.7rem;line-height:1.5;color:var(--text);z-index:9999;pointer-events:none;opacity:0;transition:opacity .15s;white-space:normal;box-shadow:0 8px 24px #000000b3}.tip-box:after{content:"";position:absolute;top:100%;left:50%;transform:translate(-50%);border:5px solid transparent;border-top-color:#1a2235}.tip-box.visible{opacity:1}.tip-title{font-weight:700;color:var(--accent);margin-bottom:4px}.btn{display:inline-flex;align-items:center;gap:5px;padding:6px 13px;border-radius:var(--radius);border:1px solid var(--border);background:transparent;color:var(--text-muted);font-family:JetBrains Mono,monospace;font-size:.78rem;cursor:pointer;transition:all .15s;white-space:nowrap}.btn:hover{background:var(--surface-2);border-color:var(--border-2);color:var(--text)}.btn:disabled{opacity:.4;cursor:not-allowed}.btn-primary{background:var(--accent);border-color:var(--accent);color:#fff;font-weight:600}.btn-primary:hover{background:var(--accent-hover);color:#fff}.btn-qb{background:linear-gradient(135deg,#3b82f6,#60a5fa);border:none;color:#fff;font-weight:600}.btn-qb:hover{opacity:.9;color:#fff}.btn-danger{border-color:var(--danger);color:var(--danger)}.btn-danger:hover{background:#f871711a}.btn-sm{padding:4px 10px;font-size:.73rem}.app-header{background:var(--surface);border-bottom:1px solid var(--border);padding:0 20px;height:54px;display:flex;align-items:center;gap:12px;position:sticky;top:0;z-index:100}.logo{font-family:Syne,sans-serif;font-size:1.05rem;font-weight:800;color:var(--accent);letter-spacing:-.5px;white-space:nowrap;display:flex;align-items:center;gap:8px;text-decoration:none}.logo-dot{width:8px;height:8px;background:var(--accent);border-radius:50%;box-shadow:0 0 8px var(--accent)}.logo span{color:var(--text-muted);font-weight:600;font-size:.9rem}.hdiv{width:1px;height:22px;background:var(--border);flex-shrink:0}.stats-pill{background:var(--surface-2);border:1px solid var(--border);border-radius:20px;padding:3px 10px;font-size:.72rem;color:var(--text-muted);white-space:nowrap}.stats-pill b{color:var(--accent)}.hspace{flex:1}.schema-select{background:var(--surface-2);border:1px solid var(--border);border-radius:var(--radius);padding:5px 10px;color:var(--text);font-family:JetBrains Mono,monospace;font-size:.76rem;outline:none;max-width:220px;cursor:pointer}.schema-select option{background:var(--surface-2)}.schema-select:focus{border-color:var(--accent)}.engine-badge{display:inline-flex;padding:2px 7px;border-radius:4px;font-size:.62rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em}.engine-sqlserver{background:#5b9cf526;color:#5b9cf5;border:1px solid rgba(91,156,245,.3)}.engine-postgresql{background:#6ee7b726;color:#6ee7b7;border:1px solid rgba(110,231,183,.3)}.engine-bigquery{background:#f59e0b26;color:#f59e0b;border:1px solid rgba(245,158,11,.3)}.engine-mysql{background:#fb923c26;color:#fb923c;border:1px solid rgba(251,146,60,.3)}.engine-oracle{background:#f8717126;color:#f87171;border:1px solid rgba(248,113,113,.3)}.toolbar{background:var(--surface);border-bottom:1px solid var(--border);padding:10px 20px;display:flex;flex-direction:column;gap:8px;position:sticky;top:54px;z-index:99}.search-row{display:flex;gap:8px;align-items:center}.srch-wrap{position:relative;flex:1;max-width:480px}.srch-icon{position:absolute;left:11px;top:50%;transform:translateY(-50%);color:var(--text-muted);pointer-events:none;font-style:normal}.srch-in{width:100%;background:var(--surface-2);border:1px solid var(--border);border-radius:var(--radius);padding:7px 11px 7px 33px;color:var(--text);font-family:JetBrains Mono,monospace;font-size:.82rem;outline:none;transition:border-color .15s}.srch-in:focus{border-color:var(--accent)}.srch-in::placeholder{color:var(--text-dim)}.rcnt{color:var(--text-muted);font-size:.72rem;white-space:nowrap}.filter-row{display:flex;gap:5px;align-items:center;flex-wrap:wrap}.filter-lbl{color:var(--text-muted);font-size:.7rem;margin-right:2px}.chip{display:inline-flex;align-items:center;gap:4px;padding:2px 9px;border-radius:20px;border:1px solid var(--border);background:transparent;color:var(--text-muted);font-family:JetBrains Mono,monospace;font-size:.7rem;cursor:pointer;transition:all .15s}.chip:hover{border-color:var(--border-2);color:var(--text)}.chip.active{font-weight:500}.chip-pk{color:var(--pk)}.chip-pk.active{background:#f5c5421f;border-color:#f5c54266}.chip-fk{color:var(--fk)}.chip-fk.active{background:#5b9cf51f;border-color:#5b9cf566}.chip-nn{color:var(--nn)}.chip-nn.active{background:#8494a81f;border-color:#8494a84d}.chip-un{color:var(--unique)}.chip-un.active{background:#c084fc1a;border-color:#c084fc4d}.chip-id{color:var(--identity)}.chip-id.active{background:#6ee7b71a;border-color:#6ee7b74d}.chip-df{color:var(--default)}.chip-df.active{background:#fb923c1a;border-color:#fb923c4d}.main{padding:18px 20px;max-width:1700px;margin:0 auto}.schema-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:10px}.tcard.expanded{grid-column:1 / -1}.empty{text-align:center;padding:80px 24px;color:var(--text-muted)}.tcard{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);overflow:hidden;transition:border-color .15s}.tcard:hover{border-color:var(--border-2)}.tcard.expanded{border-color:#3b82f666}.thead{display:flex;align-items:center;gap:8px;padding:10px 14px;cursor:pointer;-webkit-user-select:none;user-select:none;transition:background .1s}.thead:hover{background:var(--surface-2)}.t-schema{background:var(--surface-3);color:var(--text-muted);padding:1px 5px;border-radius:4px;font-size:.62rem;flex-shrink:0}.t-name{font-size:.82rem;font-weight:600;color:var(--text);flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.t-count{color:var(--text-muted);font-size:.7rem;flex-shrink:0}.t-icon{color:var(--text-dim);font-size:.65rem;transition:transform .2s;flex-shrink:0}.tcard.expanded .t-icon{transform:rotate(90deg);color:var(--accent)}.tbody{display:none;border-top:1px solid var(--border)}.tcard.expanded .tbody{display:block}.ctable{width:100%;border-collapse:collapse}.ctable th{background:var(--surface-2);color:var(--text-muted);font-size:.62rem;text-transform:uppercase;letter-spacing:.08em;padding:5px 10px;text-align:left;font-weight:500;border-bottom:1px solid var(--border)}.ctable td{padding:5px 10px;font-size:.76rem;border-bottom:1px solid var(--border);vertical-align:middle}.ctable tr:last-child td{border-bottom:none}.ctable tr:hover td{background:var(--surface-2)}.c-ord{color:var(--text-dim);font-size:.65rem;width:22px}.c-type{color:#5bc0f5;font-size:.72rem}.table-scroll-wrapper{overflow-x:auto;-webkit-overflow-scrolling:touch}.params-cell{display:flex;flex-wrap:wrap;gap:3px}.badge{display:inline-block;padding:1px 5px;border-radius:4px;font-size:.62rem;font-weight:500;white-space:nowrap;max-width:100%;overflow:hidden;text-overflow:ellipsis}.b-pk{background:#f5c5421f;color:var(--pk);border:1px solid rgba(245,197,66,.25)}.b-fk{background:#5b9cf51f;color:var(--fk);border:1px solid rgba(91,156,245,.25)}.b-nn{background:#8494a81a;color:var(--nn);border:1px solid rgba(132,148,168,.2)}.b-unique{background:#c084fc1a;color:var(--unique);border:1px solid rgba(192,132,252,.2)}.b-id{background:#6ee7b71a;color:var(--identity);border:1px solid rgba(110,231,183,.2)}.b-df{background:#fb923c1a;color:var(--default);border:1px solid rgba(251,146,60,.2)}.badge.b-fk{cursor:help;position:relative}.badge.b-fk:hover{z-index:10}.fk-tooltip{display:none;position:absolute;bottom:calc(100% + 6px);left:50%;transform:translate(-50%);background:#1a2235;border:1px solid var(--fk);border-radius:6px;padding:6px 10px;font-size:.68rem;color:var(--text);white-space:nowrap;z-index:9999;box-shadow:0 4px 16px #0009;pointer-events:none}.badge.b-fk:hover .fk-tooltip{display:block}.aq-btn{background:none;border:1px solid var(--border);color:var(--text-dim);border-radius:4px;padding:2px 6px;font-family:JetBrains Mono,monospace;font-size:.62rem;cursor:pointer;transition:all .15s}.aq-btn:hover{border-color:var(--accent);color:var(--accent);background:var(--accent-dim)}mark.hl{background:#3b82f633;border-radius:2px;color:inherit}.qb-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#000c;z-index:200;display:none;align-items:flex-start;justify-content:center;padding:12px;overflow-y:auto}.qb-overlay.open{display:flex}.qb-modal{background:var(--surface);border:1px solid var(--border-2);border-radius:var(--radius-lg);width:100%;max-width:1280px;display:flex;flex-direction:column;margin:auto;box-shadow:0 24px 80px #000000b3;overflow:hidden;min-height:700px}.qb-head{padding:12px 18px;border-bottom:1px solid var(--border);display:flex;align-items:center;gap:10px;flex-shrink:0}.qb-title{font-family:Syne,sans-serif;font-size:.95rem;font-weight:700;flex:1}.qb-body{display:flex;flex:1;overflow:hidden;min-height:0}.qb-left{flex:1;overflow-y:auto;border-right:1px solid var(--border);display:flex;flex-direction:column;gap:0;min-width:0}.qb-right{width:440px;display:flex;flex-direction:column;background:var(--bg);flex-shrink:0}.qb-right-head{padding:10px 14px;border-bottom:1px solid var(--border);display:flex;align-items:center;gap:8px;background:var(--surface);flex-shrink:0}.sql-out{flex:1;padding:14px;font-family:JetBrains Mono,monospace;font-size:.76rem;line-height:1.75;overflow-y:auto;white-space:pre-wrap;word-break:break-all}.sc-section{border-bottom:1px solid var(--border);padding:12px 16px;display:flex;flex-direction:column;gap:8px}.sc-label{font-size:.66rem;text-transform:uppercase;letter-spacing:.1em;color:var(--text-muted);font-weight:600;display:flex;align-items:center;gap:8px;margin-bottom:2px}.sc-label:after{content:"";flex:1;height:1px;background:var(--border)}.sc-row{display:flex;gap:6px;align-items:center;flex-wrap:wrap}.sc-inp{background:var(--surface-2);border:1px solid var(--border);border-radius:var(--radius);padding:6px 9px;color:var(--text);font-family:JetBrains Mono,monospace;font-size:.78rem;outline:none;transition:border-color .15s}.sc-inp:focus{border-color:var(--accent)}.sc-inp::placeholder{color:var(--text-dim)}.opt-toggle{display:flex;align-items:center;gap:7px;padding:5px 10px;background:var(--surface-2);border:1px solid var(--border);border-radius:var(--radius);cursor:pointer;font-size:.72rem;color:var(--text-muted);transition:all .15s}.opt-toggle:hover{border-color:var(--border-2);color:var(--text)}.opt-toggle input{accent-color:var(--accent)}.opt-toggle.on{border-color:var(--accent);color:var(--accent);background:var(--accent-dim)}.blocks-wrap{display:flex;flex-direction:column;gap:8px;padding:10px 16px}.block-card{background:var(--surface-2);border:1px solid var(--border-2);border-radius:var(--radius-lg);overflow:visible}.block-head{display:flex;align-items:center;gap:8px;padding:8px 12px;background:var(--surface-3);border-radius:var(--radius-lg) var(--radius-lg) 0 0;cursor:pointer;-webkit-user-select:none;user-select:none;border-bottom:1px solid var(--border)}.block-kind{font-size:.72rem;font-weight:700;padding:2px 8px;border-radius:4px}.bk-query{background:#22c55e26;color:#22c55e;border:1px solid rgba(34,197,94,.3)}.bk-if{background:#7c6af526;color:#7c6af5;border:1px solid rgba(124,106,245,.3)}.bk-cte{background:#f59e0b26;color:#f59e0b;border:1px solid rgba(245,158,11,.3)}.block-title{flex:1;font-size:.8rem;color:var(--text-muted)}.block-toggle-icon{color:var(--text-dim);font-size:.65rem;transition:transform .2s}.block-card:not(.collapsed) .block-toggle-icon{transform:rotate(90deg)}.block-body{padding:12px;display:flex;flex-direction:column;gap:10px}.block-body.hidden{display:none}.op-tabs{display:flex;gap:2px;background:var(--surface-3);padding:3px;border-radius:var(--radius);border:1px solid var(--border)}.op-tab{flex:1;padding:5px;border-radius:6px;border:none;background:transparent;color:var(--text-muted);font-family:JetBrains Mono,monospace;font-size:.78rem;font-weight:600;cursor:pointer;transition:all .15s;text-align:center}.op-tab.a-s{background:#22c55e;color:#000}.op-tab.a-i{background:#3b82f6;color:#fff}.op-tab.a-u{background:#f59e0b;color:#000}.op-tab.a-d{background:#ef4444;color:#fff}.col-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:3px;max-height:180px;overflow-y:auto;padding:6px;background:var(--surface-3);border:1px solid var(--border);border-radius:var(--radius)}.col-item{display:flex;align-items:center;gap:5px;padding:3px 5px;border-radius:4px;cursor:pointer;font-size:.72rem;transition:background .1s}.col-item:hover{background:var(--surface-2)}.col-item input{accent-color:var(--accent);cursor:pointer}.ci-name{color:var(--text);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.ci-type{color:#5bc0f5;font-size:.62rem;margin-left:auto;flex-shrink:0}.col-opts{display:flex;flex-direction:column;gap:3px;margin-top:6px}.col-opt-row{display:flex;gap:5px;align-items:center;font-size:.72rem}.co-name{color:var(--text);min-width:90px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.co-lbl{color:var(--text-dim);font-size:.6rem;white-space:nowrap}.co-inp{background:var(--surface-3);border:1px solid var(--border);border-radius:4px;padding:3px 6px;color:var(--text);font-family:JetBrains Mono,monospace;font-size:.72rem;outline:none;flex:1;min-width:50px}.ss-wrap{position:relative}.ss-display{width:100%;background:var(--surface-2);border:1px solid var(--border);border-radius:var(--radius);padding:7px 30px 7px 10px;color:var(--text);font-family:JetBrains Mono,monospace;font-size:.8rem;outline:none;cursor:pointer;transition:border-color .15s;text-overflow:ellipsis;overflow:hidden;white-space:nowrap}.ss-display:focus{border-color:var(--accent)}.ss-arrow{position:absolute;right:9px;top:50%;transform:translateY(-50%);color:var(--text-muted);pointer-events:none;font-size:.7rem;transition:transform .2s}.ss-wrap.open .ss-arrow{transform:translateY(-50%) rotate(180deg)}.ss-drop{position:absolute;top:calc(100% + 4px);left:0;right:0;background:#111827;border:1px solid var(--border-2);border-radius:var(--radius);z-index:500;display:none;flex-direction:column;box-shadow:0 12px 32px #0009;min-width:260px}.ss-wrap.open .ss-drop{display:flex}.ss-search-row{padding:7px 10px;border-bottom:1px solid var(--border);background:#0d1422}.ss-search-row input{width:100%;background:transparent;border:none;outline:none;color:var(--text);font-family:JetBrains Mono,monospace;font-size:.78rem}.ss-search-row input::placeholder{color:var(--text-dim)}.ss-list{max-height:220px;overflow-y:auto}.ss-opt{padding:6px 11px;font-size:.78rem;cursor:pointer;color:var(--text-muted);transition:all .12s;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.ss-opt:hover{background:var(--surface-3);color:var(--text)}.ss-opt.selected{color:var(--accent);font-weight:600}.ss-empty{padding:10px;font-size:.74rem;color:var(--text-dim);text-align:center}.sk{color:#a78bfa;font-weight:600}.st{color:var(--accent)}.sv{color:#f5a742}.sn{color:var(--pk)}.scm{color:var(--text-muted);font-style:italic}.sa{color:#f87171;font-weight:600}.add-btn{background:none;border:1px dashed var(--border);color:var(--text-muted);border-radius:var(--radius);padding:5px 10px;font-family:JetBrains Mono,monospace;font-size:.72rem;cursor:pointer;transition:all .15s;width:100%;text-align:center}.add-btn:hover{border-color:var(--accent);color:var(--accent);background:var(--accent-dim)}.add-btn-sm{background:none;border:1px dashed var(--border);color:var(--text-muted);border-radius:5px;padding:3px 8px;font-family:JetBrains Mono,monospace;font-size:.68rem;cursor:pointer;transition:all .15s}.add-btn-sm:hover{border-color:var(--accent);color:var(--accent);background:var(--accent-dim)}.add-block-bar{display:flex;gap:6px;padding:10px 16px;border-bottom:1px solid var(--border);flex-wrap:wrap}.set-row,.ob-row,.gb-row{display:flex;gap:5px;align-items:center;flex-wrap:wrap}.f-sel{background:var(--surface-2);border:1px solid var(--border);border-radius:4px;padding:5px 8px;color:var(--text);font-family:JetBrains Mono,monospace;font-size:.72rem;outline:none;flex:1;min-width:70px}.f-sel option{background:var(--surface-2)}.f-inp{background:var(--surface-2);border:1px solid var(--border);border-radius:4px;padding:5px 8px;color:var(--text);font-family:JetBrains Mono,monospace;font-size:.72rem;outline:none;flex:1.5;min-width:80px}.eq-lbl{color:var(--accent-2);font-weight:600;padding:0 3px;font-size:.78rem}.dir-btn{padding:3px 8px;background:var(--surface-3);border:1px solid var(--border);border-radius:4px;color:var(--text-muted);font-family:JetBrains Mono,monospace;font-size:.68rem;cursor:pointer;transition:all .15s}.dir-btn.asc{color:var(--accent);border-color:var(--accent)}.dir-btn.desc{color:var(--default);border-color:var(--default)}.rem-btn{background:none;border:none;color:var(--text-dim);cursor:pointer;padding:2px 5px;font-size:.9rem;border-radius:3px;transition:color .15s;flex-shrink:0;line-height:1}.rem-btn:hover{color:var(--danger)}.opts-grid{display:grid;grid-template-columns:1fr 1fr;gap:5px}.top-row{display:flex;align-items:center;gap:7px;font-size:.72rem;color:var(--text-muted);margin-bottom:4px}.top-row input{width:70px}.cond-list{display:flex;flex-direction:column;gap:5px}.cond-row{display:flex;gap:4px;align-items:center;flex-wrap:wrap}.cond-logic{background:var(--surface-3);border:1px solid var(--border);border-radius:4px;padding:4px 7px;color:var(--accent-2);font-family:JetBrains Mono,monospace;font-size:.72rem;font-weight:700;cursor:pointer;white-space:nowrap;min-width:38px;text-align:center}.cond-tsel,.cond-csel,.cond-op{background:var(--surface-2);border:1px solid var(--border);border-radius:4px;padding:4px 6px;color:var(--text);font-family:JetBrains Mono,monospace;font-size:.72rem;outline:none;min-width:60px}.cond-tsel{flex:1.2}.cond-csel{flex:1.8}.cond-op{flex:1.2}.cond-val{flex:1.5;min-width:80px;background:var(--surface-2);border:1px solid var(--border);border-radius:4px;padding:4px 6px;color:var(--text);font-family:JetBrains Mono,monospace;font-size:.72rem;outline:none}.if-branch{background:var(--surface-2);border:1px solid rgba(124,106,245,.3);border-radius:var(--radius);padding:10px;display:flex;flex-direction:column;gap:8px}.if-head{display:flex;align-items:center;gap:8px;font-size:.72rem;flex-wrap:wrap}.if-kw{color:var(--accent-2);font-weight:700}.if-cond{flex:1;min-width:120px;background:var(--surface-3);border:1px solid var(--border);border-radius:4px;padding:5px 8px;color:var(--text);font-family:JetBrains Mono,monospace;font-size:.74rem;outline:none}.cte-block{background:var(--surface-2);border:1px solid rgba(245,158,11,.25);border-radius:var(--radius);padding:10px;display:flex;flex-direction:column;gap:8px}.cte-name-row{display:flex;align-items:center;gap:8px;font-size:.72rem}.cte-name{background:var(--surface-3);border:1px solid var(--border);border-radius:4px;padding:5px 8px;color:var(--pk);font-family:JetBrains Mono,monospace;font-size:.74rem;outline:none;flex:1}.case-block{background:var(--surface-2);border:1px solid rgba(124,106,245,.2);border-radius:var(--radius);padding:8px;display:flex;flex-direction:column;gap:5px}.case-row{display:flex;gap:4px;align-items:center;flex-wrap:wrap}.case-kw{font-size:.7rem;font-weight:700;white-space:nowrap}.c-inp{background:var(--surface-3);border:1px solid var(--border);border-radius:4px;padding:3px 6px;color:var(--text);font-family:JetBrains Mono,monospace;font-size:.72rem;outline:none;flex:1;min-width:60px}.c-sel{background:var(--surface-3);border:1px solid var(--border);border-radius:4px;padding:3px 6px;color:var(--text);font-family:JetBrains Mono,monospace;font-size:.72rem;outline:none;flex:2}.ins-table{width:100%;border-collapse:collapse;font-size:.74rem}.ins-table th{background:var(--surface-3);padding:4px 8px;font-size:.62rem;color:var(--text-muted);text-align:left;border-bottom:1px solid var(--border)}.ins-table td{padding:3px 5px;border-bottom:1px solid var(--border)}.ins-v{width:100%;background:var(--surface-3);border:1px solid var(--border);border-radius:4px;padding:3px 6px;color:var(--text);font-family:JetBrains Mono,monospace;font-size:.72rem;outline:none}.joins-list{display:flex;flex-direction:column;gap:8px}.join-card{background:var(--surface-3);border:1px solid var(--border);border-radius:var(--radius);overflow:visible}.join-head{display:flex;align-items:center;gap:6px;padding:8px 10px;border-bottom:1px solid var(--border);flex-wrap:wrap}.jt-tabs{display:flex;gap:2px}.jt-btn{padding:3px 8px;border-radius:4px;border:1px solid var(--border);background:transparent;color:var(--text-dim);font-family:JetBrains Mono,monospace;font-size:.68rem;cursor:pointer;transition:all .15s;white-space:nowrap}.jt-btn.a{font-weight:700}.jt-inner.a{color:#22c55e;border-color:#22c55e66;background:#22c55e1a}.jt-left.a{color:#3b82f6;border-color:#3b82f666;background:#3b82f61a}.jt-right.a{color:#f59e0b;border-color:#f59e0b66;background:#f59e0b1a}.src-toggle{display:flex;gap:2px}.src-btn{padding:3px 7px;border-radius:4px;border:1px solid var(--border);background:transparent;color:var(--text-dim);font-family:JetBrains Mono,monospace;font-size:.65rem;cursor:pointer;transition:all .12s}.src-btn.a{color:var(--accent);border-color:var(--accent);background:var(--accent-dim)}.j-alias-wrap{display:flex;align-items:center;gap:4px;font-size:.65rem;color:var(--text-muted)}.j-alias{background:var(--surface-2);border:1px solid var(--border);border-radius:4px;padding:3px 6px;color:var(--text);font-family:JetBrains Mono,monospace;font-size:.72rem;outline:none;width:60px}.j-del{background:none;border:none;color:var(--text-dim);cursor:pointer;font-size:1rem;padding:2px 5px;transition:color .15s}.j-del:hover{color:var(--danger)}.join-body{padding:8px 10px;display:flex;flex-direction:column;gap:6px}.on-row{display:flex;gap:4px;align-items:center;flex-wrap:wrap;font-size:.72rem}.on-kw{color:var(--text-dim);font-weight:600;min-width:28px;font-size:.68rem}.on-sel{background:var(--surface-2);border:1px solid var(--border);border-radius:4px;padding:3px 6px;color:var(--text);font-family:JetBrains Mono,monospace;font-size:.72rem;outline:none;flex:1;min-width:60px}.on-rem{background:none;border:none;color:var(--text-dim);cursor:pointer;padding:2px}.on-rem:hover{color:var(--danger)}.jc-label{font-size:.64rem;color:var(--text-muted);margin-top:6px}.jc-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(130px,1fr));gap:2px;padding:4px;background:var(--surface-2);border:1px solid var(--border);border-radius:4px}.filter-section{display:flex;gap:5px;align-items:center;flex-wrap:wrap}.filter-section-label{color:var(--text-muted);font-size:.66rem;font-weight:600;text-transform:uppercase;letter-spacing:.06em;white-space:nowrap;margin-right:2px}.scope-chip{display:inline-flex;align-items:center;gap:3px;padding:2px 9px;border-radius:20px;border:1px solid var(--border);background:transparent;color:var(--text-muted);font-family:JetBrains Mono,monospace;font-size:.7rem;cursor:pointer;transition:all .15s}.scope-chip:hover{border-color:var(--border-2);color:var(--text)}.scope-chip.active{background:var(--accent-dim);border-color:#3b82f666;color:var(--accent);font-weight:500}.filter-divider{width:1px;height:16px;background:var(--border);margin:0 4px;flex-shrink:0}.toast{position:fixed;bottom:22px;right:22px;background:var(--surface-3);border:1px solid var(--accent);border-radius:var(--radius);padding:10px 16px;color:var(--accent);font-size:.8rem;z-index:9998;transform:translateY(70px);opacity:0;transition:all .3s cubic-bezier(.34,1.56,.64,1)}.toast.show{transform:translateY(0);opacity:1}.login-page{display:flex;align-items:center;justify-content:center;min-height:100vh;padding:20px}.login-card{background:var(--surface);border:1px solid var(--border-2);border-radius:var(--radius-lg);padding:40px 36px;width:100%;max-width:400px;box-shadow:0 24px 80px #00000080}.login-card h2{font-family:Syne,sans-serif;color:var(--accent);margin-bottom:6px;font-size:1.2rem}.login-card p{color:var(--text-muted);font-size:.76rem;margin-bottom:24px}.form-group{margin-bottom:16px}.form-group label{display:block;font-size:.68rem;color:var(--text-muted);text-transform:uppercase;letter-spacing:.08em;margin-bottom:5px}.form-group input{width:100%;background:var(--surface-2);border:1px solid var(--border);border-radius:var(--radius);padding:9px 12px;color:var(--text);font-family:JetBrains Mono,monospace;font-size:.82rem;outline:none;transition:border-color .15s}.form-group input:focus{border-color:var(--accent)}.form-error{color:var(--danger);font-size:.72rem;margin-top:12px}.form-btn{width:100%;padding:10px;margin-top:8px;background:var(--accent);border:none;border-radius:var(--radius);color:#fff;font-family:JetBrains Mono,monospace;font-size:.82rem;font-weight:600;cursor:pointer;transition:background .15s}.form-btn:hover{background:var(--accent-hover)}.form-btn:disabled{opacity:.5;cursor:not-allowed}.logo-img{height:28px;width:auto;object-fit:contain}.admin-page{padding:24px;max-width:1100px;margin:0 auto}.admin-page h2{font-family:Syne,sans-serif;color:var(--accent);font-size:1.1rem;margin-bottom:20px}.admin-tabs{display:flex;gap:4px;margin-bottom:20px}.admin-tab{padding:7px 16px;border-radius:var(--radius);border:1px solid var(--border);background:transparent;color:var(--text-muted);font-family:JetBrains Mono,monospace;font-size:.78rem;cursor:pointer;transition:all .15s}.admin-tab.active{background:var(--accent);border-color:var(--accent);color:#fff;font-weight:600}.admin-table{width:100%;border-collapse:collapse;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);overflow:hidden}.admin-table th{background:var(--surface-2);padding:8px 12px;text-align:left;font-size:.68rem;color:var(--text-muted);text-transform:uppercase;letter-spacing:.06em;border-bottom:1px solid var(--border)}.admin-table td{padding:8px 12px;font-size:.78rem;border-bottom:1px solid var(--border)}.admin-table tr:hover td{background:var(--surface-2)}.admin-actions{display:flex;gap:4px;flex-wrap:wrap}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#000000b3;display:flex;align-items:center;justify-content:center;z-index:300;padding:20px}.modal-card{background:var(--surface);border:1px solid var(--border-2);border-radius:var(--radius-lg);padding:28px;width:100%;max-width:480px;box-shadow:0 24px 60px #0009}.modal-card h3{font-family:Syne,sans-serif;color:var(--accent);margin-bottom:18px;font-size:1rem}.modal-actions{display:flex;gap:8px;margin-top:20px;justify-content:flex-end}.user-menu{position:relative}.user-btn{background:var(--surface-2);border:1px solid var(--border);border-radius:var(--radius);padding:5px 12px;color:var(--text);font-family:JetBrains Mono,monospace;font-size:.76rem;cursor:pointer;display:flex;align-items:center;gap:6px;transition:all .15s}.user-btn:hover{border-color:var(--border-2)}.user-dropdown{position:absolute;top:calc(100% + 6px);right:0;background:#111827;border:1px solid var(--border-2);border-radius:var(--radius);min-width:180px;z-index:500;box-shadow:0 12px 32px #0009;overflow:hidden}.user-dropdown button{display:block;width:100%;padding:8px 14px;background:transparent;border:none;color:var(--text-muted);font-family:JetBrains Mono,monospace;font-size:.76rem;cursor:pointer;text-align:left;transition:all .12s}.user-dropdown button:hover{background:var(--surface-3);color:var(--text)}.user-dropdown .danger{color:var(--danger)}.linter-warning{background:#f59e0b1a;border:1px solid rgba(245,158,11,.4);border-radius:var(--radius);padding:10px 14px;margin-top:8px;font-size:.72rem;color:#f59e0b}.linter-warning strong{display:block;margin-bottom:4px}@media (max-width: 1024px){.qb-right{width:360px}}@media (max-width: 900px){.qb-body{flex-direction:column}.qb-right{width:100%;min-height:260px;border-right:none;border-top:1px solid var(--border)}.qb-left{border-right:none}.schema-grid{grid-template-columns:repeat(2,1fr)}.opts-grid{grid-template-columns:1fr}.stats-pill{display:none}.hdiv:first-of-type{display:none}}@media (max-width: 600px){.app-header{padding:0 12px;gap:8px}.toolbar,.main{padding-left:12px;padding-right:12px}.app-header .btn:not(.btn-qb){display:none}.schema-grid{grid-template-columns:1fr}.schema-select{max-width:140px;font-size:.7rem}.filter-row{gap:3px}.chip{font-size:.62rem;padding:2px 6px}.qb-modal{min-height:auto;max-height:95vh}.join-head{gap:4px}.jt-btn{font-size:.6rem;padding:2px 5px}.cond-row{gap:3px}.admin-table{font-size:.7rem}.admin-table th,.admin-table td{padding:6px 8px}}
