*,:before,:after{box-sizing:border-box;margin:0;padding:0}:root{--bg:#0d1117;--surface:#161b22;--surface2:#1c2128;--surface3:#21262d;--border:#30363d;--border-sub:#21262d;--text:#e6edf3;--text-muted:#8b949e;--text-dim:#6e7681;--accent:#388bfd;--accent-hover:#58a6ff;--null:#6e7681;--blob:#bc8cff;--pk:#e3b341;--header-h:48px;--sidebar-w:228px;color:var(--text);background:var(--bg);--lightningcss-light: ;--lightningcss-dark:initial;color-scheme:dark;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,system-ui,sans-serif;font-size:14px;line-height:1.5}body{min-height:100dvh;overflow:hidden}#root{flex-direction:column;height:100dvh;display:flex}button{font:inherit;cursor:pointer;color:inherit;background:0 0;border:none}ul{list-style:none}:focus-visible{outline:2px solid var(--accent);outline-offset:2px;border-radius:3px}::-webkit-scrollbar{width:7px;height:7px}::-webkit-scrollbar-track{background:0 0}::-webkit-scrollbar-thumb{background:var(--border);border-radius:4px}::-webkit-scrollbar-thumb:hover{background:var(--text-dim)}.app{background:var(--bg);flex-direction:column;height:100dvh;display:flex}.app-header{height:var(--header-h);background:var(--surface);border-bottom:1px solid var(--border);flex-shrink:0;justify-content:space-between;align-items:center;gap:12px;padding:0 16px;display:flex}.app-header__tabs{align-items:center;gap:6px;margin-left:auto;margin-right:8px;display:flex}.app-header__tab{color:var(--text-muted);border:1px solid var(--border);background:var(--surface2);border-radius:6px;padding:5px 10px;font-size:12px;transition:border-color .15s,color .15s,background .15s}.app-header__tab:hover{color:var(--text);border-color:var(--text-dim)}.app-header__tab.active{color:var(--accent-hover);border-color:color-mix(in srgb, var(--accent) 40%, var(--border));background:color-mix(in srgb, var(--accent) 16%, var(--surface2))}.app-header__logo{color:var(--text);letter-spacing:-.01em;align-items:center;gap:8px;font-size:14px;font-weight:600;display:flex}.app-header__logo svg{color:var(--accent);flex-shrink:0}.app-header__actions{align-items:center;gap:8px;display:flex}.btn-save{border:1px solid color-mix(in srgb, var(--accent) 48%, var(--border));color:var(--accent-hover);background:color-mix(in srgb, var(--accent) 16%, var(--surface2));border-radius:6px;padding:5px 12px;font-size:13px;transition:background .15s,border-color .15s}.btn-save:hover{background:color-mix(in srgb, var(--accent) 24%, var(--surface2));border-color:color-mix(in srgb, var(--accent) 68%, var(--border))}.btn-open{border:1px solid var(--border);color:var(--text);background:var(--surface2);cursor:pointer;white-space:nowrap;-webkit-user-select:none;user-select:none;border-radius:6px;padding:5px 12px;font-size:13px;transition:background .15s,border-color .15s}.btn-open:hover{background:var(--surface3);border-color:var(--text-dim)}.app-main{flex:1;min-height:0;display:flex}.save-message{border-bottom:1px solid var(--border-sub);background:color-mix(in srgb, var(--accent) 10%, var(--surface));color:var(--accent-hover);padding:6px 12px;font-size:12px}.app-footer{border-top:1px solid var(--border);background:var(--surface);height:30px;color:var(--text-dim);text-align:center;flex-shrink:0;justify-content:center;align-items:center;gap:6px;padding:0 12px;font-size:11px;display:flex}.app-footer__sep{opacity:.6}.app-center{flex-direction:column;flex:1;justify-content:center;align-items:center;gap:20px;padding:24px;display:flex}.workspace{flex:1;min-width:0;min-height:0;display:flex}.workspace__content{background:var(--bg);flex:1;min-width:0;overflow:auto}.dropzone{border:2px dashed var(--border);text-align:center;cursor:pointer;background:var(--surface);-webkit-user-select:none;user-select:none;border-radius:12px;flex-direction:column;align-items:center;gap:8px;width:100%;max-width:420px;padding:52px 32px;transition:border-color .15s,background .15s;display:flex}.dropzone:hover,.dropzone:focus-visible{border-color:var(--accent);background:color-mix(in srgb, var(--accent) 5%, var(--surface))}.dropzone--compact{color:#fff;cursor:pointer;gap:6px;max-width:360px;padding:18px;transition:background .12s,border-color .12s,transform 80ms}.dropzone--green{color:#fff}.dropzone--green .dropzone__icon{color:#16a34a}.compact-actions{align-items:flex-start;gap:12px;display:flex}.dropzone--compact:hover,.dropzone--compact:focus-visible{border-color:#e0a800;transform:translateY(-1px)}.dropzone--green:hover,.dropzone--green:focus-visible{border-color:#16a34a;transform:translateY(-1px)}.dropzone--compact:hover .dropzone__icon,.dropzone--compact:focus-visible .dropzone__icon{color:#e0a800}.dropzone--green:hover .dropzone__icon,.dropzone--green:focus-visible .dropzone__icon{color:#16a34a}.dropzone--compact.dropzone--green{border:2px dashed var(--border)}.dropzone--compact.dropzone--green .dropzone__icon{color:#16a34a}.dropzone--compact.dropzone--green:hover,.dropzone--compact.dropzone--green:focus-visible{border-color:#16a34a}.dropzone--compact .dropzone__title{color:inherit;font-size:14px;font-weight:700}.dropzone--compact .dropzone__sub{font-size:12px}.dropzone--compact .dropzone__icon{color:#e0a800;margin-bottom:4px}.dropzone--active{border-color:var(--accent)!important;background:color-mix(in srgb, var(--accent) 10%, var(--surface))!important}.dropzone__input{display:none}.dropzone__icon{color:var(--accent);opacity:.85;margin-bottom:4px}.dropzone__title{color:var(--text);font-size:16px;font-weight:600}.dropzone__sub{color:var(--text-muted);font-size:13px}.dropzone__link{color:var(--accent);text-underline-offset:2px;text-decoration:underline}.loader{flex-direction:column;align-items:center;gap:16px;display:flex}.loader__ring{border:3px solid var(--surface3);border-top-color:var(--accent);border-radius:50%;width:36px;height:36px;animation:.7s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}.loader__text{color:var(--text-muted);font-size:14px}.error-box{color:#f85149;background:#f8514910;border:1px solid #f8514933;border-radius:8px;width:100%;max-width:420px;padding:16px 20px;font-size:13px;line-height:1.6}.error-box strong{margin-bottom:4px;font-size:14px;display:block}.error-box p{color:var(--text-muted)}.sidebar{width:var(--sidebar-w);border-right:1px solid var(--border);background:var(--surface);flex-direction:column;flex-shrink:0;display:flex;overflow:hidden}.sidebar__header{border-bottom:1px solid var(--border);align-items:center;gap:8px;min-height:44px;padding:10px 12px;display:flex}.sidebar__db-info{flex:1;align-items:center;gap:6px;min-width:0;display:flex;overflow:hidden}.sidebar__db-icon{color:var(--accent);flex-shrink:0}.sidebar__db-name{color:var(--text);white-space:nowrap;text-overflow:ellipsis;font-size:13px;font-weight:600;overflow:hidden}.sidebar__close{width:24px;height:24px;color:var(--text-dim);border-radius:5px;flex-shrink:0;justify-content:center;align-items:center;transition:background .1s,color .1s;display:flex}.sidebar__close:hover{background:var(--surface3);color:var(--text)}.sidebar__meta{color:var(--text-dim);border-bottom:1px solid var(--border-sub);padding:6px 12px;font-size:11px}.sidebar__nav{border-bottom:1px solid var(--border-sub);padding:6px 8px}.sidebar__overview-btn{width:100%;color:var(--text-muted);border-radius:6px;align-items:center;gap:7px;padding:5px 8px;font-size:13px;transition:background .1s,color .1s;display:flex}.sidebar__overview-btn:hover{background:var(--surface3);color:var(--text)}.sidebar__overview-btn.active{background:color-mix(in srgb, var(--accent) 15%, transparent);color:var(--accent-hover)}.sidebar__section{flex-shrink:0;padding:8px 0 4px}.sidebar__section+.sidebar__section{border-top:1px solid var(--border-sub)}.sidebar__section-title{text-transform:uppercase;letter-spacing:.06em;color:var(--text-dim);align-items:center;gap:6px;padding:2px 12px 6px;font-size:11px;font-weight:600;display:flex}.sidebar__badge{color:var(--text-dim);background:var(--surface3);border-radius:10px;margin-left:auto;padding:1px 5px;font-size:10px;font-weight:600}.sidebar__list{max-height:calc(100dvh - 280px);overflow-y:auto}.sidebar__item{width:100%;color:var(--text-muted);text-align:left;border-radius:0;align-items:center;gap:7px;padding:4px 12px;font-size:13px;transition:background .1s,color .1s;display:flex}.sidebar__item svg{color:var(--text-dim);flex-shrink:0}.sidebar__item:hover{background:var(--surface3);color:var(--text)}.sidebar__item.active{background:color-mix(in srgb, var(--accent) 12%, transparent);color:var(--accent-hover)}.sidebar__item.active svg{color:var(--accent)}.sidebar__item-name{white-space:nowrap;text-overflow:ellipsis;flex:1;min-width:0;overflow:hidden}.sidebar__item-count{color:var(--text-dim);flex-shrink:0;font-size:11px}.overview{max-width:900px;padding:28px 32px}.overview__header{margin-bottom:24px}.overview__title{color:var(--text);letter-spacing:-.02em;font-size:20px;font-weight:600}.overview__stats{grid-template-columns:repeat(auto-fill,minmax(130px,1fr));gap:12px;margin-bottom:32px;display:grid}.stat-card{background:var(--surface);border:1px solid var(--border);border-radius:8px;padding:14px 16px}.stat-card__value{color:var(--text);letter-spacing:-.03em;font-size:22px;font-weight:700;line-height:1.2}.stat-card__label{color:var(--text-muted);margin-top:2px;font-size:12px}.overview__section{margin-bottom:28px}.overview__section-title{text-transform:uppercase;letter-spacing:.06em;color:var(--text-dim);margin-bottom:12px;font-size:13px;font-weight:600}.meta-grid{grid-template-columns:repeat(auto-fill,minmax(190px,1fr));gap:10px;display:grid}.meta-grid__item{background:var(--surface);border:1px solid var(--border);border-radius:8px;padding:10px 12px}.meta-grid__label{text-transform:uppercase;letter-spacing:.06em;color:var(--text-dim);margin-bottom:3px;font-size:11px}.meta-grid__value{color:var(--text);word-break:break-word;font-size:14px;font-weight:600}.schema-list{flex-direction:column;gap:10px;display:flex}.schema-item{background:var(--surface);border:1px solid var(--border);border-radius:8px;overflow:hidden}.schema-item__header{border-bottom:1px solid var(--border-sub);justify-content:space-between;align-items:center;gap:12px;padding:10px 14px;display:flex}.schema-item__name{color:var(--accent-hover);align-items:center;gap:7px;font-size:14px;font-weight:600;transition:color .1s;display:flex}.schema-item__name svg{color:var(--text-dim);flex-shrink:0}.schema-item__name:hover{color:var(--accent);text-underline-offset:2px;text-decoration:underline}.schema-item__view-name{color:var(--text);font-size:14px;font-weight:600}.schema-item__rows{color:var(--text-dim);white-space:nowrap;font-size:12px}.schema-item__meta-row{border-bottom:1px solid var(--border-sub);color:var(--text-dim);flex-wrap:wrap;gap:10px;padding:8px 14px;font-size:12px;display:flex}.schema-item__relations{border-bottom:1px solid var(--border-sub);gap:10px;padding:10px 14px;display:grid}.schema-item__relations-title{text-transform:uppercase;letter-spacing:.06em;color:var(--text-dim);margin-bottom:4px;font-size:11px}.schema-item__relations-list{gap:4px;display:grid}.schema-item__relations-list li{flex-wrap:wrap;align-items:center;gap:6px;font-size:12px;display:flex}.relation-chip{color:var(--accent-hover);background:color-mix(in srgb, var(--accent) 18%, transparent);border-radius:999px;padding:1px 5px;font-size:10px;font-weight:700}.relation-chip--fk{color:#56d364;background:#56d3642e}.relation-name{color:var(--text);font-weight:600}.relation-cols{color:var(--text-muted);font-family:ui-monospace,Cascadia Code,Consolas,monospace}.relation-rule{color:var(--text-dim)}.schema-item__sql{color:var(--text-muted);white-space:pre-wrap;word-break:break-all;padding:12px 14px;font-family:ui-monospace,Cascadia Code,Fira Code,Consolas,monospace;font-size:12px;line-height:1.7;overflow:auto}.sql-code code{color:inherit}.sql-code .token.keyword,.playground__editor .token.keyword{color:#ff7b72;font-weight:600}.sql-code .token.string,.playground__editor .token.string{color:#a5d6ff}.sql-code .token.number,.playground__editor .token.number{color:#79c0ff}.sql-code .token.operator,.sql-code .token.punctuation,.playground__editor .token.operator,.playground__editor .token.punctuation{color:#c9d1d9}.sql-code .token.function,.sql-code .token.property,.sql-code .token.selector,.playground__editor .token.function,.playground__editor .token.property,.playground__editor .token.selector{color:#d2a8ff}.sql-code .token.comment,.playground__editor .token.comment{color:#8b949e;font-style:italic}.table-view{flex-direction:column;height:100%;min-height:0;display:flex}.table-view__topbar{border-bottom:1px solid var(--border);background:var(--surface);flex-shrink:0;justify-content:space-between;align-items:center;gap:16px;padding:12px 20px;display:flex}.table-view__tabs{align-items:center;gap:6px;margin-left:auto;display:flex}.table-view__tab{color:var(--text-muted);border:1px solid var(--border);background:var(--surface2);border-radius:6px;padding:5px 10px;font-size:12px;transition:border-color .15s,color .15s,background .15s}.table-view__tab:hover{color:var(--text);border-color:var(--text-dim)}.table-view__tab.active{color:var(--accent-hover);border-color:color-mix(in srgb, var(--accent) 40%, var(--border));background:color-mix(in srgb, var(--accent) 16%, var(--surface2))}.table-view__title-row{align-items:baseline;gap:10px;display:flex}.table-view__title{color:var(--text);letter-spacing:-.01em;font-size:16px;font-weight:600}.table-view__count{color:var(--text-dim);font-size:12px}.table-wrap{flex:1;min-height:0;overflow:auto}.table-schema{flex-direction:column;gap:14px;padding:14px 18px;display:flex;overflow:auto}.table-schema__section{border:1px solid var(--border);background:var(--surface);border-radius:8px;overflow:hidden}.table-schema__title{text-transform:uppercase;letter-spacing:.06em;color:var(--text-dim);border-bottom:1px solid var(--border-sub);padding:10px 12px;font-size:12px}.table-schema__list{gap:8px;padding:10px;display:grid}.table-schema__card{border:1px solid var(--border-sub);border-radius:6px;overflow:hidden}.table-schema__card-head{color:var(--text);border-bottom:1px solid var(--border-sub);background:var(--surface2);padding:8px 10px;font-size:13px;font-weight:600}.table-schema__empty{color:var(--text-dim);padding:12px;font-size:12px}.data-table{border-collapse:collapse;width:max-content;min-width:100%;font-size:13px}.data-table__th{background:var(--surface);border-bottom:1px solid var(--border);border-right:1px solid var(--border-sub);white-space:nowrap;-webkit-user-select:none;user-select:none;cursor:pointer;z-index:2;min-width:80px;max-width:320px;padding:0;position:sticky;top:0}.data-table__th:hover{background:var(--surface3)}.data-table__th.sorted{background:color-mix(in srgb, var(--accent) 8%, var(--surface))}--rn.data-table__th{cursor:default;width:48px;min-width:48px;max-width:48px;color:var(--text-dim);text-align:right}--rn.data-table__th:hover{background:var(--surface)}.th-inner{justify-content:space-between;align-items:center;gap:6px;padding:7px 10px;display:flex}.th-left{align-items:center;gap:5px;min-width:0;display:flex;overflow:hidden}.th-name{color:var(--text);text-overflow:ellipsis;font-weight:600;overflow:hidden}.th-type{color:var(--text-dim);background:var(--surface3);border-radius:4px;flex-shrink:0;padding:1px 5px;font-family:ui-monospace,monospace;font-size:10px}.th-pk{color:var(--pk);background:color-mix(in srgb, var(--pk) 12%, transparent);border-radius:4px;flex-shrink:0;padding:1px 5px;font-size:10px;font-weight:700}.th-sort{color:var(--text-dim);flex-shrink:0;font-size:11px}.sorted .th-sort{color:var(--accent)}.data-table__row:hover td,.data-table__row:hover .data-table__td--rn{background:var(--surface)}.data-table__td{border-bottom:1px solid var(--border-sub);border-right:1px solid var(--border-sub);text-overflow:ellipsis;white-space:nowrap;max-width:320px;color:var(--text-muted);padding:5px 10px;overflow:hidden}--rn.data-table__td{text-align:right;color:var(--text-dim);font-variant-numeric:tabular-nums;-webkit-user-select:none;user-select:none;background:var(--surface);border-right:1px solid var(--border);width:48px;min-width:48px;padding:5px 8px;font-size:11px;position:sticky;left:0}.data-table__empty{text-align:center;color:var(--text-dim);padding:48px;font-style:italic}.cell-null{color:var(--null);font-size:12px;font-style:italic}.cell-blob{color:var(--blob);font-family:ui-monospace,monospace;font-size:12px}.pagination{align-items:center;gap:4px;display:flex}.pagination__btn{border:1px solid var(--border);background:var(--surface2);width:28px;height:28px;color:var(--text);border-radius:5px;justify-content:center;align-items:center;font-size:14px;transition:background .1s,border-color .1s;display:flex}.pagination__btn:hover:not(:disabled){background:var(--surface3);border-color:var(--text-dim)}.pagination__btn:disabled{opacity:.35;cursor:not-allowed}.pagination__info{color:var(--text-muted);white-space:nowrap;font-variant-numeric:tabular-nums;padding:0 8px;font-size:12px}.schema-explorer{flex-direction:column;gap:16px;padding:24px 28px;display:flex}.schema-explorer__header{flex-direction:column;gap:2px;display:flex}.schema-explorer__title{color:var(--text);font-size:20px;font-weight:700}.schema-explorer__subtitle{color:var(--text-dim);font-size:12px}.schema-explorer__grid{grid-template-columns:repeat(auto-fill,minmax(360px,1fr));gap:12px;display:grid}.schema-explorer__card{border:1px solid var(--border);background:var(--surface);border-radius:8px;flex-direction:column;gap:10px;padding:12px;display:flex}.schema-explorer__card-header{justify-content:space-between;align-items:center;gap:8px;display:flex}.schema-explorer__table-name{color:var(--accent-hover);font-size:15px;font-weight:700}.schema-explorer__table-name:hover{color:var(--accent);text-underline-offset:2px;text-decoration:underline}.schema-explorer__table-sub{color:var(--text-dim);font-size:12px}.schema-explorer__section{flex-direction:column;gap:4px;display:flex}.schema-explorer__section-title{color:var(--text-dim);text-transform:uppercase;letter-spacing:.06em;font-size:11px}.schema-explorer__rows{flex-direction:column;gap:4px;display:flex}.schema-explorer__row{flex-wrap:wrap;align-items:center;gap:6px;font-size:12px;display:flex}.schema-explorer__pill{color:var(--accent-hover);background:color-mix(in srgb, var(--accent) 18%, transparent);border-radius:999px;padding:1px 6px;font-size:10px;font-weight:700}.schema-explorer__pill--fk{color:#56d364;background:#56d3642e}.schema-explorer__pill--trigger{color:#d2a8ff;background:#d2a8ff2e}.schema-explorer__row-name{color:var(--text);font-weight:600}.schema-explorer__row-detail{color:var(--text-dim);font-family:ui-monospace,Cascadia Code,Consolas,monospace}.schema-explorer__empty{color:var(--text-dim);font-size:12px}.schema-explorer__triggers{border:1px solid var(--border);background:var(--surface);border-radius:8px;flex-direction:column;gap:6px;padding:12px;display:flex}.playground{flex-direction:column;gap:14px;padding:24px 28px;display:flex}.playground__header{flex-direction:column;gap:2px;display:flex}.playground__title{color:var(--text);font-size:20px;font-weight:700}.playground__subtitle{color:var(--text-dim);font-size:12px}.playground__editor-block{border:1px solid var(--border);background:var(--surface);border-radius:8px;flex-direction:column;gap:8px;padding:10px;display:flex}.playground__editor{border:1px solid var(--border-sub);background:var(--bg);width:100%;min-height:140px;color:var(--text);border-radius:6px;font-family:ui-monospace,Cascadia Code,Consolas,monospace;font-size:13px;line-height:1.55;overflow:auto}.playground__editor-pre,.playground__editor-textarea{white-space:pre;outline:none;margin:0}.playground__editor-textarea{caret-color:var(--text);color:#0000!important}.playground__editor-pre{pointer-events:none}.playground__actions{flex-wrap:wrap;align-items:center;gap:10px;display:flex}.playground__run-btn{border:1px solid color-mix(in srgb, var(--accent) 55%, var(--border));background:color-mix(in srgb, var(--accent) 16%, var(--surface2));height:30px;color:var(--accent-hover);border-radius:6px;padding:0 12px;font-size:13px;font-weight:600}.playground__run-btn:hover:not(:disabled){background:color-mix(in srgb, var(--accent) 24%, var(--surface2))}.playground__run-btn:disabled{opacity:.45;cursor:not-allowed}.playground__summary{color:var(--text-muted);font-size:12px}.playground__results{flex-direction:column;gap:12px;display:flex}.playground__result-block{border:1px solid var(--border);background:var(--surface);border-radius:8px;overflow:hidden}.playground__result-head{border-bottom:1px solid var(--border-sub);justify-content:space-between;align-items:center;gap:10px;padding:10px 12px;display:flex}.playground__result-title{color:var(--text);font-size:13px;font-weight:700}.playground__result-count{color:var(--text-dim);font-size:11px}.playground__error-overlay{z-index:60;background:#010409a3;place-items:center;padding:16px;display:grid;position:fixed;inset:0}.playground__error-popup{background:#1a0f11;border:1px solid #f8514960;border-radius:10px;width:min(520px,100%);padding:14px;box-shadow:0 10px 34px #00000080}.playground__error-title{color:#ffb4b0;margin-bottom:6px;font-size:14px;font-weight:700}.playground__error-message{color:#ffd1ce;white-space:pre-wrap;margin-bottom:10px;font-size:13px;line-height:1.5}.playground__error-close{color:#ffb4b0;background:#f8514924;border:1px solid #f8514960;border-radius:6px;height:30px;padding:0 12px;font-size:12px;font-weight:600}.playground__error-close:hover{background:#f8514936}@media (width<=840px){.app-header{flex-wrap:wrap;height:auto;padding-top:8px;padding-bottom:8px}.app-header__tabs{order:3;width:100%;margin:0}.schema-explorer,.playground{padding:16px}.schema-explorer__grid{grid-template-columns:1fr}.app-footer{flex-wrap:wrap;height:auto;padding:6px 10px;line-height:1.4}}
