@import "https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700&family=JetBrains+Mono:wght@400;500&display=swap";:root{--color-bg-main:#0a0e1a;--color-bg-card:#111827;--color-bg-elevated:#1a2233;--color-bg-input:#0f1624;--color-bg-hover:#ffffff0a;--color-bg-active:#c8ff000f;--color-bg-overlay:#0a0e1ad9;--color-accent-lime:#c8ff00;--color-accent-lime-dim:#7ab800;--color-accent-lime-bg:#c8ff0014;--color-vector-blue:#3b82f6;--color-vector-blue-dim:#1d4ed8;--color-vector-bg:#3b82f61a;--color-vector-border:#3b82f64d;--color-calc-purple:#a855f7;--color-calc-purple-dim:#7c3aed;--color-calc-bg:#a855f71a;--color-calc-border:#a855f74d;--color-success:#22c55e;--color-warning:#f59e0b;--color-error:#ef4444;--color-info:--color-vector-blue;--color-success-bg:#22c55e1a;--color-error-bg:#ef44441a;--color-warning-bg:#f59e0b1a;--color-text-primary:#f1f5f9;--color-text-secondary:#94a3b8;--color-text-muted:#475569;--color-text-accent:var(--color-accent-lime);--color-text-inverse:#0a0e1a;--color-border-soft:#ffffff0f;--color-border-medium:#ffffff1a;--color-border-strong:#fff3;--color-border-accent:#c8ff0040;--radius-xs:4px;--radius-sm:6px;--radius-md:10px;--radius-card:14px;--radius-lg:18px;--radius-xl:24px;--radius-pill:9999px;--shadow-sm:0 1px 3px #0006;--shadow-card:0 4px 16px #00000080;--shadow-glow:0 0 24px #c8ff001f, 0 0 8px #c8ff0014;--shadow-glow-blue:0 0 20px #3b82f626;--shadow-glow-purple:0 0 20px #a855f726;--shadow-modal:0 24px 80px #000c;--space-1:4px;--space-2:8px;--space-3:12px;--space-4:16px;--space-5:20px;--space-6:24px;--space-8:32px;--space-10:40px;--space-12:48px;--space-16:64px;--font-sans:"Inter", "Segoe UI", system-ui, sans-serif;--font-mono:"JetBrains Mono", "Fira Code", "Courier New", monospace;--text-xs:11px;--text-sm:13px;--text-base:15px;--text-md:17px;--text-lg:20px;--text-xl:24px;--text-2xl:30px;--text-3xl:38px;--text-hero:56px;--weight-normal:400;--weight-medium:500;--weight-semibold:600;--weight-bold:700;--leading-tight:1.2;--leading-normal:1.5;--leading-relaxed:1.7;--transition-fast:.15s ease;--transition-base:.22s ease;--transition-slow:.38s ease;--z-dropdown:100;--z-sticky:200;--z-sidebar:300;--z-modal:500;--z-toast:900;--z-overlay:400;--sidebar-width:240px;--topbar-height:56px;--content-max:1280px}*,:before,:after{box-sizing:border-box;margin:0;padding:0}html{scroll-behavior:smooth;font-size:16px}body{font-family:var(--font-sans);font-size:var(--text-base);line-height:var(--leading-normal);color:var(--color-text-primary);background:var(--color-bg-main);-webkit-font-smoothing:antialiased;min-height:100vh}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:0 0}::-webkit-scrollbar-thumb{background:var(--color-border-medium);border-radius:var(--radius-pill)}::-webkit-scrollbar-thumb:hover{background:var(--color-border-strong)}h1,h2,h3,h4,h5,h6{font-weight:var(--weight-semibold);line-height:var(--leading-tight);color:var(--color-text-primary)}h1{font-size:var(--text-3xl)}h2{font-size:var(--text-2xl)}h3{font-size:var(--text-xl)}h4{font-size:var(--text-lg)}p{color:var(--color-text-secondary);line-height:var(--leading-relaxed)}a{color:var(--color-accent-lime);text-decoration:none}a:hover{text-decoration:underline}code,pre{font-family:var(--font-mono);font-size:var(--text-sm)}pre{background:var(--color-bg-input);padding:var(--space-4);border-radius:var(--radius-md);overflow-x:auto}.btn{align-items:center;gap:var(--space-2);padding:0 var(--space-5);height:38px;font-size:var(--text-sm);font-weight:var(--weight-semibold);border-radius:var(--radius-sm);cursor:pointer;transition:all var(--transition-fast);white-space:nowrap;-webkit-user-select:none;user-select:none;border:1px solid #0000;text-decoration:none;display:inline-flex}.btn:disabled{opacity:.45;cursor:not-allowed;pointer-events:none}.btn-primary{background:var(--color-accent-lime);color:var(--color-text-inverse);border-color:var(--color-accent-lime)}.btn-primary:hover{filter:brightness(1.1);box-shadow:var(--shadow-glow)}.btn-secondary{color:var(--color-text-primary);border-color:var(--color-border-medium);background:0 0}.btn-secondary:hover{background:var(--color-bg-hover);border-color:var(--color-border-strong)}.btn-ghost{color:var(--color-text-secondary);background:0 0;border-color:#0000}.btn-ghost:hover{background:var(--color-bg-hover);color:var(--color-text-primary)}.btn-danger{background:var(--color-error-bg);color:var(--color-error);border-color:#ef444440}.btn-danger:hover{background:#ef44442e}.btn-sm{height:30px;padding:0 var(--space-3);font-size:var(--text-xs)}.btn-lg{height:46px;padding:0 var(--space-8);font-size:var(--text-md)}.btn-icon{justify-content:center;width:38px;padding:0}.btn-icon.btn-sm{width:30px}.card{background:var(--color-bg-card);border:1px solid var(--color-border-soft);border-radius:var(--radius-card);padding:var(--space-6);transition:border-color var(--transition-base), box-shadow var(--transition-base)}.card:hover{border-color:var(--color-border-medium)}.card-elevated{background:var(--color-bg-elevated)}.card-glow:hover{box-shadow:var(--shadow-glow);border-color:var(--color-border-accent)}.form-group{gap:var(--space-2);flex-direction:column;display:flex}.form-label{font-size:var(--text-sm);font-weight:var(--weight-medium);color:var(--color-text-secondary)}.form-label.required:after{content:" *";color:var(--color-error)}.form-control{width:100%;padding:var(--space-2) var(--space-3);background:var(--color-bg-input);color:var(--color-text-primary);border:1px solid var(--color-border-medium);border-radius:var(--radius-sm);font-size:var(--text-sm);font-family:var(--font-sans);transition:border-color var(--transition-fast);outline:none}.form-control:focus{border-color:var(--color-accent-lime);box-shadow:0 0 0 2px #c8ff001f}.form-control::placeholder{color:var(--color-text-muted)}select.form-control{cursor:pointer}textarea.form-control{resize:vertical;min-height:80px}.badge{border-radius:var(--radius-pill);font-size:var(--text-xs);font-weight:var(--weight-semibold);letter-spacing:.02em;text-transform:uppercase;align-items:center;gap:4px;padding:2px 8px;display:inline-flex}.badge-vector{background:var(--color-vector-bg);color:var(--color-vector-blue);border:1px solid var(--color-vector-border)}.badge-calc{background:var(--color-calc-bg);color:var(--color-calc-purple);border:1px solid var(--color-calc-border)}.badge-lime{background:var(--color-accent-lime-bg);color:var(--color-accent-lime);border:1px solid var(--color-border-accent)}.badge-success{background:var(--color-success-bg);color:var(--color-success)}.badge-error{background:var(--color-error-bg);color:var(--color-error)}.badge-warning{background:var(--color-warning-bg);color:var(--color-warning)}.badge-muted{background:var(--color-bg-elevated);color:var(--color-text-muted)}.status-dot{border-radius:50%;width:8px;height:8px;display:inline-block}.status-dot.running{background:var(--color-success);box-shadow:0 0 6px var(--color-success)}.status-dot.stopped{background:var(--color-text-muted)}.status-dot.failed{background:var(--color-error)}.status-dot.building{background:var(--color-warning);animation:1.2s ease-in-out infinite pulse}.status-dot.pending{background:var(--color-vector-blue);animation:1.2s ease-in-out infinite pulse}.table-wrap{border-radius:var(--radius-card);border:1px solid var(--color-border-soft);overflow-x:auto}table{border-collapse:collapse;width:100%;font-size:var(--text-sm)}thead th{background:var(--color-bg-elevated);padding:var(--space-3) var(--space-4);text-align:left;font-weight:var(--weight-semibold);color:var(--color-text-secondary);font-size:var(--text-xs);text-transform:uppercase;letter-spacing:.06em;border-bottom:1px solid var(--color-border-soft)}tbody tr{border-bottom:1px solid var(--color-border-soft);transition:background var(--transition-fast)}tbody tr:last-child{border-bottom:none}tbody tr:hover{background:var(--color-bg-hover)}tbody td{padding:var(--space-3) var(--space-4);color:var(--color-text-primary);vertical-align:middle}.tabs{border-bottom:1px solid var(--color-border-soft);gap:2px;display:flex}.tab-btn{padding:var(--space-3) var(--space-4);font-size:var(--text-sm);font-weight:var(--weight-medium);color:var(--color-text-muted);cursor:pointer;transition:all var(--transition-fast);background:0 0;border:none;border-bottom:2px solid #0000;margin-bottom:-1px}.tab-btn:hover{color:var(--color-text-primary)}.tab-btn.active{color:var(--color-accent-lime);border-bottom-color:var(--color-accent-lime)}.tab-panel{display:none}.tab-panel.active{display:block}.skeleton{background:linear-gradient(90deg, var(--color-bg-elevated) 25%, var(--color-bg-hover) 50%, var(--color-bg-elevated) 75%);border-radius:var(--radius-sm);background-size:200% 100%;animation:1.4s infinite skeleton-shimmer}@keyframes skeleton-shimmer{0%{background-position:200% 0}to{background-position:-200% 0}}.spinner{border:2px solid var(--color-border-medium);border-top-color:var(--color-accent-lime);border-radius:50%;width:20px;height:20px;animation:.7s linear infinite spin;display:inline-block}.spinner-sm{border-width:2px;width:14px;height:14px}.spinner-lg{border-width:3px;width:32px;height:32px}@keyframes spin{to{transform:rotate(360deg)}}.progress{background:var(--color-bg-elevated);border-radius:var(--radius-pill);height:6px;overflow:hidden}.progress-bar{background:linear-gradient(90deg, var(--color-accent-lime-dim), var(--color-accent-lime));border-radius:var(--radius-pill);height:100%;transition:width .5s}.modal-overlay{background:var(--color-bg-overlay);z-index:var(--z-modal);-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);opacity:0;pointer-events:none;transition:opacity var(--transition-base);justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.modal-overlay.open{opacity:1;pointer-events:all}.modal-box{background:var(--color-bg-elevated);border:1px solid var(--color-border-medium);border-radius:var(--radius-lg);padding:var(--space-8);width:min(600px,100vw - 32px);box-shadow:var(--shadow-modal);max-height:90vh;transition:transform var(--transition-base);overflow-y:auto;transform:translateY(16px)scale(.98)}.modal-overlay.open .modal-box{transform:none}.modal-header{margin-bottom:var(--space-6);justify-content:space-between;align-items:center;display:flex}.modal-title{font-size:var(--text-lg);font-weight:var(--weight-semibold)}.modal-footer{gap:var(--space-3);margin-top:var(--space-6);justify-content:flex-end;display:flex}#toast-container{z-index:var(--z-toast);gap:var(--space-2);flex-direction:column;align-items:flex-end;display:flex;position:fixed;bottom:24px;right:24px}.toast{align-items:center;gap:var(--space-3);padding:var(--space-3) var(--space-5);border-radius:var(--radius-md);font-size:var(--text-sm);font-weight:var(--weight-medium);box-shadow:var(--shadow-modal);border:1px solid var(--color-border-medium);min-width:240px;max-width:400px;animation:.25s toast-in;display:flex}.toast.success{color:var(--color-success);background:#0f2a1a;border-color:#22c55e40}.toast.error{color:var(--color-error);background:#2a0f0f;border-color:#ef444440}.toast.info{color:var(--color-vector-blue);border-color:var(--color-vector-border);background:#0f1a2a}.toast.warning{color:var(--color-warning);background:#2a1f0f;border-color:#f59e0b40}@keyframes toast-in{0%{opacity:0;transform:translate(20px)}to{opacity:1;transform:none}}@keyframes pulse{0%,to{opacity:1}50%{opacity:.4}}@keyframes fade-in{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:none}}.animate-in{animation:.3s forwards fade-in}.flow-arrow{background:linear-gradient(to bottom, transparent, var(--color-accent-lime), transparent);width:2px;position:relative;overflow:hidden}.flow-arrow:after{content:"";background:linear-gradient(to bottom, transparent, var(--color-accent-lime));width:100%;height:40px;animation:1.8s ease-in-out infinite flow-down;position:absolute;top:-40px;left:0}@keyframes flow-down{0%{transform:translateY(0)}to{transform:translateY(200px)}}.flex{display:flex}.flex-col{flex-direction:column}.items-center{align-items:center}.justify-between{justify-content:space-between}.justify-center{justify-content:center}.gap-1{gap:var(--space-1)}.gap-2{gap:var(--space-2)}.gap-3{gap:var(--space-3)}.gap-4{gap:var(--space-4)}.gap-6{gap:var(--space-6)}.gap-8{gap:var(--space-8)}.grid-2{gap:var(--space-4);grid-template-columns:repeat(2,1fr);align-items:start;display:grid}.grid-3{gap:var(--space-4);grid-template-columns:repeat(3,1fr);align-items:start;display:grid}.grid-4{gap:var(--space-4);grid-template-columns:repeat(4,1fr);align-items:start;display:grid}.text-xs{font-size:var(--text-xs)}.text-sm{font-size:var(--text-sm)}.text-secondary{color:var(--color-text-secondary)}.text-accent{color:var(--color-accent-lime)}.text-error{color:var(--color-error)}.text-success{color:var(--color-success)}.font-semibold{font-weight:var(--weight-semibold)}.font-mono{font-family:var(--font-mono)}.truncate{text-overflow:ellipsis;white-space:nowrap;overflow:hidden}.w-full{width:100%}.mt-1{margin-top:var(--space-1)}.mt-2{margin-top:var(--space-2)}.mt-4{margin-top:var(--space-4)}.mt-6{margin-top:var(--space-6)}.mb-2{margin-bottom:var(--space-2)}.mb-4{margin-bottom:var(--space-4)}.mb-6{margin-bottom:var(--space-6)}.p-4{padding:var(--space-4)}.p-6{padding:var(--space-6)}.hidden{display:none!important}.sr-only{clip:rect(0,0,0,0);width:1px;height:1px;position:absolute;overflow:hidden}.material-symbols-outlined{letter-spacing:normal;text-transform:none;white-space:nowrap;word-wrap:normal;-webkit-font-smoothing:antialiased;font-variation-settings:"FILL" 0, "wght" 400, "GRAD" 0, "opsz" 20;direction:ltr;font-family:Material Symbols Outlined;font-size:20px;font-style:normal;font-weight:400;line-height:1;display:inline-block}@media (width<=1024px){.grid-4,.grid-3{grid-template-columns:repeat(2,1fr)}}@media (width<=640px){.grid-4,.grid-3,.grid-2{grid-template-columns:1fr}.btn-lg{height:42px}}.toggle-switch{flex-shrink:0;width:44px;height:24px;display:inline-block;position:relative}.toggle-switch input{opacity:0;width:0;height:0;position:absolute}.toggle-track{cursor:pointer;background:var(--color-border-medium,#374151);border-radius:24px;transition:background .25s;position:absolute;inset:0}.toggle-track:before{content:"";background:#fff;border-radius:50%;width:18px;height:18px;transition:transform .25s,background .25s;position:absolute;bottom:3px;left:3px}.toggle-switch input:checked+.toggle-track{background:var(--color-accent-lime,#c8ff00)}.toggle-switch input:checked+.toggle-track:before{background:#0a0e1a;transform:translate(20px)}.toggle-switch input:focus-visible+.toggle-track{outline:2px solid var(--color-accent-lime,#c8ff00);outline-offset:2px}.radio-dot{border:2px solid var(--color-border-medium,#374151);border-radius:50%;flex-shrink:0;width:18px;height:18px;transition:border-color .2s,background .2s,box-shadow .2s}.radio-dot.checked{border-color:var(--color-accent-lime,#c8ff00);background:var(--color-accent-lime,#c8ff00);box-shadow:inset 0 0 0 3px var(--color-bg-card,#141929)}.module-pulse{pointer-events:none;animation:2.4s ease-in-out infinite module-pulse-anim;position:absolute;inset:0}@keyframes module-pulse-anim{0%,to{opacity:.04}50%{opacity:.18}}.studio-layout{grid-template-columns:var(--sidebar-width) 1fr;grid-template-rows:var(--topbar-height) 1fr;min-height:100vh;display:grid}.studio-topbar{padding:0 var(--space-6);background:var(--color-bg-card);border-bottom:1px solid var(--color-border-soft);z-index:var(--z-sticky);grid-column:1/-1;justify-content:space-between;align-items:center;display:flex;position:sticky;top:0}.topbar-left{align-items:center;gap:var(--space-4);display:flex}.topbar-title{font-size:var(--text-base);font-weight:var(--weight-semibold)}.studio-sidebar{background:var(--color-bg-card);border-right:1px solid var(--color-border-soft);flex-direction:column;display:flex;overflow-y:auto}.sidebar-section{padding:var(--space-4) var(--space-3) var(--space-2)}.sidebar-section-label{font-size:10px;font-weight:var(--weight-semibold);letter-spacing:.1em;text-transform:uppercase;color:var(--color-text-muted);padding:0 var(--space-3);margin-bottom:var(--space-1)}.sidebar-nav{list-style:none}.sidebar-nav li a{align-items:center;gap:var(--space-3);padding:var(--space-2) var(--space-3);border-radius:var(--radius-sm);font-size:var(--text-sm);color:var(--color-text-secondary);transition:all var(--transition-fast);text-decoration:none;display:flex}.sidebar-nav li a .material-symbols-outlined{font-size:18px}.sidebar-nav li a .nav-badge{background:var(--color-vector-bg);color:var(--color-vector-blue);border-radius:var(--radius-pill);margin-left:auto;padding:1px 6px;font-size:10px}.studio-main{padding:var(--space-6);overflow-y:auto}#view-container{gap:var(--space-6);flex-direction:column;display:flex}.page-header{justify-content:space-between;align-items:flex-start;gap:var(--space-4);display:flex}.page-header-actions{gap:var(--space-2);flex-shrink:0;display:flex}.page-title{font-size:var(--text-xl);font-weight:var(--weight-bold)}.page-subtitle{font-size:var(--text-sm);color:var(--color-text-secondary);margin-top:var(--space-1)}.stats-row{gap:var(--space-4);grid-template-columns:repeat(4,1fr);display:grid}.stat-card{background:var(--color-bg-card);border:1px solid var(--color-border-soft);border-radius:var(--radius-card);padding:var(--space-5)}.stat-card .stat-label{font-size:var(--text-xs);color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.06em}.stat-card .stat-value{font-size:var(--text-2xl);font-weight:var(--weight-bold);margin-top:var(--space-1)}.stat-card .stat-delta{font-size:var(--text-xs);color:var(--color-text-muted);margin-top:var(--space-1)}.app-grid{gap:var(--space-4);grid-template-columns:repeat(auto-fill,minmax(300px,1fr));display:grid}.app-card{background:var(--color-bg-card);border:1px solid var(--color-border-soft);border-radius:var(--radius-card);padding:var(--space-5);transition:all var(--transition-base);cursor:pointer}.app-card:hover{border-color:var(--color-border-medium);box-shadow:var(--shadow-card);transform:translateY(-2px)}.app-icon{border-radius:var(--radius-md);background:var(--color-accent-lime-bg);width:42px;height:42px;color:var(--color-accent-lime);justify-content:center;align-items:center;display:flex}.app-card-name{font-weight:var(--weight-semibold)}.app-card-route{font-size:var(--text-xs);color:var(--color-text-muted);font-family:var(--font-mono)}.app-card-footer{margin-top:var(--space-4);padding-top:var(--space-4);border-top:1px solid var(--color-border-soft);justify-content:space-between;align-items:center;display:flex}.secret-value{font-family:var(--font-mono);font-size:var(--text-sm);color:var(--color-text-muted)}.secret-scope-chip{background:var(--color-bg-elevated);border-radius:var(--radius-pill);color:var(--color-text-muted);padding:2px 8px;font-size:10px}.connector-card{background:var(--color-bg-card);border:1px solid var(--color-border-soft);border-radius:var(--radius-card);padding:var(--space-5);transition:all var(--transition-base)}.connector-card:hover{border-color:var(--color-border-medium)}.connector-icon{border-radius:var(--radius-md);justify-content:center;align-items:center;width:40px;height:40px;display:flex}.connector-icon.rest{background:var(--color-accent-lime-bg);color:var(--color-accent-lime)}.connector-icon.db{background:var(--color-vector-bg);color:var(--color-vector-blue)}.connector-icon.mcp{background:var(--color-calc-bg);color:var(--color-calc-purple)}.connector-icon.uknow{background:var(--color-success-bg);color:var(--color-success)}.log-viewer{border:1px solid var(--color-border-soft);border-radius:var(--radius-md);padding:var(--space-4);font-family:var(--font-mono);font-size:var(--text-xs);color:#7dd3a8;white-space:pre-wrap;background:#060b12;max-height:360px;line-height:1.6;overflow-y:auto}.log-viewer .log-ts{color:var(--color-text-muted)}.log-viewer .log-error{color:var(--color-error)}.log-viewer .log-warn{color:var(--color-warning)}.log-viewer .log-info{color:var(--color-vector-blue)}.preview-panel{background:var(--color-bg-card);border-radius:var(--radius-card);border:1px solid var(--color-border-soft);flex-direction:column;display:flex;overflow:hidden}.preview-toolbar{align-items:center;gap:var(--space-3);padding:var(--space-3) var(--space-4);border-bottom:1px solid var(--color-border-soft);display:flex}.preview-url{font-family:var(--font-mono);font-size:var(--text-xs);color:var(--color-text-muted);background:var(--color-bg-input);border:1px solid var(--color-border-soft);border-radius:var(--radius-sm);padding:var(--space-1) var(--space-3);flex:1}.preview-frame{background:#fff;border:none;flex:1;width:100%}.deploy-steps{gap:var(--space-3);flex-direction:column;display:flex}.deploy-step{align-items:center;gap:var(--space-3);padding:var(--space-3);border-radius:var(--radius-sm);display:flex}.deploy-step.pending{color:var(--color-text-muted)}.deploy-step.active{color:var(--color-accent-lime);background:var(--color-accent-lime-bg)}.deploy-step.done{color:var(--color-success)}.deploy-step.failed{color:var(--color-error);background:var(--color-error-bg)}.deploy-step-icon{border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:24px;height:24px;font-size:14px;display:flex}.deploy-step.done .deploy-step-icon{background:var(--color-success-bg);color:var(--color-success)}.deploy-step.active .deploy-step-icon{background:var(--color-accent-lime-bg);color:var(--color-accent-lime)}.deploy-step.failed .deploy-step-icon{background:var(--color-error-bg);color:var(--color-error)}.db-table-list{gap:var(--space-1);flex-direction:column;display:flex}.db-table-item{align-items:center;gap:var(--space-2);padding:var(--space-2) var(--space-3);border-radius:var(--radius-sm);cursor:pointer;transition:background var(--transition-fast);display:flex}.code-file-tree{background:var(--color-bg-elevated)}.file-tree-item{align-items:center;gap:var(--space-2);padding:var(--space-2) var(--space-3);cursor:pointer;transition:background var(--transition-fast);border-bottom:1px solid #0000;display:flex}.file-tree-item:hover{background:var(--color-bg-hover)}.file-tree-item.active{background:var(--color-bg-active);border-left:2px solid var(--color-accent-lime);color:var(--color-accent-lime)}.file-tree-item .text-xs{white-space:nowrap;text-overflow:ellipsis;max-width:140px;overflow:hidden}.code-tab{cursor:pointer;color:var(--color-text-muted);transition:color var(--transition-fast), border-color var(--transition-fast);background:0 0;border:none;border-bottom:2px solid #0000;align-items:center;gap:4px;padding:5px 12px;font-size:11px;font-weight:500;display:flex}.code-tab:hover{color:var(--color-text-primary)}.code-tab.active{color:var(--color-accent-lime);border-bottom-color:var(--color-accent-lime)}.session-tab{border-radius:var(--radius-sm);cursor:pointer;white-space:nowrap;max-width:160px;color:var(--color-text-muted);transition:color var(--transition-fast), border-color var(--transition-fast), background var(--transition-fast);background:0 0;border:none;border-bottom:2px solid #0000;align-items:center;gap:4px;padding:3px 10px;font-size:11px;font-weight:500;display:flex;position:relative}.session-tab:hover{color:var(--color-text-primary);background:var(--color-bg-main)}.session-tab.active{color:var(--color-text-primary);border-bottom-color:var(--color-accent-lime);background:var(--color-bg-main);font-weight:600}.session-tab .session-actions{flex-shrink:0;align-items:center;gap:1px;margin-left:2px;display:none}.session-tab:hover .session-actions,.session-tab.active .session-actions{display:flex}.session-action-btn{cursor:pointer;width:16px;height:16px;color:var(--color-text-muted);transition:color var(--transition-fast), background var(--transition-fast);background:0 0;border:none;border-radius:3px;justify-content:center;align-items:center;padding:0;font-size:13px;display:flex}.session-action-btn:hover{color:var(--color-text-primary);background:var(--color-bg-elevated)}.session-action-btn.danger:hover{color:var(--color-danger)}.session-tab-name{text-overflow:ellipsis;white-space:nowrap;max-width:120px;overflow:hidden}.btn-active-session{border-bottom:2px solid var(--color-accent-lime)!important;font-weight:600!important}.hljs{background:0 0!important;padding:0!important}#code-panel pre{background:var(--color-bg-main)}.app-shell{grid-template-columns:var(--sidebar-width,240px) 1fr;grid-template-rows:var(--topbar-height,56px) 1fr;height:100vh;display:grid;overflow:hidden}.sidebar{background:var(--color-bg-card);border-right:1px solid var(--color-border-soft);flex-direction:column;grid-row:1/-1;display:flex;overflow-y:auto}.sidebar-logo{padding:var(--space-5) var(--space-4);border-bottom:1px solid var(--color-border-soft)}.sidebar-logo-text{font-size:var(--text-base);color:var(--color-accent-lime);letter-spacing:.05em;font-weight:700}.sidebar-logo-sub{color:var(--color-text-muted);letter-spacing:.08em;text-transform:uppercase;font-size:10px}.sidebar-nav-wrap{padding:var(--space-2) 0;flex:1;overflow-y:auto}.sidebar-section-label{letter-spacing:.1em;text-transform:uppercase;color:var(--color-text-muted);padding:var(--space-3) var(--space-4) var(--space-1);font-size:10px;font-weight:600}.sidebar-nav{margin:0;padding:0;list-style:none}.sidebar-nav li a{align-items:center;gap:var(--space-3);padding:var(--space-2) var(--space-4);font-size:var(--text-sm);color:var(--color-text-secondary);transition:all var(--transition-fast);border-radius:0;text-decoration:none;display:flex}.sidebar-nav li a:hover{background:var(--color-bg-hover);color:var(--color-text-primary)}.sidebar-nav li a.active{background:var(--color-bg-active);color:var(--color-accent-lime)}.sidebar-nav li a .material-symbols-outlined{flex-shrink:0;font-size:18px}.sidebar-footer{padding:var(--space-4);border-top:1px solid var(--color-border-soft)}.sidebar-user{align-items:center;gap:var(--space-2);margin-bottom:var(--space-3);display:flex}.sidebar-user-name{font-size:var(--text-sm);color:var(--color-text-secondary);text-overflow:ellipsis;white-space:nowrap;overflow:hidden}.sidebar-lang{gap:var(--space-1);margin-bottom:var(--space-2);display:flex}.lang-btn{border-radius:var(--radius-sm);border:1px solid var(--color-border-soft);color:var(--color-text-muted);cursor:pointer;transition:all var(--transition-fast);background:0 0;padding:2px 10px;font-size:11px;font-weight:600}.lang-btn.active,.lang-btn:hover{background:var(--color-accent-lime);color:#000;border-color:var(--color-accent-lime)}.sidebar-logout{align-items:center;gap:var(--space-2);width:100%;padding:var(--space-2) var(--space-3);border-radius:var(--radius-sm);border:1px solid var(--color-border-soft);color:var(--color-text-secondary);font-size:var(--text-sm);cursor:pointer;transition:all var(--transition-fast);background:0 0;display:flex}.sidebar-logout:hover{border-color:var(--color-danger);color:var(--color-danger)}.topbar{padding:0 var(--space-5);background:var(--color-bg-card);border-bottom:1px solid var(--color-border-soft);z-index:10;justify-content:space-between;align-items:center;display:flex;position:sticky;top:0}.topbar-right{align-items:center;gap:var(--space-3);display:flex}.topbar-version{color:var(--color-text-muted);font-size:11px}.topbar-loading{font-size:var(--text-sm);color:var(--color-text-muted)}.topbar-instance-selector{align-items:center;gap:var(--space-2);display:flex}.topbar-instance-icon{color:var(--color-text-muted);font-size:16px}.topbar-instance-select{background:var(--color-bg-elevated);border:1px solid var(--color-border-soft);color:var(--color-text-primary);font-size:var(--text-sm);padding:4px var(--space-3);border-radius:var(--radius-sm);cursor:pointer}.status-dot{background:var(--color-text-muted);border-radius:50%;flex-shrink:0;width:8px;height:8px}.status-dot--running,.status-dot--active{background:var(--color-success,#22c55e)}.status-dot--stopped,.status-dot--error{background:var(--color-danger,#ef4444)}.status-dot--pending,.status-dot--provisioning{background:var(--color-warning,#f59e0b);animation:1.5s infinite pulse}.main-content{height:calc(100vh - var(--topbar-height,56px));overflow-y:auto}.view-container{padding:var(--space-6);box-sizing:border-box;gap:var(--space-5);flex-direction:column;max-width:100%;height:100%;display:flex;overflow-y:auto}.view-container>*{flex-shrink:0}.view-header{justify-content:space-between;align-items:flex-start;gap:var(--space-4);display:flex}.view-title{font-size:var(--text-xl);color:var(--color-text-primary);margin:0 0 var(--space-1);font-weight:700}.view-subtitle{font-size:var(--text-sm);color:var(--color-text-muted);margin:0}.loading-state{padding:var(--space-16,64px);justify-content:center;align-items:center;display:flex}.empty-state{padding:var(--space-10) var(--space-6);text-align:center;color:var(--color-text-muted);justify-content:center;align-items:center;gap:var(--space-3);flex-direction:column;display:flex}.empty-state>h3{font-size:var(--text-lg);color:var(--color-text-primary);margin:0;font-weight:600}.empty-state>p{font-size:var(--text-sm);max-width:380px;margin:0}.empty-state>.btn{margin-top:var(--space-2)}.empty-icon{opacity:.35;font-size:40px}.kpi-row{gap:var(--space-4);grid-template-columns:repeat(auto-fit,minmax(160px,1fr));display:grid}.kpi-card{background:var(--color-bg-card);border:1px solid var(--color-border-soft);border-radius:var(--radius-md);padding:var(--space-4)}.kpi-value{font-size:var(--text-2xl,24px);color:var(--color-text-primary);font-weight:700}.kpi-label{font-size:var(--text-sm);color:var(--color-text-muted);margin-top:var(--space-1)}.kpi-sub{color:var(--color-text-muted);margin-top:2px;font-size:11px}.card{background:var(--color-bg-card);border:1px solid var(--color-border-soft);border-radius:var(--radius-md);overflow:hidden}.card-header{padding:var(--space-4) var(--space-5);border-bottom:1px solid var(--color-border-soft);justify-content:space-between;align-items:center;display:flex}.card-title{font-size:var(--text-base);margin:0;font-weight:600}.card-body{padding:var(--space-5)}.badge{border-radius:var(--radius-pill,999px);letter-spacing:.02em;align-items:center;padding:2px 8px;font-size:11px;font-weight:600;display:inline-flex}.badge--success{color:#4ade80;background:#22c55e26}.badge--error{color:#f87171;background:#ef444426}.badge--neutral{background:var(--color-bg-elevated);color:var(--color-text-muted)}.badge--accent{color:var(--color-accent-lime);background:#c8ff0026}.badge--warning{color:#fbbf24;background:#f59e0b26}.status-badge{border-radius:var(--radius-pill);align-items:center;padding:2px 8px;font-size:11px;font-weight:600;display:inline-flex}.status-badge--success{color:#4ade80;background:#22c55e26}.status-badge--neutral{background:var(--color-bg-elevated);color:var(--color-text-muted)}.data-table{border-collapse:collapse;width:100%;font-size:var(--text-sm)}.data-table th{text-align:left;padding:var(--space-2) var(--space-3);text-transform:uppercase;letter-spacing:.06em;color:var(--color-text-muted);border-bottom:1px solid var(--color-border-soft);font-size:11px;font-weight:600}.data-table td{padding:var(--space-3);border-bottom:1px solid var(--color-border-soft);color:var(--color-text-secondary);vertical-align:middle}.data-table tr:last-child td{border-bottom:none}.data-table tr:hover td{background:var(--color-bg-hover)}.null-cell{color:var(--color-text-muted);font-style:italic}.mono-cell{font-family:var(--font-mono,monospace);font-size:12px}.table-actions{gap:var(--space-2);display:flex}.form-label{font-size:var(--text-sm);color:var(--color-text-secondary);margin-bottom:var(--space-2);font-weight:600;display:block}.form-label-xs{color:var(--color-text-muted);margin-bottom:var(--space-1);text-transform:uppercase;letter-spacing:.06em;font-size:11px;font-weight:600;display:block}.form-label-hint{color:var(--color-text-muted);margin-left:var(--space-2);font-weight:400}.form-input{width:100%;padding:var(--space-2) var(--space-3);background:var(--color-bg-elevated);border:1px solid var(--color-border-soft);border-radius:var(--radius-sm);color:var(--color-text-primary);font-size:var(--text-sm);transition:border-color var(--transition-fast)}.form-input:focus{border-color:var(--color-accent-lime);outline:none}.form-input--error{border-color:var(--color-danger,#ef4444)}.form-select{width:100%;padding:var(--space-2) var(--space-3);background:var(--color-bg-elevated);border:1px solid var(--color-border-soft);border-radius:var(--radius-sm);color:var(--color-text-primary);font-size:var(--text-sm);cursor:pointer}.form-select--sm{padding:4px var(--space-3);width:auto;font-size:12px}.form-error{color:var(--color-danger,#ef4444);margin-top:var(--space-1);font-size:12px}.form-actions{justify-content:flex-end;gap:var(--space-3);margin-top:var(--space-5);display:flex}.form-grid-2{gap:var(--space-4);grid-template-columns:1fr 1fr;display:grid}.form-grid-3{gap:var(--space-4);grid-template-columns:1fr 1fr 1fr;display:grid}.color-input-row{align-items:center;gap:var(--space-2);display:flex}.font-mono{font-family:var(--font-mono,monospace);font-size:13px}.modal-overlay{z-index:1000;padding:var(--space-4);background:#0009;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.modal{background:var(--color-bg-card);border:1px solid var(--color-border-soft);border-radius:var(--radius-lg);flex-direction:column;width:480px;max-width:100%;max-height:90vh;display:flex;overflow:hidden}.modal--md{width:600px}.modal--wide{width:860px}.modal-2col{flex:1;grid-template-columns:1fr 1fr;gap:0;min-height:0;display:grid;overflow:hidden}.modal-2col-left{padding:var(--space-5);gap:var(--space-4);border-right:1px solid var(--color-border-soft);flex-direction:column;display:flex;overflow-y:auto}.modal-2col-right{padding:var(--space-5);gap:var(--space-3);background:var(--color-bg-elevated);flex-direction:column;display:flex;overflow-y:auto}.modal-footer{padding:var(--space-4) var(--space-5);border-top:1px solid var(--color-border-soft);justify-content:flex-end;gap:var(--space-3);flex-shrink:0;display:flex}.color-mode-toggle{border:1px solid var(--color-border);border-radius:var(--radius-md);display:flex;overflow:hidden}.color-mode-option{justify-content:center;align-items:center;gap:var(--space-2);padding:var(--space-2) var(--space-3);cursor:pointer;font-size:var(--text-sm);transition:background var(--transition-fast), color var(--transition-fast);color:var(--color-text-muted);flex:1;display:flex}.color-mode-option:first-child{border-right:1px solid var(--color-border)}.color-mode-option--active{background:var(--color-bg-card);color:var(--color-text-primary);font-weight:600}.modal-header{padding:var(--space-4) var(--space-5);border-bottom:1px solid var(--color-border-soft);justify-content:space-between;align-items:center;display:flex}.modal-close{border-radius:var(--radius-sm);cursor:pointer;width:28px;height:28px;color:var(--color-text-muted);transition:all var(--transition-fast);background:0 0;border:none;justify-content:center;align-items:center;font-size:18px;display:flex}.modal-close:hover{background:var(--color-bg-hover);color:var(--color-text-primary)}.modal-body{padding:var(--space-5);gap:var(--space-4);flex-direction:column;display:flex;overflow-y:auto}.apps-grid{gap:var(--space-4);grid-template-columns:repeat(auto-fill,minmax(220px,1fr));display:grid}.app-card{background:var(--color-bg-card);border:1px solid var(--color-border-soft);border-radius:var(--radius-md);padding:var(--space-4);cursor:pointer;transition:border-color var(--transition-fast)}.app-card:hover{border-color:var(--color-accent-lime)}.app-card-header{align-items:center;gap:var(--space-3);margin-bottom:var(--space-3);display:flex}.app-card-icon{color:var(--color-accent-lime);font-size:24px}.app-card-name{font-size:var(--text-base);font-weight:600}.app-card-slug{color:var(--color-text-muted);font-size:11px;font-family:var(--font-mono)}.app-list-item{align-items:center;gap:var(--space-4);padding:var(--space-3) var(--space-4);background:var(--color-bg-card);border:1px solid var(--color-border-soft);border-radius:var(--radius-md);transition:border-color var(--transition-fast);display:flex}.app-list-item:hover{border-color:var(--color-accent-lime)}.app-list-icon{color:var(--color-accent-lime);font-size:20px}.app-list-info{flex:1;min-width:0}.app-list-name{font-size:var(--text-sm);font-weight:600}.app-list-meta{color:var(--color-text-muted);font-size:12px}.app-list-date{color:var(--color-text-muted);white-space:nowrap;font-size:12px}.app-list-actions{gap:var(--space-2);display:flex}.builder-shell{flex-direction:column;height:100%;display:flex;overflow:hidden}.builder-topbar{background:var(--color-bg-elevated);border-bottom:1px solid var(--color-border-soft);flex-direction:column;flex-shrink:0;display:flex}.builder-topbar-title{padding:var(--space-4) var(--space-5) var(--space-2)}.builder-topbar-title .view-title{font-size:var(--text-xl);color:var(--color-text-primary);margin:0 0 2px;font-weight:700}.builder-topbar-title .view-subtitle{font-size:var(--text-sm);color:var(--color-text-muted);margin:0}.builder-topbar-controls{align-items:center;gap:var(--space-6);padding:var(--space-2) var(--space-5) var(--space-3);border-top:1px solid var(--color-border-soft);flex-wrap:wrap;display:flex}.builder-topbar-group{align-items:center;gap:var(--space-2);display:flex}.builder-topbar-label{color:var(--color-text-muted);white-space:nowrap;font-size:11px}.builder-topbar-select{background:var(--color-bg-card);border:1px solid var(--color-border-medium);color:var(--color-text-primary);border-radius:var(--radius-sm);padding:0 var(--space-2);height:28px;font-size:var(--text-sm);cursor:pointer;min-width:100px}.builder-topbar-select:focus{border-color:var(--color-accent-lime);outline:none}.builder-topbar-provider-badge{background:var(--color-bg-card);border:1px solid var(--color-border-soft);border-radius:var(--radius-sm);padding:3px var(--space-3);font-size:var(--text-sm);color:var(--color-text-primary);cursor:pointer;align-items:center;gap:5px;display:flex}.builder-topbar-model{color:var(--color-text-muted);font-size:12px;font-family:var(--font-mono)}.builder-body{flex:1;grid-template-columns:340px 6px 160px 1fr;min-height:0;display:grid;overflow:hidden}.builder-body--no-tree{grid-template-columns:340px 6px 1fr}.builder-right{flex-direction:column;min-width:0;min-height:0;display:flex;overflow:hidden}.builder-resizer{cursor:col-resize;background:var(--color-border-soft);transition:background var(--transition-fast)}.builder-resizer:hover,.builder-resizer:active{background:var(--color-accent-lime)}.file-tree-panel{border-left:1px solid var(--color-border-soft);border-right:1px solid var(--color-border-soft);padding:var(--space-2) 0;background:var(--color-bg-card);min-height:0;overflow-y:auto}.chat-panel{background:var(--color-bg-card);border-right:1px solid var(--color-border-soft);flex-direction:column;min-height:0;display:flex;overflow:hidden}.chat-sessions-bar{background:var(--color-bg-elevated);border-bottom:1px solid var(--color-border-soft);scrollbar-width:none;flex-shrink:0;align-items:center;min-height:36px;padding:0 4px;display:flex;overflow-x:auto}.chat-sessions-bar::-webkit-scrollbar{display:none}.session-tab-add{height:28px;color:var(--color-text-muted);cursor:pointer;border-radius:var(--radius-sm);transition:color var(--transition-fast), background var(--transition-fast);background:0 0;border:none;flex-shrink:0;align-items:center;margin-left:auto;padding:0 6px;display:flex}.session-tab-add:hover{color:var(--color-text-primary);background:var(--color-bg-hover)}.chat-session-header{align-items:center;gap:var(--space-2);padding:var(--space-2) var(--space-3);background:var(--color-bg-elevated);border-bottom:1px solid var(--color-border-soft);flex-shrink:0;display:flex}.chat-session-time{color:var(--color-text-muted);white-space:nowrap;font-size:11px}.chat-session-title{color:var(--color-text-secondary);text-overflow:ellipsis;white-space:nowrap;flex:1;font-size:11px;overflow:hidden}.ai-card{padding:var(--space-3) var(--space-4)!important}.ai-card-status{align-items:center;gap:var(--space-2);margin-bottom:var(--space-2);display:flex}.ai-card-check{color:var(--color-accent-lime);font-size:16px}.ai-card-title{font-size:var(--text-sm);color:var(--color-text-primary);font-weight:600}.ai-card-log{font-size:11px;font-family:var(--font-mono);white-space:pre-wrap;word-break:break-all;color:var(--color-text-secondary);background:var(--color-bg-main);max-height:200px;padding:var(--space-2) var(--space-3);border-radius:var(--radius-sm);line-height:1.6;overflow-y:auto;margin:var(--space-2) 0!important}.ai-card-files{margin:var(--space-2) 0}.ai-card-files-label{color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.05em;margin-bottom:4px;font-size:11px;font-weight:600}.ai-card-file-item{font-size:12px;font-family:var(--font-mono);color:var(--color-text-secondary);cursor:pointer;transition:color var(--transition-fast);align-items:center;gap:5px;padding:2px 0;display:flex}.ai-card-file-item:hover,.ai-card-file-item.active{color:var(--color-accent-lime)}.ai-card-actions{gap:var(--space-2);margin-top:var(--space-3);padding-top:var(--space-2);border-top:1px solid var(--color-border-soft);display:flex}.chat-build-actions{gap:var(--space-2);padding:var(--space-2) var(--space-4) var(--space-3);display:flex}.bubble--commit{background:#c8ff000f!important;border:1px solid #c8ff0033!important}.commit-result-title{font-size:var(--text-sm);color:var(--color-accent-lime);margin-bottom:var(--space-2);font-weight:600}.commit-result-row{color:var(--color-text-secondary);margin-bottom:2px;font-size:12px}.commit-result-row code{font-family:var(--font-mono);color:var(--color-accent-lime)}.commit-result-link{color:var(--color-vector-blue,#60a5fa);margin-top:var(--space-2);font-size:12px;text-decoration:none;display:inline-block}.commit-result-link:hover{text-decoration:underline}.chat-messages{padding:var(--space-4);gap:var(--space-4);flex-direction:column;flex:1;display:flex;overflow-y:auto}.chat-msg{gap:var(--space-3);display:flex}.chat-msg.assistant .bubble{background:var(--color-bg-elevated);border-radius:0 var(--radius-md) var(--radius-md) var(--radius-md);border:1px solid var(--color-border-soft)}.chat-msg.user{justify-content:flex-end}.chat-msg.user .bubble{background:var(--color-accent-lime-bg);border:1px solid var(--color-border-accent);border-radius:var(--radius-md) 0 var(--radius-md) var(--radius-md)}.bubble{padding:var(--space-3) var(--space-4);font-size:var(--text-sm);line-height:var(--leading-relaxed);overflow-wrap:break-word;min-width:0;max-width:90%;position:relative}.chat-copy-btn{border-radius:var(--radius-sm);background:var(--color-bg-card);width:22px;height:22px;color:var(--color-text-muted);cursor:pointer;opacity:0;transition:opacity var(--transition-fast), color var(--transition-fast), background var(--transition-fast);border:none;justify-content:center;align-items:center;padding:0;display:inline-flex;position:absolute;top:4px;right:4px}.chat-msg:hover .chat-copy-btn{opacity:.75}.chat-copy-btn:hover{color:var(--color-text-primary);background:var(--color-bg-hover);opacity:1!important}.chat-copy-btn.copied{color:var(--color-accent-lime);opacity:1!important}.bubble--error{color:#f87171;background:#f8717114!important;border-color:#f871714d!important}.bubble--thinking{align-items:center;gap:var(--space-2);color:var(--color-text-muted);display:flex}.bubble--log{background:var(--color-bg-main)!important;border:1px solid var(--color-border-soft)!important}.bubble-log{font-size:11px;font-family:var(--font-mono);white-space:pre-wrap;word-break:break-all;color:var(--color-text-secondary);margin:0;line-height:1.6}.chat-input-area{padding:var(--space-3) var(--space-4);border-top:1px solid var(--color-border-soft);gap:var(--space-2);flex-shrink:0;align-items:flex-end;display:flex}.chat-input-wrap{border:1px solid var(--color-border-medium);border-radius:var(--radius-md);background:var(--color-bg-input);transition:border-color var(--transition-fast);flex-direction:column;flex:1;display:flex;overflow:hidden}.chat-input-wrap:focus-within{border-color:var(--color-accent-lime)}.chat-input{padding:var(--space-3) var(--space-4);color:var(--color-text-primary);font-size:var(--text-sm);resize:none;font-family:var(--font-sans);background:0 0;border:none;outline:none;flex:1}.chat-input:focus{border-color:unset}.chat-toolbar{padding:var(--space-2) var(--space-2);border-top:1px solid var(--color-border-soft);justify-content:space-between;align-items:center;gap:var(--space-1);display:flex}.chat-toolbar-left,.chat-toolbar-right{align-items:center;gap:var(--space-1);display:flex}.chat-send-col{gap:var(--space-1);flex-direction:column;display:flex}.chat-url-chip{border-radius:var(--radius-full,999px);background:color-mix(in srgb, var(--color-accent-lime) 12%, transparent);color:var(--color-accent-lime);border:1px solid color-mix(in srgb, var(--color-accent-lime) 30%, transparent);pointer-events:none;-webkit-user-select:none;user-select:none;align-items:center;gap:3px;padding:2px 8px;font-size:11px;font-weight:500;display:inline-flex}.btn--active{background:color-mix(in srgb, var(--color-accent-lime) 15%, transparent)!important;color:var(--color-accent-lime)!important;border-color:color-mix(in srgb, var(--color-accent-lime) 40%, transparent)!important}.builder-tab-header{padding:0 var(--space-3);border-bottom:1px solid var(--color-border-soft);justify-content:space-between;align-items:center;gap:var(--space-3);flex-shrink:0;height:40px;display:flex}.builder-tab-path-area{flex:1;min-width:0;overflow:hidden}.builder-run-indicator{align-items:center;gap:var(--space-2);display:flex}.builder-run-url-text{font-size:12px;font-family:var(--font-mono);color:var(--color-text-secondary);text-overflow:ellipsis;white-space:nowrap;overflow:hidden}.run-status-dot{background:var(--color-success,#4ade80);border-radius:50%;flex-shrink:0;width:8px;height:8px}.builder-tabs{flex-shrink:0;gap:2px;display:flex}.builder-tab{padding:var(--space-1) var(--space-2);border-radius:var(--radius-sm);color:var(--color-text-muted);font-size:var(--text-sm);cursor:pointer;transition:all var(--transition-fast);align-items:center;gap:var(--space-1);background:0 0;border:none;min-width:32px;display:flex}.builder-tab:hover{color:var(--color-text-primary);background:var(--color-bg-hover)}.builder-tab.active{color:var(--color-accent-lime);background:var(--color-bg-active)}.builder-tab-badge{background:var(--color-bg-elevated);border-radius:var(--radius-pill);padding:1px 5px;font-size:10px}.builder-tab-content{flex:1;min-height:0;overflow:hidden}.file-tree{border-right:1px solid var(--color-border-soft);padding:var(--space-2) 0;min-width:0;overflow-y:auto}.file-tree-item{align-items:center;gap:var(--space-2);padding:var(--space-2) var(--space-3);cursor:pointer;font-size:12px;font-family:var(--font-mono);color:var(--color-text-secondary);transition:all var(--transition-fast);text-align:left;background:0 0;border:none;width:100%;display:flex}.file-tree-item:hover{background:var(--color-bg-hover);color:var(--color-text-primary)}.file-tree-item.active{background:var(--color-bg-active);color:var(--color-accent-lime)}.file-tree-empty{padding:var(--space-4);color:var(--color-text-muted);text-align:center;font-size:12px}.file-tree-folder{align-items:center;gap:var(--space-2);padding:var(--space-2) var(--space-3);cursor:pointer;font-size:12px;font-family:var(--font-mono);color:var(--color-text-primary);transition:all var(--transition-fast);text-align:left;width:100%;font-weight:var(--weight-medium);background:0 0;border:none;display:flex}.file-tree-folder:hover{background:var(--color-bg-hover)}.file-tree-chevron{color:var(--color-text-muted);flex-shrink:0;font-size:16px}.file-name{text-overflow:ellipsis;white-space:nowrap;overflow:hidden}.code-view{flex-direction:column;min-width:0;height:100%;display:flex;overflow:hidden}.code-view-header{padding:var(--space-2) var(--space-4);border-bottom:1px solid var(--color-border-soft);align-items:center;display:flex}.code-view-path{font-size:12px;font-family:var(--font-mono);color:var(--color-text-muted)}.code-view-content{padding:var(--space-4);font-size:12px;font-family:var(--font-mono);white-space:pre;flex:1;margin:0;line-height:1.6;overflow:auto}.code-view-empty{width:100%;height:100%;color:var(--color-text-muted);text-align:center;padding:var(--space-6);justify-content:center;align-items:center;font-size:13px;display:flex}.run-panel{flex-direction:column;height:100%;display:flex;overflow:hidden}.run-url-bar{align-items:center;gap:var(--space-3);padding:var(--space-2) var(--space-3);background:var(--color-bg-elevated);border-bottom:1px solid var(--color-border-soft);flex-shrink:0;display:flex}.runtime-error-banner{align-items:flex-start;gap:var(--space-3);padding:var(--space-3) var(--space-4);border-bottom:1px solid color-mix(in srgb, var(--color-error) 30%, transparent);background:color-mix(in srgb, var(--color-error) 8%, var(--color-bg-elevated));flex-shrink:0;animation:.2s slideDown;display:flex}.runtime-error-icon{color:var(--color-error);flex-shrink:0;margin-top:1px;font-size:20px}.runtime-error-body{flex-direction:column;flex:1;gap:4px;min-width:0;display:flex}.runtime-error-body strong{font-size:var(--text-sm);color:var(--color-error)}.runtime-error-preview{font-size:11px;font-family:var(--font-mono);color:var(--color-text-muted);white-space:pre;text-overflow:ellipsis;line-clamp:3;max-height:3.6em;display:block;overflow:hidden}@keyframes slideDown{0%{opacity:0;transform:translateY(-6px)}to{opacity:1;transform:translateY(0)}}.run-url-text{font-size:12px;font-family:var(--font-mono);color:var(--color-text-secondary)}.run-frame{border:none;flex:1;width:100%;min-height:0}.run-console{border-top:1px solid var(--color-border-soft);background:#080e18;flex-shrink:0;height:160px;overflow-y:auto}.run-console-label{letter-spacing:.08em;text-transform:uppercase;color:var(--color-text-muted);padding:var(--space-2) var(--space-3) 0;font-size:10px;font-weight:600}.run-console-text{padding:var(--space-1) var(--space-3) var(--space-2);font-size:11px;font-family:var(--font-mono);color:#4ade80;white-space:pre-wrap;margin:0;line-height:1.6}.run-start-view{justify-content:center;align-items:center;gap:var(--space-3);flex-direction:column;flex:1;display:flex}.run-play-icon{color:var(--color-text-muted);opacity:.4;font-size:48px}.run-hint-text{font-size:var(--text-sm);color:var(--color-text-muted)}.run-controls{gap:var(--space-3);align-items:center;display:flex}.run-empty{height:200px;color:var(--color-text-muted);justify-content:center;align-items:center;display:flex}.vscode-panel{flex-direction:column;height:100%;display:flex;overflow:hidden}.vscode-frame{border:none;flex:1;width:100%;min-height:0}.preview-panel{flex-direction:column;height:100%;display:flex}.preview-iframe{border:none;flex:1;width:100%}.preview-empty{color:var(--color-text-muted);flex:1;justify-content:center;align-items:center;display:flex}.history-panel{padding:var(--space-4);gap:var(--space-4);flex-direction:column;height:100%;display:flex;overflow-y:auto}.history-empty{color:var(--color-text-muted);text-align:center;padding:var(--space-8) 0}.history-section-label{color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.06em;margin-bottom:var(--space-1);font-size:11px;font-weight:600}.session-list{gap:var(--space-1);flex-direction:column;display:flex}.session-item{align-items:center;gap:var(--space-2);padding:var(--space-2) var(--space-3);background:var(--color-bg-elevated);border-radius:var(--radius-sm);cursor:pointer;text-align:left;width:100%;color:var(--color-text-secondary);font-size:var(--text-sm);transition:all var(--transition-fast);border:none;display:flex}.session-item:hover{background:var(--color-bg-hover);color:var(--color-text-primary)}.session-item-name{text-overflow:ellipsis;white-space:nowrap;flex:1;overflow:hidden}.session-item-count{color:var(--color-text-muted);flex-shrink:0;font-size:11px}.commit-list{gap:var(--space-2);flex-direction:column;display:flex}.commit-item{align-items:flex-start;gap:var(--space-3);padding:var(--space-3);background:var(--color-bg-elevated);border-radius:var(--radius-sm);display:flex}.commit-sha{font-family:var(--font-mono);color:var(--color-accent-lime);flex-shrink:0;font-size:12px}.commit-info{flex:1;min-width:0}.commit-message{font-size:var(--text-sm);color:var(--color-text-primary)}.commit-meta{color:var(--color-text-muted);margin-top:2px;font-size:11px}.provider-cards{gap:var(--space-4);grid-template-columns:repeat(auto-fill,minmax(260px,1fr));display:grid}.provider-card{background:var(--color-bg-card);border:1px solid var(--color-border-soft);border-radius:var(--radius-md);padding:var(--space-4);gap:var(--space-3);flex-direction:column;display:flex}.provider-card--default{border-color:var(--color-accent-lime)}.provider-card-header{align-items:flex-start;gap:var(--space-3);display:flex}.provider-card-icon{color:var(--color-accent-lime);flex-shrink:0;margin-top:2px;font-size:22px}.provider-card-info{gap:var(--space-1);flex-direction:column;flex:1;min-width:0;display:flex}.provider-card-name{font-size:var(--text-sm);white-space:nowrap;text-overflow:ellipsis;font-weight:700;overflow:hidden}.provider-card-model{color:var(--color-text-muted);white-space:nowrap;text-overflow:ellipsis;font-size:11px;overflow:hidden}.provider-card-badges{gap:var(--space-1);flex-wrap:wrap;display:flex}.provider-card-actions{gap:var(--space-2);flex-wrap:wrap;display:flex}.provider-list{gap:var(--space-2);flex-direction:column;display:flex}.provider-row{align-items:center;gap:var(--space-3);padding:var(--space-3);background:var(--color-bg-card);border:1px solid var(--color-border-soft);border-radius:var(--radius-sm);display:flex}.provider-info{flex:1;min-width:0}.provider-name{font-size:var(--text-sm);font-weight:600}.provider-model{color:var(--color-text-muted);font-size:12px;font-family:var(--font-mono)}.provider-badges{gap:var(--space-1);display:flex}.design-card{background:var(--color-bg-card);border:1px solid var(--color-border-soft);border-radius:var(--radius-md);cursor:pointer;transition:border-color var(--transition-fast);overflow:hidden}.design-card:hover,.design-card--default{border-color:var(--color-accent-lime)}.design-card-preview{height:80px;position:relative;overflow:hidden}.design-preview-bar{height:56px}.design-preview-accent{height:6px}.design-card-body{padding:var(--space-3) var(--space-3) var(--space-2)}.design-card-name{font-size:var(--text-sm);align-items:center;gap:var(--space-2);flex-wrap:wrap;font-weight:600;display:flex}.design-card-meta{color:var(--color-text-muted);margin-top:var(--space-2);align-items:center;gap:var(--space-2);font-size:11px;display:flex}.design-card-actions{gap:var(--space-2);padding:0 var(--space-3) var(--space-3);flex-wrap:wrap;display:flex}.db-shell{flex:1;grid-template-columns:240px 1fr;min-height:0;display:grid;overflow:hidden}.db-sidebar{border-right:1px solid var(--color-border-soft);padding:var(--space-2) 0;background:var(--color-bg-elevated);min-height:0;overflow-y:auto}.db-group-label{text-transform:uppercase;letter-spacing:.07em;color:var(--color-text-muted);padding:var(--space-2) var(--space-3) var(--space-1);margin-top:var(--space-1);font-size:10px;font-weight:600}.db-group-header{padding:var(--space-2) var(--space-3) var(--space-1);margin-top:var(--space-1);justify-content:space-between;align-items:center;display:flex}.db-group-label-text{text-transform:uppercase;letter-spacing:.07em;color:var(--color-text-muted);font-size:10px;font-weight:600}.db-group-delete{cursor:pointer;color:var(--color-text-muted);border-radius:var(--radius-sm);opacity:0;background:0 0;border:none;align-items:center;padding:2px;transition:opacity .15s,color .15s;display:flex}.db-group-delete .material-symbols-outlined{font-size:14px}.db-group-header:hover .db-group-delete{opacity:1}.db-group-delete:hover{color:var(--color-error,#f87171)}.db-sidebar-empty{padding:var(--space-4);font-size:var(--text-sm);color:var(--color-text-muted);text-align:center}.db-sidebar-item{align-items:flex-start;gap:var(--space-2);padding:var(--space-2) var(--space-3);cursor:pointer;transition:all var(--transition-fast);text-align:left;width:100%;color:var(--color-text-secondary);background:0 0;border:none;border-left:2px solid #0000;display:flex}.db-sidebar-item:hover{background:var(--color-bg-hover);color:var(--color-text-primary)}.db-sidebar-item.active{background:var(--color-bg-active);color:var(--color-accent-lime);border-left-color:var(--color-accent-lime)}.db-item-body{flex:1;min-width:0}.db-item-name-row{align-items:center;gap:var(--space-1);display:flex}.db-item-name{font-size:var(--text-sm);text-overflow:ellipsis;white-space:nowrap;font-weight:600;overflow:hidden}.db-item-slug{color:var(--color-text-muted);font-size:11px;font-family:var(--font-mono)}.db-env-badge{letter-spacing:.05em;white-space:nowrap;border-radius:3px;flex-shrink:0;padding:1px 5px;font-size:9px;font-weight:700}.db-main{flex-direction:column;min-width:0;min-height:0;display:flex;overflow:hidden}.db-empty{justify-content:center;align-items:center;gap:var(--space-2);height:100%;color:var(--color-text-muted);flex-direction:column;display:flex}.db-empty-sm{padding:var(--space-6);text-align:center;color:var(--color-text-muted);font-size:var(--text-sm)}.db-tables-view{flex-direction:column;height:100%;display:flex}.db-table-list{gap:var(--space-1);padding:var(--space-3);flex-direction:column;display:flex}.db-table-item{align-items:center;gap:var(--space-2);padding:var(--space-2) var(--space-3);border-radius:var(--radius-sm);cursor:pointer;font-size:var(--text-sm);transition:all var(--transition-fast);color:var(--color-text-secondary);text-align:left;background:0 0;border:none;width:100%;display:flex}.db-table-item:hover{background:var(--color-bg-hover)}.db-table-item.active{background:var(--color-bg-active);color:var(--color-accent-lime)}.db-rows-view{flex-direction:column;flex:1;display:flex;overflow:hidden}.db-rows-header{padding:var(--space-3) var(--space-4);border-bottom:1px solid var(--color-border-soft);justify-content:space-between;align-items:center;display:flex}.db-sql-view{gap:var(--space-3);padding:var(--space-4);flex-direction:column;height:100%;display:flex}.sql-editor-wrapper{position:relative}.sql-editor{resize:vertical;width:100%;min-height:120px;padding:var(--space-3);font-family:var(--font-mono);background:var(--color-bg-main);border:1px solid var(--color-border-soft);border-radius:var(--radius-sm);color:var(--color-text-primary);font-size:13px}.sql-result{flex:1;overflow:auto}.sql-result-raw{font-family:var(--font-mono);white-space:pre;font-size:12px}.db-studio-root{flex-direction:column;height:100%;display:flex;overflow:hidden}.db-header-bar{padding:var(--space-3) var(--space-4);border-bottom:1px solid var(--color-border-soft);justify-content:space-between;align-items:center;gap:var(--space-3);background:var(--color-bg-elevated);flex-shrink:0;display:flex}.db-header-info{align-items:center;gap:var(--space-2);min-width:0;display:flex}.db-header-name{font-size:var(--text-sm);color:var(--color-text-primary);font-weight:700}.db-header-slug{color:var(--color-text-muted);font-size:12px;font-family:var(--font-mono);margin-left:var(--space-1)}.db-header-actions{align-items:center;gap:var(--space-1);flex-shrink:0;display:flex}.db-btn-active{background:var(--color-bg-active)!important;color:var(--color-accent-lime)!important}.db-table-tabs{border-bottom:1px solid var(--color-border-soft);background:var(--color-bg-elevated);flex-shrink:0;align-items:stretch;display:flex;overflow-x:auto}.db-tab{padding:var(--space-2) var(--space-3);color:var(--color-text-muted);font-size:var(--text-sm);cursor:pointer;transition:all var(--transition-fast);white-space:nowrap;background:0 0;border:none;border-bottom:2px solid #0000;align-items:center;gap:5px;display:flex}.db-tab:hover{color:var(--color-text-primary);background:var(--color-bg-hover)}.db-tab.active{color:var(--color-accent-lime);border-bottom-color:var(--color-accent-lime);background:0 0}.db-tab-count{background:var(--color-bg-active);color:var(--color-text-muted);text-align:center;border-radius:9px;min-width:18px;padding:1px 6px;font-size:10px;font-weight:700}.db-tab.active .db-tab-count{color:var(--color-accent-lime);background:#c8ff0026}.db-tab-close{opacity:0;color:var(--color-text-muted);transition:opacity var(--transition-fast);margin-left:2px;font-size:14px;line-height:1}.db-tab:hover .db-tab-close{opacity:.6}.db-tab-close:hover{color:var(--color-danger,#f87171);opacity:1!important}.db-tab-add{padding:var(--space-2) var(--space-3);color:var(--color-text-muted);cursor:pointer;transition:color var(--transition-fast);background:0 0;border:none;font-size:18px;line-height:1}.db-tab-add:hover{color:var(--color-accent-lime)}.db-sql-panel{padding:var(--space-4);border-bottom:1px solid var(--color-border-soft);background:var(--color-bg-main);flex-shrink:0}.db-toolbar{padding:var(--space-2) var(--space-4);border-bottom:1px solid var(--color-border-soft);justify-content:space-between;align-items:center;gap:var(--space-3);flex-shrink:0;display:flex}.db-toolbar-left{align-items:center;gap:var(--space-3);display:flex}.db-search-wrap{align-items:center;gap:var(--space-2);background:var(--color-bg-main);border:1px solid var(--color-border-soft);border-radius:var(--radius-sm);padding:4px var(--space-2);display:flex}.db-search-wrap .material-symbols-outlined{color:var(--color-text-muted);font-size:16px}.db-search-input{font-size:var(--text-sm);color:var(--color-text-primary);background:0 0;border:none;outline:none;width:180px}.db-row-count-badge{color:var(--color-text-muted);background:var(--color-bg-active);border-radius:var(--radius-sm);padding:3px var(--space-2);white-space:nowrap;font-size:12px}.db-col-header{align-items:center;gap:4px;display:flex}.db-row-actions{text-align:right;white-space:nowrap;opacity:0;transition:opacity var(--transition-fast)}tr:hover .db-row-actions{opacity:1}.db-empty-row{text-align:center;color:var(--color-text-muted);font-size:var(--text-sm);padding:var(--space-6)!important}.db-sidebar-icon{color:var(--color-text-muted);flex-shrink:0;margin-top:2px;font-size:16px}.db-item-delete{cursor:pointer;color:var(--color-text-muted);border-radius:var(--radius-sm);transition:color var(--transition-fast);background:0 0;border:none;flex-shrink:0;padding:2px;display:none}.db-item-delete .material-symbols-outlined{font-size:15px}.db-item-delete:hover{color:var(--color-danger,#f87171)}.db-sidebar-item:hover .db-item-delete{align-items:center;display:flex}.db-col-editor{flex-direction:column;gap:6px;display:flex}.db-col-editor-head{align-items:center;gap:var(--space-2);padding:0 var(--space-2);text-transform:uppercase;letter-spacing:.05em;color:var(--color-text-muted);font-size:11px;font-weight:600;display:flex}.db-col-editor-row{align-items:center;gap:var(--space-2);background:var(--color-bg-main);border:1px solid var(--color-border-soft);border-radius:var(--radius-sm);padding:4px;display:flex}.db-col-input{height:32px;padding:5px var(--space-2)!important;font-size:var(--text-sm)!important}.db-col-check{width:16px;height:16px;accent-color:var(--color-accent-lime);cursor:pointer}.form-hint{color:var(--color-text-muted);margin-top:4px;font-size:12px}.form-hint code{font-family:var(--font-mono);color:var(--color-accent-lime)}.form-error{font-size:var(--text-sm);color:var(--color-danger,#f87171);padding:var(--space-2) var(--space-3);border-radius:var(--radius-sm);background:#ef444414;border:1px solid #ef444433}.ki-schema-result{border-radius:var(--radius-md);background:#c8ff000a;border:1px solid #c8ff0040;overflow:hidden}.ki-schema-result-label{align-items:center;gap:var(--space-2);padding:var(--space-2) var(--space-3);font-size:var(--text-sm);border-bottom:1px solid #c8ff0026;font-weight:600;display:flex}.ki-schema-sql{padding:var(--space-3);font-family:var(--font-mono);white-space:pre-wrap;color:var(--color-text-secondary);max-height:200px;margin:0;font-size:12px;line-height:1.6;overflow-y:auto}.connector-list{gap:var(--space-3);flex-direction:column;display:flex}.connector-card{align-items:center;gap:var(--space-4);padding:var(--space-4);background:var(--color-bg-card);border:1px solid var(--color-border-soft);border-radius:var(--radius-md);display:flex}.connector-icon{color:var(--color-accent-lime);flex-shrink:0;font-size:24px}.connector-info{flex:1;min-width:0}.connector-name{font-size:var(--text-sm);font-weight:600}.connector-type{color:var(--color-text-muted);font-size:12px}.connector-actions{gap:var(--space-2);display:flex}.info-box{gap:var(--space-3);padding:var(--space-4);border-radius:var(--radius-md);background:#c8ff000f;border:1px solid #c8ff0033;display:flex}.info-box-icon{color:var(--color-accent-lime);flex-shrink:0;margin-top:2px;font-size:20px}.info-box-title{font-size:var(--text-sm);margin-bottom:var(--space-1);font-weight:600}.info-box-list{margin:var(--space-1) 0 0;padding-left:var(--space-4);font-size:var(--text-sm);color:var(--color-text-secondary)}.info-box-list li{margin-bottom:2px}.period-selector{gap:var(--space-1);display:flex}.log-viewer{background:var(--color-bg-main);padding:var(--space-4);font-family:var(--font-mono);white-space:pre-wrap;max-height:70vh;color:var(--color-text-secondary);border-radius:0;margin:0;font-size:12px;line-height:1.6;overflow:auto}.spinner--sm{width:16px;height:16px}.wizard-shell{background:var(--color-bg-main);justify-content:center;align-items:center;min-height:100vh;display:flex}.wizard-card{background:var(--color-bg-card);border:1px solid var(--color-border-soft);border-radius:var(--radius-lg);padding:var(--space-10,40px);text-align:center;width:480px;max-width:100%}.wizard-logo{margin-bottom:var(--space-6)}.wizard-body{gap:var(--space-4);flex-direction:column;align-items:center;display:flex}.text-muted{color:var(--color-text-muted)}.studio-shell{grid-template-columns:var(--sidebar-width,240px) 1fr;grid-template-rows:var(--topbar-height,56px) 1fr;height:100vh;display:grid;overflow:hidden}.studio-topbar{grid-area:1/1/auto/-1}.studio-sidebar{grid-area:2/1;overflow-y:auto}.studio-content{grid-area:2/2;min-height:0;overflow:hidden}.nav-section{margin-bottom:var(--space-1)}.nav-section-label{letter-spacing:.1em;text-transform:uppercase;color:var(--color-text-muted);padding:var(--space-2) var(--space-4) var(--space-1);font-size:10px;font-weight:600}.nav-item{align-items:center;gap:var(--space-3);padding:var(--space-2) var(--space-3);margin:1px var(--space-2);border-radius:var(--radius-sm);font-size:var(--text-sm);color:var(--color-text-secondary);transition:all var(--transition-fast);text-decoration:none;display:flex}.nav-item:hover{background:var(--color-bg-hover);color:var(--color-text-primary);text-decoration:none}.nav-item.active{background:var(--color-bg-active);color:var(--color-accent-lime)}.nav-item-icon{flex-shrink:0;font-size:18px}.nav-item-label{flex:1}.btn--primary{background:var(--color-accent-lime);color:#000;border-color:var(--color-accent-lime);font-weight:700}.btn--primary:hover:not(:disabled){filter:brightness(1.08);box-shadow:var(--shadow-glow,0 0 8px #c8ff0059)}.btn--secondary{background:var(--color-bg-elevated);border:1px solid var(--color-border-soft);color:var(--color-text-primary)}.btn--secondary:hover:not(:disabled){background:var(--color-bg-hover);border-color:var(--color-border-strong)}.btn--ghost{border:1px solid var(--color-border-soft);color:var(--color-text-secondary);background:0 0}.btn--ghost:hover:not(:disabled){background:var(--color-bg-hover);color:var(--color-text-primary)}.btn--danger{color:var(--color-danger,#ef4444);background:0 0;border:1px solid #ef444466}.btn--danger:hover:not(:disabled){border-color:var(--color-danger,#ef4444);background:#ef44441f}.btn--sm{height:30px;padding:0 var(--space-3);font-size:var(--text-xs,12px)}.btn--xs{height:24px;padding:0 var(--space-2);font-size:11px}.btn--lg{height:46px;padding:0 var(--space-8);font-size:var(--text-md,15px)}.btn--icon{justify-content:center;width:38px;padding:0}.btn--ghost.btn--danger{background:0 0;border-color:#0000}.btn--ghost.btn--danger:hover{color:var(--color-danger,#ef4444);background:#ef44441a;border-color:#0000}.db-tabs{border-bottom:1px solid var(--color-border-soft);background:var(--color-bg-elevated);display:flex}.db-row-count{color:var(--color-text-muted);background:var(--color-bg-elevated);border-radius:var(--radius-pill);margin-left:auto;padding:1px 6px;font-size:11px}.db-table-title{font-size:var(--text-sm);font-weight:600}.db-table-scroll{flex:1;overflow:auto}.sql-run-btn{align-self:flex-end}.sql-error{color:var(--color-danger,#ef4444);font-size:var(--text-sm);padding:var(--space-3);border-radius:var(--radius-sm);background:#ef444414}.builder-tabs{border-bottom:1px solid var(--color-border-soft);background:var(--color-bg-elevated);flex-shrink:0;display:flex}.builder-app-select{align-items:center;gap:var(--space-2);margin-top:var(--space-2);display:flex}.builder-provider-label{font-size:var(--text-sm);color:var(--color-text-secondary)}.file-icon{font-size:14px!important}.file-name{text-overflow:ellipsis;white-space:nowrap;font-size:12px;overflow:hidden}.apps-list{gap:var(--space-3);flex-direction:column;display:flex}.app-row{align-items:center;gap:var(--space-4);background:var(--color-bg-card);border:1px solid var(--color-border-soft);border-radius:var(--radius-md);padding:var(--space-3) var(--space-4);transition:border-color var(--transition-fast);display:flex}.app-row:hover{border-color:var(--color-border-strong)}.app-icon{color:var(--color-text-muted);flex-shrink:0;font-size:24px}.app-info{flex:1;min-width:0}.app-name{font-weight:600;font-size:var(--text-base)}.app-slug{color:var(--color-text-muted);font-size:12px;font-family:var(--font-mono)}.app-date{color:var(--color-text-muted);font-size:11px}.app-actions{gap:var(--space-2);flex-shrink:0;display:flex}.status-badge--running{color:#4ade80;background:#22c55e26}.status-badge--stopped{color:#f87171;background:#ef44441a}.status-badge--draft{background:var(--color-bg-elevated);color:var(--color-text-muted)}.status-badge--error{color:#f87171;background:#ef444426}.status-badge--building{color:#fbbf24;background:#f59e0b26}.design-grid{gap:var(--space-4);grid-template-columns:repeat(auto-fill,minmax(220px,1fr));display:grid}.design-card{background:var(--color-bg-card);border:2px solid var(--color-border-soft);border-radius:var(--radius-md);padding:var(--space-4);cursor:pointer;transition:all var(--transition-fast)}.design-card:hover{border-color:var(--color-border-strong)}.design-card.active{border-color:var(--color-accent-lime)}.design-card-preview{border-radius:var(--radius-sm);height:80px;margin-bottom:var(--space-3)}.design-card-name{font-weight:600;font-size:var(--text-sm)}.design-card-meta{color:var(--color-text-muted);margin-top:2px;font-size:11px}.provider-grid{gap:var(--space-4);grid-template-columns:repeat(auto-fill,minmax(280px,1fr));display:grid}.provider-card{background:var(--color-bg-card);border:1px solid var(--color-border-soft);border-radius:var(--radius-md);padding:var(--space-4)}.provider-card-header{margin-bottom:var(--space-3);justify-content:space-between;align-items:center;display:flex}.provider-card-name{font-weight:600;font-size:var(--text-base)}.provider-card-body{gap:var(--space-2);flex-direction:column;display:flex}.provider-card-actions{gap:var(--space-2);margin-top:var(--space-3);display:flex}.connectors-grid{gap:var(--space-4);grid-template-columns:repeat(auto-fill,minmax(300px,1fr));display:grid}.connector-card{background:var(--color-bg-card);border:1px solid var(--color-border-soft);border-radius:var(--radius-md);padding:var(--space-4)}.connector-card-header{align-items:center;gap:var(--space-3);margin-bottom:var(--space-3);display:flex}.connector-icon{color:var(--color-text-muted);font-size:24px}.connector-card-name{font-weight:600;font-size:var(--text-base)}.connector-card-type{color:var(--color-text-muted);font-size:12px}.connector-card-actions{gap:var(--space-2);margin-top:var(--space-3);border-top:1px solid var(--color-border-soft);padding-top:var(--space-3);display:flex}.secrets-table-wrap{overflow-x:auto}.deployments-list{gap:var(--space-4);flex-direction:column;display:flex}.deployment-card{background:var(--color-bg-card);border:1px solid var(--color-border-soft);border-radius:var(--radius-md);padding:var(--space-4)}.deployment-header{margin-bottom:var(--space-3);justify-content:space-between;align-items:center;display:flex}.deployment-title{font-weight:600;font-size:var(--text-base)}.deployment-meta{gap:var(--space-2);font-size:var(--text-sm);color:var(--color-text-secondary);flex-direction:column;display:flex}.deployment-actions{gap:var(--space-2);margin-top:var(--space-4);display:flex}.usage-period{gap:var(--space-1);margin-bottom:var(--space-6);display:flex}.usage-period-btn{padding:var(--space-1) var(--space-3);font-size:var(--text-sm);border-radius:var(--radius-pill);border:1px solid var(--color-border-soft);color:var(--color-text-secondary);cursor:pointer;transition:all var(--transition-fast);background:0 0}.usage-period-btn:hover{background:var(--color-bg-hover)}.usage-period-btn.active{background:var(--color-accent-lime);color:#000;border-color:var(--color-accent-lime);font-weight:700}.audit-filters{gap:var(--space-3);margin-bottom:var(--space-4);flex-wrap:wrap;display:flex}.logs-toolbar{gap:var(--space-3);margin-bottom:var(--space-3);flex-wrap:wrap;align-items:center;display:flex}.logs-container{border-radius:var(--radius-md);border:1px solid var(--color-border-soft);overflow:hidden}.preview-empty{gap:var(--space-3);flex-direction:column}.topbar-instance-selector select{min-width:120px}.topbar-logo{align-items:center;gap:var(--space-2);text-decoration:none;display:flex}.topbar-logo-img{object-fit:contain;flex-shrink:0;width:28px;height:28px}.topbar-logo-uknow{font-size:var(--text-sm);color:var(--color-text-primary);font-weight:700}.topbar-logo-ai{font-size:var(--text-sm);color:var(--color-accent-lime);font-weight:700}.topbar-logo-studio{font-size:var(--text-sm);color:var(--color-text-primary);font-weight:700}.topbar-sep{background:var(--color-border-soft);flex-shrink:0;width:1px;height:20px}.topbar-instance-name{font-size:var(--text-sm);color:var(--color-text-secondary)}.topbar-lang-toggle{min-width:56px;font-size:13px}.topbar-user{align-items:center;gap:var(--space-2);display:flex}.topbar-user-name{font-size:var(--text-sm);color:var(--color-text-secondary);text-overflow:ellipsis;white-space:nowrap;max-width:160px;overflow:hidden}.sidebar-instance-wrap{padding:var(--space-3);border-bottom:1px solid var(--color-border-soft);border-top:1px solid var(--color-border-soft)}.sidebar-instance-select{width:100%;font-size:var(--text-xs);background:var(--color-bg-elevated);border:1px solid var(--color-border-soft);color:var(--color-text-primary);padding:5px var(--space-2);border-radius:var(--radius-sm);cursor:pointer}.sidebar-instance-select:focus{border-color:var(--color-accent-lime);outline:none}.sidebar-instance-loading{font-size:var(--text-xs);color:var(--color-text-muted);padding:4px 0}.sidebar-bottom{padding:var(--space-3);border-top:1px solid var(--color-border-soft);flex-shrink:0}.sidebar-new-instance{justify-content:center;align-items:center;gap:var(--space-2);width:100%;padding:var(--space-2) var(--space-3);font-size:var(--text-xs);border-radius:var(--radius-sm);border:1px solid var(--color-border-soft);color:var(--color-text-secondary);background:var(--color-bg-elevated);transition:all var(--transition-fast);font-weight:600;text-decoration:none;display:flex}.sidebar-new-instance:hover{border-color:var(--color-accent-lime);color:var(--color-accent-lime)}.dash-stats-row{gap:var(--space-4);grid-template-columns:repeat(4,1fr);display:grid}@media (width<=860px){.dash-stats-row{grid-template-columns:repeat(2,1fr)}}@media (width<=640px){.dash-stats-row{grid-template-columns:1fr}}.stat-card{background:var(--color-bg-card);border:1px solid var(--color-border-soft);border-radius:var(--radius-md);padding:var(--space-4) var(--space-5);gap:var(--space-1);flex-direction:column;display:flex}.stat-label{font-size:var(--text-xs);text-transform:uppercase;letter-spacing:.08em;color:var(--color-text-muted);font-weight:600}.stat-value{font-size:var(--text-2xl,28px);color:var(--color-text-primary);font-weight:700;line-height:1.1}.stat-delta{font-size:var(--text-xs);color:var(--color-text-muted)}.dash-grid-2{gap:var(--space-4);grid-template-columns:1fr 1fr;display:grid}@media (width<=900px){.dash-grid-2{grid-template-columns:1fr}}.dash-card{background:var(--color-bg-card);border:1px solid var(--color-border-soft);border-radius:var(--radius-md);padding:var(--space-4) var(--space-5);gap:var(--space-3);flex-direction:column;display:flex}.dash-card-header{padding-bottom:var(--space-2);border-bottom:1px solid var(--color-border-soft);justify-content:space-between;align-items:center;display:flex}.dash-card-title{font-size:var(--text-sm);color:var(--color-text-primary);text-transform:uppercase;letter-spacing:.05em;margin:0;font-weight:700}.dash-cost-grid{gap:var(--space-3);grid-template-columns:repeat(4,1fr);display:grid}@media (width<=900px){.dash-cost-grid{grid-template-columns:repeat(2,1fr)}}.dash-ai-section{gap:var(--space-2);flex-direction:column;display:flex}.dash-ai-header{justify-content:space-between;align-items:center;display:flex}.dash-provider-row{padding:var(--space-2) var(--space-3);background:var(--color-bg-elevated);border-radius:var(--radius-sm);justify-content:space-between;align-items:center;gap:var(--space-3);display:flex}.dash-provider-left{align-items:center;gap:var(--space-3);flex:1;display:flex}.dash-provider-right{align-items:center;gap:var(--space-4);display:flex}.dash-usage-totals{align-items:center;gap:var(--space-6);padding:var(--space-3) var(--space-3) var(--space-2);border-top:1px solid var(--color-border-soft);margin-top:var(--space-1);display:flex}.dash-app-list{gap:var(--space-2);flex-direction:column;display:flex}.dash-app-row{align-items:center;gap:var(--space-3);padding:var(--space-2) var(--space-2);border-radius:var(--radius-sm);cursor:pointer;transition:background var(--transition-fast);display:flex}.dash-app-row:hover{background:var(--color-bg-hover)}.dash-app-icon{border-radius:var(--radius-sm);background:var(--color-bg-elevated);flex-shrink:0;justify-content:center;align-items:center;width:28px;height:28px;display:flex}.dash-app-info{flex:1;min-width:0}.dash-modules{gap:var(--space-3);flex-direction:column;display:flex}.dash-module{padding:var(--space-3) var(--space-3);border-radius:var(--radius-sm);border:1px solid var(--color-border-soft);justify-content:space-between;align-items:center;display:flex}.dash-module--vector{background:#3b82f60a;border-color:#3b82f640}.dash-module--calc{background:#a855f70a;border-color:#a855f740}.dash-module-left{align-items:center;gap:var(--space-3);display:flex}.kpi-grid{gap:var(--space-4);grid-template-columns:repeat(auto-fit,minmax(140px,1fr));display:grid}.form-row{gap:var(--space-4);flex-wrap:wrap;align-items:flex-start;display:flex}.form-row .form-group{flex:1;min-width:120px}.form-row .form-group--sm{flex:0 0 130px}.form-row .form-group--grow{flex:2}.form-stack{gap:var(--space-3);flex-direction:column;display:flex}.form-textarea{resize:vertical;min-height:72px;line-height:1.5}.form-textarea--sm{min-height:52px}.form-section-label{letter-spacing:.06em;text-transform:uppercase;color:var(--color-text-muted);padding-top:var(--space-2);border-top:1px solid var(--color-border-soft);margin-top:var(--space-2);font-size:11px;font-weight:700}.tab-bar{border-bottom:1px solid var(--color-border-soft);margin-bottom:var(--space-4);gap:2px;display:flex}.tab-btn--active{color:var(--color-accent-lime)!important;border-bottom-color:var(--color-accent-lime)!important}.modal-backdrop{z-index:1000;padding:var(--space-4);background:#0009;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.spinner--sm{border-width:2px;width:14px;height:14px}*,:before,:after{box-sizing:border-box}html,body,#root{height:100%;margin:0;padding:0}.toast-container{bottom:var(--space-6);right:var(--space-6);gap:var(--space-2);z-index:9999;flex-direction:column;display:flex;position:fixed}.toast{padding:var(--space-3) var(--space-5);border-radius:var(--radius-md);font-size:var(--text-sm);font-weight:var(--weight-medium);cursor:pointer;max-width:340px;animation:.2s slideIn}.toast--success{background:var(--color-success-bg);color:var(--color-success);border:1px solid var(--color-success)}.toast--error{background:var(--color-error-bg);color:var(--color-error);border:1px solid var(--color-error)}.toast--info{background:var(--color-accent-lime-bg);color:var(--color-accent-lime);border:1px solid var(--color-border-accent)}@keyframes slideIn{0%{opacity:0;transform:translate(100%)}to{opacity:1;transform:translate(0)}}.spinner{border:3px solid var(--color-border-medium);border-top-color:var(--color-accent-lime);border-radius:50%;width:32px;height:32px;animation:.8s linear infinite spin}
