@import"https://fonts.googleapis.com/css2?family=Roboto+Flex:opsz,wght@8..144,100..1000&display=swap";:root{--bg-base: #F9F9F9;--bg-surface: #ffffff;--bg-surface-hover: #f3f4f6;--bg-raised: #f0f0f0;--bg-sidebar: #ffffff;--bg-sidebar-surface: #f3f4f6;--border-base: #e5e7eb;--border-strong: #d1d5db;--text-base: #333333;--text-muted: #646464;--text-inverse: #ffffff;--brand-primary: #E85002;--brand-primary-hover: #C10801;--brand-primary-light: rgba(232, 80, 2, .08);--brand-danger: #ef4444;--brand-danger-hover: #dc2626;--brand-success: #22c55e;--font-sans: "Roboto Flex", sans-serif;--font-mono: "Menlo", "Monaco", "Courier New", monospace;--radius-sm: 4px;--radius-md: 6px;--radius-lg: 10px}*{box-sizing:border-box;margin:0;padding:0}body{font-family:var(--font-sans);background-color:var(--bg-base);color:var(--text-base);line-height:1.5;-webkit-font-smoothing:antialiased}a{color:var(--brand-primary);text-decoration:none}a:hover{text-decoration:underline}button{font-family:inherit;cursor:pointer;border:none;background:none}input,select,textarea{font-family:inherit;color:inherit}.page{min-height:100vh;display:grid;place-items:center;padding:2rem;background-color:var(--bg-base)}.card{width:min(400px,92vw);background:var(--bg-surface);border:1px solid var(--border-base);border-radius:var(--radius-lg);padding:2rem;box-shadow:0 2px 8px #0000000f}header{margin-bottom:2rem;text-align:center}.eyebrow{font-size:.75rem;font-weight:600;letter-spacing:.05em;text-transform:uppercase;color:var(--brand-primary);margin-bottom:.5rem}h1{font-size:1.5rem;font-weight:600;color:var(--text-base);margin-bottom:.5rem}.subtle{color:var(--text-muted);font-size:.9rem}.form{display:grid;gap:1.25rem}.grid{display:grid;grid-template-columns:1fr 1fr;gap:1rem}label{display:grid;gap:.5rem;font-size:.85rem;color:var(--text-muted);font-weight:500}input{background:var(--bg-base);border:1px solid var(--border-base);color:var(--text-base);border-radius:var(--radius-md);padding:.6rem .8rem;font-size:.9rem;transition:all .2s ease;width:100%}input:focus{outline:none;border-color:var(--brand-primary);box-shadow:0 0 0 3px #e850021a}select{background:var(--bg-base);border:1px solid var(--border-base);color:var(--text-base);border-radius:var(--radius-md);padding:.5rem .7rem;font-size:.9rem}select:focus{outline:none;border-color:var(--brand-primary);box-shadow:0 0 0 3px #e850021a}.muted{color:var(--text-muted)}.primary{background:linear-gradient(135deg,#e85002,#f16001);color:#fff;font-weight:600;padding:.6rem 1rem;border-radius:var(--radius-md);transition:all .2s;box-shadow:0 1px 3px #e8500240}.primary:hover{background:linear-gradient(135deg,#c10801,#e85002);box-shadow:0 2px 8px #e8500259}.primary:disabled{opacity:.5;cursor:not-allowed;box-shadow:none}.danger{border:1px solid var(--border-base);color:var(--brand-danger);padding:.35rem .7rem;border-radius:var(--radius-md);transition:border-color .2s,background-color .2s}.danger:hover{border-color:var(--brand-danger);background:#ef44440f}.swap-link{margin-top:1.5rem;text-align:center;font-size:.85rem}.swap-link a{color:var(--text-muted);transition:color .2s}.swap-link a:hover{color:var(--brand-primary)}.status{min-height:1.5rem;margin-top:1rem;font-size:.85rem;text-align:center}.error{color:var(--brand-danger)}.ok{color:var(--brand-primary)}.session{margin-top:1.5rem;padding-top:1rem;border-top:1px solid var(--border-base);text-align:center;font-size:.85rem;color:var(--text-muted)}.session strong{color:var(--text-base)}.dashboard{min-height:100vh;background-color:var(--bg-base)}.sidebar{background-color:var(--bg-sidebar);border-right:1px solid var(--border-base);display:flex;flex-direction:column;align-items:flex-start;padding:1.5rem 0;gap:1rem;position:fixed;left:0;top:0;bottom:0;height:100vh;width:64px;transition:width .3s ease,box-shadow .3s ease;overflow:hidden;z-index:50;white-space:nowrap}.sidebar:hover{width:240px;box-shadow:4px 0 24px #00000014}.icon-btn{width:calc(100% - 16px);margin:4px 8px;height:40px;border-radius:8px;color:var(--text-muted);display:flex;align-items:center;gap:1rem;padding-left:.8rem;transition:all .2s cubic-bezier(.4,0,.2,1);cursor:pointer;border:none;background:transparent}.link-text{opacity:0;transform:translate(-10px);transition:opacity .2s ease,transform .2s ease;font-size:.95rem;font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;flex:1;min-width:0}.sidebar:hover .link-text{opacity:1;transform:translate(0);transition-delay:.1s}.icon-btn svg{width:22px;height:22px;stroke-width:2;stroke:currentColor;fill:none}.icon-btn:hover{background-color:var(--bg-surface-hover);color:var(--text-base)}.icon-btn.active{background-color:var(--brand-primary-light);color:var(--brand-primary);font-weight:600}.icon-btn.active svg{color:var(--brand-primary)}.panel{padding:2rem 4rem;overflow-y:auto;max-width:1600px;min-height:100vh;margin:0 auto;width:100%}.dashboard.with-sidebar .panel{margin-left:64px;width:auto}.panel-header{display:flex;justify-content:space-between;align-items:flex-end;margin-bottom:3rem;padding-bottom:1rem;border-bottom:1px solid var(--border-base)}.header-right{display:flex;align-items:center;gap:1.5rem}.header-meta{display:grid;gap:.25rem;text-align:right}.project-switcher label{display:grid;gap:.25rem;font-size:.75rem;color:var(--text-muted);font-weight:500}.project-switcher select{background-color:var(--bg-surface);border:1px solid var(--border-base);color:var(--text-base);padding:.5rem 1rem;border-radius:var(--radius-md);font-size:.9rem;min-width:240px;cursor:pointer;transition:border-color .2s}.project-switcher select:hover{border-color:var(--brand-primary)}.panel-body{display:grid;grid-template-columns:350px 1fr;gap:2rem;align-items:start}.profile-card,.sql-card{background:var(--bg-surface);border:1px solid var(--border-base);border-radius:var(--radius-lg);padding:1.5rem}.profile-card h2,.sql-card h2{font-size:1.1rem;margin-bottom:1.5rem;color:var(--text-base)}.card-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem}.ghost{color:var(--text-muted);font-size:.85rem;padding:.3rem .6rem;border-radius:var(--radius-sm);transition:color .2s,background .2s}.ghost:hover{background:var(--bg-surface-hover);color:var(--text-base)}.project-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:1.5rem}.project-card,.create-project-card{background:var(--bg-surface);border:1px solid var(--border-base);border-radius:var(--radius-lg);padding:1.5rem;display:flex;flex-direction:column;justify-content:space-between;min-height:180px;transition:transform .2s,border-color .2s,box-shadow .2s;cursor:pointer;position:relative}.project-card:hover{transform:translateY(-2px);border-color:var(--brand-primary);box-shadow:0 4px 16px #e850021a}.project-card h3{margin:0 0 .5rem;font-size:1.1rem;color:var(--text-base)}.project-card p{color:var(--text-muted);font-size:.9rem;flex-grow:1;margin-bottom:1rem}.card-actions{display:flex;justify-content:flex-end;margin-top:auto}.create-project-card{border-style:dashed;border-color:var(--border-strong);background:transparent;align-items:center;justify-content:center;gap:1rem;color:var(--text-muted);cursor:default}.create-project-card:hover{border-color:var(--brand-primary);background:#e8500208;transform:none;box-shadow:none}.create-project-form{width:100%;display:flex;flex-direction:column;gap:.75rem}.create-project-form h3{text-align:center;color:var(--text-base);margin-bottom:.5rem}.project-detail-layout{display:grid;grid-template-columns:350px 1fr;gap:2rem;align-items:start;height:calc(100vh - 120px)}.overview-main{display:grid;gap:1.5rem;align-content:start}.detail-sidebar{display:flex;flex-direction:column;gap:1.5rem}.info-card{background:var(--bg-surface);border:1px solid var(--border-base);border-radius:var(--radius-lg);padding:1.5rem}.info-card h3{font-size:1rem;color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em;margin-bottom:1rem}.info-row{display:flex;justify-content:space-between;padding:.5rem 0;border-bottom:1px solid var(--border-base);font-size:.9rem}.info-row:last-child{border-bottom:none}.info-row span{color:var(--text-muted)}.info-row strong{color:var(--text-base);font-family:var(--font-mono)}.sql-editor-container{display:flex;flex-direction:column;gap:1rem;height:100%}.sql-card{background:var(--bg-surface);border:1px solid var(--border-base);border-radius:var(--radius-lg);padding:0;display:flex;flex-direction:column;flex-grow:1;overflow:hidden}.sql-toolbar{padding:.75rem 1rem;border-bottom:1px solid var(--border-base);display:flex;justify-content:space-between;align-items:center;background:var(--bg-base)}.sql-toolbar h2{font-size:.95rem;margin:0;color:var(--text-muted);font-weight:500}.editor-area{flex-grow:1;position:relative;display:flex;flex-direction:column;gap:1rem}.editor-area textarea{width:100%;height:100%;flex:1;background-color:#fafafa;color:var(--text-base);font-family:var(--font-mono);border:none;padding:1rem;font-size:.95rem;line-height:1.6;resize:none}.editor-area textarea:focus{outline:none}.sql-result-area{border-top:1px solid var(--border-base);background:var(--bg-base);max-height:40%;overflow:auto;display:flex;flex-direction:column}.connect-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:1.25rem;padding:1.25rem}.connect-block{background:var(--bg-surface);border:1px solid var(--border-base);border-radius:var(--radius-md);padding:1rem;display:grid;gap:.75rem}.connect-block h3{margin:0;font-size:.85rem;text-transform:uppercase;letter-spacing:.05em;color:var(--text-muted)}.code-row{display:flex;align-items:center;justify-content:space-between;gap:.5rem}.code-list{display:grid;gap:.4rem}.connect-block code,.code-list code{font-family:var(--font-mono);font-size:.8rem;background:var(--bg-base);border:1px solid var(--border-base);border-radius:var(--radius-sm);padding:.4rem .6rem;display:block;overflow-x:auto}.sql-meta{display:flex;align-items:center;justify-content:space-between;gap:1rem;flex-wrap:wrap;padding:.75rem 1rem;border-bottom:1px solid var(--border-base);background:var(--bg-surface)}.sql-actions{display:flex;align-items:center;gap:.75rem;flex-wrap:wrap;margin-top:.5rem}.result-header{padding:.5rem 1rem;background:var(--bg-surface);border-bottom:1px solid var(--border-base);font-size:.8rem;color:var(--text-muted);position:sticky;top:0}@media(max-width:1024px){.project-detail-layout{grid-template-columns:1fr;height:auto}.sql-card{min-height:500px}}@media(max-width:768px){.panel{padding:1.5rem}.grid{grid-template-columns:1fr}}.modal-backdrop{position:fixed;inset:0;background:#00000059;display:grid;place-items:center;z-index:100;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px)}.modal{width:min(420px,92vw);background:var(--bg-surface);border:1px solid var(--border-base);border-radius:var(--radius-lg);padding:1.5rem;display:grid;gap:.9rem;box-shadow:0 12px 40px #0000001f}.modal h3{margin:0;font-size:1.1rem;color:var(--text-base)}.modal textarea{background:var(--bg-base);border:1px solid var(--border-base);color:var(--text-base);border-radius:var(--radius-md);padding:.6rem .8rem;font-size:.9rem;resize:vertical;width:100%}.modal-actions{display:flex;justify-content:flex-end;gap:.5rem}.schema-list{display:grid;gap:.5rem}.schema-row{display:flex;align-items:center;gap:.5rem}.schema-row .schema-item{flex:1}.schema-item{text-align:left;border:1px solid var(--border-base);background:var(--bg-base);color:var(--text-base);padding:.45rem .6rem;border-radius:var(--radius-md);cursor:pointer;transition:border-color .2s}.schema-item.active,.schema-item:hover{border-color:var(--brand-primary)}.table-wrap{border:1px solid var(--border-base);border-radius:var(--radius-md);overflow:auto;background:var(--bg-surface)}table{width:100%;border-collapse:collapse;font-size:.85rem}th,td{padding:.6rem .75rem;border-bottom:1px solid var(--border-base);text-align:left}thead th{background:var(--bg-base);color:var(--text-muted);font-weight:600;font-size:.75rem;text-transform:uppercase;letter-spacing:.04em;position:sticky;top:0}tbody tr:hover{background:var(--bg-surface-hover)}.column-builder{display:grid;gap:.75rem}.column-row{display:grid;grid-template-columns:1.2fr 1fr auto auto;gap:.5rem;align-items:center}.column-row select,.column-row input{background:var(--bg-base);border:1px solid var(--border-base);color:var(--text-base);border-radius:var(--radius-md);padding:.45rem .6rem;font-size:.85rem}.checkbox{display:flex;align-items:center;gap:.4rem;font-size:.75rem;color:var(--text-muted)}.policy-grid{display:grid;gap:.5rem;margin-top:.5rem}@media(max-width:1024px){.column-row{grid-template-columns:1fr 1fr}}.sidebar .icon-btn{width:calc(100% - 16px)!important;margin:2px 8px!important;height:40px!important;border-radius:6px!important;padding-left:12px!important;gap:12px!important;color:var(--text-muted)}.sidebar .icon-btn:hover{background-color:var(--bg-surface-hover)!important;color:var(--text-base)!important}.sidebar .icon-btn.active{background-color:var(--brand-primary-light)!important;color:var(--brand-primary)!important;font-weight:500}
