*{margin:0;padding:0;box-sizing:border-box}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,system-ui,sans-serif;background:#0d1117;color:#e6edf3}.nav{display:flex;align-items:center;gap:24px;padding:12px 32px;background:#161b22;border-bottom:1px solid #30363d}.nav .logo{font-size:20px;font-weight:700;color:#58a6ff;letter-spacing:-.5px}.nav .logo span{color:#f78166}.nav a{color:#8b949e;text-decoration:none;font-size:14px;font-weight:500}.nav a:hover{color:#e6edf3}.nav .spacer{flex:1}.nav .badge{background:#1f6feb;color:#fff;font-size:11px;padding:2px 8px;border-radius:99px}.nav .avatar{width:28px;height:28px;border-radius:50%;background:#30363d}.page{max-width:1200px;margin:0 auto;padding:32px 24px}h1{font-size:28px;font-weight:600;margin-bottom:4px}.subtitle{color:#8b949e;font-size:14px;margin-bottom:32px}.quick-start{display:grid;grid-template-columns:repeat(4,1fr);gap:12px;margin-bottom:40px}.qs-card{background:#161b22;border:1px solid #30363d;border-radius:12px;padding:20px;cursor:pointer;transition:all .2s}.qs-card:hover{border-color:#58a6ff;background:#1c2129}.qs-card .icon{font-size:28px;margin-bottom:8px}.qs-card .name{font-weight:600;font-size:14px;margin-bottom:2px}.qs-card .desc{color:#8b949e;font-size:12px}.qs-card .tag{display:inline-block;background:#1f6feb22;color:#58a6ff;font-size:10px;padding:2px 8px;border-radius:99px;margin-top:8px}.section-title{display:flex;align-items:center;gap:8px;font-size:16px;font-weight:600;margin-bottom:16px}.section-title .count{color:#8b949e;font-weight:400;font-size:14px}.section-title .spacer{flex:1}.section-title .btn{background:#238636;color:#fff;border:none;padding:6px 16px;border-radius:6px;font-size:13px;font-weight:500;cursor:pointer}.section-title .btn:hover{background:#2ea043}.section-title .btn-outline{background:transparent;color:#8b949e;border:1px solid #30363d;padding:6px 16px;border-radius:6px;font-size:13px;cursor:pointer}.section-title .btn-outline:hover{border-color:#8b949e;color:#e6edf3}.project-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}.project-card{background:#161b22;border:1px solid #30363d;border-radius:12px;overflow:hidden;transition:all .2s;cursor:pointer}.project-card:hover{border-color:#58a6ff}.project-card .preview{height:120px;background:#0d1117;display:flex;align-items:center;justify-content:center;font-size:32px;border-bottom:1px solid #21262d}.project-card .body{padding:16px}.project-card .body .name{font-weight:600;font-size:15px;margin-bottom:4px}.project-card .body .lang{color:#8b949e;font-size:12px}.project-card .body .footer{display:flex;align-items:center;gap:12px;margin-top:12px;font-size:12px;color:#8b949e}.project-card .body .dot{width:8px;height:8px;border-radius:50%}.dot.green{background:#3fb950}.dot.yellow{background:#d29922}.dot.blue{background:#58a6ff}.empty-state{grid-column:1 / -1;text-align:center;padding:60px 20px;color:#8b949e}.empty-state .big-icon{font-size:48px;margin-bottom:16px}.empty-state p{font-size:14px;margin-bottom:8px}.modal-overlay{display:none;position:fixed;top:0;left:0;width:100%;height:100%;background:#0009;align-items:center;justify-content:center;z-index:100}.modal-overlay.show{display:flex}.modal{background:#161b22;border:1px solid #30363d;border-radius:12px;width:560px;padding:24px}.modal h2{font-size:20px;margin-bottom:4px}.modal .sub{color:#8b949e;font-size:13px;margin-bottom:20px}.modal .field{margin-bottom:16px}.modal label{display:block;font-size:13px;font-weight:500;margin-bottom:4px}.modal input,.modal select{width:100%;padding:10px 12px;border-radius:6px;border:1px solid #30363d;background:#0d1117;color:#e6edf3;font-size:14px}.modal select{-webkit-appearance:auto;-moz-appearance:auto;appearance:auto}.modal .templates{display:grid;grid-template-columns:1fr 1fr;gap:8px;margin-bottom:16px}.modal .template{padding:12px;border:1px solid #30363d;border-radius:8px;cursor:pointer;text-align:center;transition:all .15s}.modal .template:hover,.modal .template.selected{border-color:#58a6ff;background:#1c2129}.modal .template .icon{font-size:24px;margin-bottom:4px}.modal .template .name{font-size:13px;font-weight:500}.modal .template .desc{font-size:11px;color:#8b949e}.modal .actions{display:flex;gap:8px;justify-content:flex-end;margin-top:8px}.modal .actions .btn{padding:8px 20px;border-radius:6px;font-size:14px;cursor:pointer;border:none}.modal .actions .btn:disabled{opacity:.5;cursor:not-allowed}.modal .actions .btn-primary{background:#238636;color:#fff}.modal .actions .btn-primary:hover:not(:disabled){background:#2ea043}.modal .actions .btn-secondary{background:#21262d;color:#8b949e;border:1px solid #30363d}.modal .actions .btn-secondary:hover{background:#30363d}.status-bar{margin-top:48px;padding:16px 0;border-top:1px solid #21262d;display:flex;align-items:center;gap:20px;font-size:12px;color:#8b949e;flex-wrap:wrap}.status-bar .up{color:#3fb950}.status-bar .down{color:#f85149}.status-bar .sep{color:#21262d}.error-toast{position:fixed;bottom:24px;right:24px;background:#f85149;color:#fff;padding:12px 20px;border-radius:8px;font-size:13px;z-index:200;animation:slideUp .3s ease}@keyframes slideUp{0%{transform:translateY(20px);opacity:0}to{transform:translateY(0);opacity:1}}.loading{text-align:center;padding:40px;color:#8b949e}.loading-spinner{width:32px;height:32px;border:3px solid #21262d;border-top:3px solid #58a6ff;border-radius:50%;animation:spin .8s linear infinite;margin:0 auto 12px}@keyframes spin{to{transform:rotate(360deg)}}.auth-page{display:flex;align-items:center;justify-content:center;min-height:100vh;padding:24px}.auth-card{background:#161b22;border:1px solid #30363d;border-radius:12px;padding:32px;width:400px;max-width:100%}.auth-logo{font-size:24px;font-weight:700;color:#58a6ff;letter-spacing:-.5px;margin-bottom:24px;text-align:center}.auth-logo span{color:#f78166}.auth-card h2{font-size:22px;font-weight:600;margin-bottom:4px;text-align:center}.auth-sub{color:#8b949e;font-size:13px;margin-bottom:24px;text-align:center}.auth-field{margin-bottom:16px}.auth-field label{display:block;font-size:13px;font-weight:500;margin-bottom:4px;color:#e6edf3}.auth-field input{width:100%;padding:10px 12px;border-radius:6px;border:1px solid #30363d;background:#0d1117;color:#e6edf3;font-size:14px;outline:none}.auth-field input:focus{border-color:#58a6ff}.auth-error{background:#f8514911;border:1px solid #f8514944;color:#f85149;padding:10px 12px;border-radius:6px;font-size:13px;margin-bottom:16px}.auth-btn{width:100%;padding:10px 20px;border-radius:6px;border:none;background:#238636;color:#fff;font-size:14px;font-weight:500;cursor:pointer;transition:background .15s}.auth-btn:hover{background:#2ea043}.auth-btn:disabled{opacity:.5;cursor:not-allowed}.auth-btn-sso{background:#1f6feb;margin-bottom:8px;display:flex;align-items:center;justify-content:center;gap:8px}.auth-btn-sso:hover{background:#388bfd}.sso-icon{font-size:18px}.auth-divider{display:flex;align-items:center;gap:16px;margin:20px 0;color:#484f58;font-size:12px}.auth-divider:before,.auth-divider:after{content:"";flex:1;height:1px;background:#21262d}.auth-toggle{text-align:center;margin-top:20px;font-size:13px;color:#8b949e}.auth-toggle a{color:#58a6ff;text-decoration:none}.auth-toggle a:hover{text-decoration:underline}.user-dropdown-org{font-size:11px;color:#58a6ff;margin-top:2px}.user-menu{position:relative}.user-avatar{width:32px;height:32px;border-radius:50%;background:#1f6feb;color:#fff;display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:700;cursor:pointer;-webkit-user-select:none;user-select:none}.user-avatar:hover{background:#388bfd}.user-dropdown{position:absolute;top:40px;right:0;background:#161b22;border:1px solid #30363d;border-radius:8px;min-width:200px;z-index:50;box-shadow:0 8px 24px #0006}.user-dropdown-header{padding:12px 16px}.user-dropdown-name{font-size:14px;font-weight:600;color:#e6edf3}.user-dropdown-email{font-size:12px;color:#8b949e}.user-dropdown-divider{height:1px;background:#30363d}.user-dropdown-item{padding:10px 16px;font-size:13px;color:#e6edf3;cursor:pointer;transition:background .15s}.user-dropdown-item:hover{background:#1c2129}.share-link-box input{width:100%;padding:10px 12px;border-radius:6px;border:1px solid #30363d;background:#0d1117;color:#58a6ff;font-size:13px;font-family:monospace;margin-bottom:8px}.success-toast{background:#238636!important}.status-badge{display:inline-flex;align-items:center;gap:4px;padding:2px 10px;border-radius:99px;font-size:11px;font-weight:500}.status-badge.running{background:#3fb95022;color:#3fb950}.status-badge.stopped{background:#58a6ff22;color:#58a6ff}.status-badge.building{background:#d2992222;color:#d29922}.status-badge.error{background:#f8514922;color:#f85149}.ide-container{height:100vh;display:flex;flex-direction:column;background:#0d1117;overflow:hidden}.ide-topbar{display:flex;align-items:center;gap:10px;padding:6px 14px;background:#161b22;border-bottom:1px solid #30363d;flex-shrink:0;min-height:40px}.topbar-btn{background:none;border:none;color:#58a6ff;cursor:pointer;font-size:13px;font-family:inherit;padding:4px 8px;border-radius:4px;transition:background .15s}.topbar-btn:hover{background:#1c2129}.topbar-btn:disabled{opacity:.5;cursor:not-allowed}.topbar-btn-green{background:#238636;color:#fff;font-size:11px;padding:3px 10px;border-radius:4px}.topbar-btn-green:hover:not(:disabled){background:#2ea043}.topbar-btn-blue{background:#1f6feb;color:#fff;font-size:11px;padding:3px 10px;border-radius:4px}.topbar-btn-blue:hover:not(:disabled){background:#388bfd}.topbar-btn-deploy{background:linear-gradient(135deg,#da3633,#b62324);color:#fff;font-size:11px;padding:4px 12px;border-radius:4px;font-weight:500}.topbar-btn-deploy:hover{background:linear-gradient(135deg,#f85149,#da3633)}.topbar-icon-btn{background:none;border:none;cursor:pointer;font-size:14px;padding:2px 4px;margin-right:4px;border-radius:3px;transition:background .15s}.topbar-icon-btn:hover{background:#1c2129}.topbar-project-name{font-weight:600;font-size:14px;color:#e6edf3;display:flex;align-items:center;white-space:nowrap}.topbar-badge{background:#1f6feb22;color:#58a6ff;font-size:11px;padding:2px 8px;border-radius:99px;white-space:nowrap}.topbar-spacer{flex:1;min-width:8px}.topbar-save-status{font-size:11px;color:#d29922;padding:2px 8px;background:#d2992222;border-radius:4px;white-space:nowrap}.topbar-save-status.saved{color:#3fb950;background:#3fb95022}.topbar-git{display:flex;align-items:center;gap:6px}.topbar-input{padding:3px 8px;font-size:12px;background:#0d1117;border:1px solid #30363d;border-radius:4px;color:#e6edf3;outline:none;font-family:inherit}.topbar-input:focus{border-color:#58a6ff}.git-commit-input{width:130px}.git-url-input{width:180px}.git-branch{display:flex;align-items:center;gap:4px;font-size:11px;color:#8b949e;padding:2px 8px;background:#21262d;border-radius:4px}.git-icon{font-size:13px}.git-changes{color:#d29922;font-weight:600;margin-left:2px}.ide-loading{display:flex;align-items:center;justify-content:center;flex:1;color:#8b949e}.ide-error{display:flex;flex-direction:column;align-items:center;justify-content:center;flex:1;color:#f85149;padding:40px}.ide-main-area{display:flex;flex:0 0 auto;overflow:hidden}.ide-file-tree{width:220px;min-width:180px;background:#161b22;border-right:1px solid #30363d;display:flex;flex-direction:column;overflow:hidden;flex-shrink:0}.file-tree-header{display:flex;align-items:center;gap:6px;padding:8px 12px;font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.5px;color:#8b949e;border-bottom:1px solid #21262d}.file-tree-count{color:#484f58;font-weight:400;font-size:10px}.file-tree-list{flex:1;overflow-y:auto;padding:4px 0}.file-tree-item{padding:3px 12px;font-size:13px;color:#8b949e;cursor:pointer;transition:background .1s;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.file-tree-item:hover{background:#1c2129}.file-tree-item.active{color:#e6edf3;background:#1f6feb33}.file-tree-item.file-tree-folder{color:#58a6ff;font-size:12px}.file-tree-empty{padding:16px;color:#484f58;font-size:12px}.ide-editor-area{flex:1;display:flex;flex-direction:column;overflow:hidden;min-width:200px}.editor-tab{display:flex;align-items:center;gap:8px;padding:4px 12px;background:#161b22;border-bottom:1px solid #30363d;flex-shrink:0}.editor-tab-label{font-size:12px;font-weight:500;color:#e6edf3}.editor-tab-path{font-size:11px;color:#484f58}.editor-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100%;color:#8b949e}.editor-empty-icon{font-size:48px;margin-bottom:12px}.editor-empty p{font-size:14px}.ide-resizer{width:4px;cursor:col-resize;background:#21262d;flex-shrink:0;transition:background .15s;position:relative}.ide-resizer:hover{background:#58a6ff}.ide-resizer:after{content:"";position:absolute;top:0;left:-4px;right:-4px;bottom:0}.ide-preview{display:flex;flex-direction:column;background:#0d1117;border-left:1px solid #30363d;overflow:hidden;flex-shrink:0}.preview-header{display:flex;align-items:center;justify-content:space-between;padding:6px 10px;font-size:12px;font-weight:500;color:#8b949e;background:#161b22;border-bottom:1px solid #30363d;flex-shrink:0}.preview-open-btn{color:#58a6ff;text-decoration:none;font-size:14px;padding:2px 6px;border-radius:3px;transition:background .15s}.preview-open-btn:hover{background:#1c2129}.preview-iframe-container{flex:1;overflow:hidden;background:#fff}.preview-iframe{width:100%;height:100%;border:none}.ide-chat-resizer{height:4px;cursor:row-resize;background:#21262d;flex-shrink:0;transition:background .15s;position:relative}.ide-chat-resizer:hover{background:#58a6ff}.ide-chat-resizer:after{content:"";position:absolute;top:-4px;left:0;right:0;bottom:-4px}.ide-chat-panel{display:flex;flex-direction:column;background:#161b22;border-top:1px solid #30363d;overflow:hidden;flex-shrink:0}.chat-header{display:flex;align-items:center;gap:8px;padding:6px 12px;font-size:12px;font-weight:600;color:#e6edf3;background:#1c2129;border-bottom:1px solid #30363d;flex-shrink:0}.chat-model-badge{font-size:10px;font-weight:400;color:#58a6ff;background:#1f6feb22;padding:1px 6px;border-radius:99px}.chat-messages{flex:1;overflow-y:auto;padding:8px 12px;display:flex;flex-direction:column;gap:8px}.chat-empty{text-align:center;padding:24px;color:#8b949e}.chat-empty p{font-size:13px;margin-bottom:4px}.chat-hint{font-size:12px!important;color:#484f58;font-style:italic}.chat-msg{display:flex;gap:8px;align-items:flex-start}.chat-msg-avatar{width:24px;height:24px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:12px;flex-shrink:0;background:#21262d}.chat-msg.user .chat-msg-avatar{background:#1f6feb33}.chat-msg.assistant .chat-msg-avatar{background:#23863633}.chat-msg-content{flex:1;font-size:13px;line-height:1.5;color:#e6edf3;min-width:0}.chat-text{margin:0 0 4px}.chat-text:last-child{margin-bottom:0}.chat-inline-code{background:#21262d;padding:1px 4px;border-radius:3px;font-size:12px;font-family:Fira Code,Cascadia Code,JetBrains Mono,monospace;color:#f78166}.chat-code-block{background:#0d1117;border:1px solid #30363d;border-radius:6px;padding:8px 12px;margin:6px 0;overflow-x:auto;font-size:12px;line-height:1.4;font-family:Fira Code,Cascadia Code,JetBrains Mono,monospace}.chat-image{max-width:100%;max-height:300px;border-radius:6px;margin-top:6px;display:block;border:1px solid #30363d;cursor:pointer;transition:transform .2s}.chat-image:hover{transform:scale(1.02)}.chat-code-lang{font-size:10px;text-transform:uppercase;color:#8b949e;margin-bottom:4px;letter-spacing:.5px}.chat-code-block code{color:#e6edf3;white-space:pre}.chat-typing{color:#8b949e;font-size:13px}.chat-typing-dots span{animation:blink 1.4s infinite;font-size:18px;line-height:0;color:#8b949e}.chat-typing-dots span:nth-child(2){animation-delay:.2s}.chat-typing-dots span:nth-child(3){animation-delay:.4s}@keyframes blink{0%,20%{opacity:0}50%{opacity:1}to{opacity:1}}.chat-input-area{display:flex;align-items:center;gap:6px;padding:8px 12px;border-top:1px solid #30363d;background:#161b22;flex-shrink:0}.chat-input{flex:1;padding:8px 12px;font-size:13px;background:#0d1117;border:1px solid #30363d;border-radius:6px;color:#e6edf3;outline:none;font-family:inherit}.chat-input:focus{border-color:#58a6ff}.chat-input:disabled{opacity:.5}.chat-send-btn{padding:8px 16px;background:#238636;color:#fff;border:none;border-radius:6px;font-size:13px;font-weight:500;cursor:pointer;white-space:nowrap;transition:background .15s}.chat-send-btn:hover:not(:disabled){background:#2ea043}.chat-send-btn:disabled{opacity:.5;cursor:not-allowed}:root{--bg: #0e0f11;--bg-lighter: #131517;--bg-panel: #16181c;--bg-input: #1c1e22;--bg-hover: #1e2025;--bg-active: #1f2328;--border: #2b2d31;--border-light: #36383d;--text: #e4e5e7;--text-dim: #9ba0a6;--text-muted: #5e6167;--text-icon: #7c8087;--accent: #7c3aed;--accent-dim: #2e1a5e;--accent-light: #a78bfa;--green: #4ade80;--green-dim: #14532d;--red: #f87171;--yellow: #facc15;--term-bg: #0b0d0e;--scrollbar: #2b2d31;--font: "JetBrains Mono", "SF Mono", "Fira Code", "Cascadia Code", monospace;--font-ui: -apple-system, BlinkMacSystemFont, "Segoe UI", system-ui, sans-serif}.app{display:flex;flex-direction:column;height:100vh;width:100vw;overflow:hidden;background:var(--bg);color:var(--text);font-family:var(--font-ui);font-size:13px}.topbar{height:36px;min-height:36px;background:var(--bg);border-bottom:1px solid var(--border);display:flex;align-items:center;padding:0 8px;gap:4px;flex-shrink:0}.topbar-left{display:flex;align-items:center;gap:6px;flex:1;min-width:0}.topbar-left .brand{font-size:13px;font-weight:600;display:flex;align-items:center;gap:6px;padding:0 6px;color:var(--text)}.topbar-left .brand .logo{background:var(--accent);color:#fff;width:20px;height:20px;border-radius:5px;display:inline-flex;align-items:center;justify-content:center;font-size:10px;font-weight:700}.topbar-left .path{color:var(--text-muted);font-size:12px;margin-left:8px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.topbar-left .path span{color:var(--text-dim)}.topbar-save-indicator{color:#d29922;background:#d2992222;font-size:10px;padding:1px 6px;border-radius:3px;margin-left:8px}.topbar-save-indicator.saved{color:var(--green);background:var(--green-dim)}.topbar-right{display:flex;align-items:center;gap:4px;margin-left:auto;flex-shrink:0}.run-btn{background:var(--green);color:#000;border:none;border-radius:6px;padding:3px 12px 3px 8px;font-size:12px;font-weight:600;cursor:pointer;display:flex;align-items:center;gap:5px;height:24px}.run-btn:hover{opacity:.9}.run-btn svg{width:12px;height:12px;flex-shrink:0}.tb-btn{background:none;border:none;color:var(--text-muted);width:26px;height:26px;border-radius:5px;cursor:pointer;font-size:14px;display:flex;align-items:center;justify-content:center}.tb-btn:hover{background:var(--bg-hover);color:var(--text)}.tb-btn-small{background:none;border:none;color:var(--text-muted);width:22px;height:22px;border-radius:4px;cursor:pointer;font-size:14px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.tb-btn-small:hover{background:var(--bg-hover);color:var(--text)}.tb-sep{width:1px;height:18px;background:var(--border);flex-shrink:0}.main-row{flex:1;display:flex;min-height:0;overflow:hidden}.panel{display:flex;flex-direction:column;background:var(--bg-lighter);position:relative;overflow:hidden}.panel-header{display:flex;align-items:center;padding:6px 8px;border-bottom:1px solid var(--border);font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.5px;color:var(--text-muted);-webkit-user-select:none;user-select:none;min-height:30px;gap:6px;flex-shrink:0}.panel-header .dh{color:var(--text-muted);font-size:10px;opacity:.4}.panel-header .pt{flex:1;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.panel-header .pa{display:flex;gap:2px}.panel-header .pa button{background:none;border:none;color:var(--text-muted);width:20px;height:20px;border-radius:3px;cursor:pointer;font-size:12px;display:flex;align-items:center;justify-content:center;opacity:.5}.panel-header .pa button:hover{opacity:1;background:var(--bg-hover);color:var(--text)}.panel-body{flex:1;display:flex;flex-direction:column;min-height:0;overflow:hidden}.panel-left{border-right:1px solid var(--border);flex-shrink:0}.chat-top{padding:6px 10px;border-bottom:1px solid var(--border);display:flex;align-items:center;gap:6px}.chat-top .model-select{background:var(--bg-input);border:1px solid var(--border);border-radius:5px;color:var(--text);font-size:11px;padding:3px 6px;font-family:var(--font-ui);outline:none;flex:1;cursor:pointer;min-width:0}.chat-top .model-select:focus{border-color:var(--accent)}.chat-top .model-select option{background:var(--bg-lighter);color:var(--text)}.chat-top .status-dot{width:6px;height:6px;border-radius:50%;flex-shrink:0;background:var(--text-muted)}.chat-top .status-dot.online{background:var(--green)}.chat-msg-area{flex:1;overflow-y:auto;padding:10px;display:flex;flex-direction:column;gap:8px}.msg{display:flex;gap:7px;max-width:98%;animation:fadeIn .2s ease}@keyframes fadeIn{0%{opacity:0;transform:translateY(3px)}to{opacity:1;transform:translateY(0)}}.msg.user{flex-direction:row-reverse;align-self:flex-end}.msg .av{width:22px;height:22px;border-radius:5px;flex-shrink:0;display:flex;align-items:center;justify-content:center;font-size:10px;font-weight:700;margin-top:2px}.msg.assistant .av{background:var(--accent-dim);color:var(--accent-light)}.msg.user .av{background:#2d2f36;color:var(--text);font-size:8px}.msg .bubble{background:var(--bg-panel);border:1px solid var(--border);border-radius:7px;padding:6px 9px;font-size:12.5px;line-height:1.5;white-space:pre-wrap;word-break:break-word;color:var(--text-dim)}.msg.user .bubble{background:var(--accent-dim);border-color:var(--accent-dim);color:var(--text)}.msg .bubble code{background:#ffffff0f;padding:1px 4px;border-radius:3px;font-family:var(--font);font-size:11px}.msg .bubble pre{background:var(--bg);border:1px solid var(--border);border-radius:4px;padding:6px;margin:4px 0;overflow-x:auto;font-family:var(--font);font-size:11px;line-height:1.35}.typing-dots{display:flex;gap:3px;padding:2px 0}.typing-dots span{width:5px;height:5px;border-radius:50%;background:var(--text-muted);animation:pulse 1.4s ease-in-out infinite}.typing-dots span:nth-child(2){animation-delay:.2s}.typing-dots span:nth-child(3){animation-delay:.4s}@keyframes pulse{0%,80%,to{opacity:.2}40%{opacity:1}}.panel-center{flex:1;display:flex;flex-direction:column;min-width:0;background:var(--bg-panel)}.tool-tabs{display:flex;align-items:center;background:var(--bg);border-bottom:1px solid var(--border);padding:0 4px;height:32px;min-height:32px;gap:1px;overflow-x:auto;flex-shrink:0}.tool-tab{display:flex;align-items:center;gap:4px;padding:5px 9px;font-size:12px;color:var(--text-muted);cursor:pointer;border-bottom:2px solid transparent;white-space:nowrap;flex-shrink:0}.tool-tab .ti{font-size:13px}.tool-tab:hover{color:var(--text);background:var(--bg-hover)}.tool-tab.active{color:var(--text);border-bottom-color:var(--accent);background:var(--bg-panel)}.tool-sep{width:1px;height:18px;background:var(--border);padding:0;margin:0 4px;cursor:default;flex-shrink:0}.file-tabs{display:flex;align-items:center;background:var(--bg-lighter);border-bottom:1px solid var(--border);padding:0 6px;height:30px;min-height:30px;overflow-x:auto;flex-shrink:0;position:relative}.file-tab{display:flex;align-items:center;gap:5px;padding:4px 10px;font-size:11.5px;color:var(--text-muted);cursor:pointer;border-bottom:2px solid transparent;white-space:nowrap;flex-shrink:0;position:relative}.file-tab.active{color:var(--text);border-bottom-color:var(--accent);background:var(--bg-panel)}.file-tab:hover{color:var(--text)}.file-tab .close{font-size:12px;opacity:0;margin-left:2px;cursor:pointer}.file-tab:hover .close{opacity:.5}.file-tab .close:hover{opacity:1}.file-tab .dot{width:8px;height:8px;border-radius:2px;flex-shrink:0}.file-tab .dot.preview{background:var(--accent)}.file-tab .dot.file{background:#3b82f6}.file-tab.pinned .close,.file-tab.pinned:hover .close{display:none}.add-tab{font-size:16px;font-weight:600;padding:4px 8px;color:var(--text-muted);opacity:.6;cursor:pointer;flex-shrink:0}.add-tab:hover{opacity:1;color:var(--text)}.new-tab-menu{position:absolute;top:100%;right:0;background:var(--bg-lighter);border:1px solid var(--border);border-radius:8px;padding:6px;z-index:100;min-width:180px;box-shadow:0 8px 30px #0006}.new-tab-item{display:flex;align-items:center;gap:8px;padding:6px 10px;border-radius:5px;cursor:pointer;font-size:12px;color:var(--text-dim)}.new-tab-item:hover{background:var(--bg-hover);color:var(--text)}.new-tab-sep{height:1px;background:var(--border);margin:4px 0}.center-content{flex:1;display:flex;flex-direction:column;min-height:0;position:relative;overflow:hidden}.tool-view{flex:1;display:none;flex-direction:column;min-height:0;overflow-y:auto;padding:16px;gap:8px}.tool-view.active{display:flex}.editor-view{flex:1;display:none;min-height:0;overflow:hidden}.editor-view.active{display:flex;flex-direction:column}.editor-monaco-container{flex:1;overflow:hidden}.preview-view{flex:1;display:none;flex-direction:column;background:#0d1117;color:#e6edf3;overflow:hidden;border:1px solid #30363d;border-radius:8px;margin:0}.preview-view.active{display:flex}.preview-view .preview-iframe{width:100%;height:100%;border:none;background:#fff}.plc{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:400px;height:100%;width:100%;color:var(--text-muted);gap:8px;background:#0d1117;border-radius:0 0 8px 8px}.plc .big{font-size:40px;opacity:.3}.plc .txt{font-size:13px}.plc .sub{font-size:11px;opacity:.6}.deploy-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-top:16px}.deploy-card{background:var(--bg-panel);border:1px solid var(--border);border-radius:8px;padding:16px}.deploy-card .icon{font-size:24px;margin-bottom:8px}.deploy-card .title{font-weight:600;font-size:14px}.deploy-card .desc{font-size:11px;color:var(--text-muted);margin:6px 0 12px}.empty-state-card{background:var(--bg-panel);border:1px solid var(--border);border-radius:6px;padding:12px;color:var(--text-dim);font-size:12px;text-align:center}.settings-section{max-width:720px;margin:0 auto;width:100%}.settings-section h2{font-size:16px;font-weight:600;margin-bottom:4px;color:var(--text)}.settings-section .desc{font-size:12px;color:var(--text-muted);margin-bottom:16px}.settings-tab-bar{display:flex;gap:8px;border-bottom:1px solid var(--border);padding-bottom:8px;margin-bottom:16px}.models-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:12px}.model-list{display:flex;flex-direction:column;gap:8px}.model-card{background:var(--bg-panel);border:1px solid var(--border);border-radius:8px;padding:12px 14px;display:flex;align-items:center;gap:12px}.model-card:hover{border-color:var(--border-light)}.model-card .mc-icon{width:32px;height:32px;border-radius:6px;display:flex;align-items:center;justify-content:center;font-size:16px;flex-shrink:0}.model-card .mc-info{flex:1;min-width:0}.model-card .mc-name{font-weight:600;font-size:13px}.model-card .mc-provider{font-size:11px;color:var(--text-muted)}.model-card .mc-model{font-size:11px;color:var(--text-dim);font-family:var(--font)}.model-card .mc-tag{font-size:10px;padding:1px 6px;border-radius:4px;font-weight:500}.model-card .mc-tag.active{background:var(--green-dim);color:var(--green)}.model-card .mc-tag.inactive{background:#2d2f36;color:var(--text-muted)}.model-card .mc-actions{display:flex;gap:4px}.model-card .mc-actions button{background:none;border:1px solid var(--border);border-radius:5px;color:var(--text-muted);width:28px;height:28px;cursor:pointer;font-size:12px;display:flex;align-items:center;justify-content:center}.model-card .mc-actions button:hover{background:var(--bg-hover);color:var(--text);border-color:var(--accent)}.empty-state-model{text-align:center;padding:40px 20px;color:var(--text-muted)}.empty-state-model .big{font-size:36px;opacity:.3;margin-bottom:8px}.empty-state-model .txt{font-size:13px}.empty-state-model .sub{font-size:11px;opacity:.6;margin-top:4px}.form-group{margin-bottom:12px}.form-group label{display:block;font-size:11px;font-weight:500;color:var(--text-dim);margin-bottom:4px;text-transform:uppercase;letter-spacing:.3px}.form-input{width:100%;background:var(--bg-input);border:1px solid var(--border);border-radius:6px;padding:7px 10px;color:var(--text);font-size:12.5px;font-family:var(--font-ui);outline:none}.form-input:focus{border-color:var(--accent)}.form-input::placeholder{color:var(--text-muted)}.form-row{display:flex;gap:10px}.form-row .form-group{flex:1}select.form-input{cursor:pointer}select.form-input option{background:var(--bg-lighter);color:var(--text)}.btn{padding:6px 14px;border-radius:6px;font-size:12px;font-weight:500;cursor:pointer;border:none;display:inline-flex;align-items:center;gap:5px;font-family:var(--font-ui)}.btn-primary{background:var(--accent);color:#fff}.btn-primary:hover{opacity:.9}.btn-secondary{background:var(--bg-input);color:var(--text);border:1px solid var(--border)}.btn-secondary:hover{border-color:var(--accent)}.btn-sm{padding:4px 10px;font-size:11px}.btn-danger{background:var(--red);color:#fff}.btn-danger:hover{opacity:.9}.btn-full{width:100%;justify-content:center}.btn:disabled{opacity:.5;cursor:not-allowed}.modal-overlay{display:none;position:fixed;top:0;right:0;bottom:0;left:0;background:#00000080;z-index:200;align-items:center;justify-content:center}.modal-overlay.active{display:flex}.modal-dialog{background:var(--bg-lighter);border:1px solid var(--border);border-radius:12px;padding:20px;width:480px;max-width:90vw;max-height:80vh;overflow-y:auto;box-shadow:0 20px 60px #00000080}.modal-dialog h3{font-size:15px;margin-bottom:16px;display:flex;align-items:center;gap:8px}.modal-icon{font-size:20px}.modal-actions{display:flex;gap:8px;justify-content:flex-end;margin-top:16px}.panel-right{border-left:1px solid var(--border);flex-shrink:0}.file-tree{flex:1;overflow-y:auto;padding:4px 0}.file-tree-inner{min-height:100%}.file-item{padding:2px 10px;font-size:12.5px;cursor:pointer;color:var(--text-dim);display:flex;align-items:center;gap:5px;white-space:nowrap;line-height:26px}.file-item:hover{background:var(--bg-hover);color:var(--text)}.file-item .fi{font-size:14px;width:16px;text-align:center;flex-shrink:0}.file-item .nm{overflow:hidden;text-overflow:ellipsis;flex:1;min-width:0}.file-item.folder{color:var(--text)}.file-item .sp{width:14px;flex-shrink:0}.file-item.active{background:var(--accent-dim);color:var(--accent-light)}.file-tree-empty-msg{padding:16px;color:var(--text-muted);font-size:12px;text-align:center}.panel.collapsed{min-width:36px;width:36px!important;overflow:hidden}.panel.collapsed .panel-body{display:none}.panel.collapsed .panel-header{justify-content:center;padding:6px 4px}.panel.collapsed .panel-header .pt,.panel.collapsed .panel-header .dh{display:none}.panel.collapsed .pa button:not(.collapse-toggle){display:none}.resize-h{width:4px;cursor:ew-resize;background:transparent;flex-shrink:0;position:relative;z-index:20}.resize-h:hover,.resize-h:active{background:var(--accent)}.panel-bottom{border-top:1px solid var(--border);min-height:28px;display:flex;flex-direction:column;background:var(--term-bg);flex-shrink:0;overflow:hidden}.panel-bottom.collapsed{height:28px!important;min-height:28px}.panel-bottom.collapsed .console-body,.panel-bottom.collapsed .console-input-line{display:none}.console-tabs{display:flex;align-items:center;background:var(--bg);border-bottom:1px solid var(--border);padding:0 8px;height:28px;min-height:28px;flex-shrink:0}.console-tab{padding:4px 8px;font-size:11px;color:var(--text-muted);cursor:pointer;border-bottom:2px solid transparent;display:flex;align-items:center;gap:4px}.console-tab.active{color:var(--text);border-bottom-color:var(--accent)}.console-tab:hover{color:var(--text)}.console-actions{margin-left:auto;display:flex;gap:2px}.console-actions button{background:none;border:none;color:var(--text-muted);width:20px;height:20px;border-radius:3px;cursor:pointer;font-size:11px;display:flex;align-items:center;justify-content:center}.console-actions button:hover{background:var(--bg-hover);color:var(--text)}.console-body{flex:1;background:var(--term-bg);padding:6px 10px;font-family:var(--font);font-size:12.5px;line-height:1.4;overflow-y:auto;color:var(--text-dim)}.console-body .cl{white-space:pre-wrap;word-break:break-all;margin:1px 0}.console-body .cl.prompt{color:var(--green)}.console-body .cl.output{color:var(--text-dim)}.console-body .cl.err{color:var(--red)}.console-body .cl.info{color:#60a5fa}.console-input-line{display:flex;align-items:center;padding:2px 10px 6px;background:var(--term-bg);border-top:1px solid var(--border);flex-shrink:0}.console-input-line .ps{color:var(--green);font-family:var(--font);font-size:12.5px;margin-right:5px;flex-shrink:0}.console-input-line input{flex:1;background:transparent;border:none;color:var(--text-dim);font-family:var(--font);font-size:12.5px;outline:none}.console-input-line input::placeholder{color:var(--text-muted)}.console-tool-view{padding:0!important}.console-inline-tabs{display:flex;align-items:center;background:var(--bg);border-bottom:1px solid var(--border);padding:0 8px;height:28px;min-height:28px;flex-shrink:0}.console-inline-tab{padding:4px 8px;font-size:11px;color:var(--text-muted);cursor:pointer;border-bottom:2px solid transparent}.console-inline-tab.active{color:var(--text);border-bottom-color:var(--accent)}.console-inline-tab:hover{color:var(--text)}.console-body-inline{flex:1;background:var(--term-bg);padding:10px 14px;font-family:var(--font);font-size:13px;line-height:1.45;overflow-y:auto;color:var(--text-dim)}.console-body-inline .cl{white-space:pre-wrap;word-break:break-all;margin:1px 0}.console-body-inline .cl.prompt{color:var(--green)}.console-body-inline .cl.output{color:var(--text-dim)}.console-body-inline .cl.err{color:var(--red)}.console-body-inline .cl.info{color:#60a5fa}.console-input-inline{display:flex;align-items:center;padding:4px 14px 8px;background:var(--term-bg);border-top:1px solid var(--border);flex-shrink:0}.console-input-inline .ps{color:var(--green);font-family:var(--font);font-size:13px;margin-right:6px;flex-shrink:0}.console-input-inline input{flex:1;background:transparent;border:none;color:var(--text-dim);font-family:var(--font);font-size:13px;outline:none}.console-input-inline input::placeholder{color:var(--text-muted)}.git-tool-header{display:flex;align-items:center;gap:8px;margin-bottom:12px}.git-badge{display:inline-flex;align-items:center;gap:4px;font-size:11px;color:var(--text);padding:2px 8px;background:var(--bg-input);border-radius:4px;font-family:var(--font)}.git-changes-badge{color:var(--yellow);font-size:11px;font-weight:600}.git-file-item{padding:4px 8px;font-size:12px;color:var(--text-dim);font-family:var(--font);border-bottom:1px solid var(--border)}.git-tool-actions{margin-top:16px}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--scrollbar);border-radius:3px}::-webkit-scrollbar-thumb:hover{background:#3b3d41}.ide-container{height:100vh;display:flex;flex-direction:column;background:var(--bg);overflow:hidden}.ide-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;flex:1;gap:12px;color:var(--text-muted)}.ide-error{display:flex;flex-direction:column;align-items:center;justify-content:center;flex:1;color:var(--red);padding:40px}.chat-input-area textarea{flex:1;background:var(--bg-input);border:1px solid var(--border);border-radius:7px;padding:6px 9px;color:var(--text);font-size:12.5px;font-family:var(--font-ui);outline:none;resize:none;line-height:1.4;min-height:28px;max-height:100px}.chat-input-area textarea:focus{border-color:var(--accent)}.chat-input-area textarea::placeholder{color:var(--text-muted)}.chat-input-area .send-btn{background:var(--accent);border:none;border-radius:7px;width:30px;height:30px;display:flex;align-items:center;justify-content:center;cursor:pointer;color:#fff;font-size:14px;flex-shrink:0}.chat-input-area .send-btn:hover{opacity:.9}.chat-input-area .send-btn:disabled{opacity:.5;cursor:not-allowed}.chat-input-area{padding:7px 8px 8px;border-top:1px solid var(--border);display:flex;gap:5px;align-items:flex-end}.bottom-chat-panel{flex:1;display:flex;flex-direction:column;overflow:hidden;background:var(--bg)}.bottom-chat-panel .chat-msg-area{flex:1;overflow-y:auto;padding:8px 10px;display:flex;flex-direction:column;gap:6px;max-height:calc(100% - 48px)}.bottom-chat-panel .chat-msg-area .msg{max-width:100%}.bottom-chat-panel .chat-msg-area .msg .bubble{font-size:12px;line-height:1.45;padding:5px 8px}.bottom-chat-panel .chat-input-area{border-top:1px solid var(--border);padding:5px 8px 6px;display:flex;gap:4px;align-items:flex-end;flex-shrink:0}.bottom-chat-panel .chat-input-area textarea{flex:1;background:var(--bg-input);border:1px solid var(--border);border-radius:5px;color:var(--text);font-size:12px;padding:5px 8px;font-family:var(--font-ui);resize:none;outline:none;min-height:26px;max-height:80px;line-height:1.3}.bottom-chat-panel .chat-input-area textarea:focus{border-color:var(--accent)}.bottom-chat-panel .chat-input-area .send-btn{background:var(--accent);color:#fff;border:none;border-radius:5px;width:28px;height:28px;font-size:14px;cursor:pointer;flex-shrink:0;display:flex;align-items:center;justify-content:center;transition:background .15s}.bottom-chat-panel .chat-input-area .send-btn:hover:not(:disabled){background:var(--accent-hover)}.bottom-chat-panel .chat-input-area .send-btn:disabled{opacity:.4;cursor:not-allowed}.drag-ghost{position:fixed;pointer-events:none;z-index:9999;background:var(--bg-lighter);border:1px solid var(--accent);border-radius:6px;padding:6px 14px;font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.5px;color:var(--accent-light);opacity:.9;box-shadow:0 4px 20px #0006;display:none}
