.oracle-chat{display:flex;flex-direction:column;height:100%;min-height:0}.oracle-messages{flex:1;overflow-y:auto;padding:12px 16px;display:flex;flex-direction:column;gap:12px;min-height:0}.oracle-msg{display:flex;flex-direction:column;gap:4px;max-width:90%}.oracle-msg-user{align-self:flex-end;align-items:flex-end}.oracle-msg-assistant{align-self:flex-start;align-items:flex-start}.oracle-badge{font-size:10px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--accent);padding:1px 6px;background:var(--accent-dim);border-radius:3px}.oracle-msg-text{background:var(--surface-hover);border:1px solid var(--border);border-radius:8px;padding:10px 13px;font-size:13px;line-height:1.55;color:var(--text);white-space:pre-wrap;word-break:break-word}.oracle-msg-user .oracle-msg-text{background:var(--accent-dim);border-color:transparent}.oracle-cursor{display:inline-block;width:2px;height:13px;background:var(--accent);border-radius:1px;margin-left:2px;vertical-align:text-bottom;animation:oracle-blink .9s steps(2) infinite}@keyframes oracle-blink{0%,to{opacity:1}50%{opacity:0}}.oracle-dots:before{content:"● ● ●";color:var(--text-muted);font-size:10px;letter-spacing:4px;animation:oracle-pulse 1.4s ease infinite}@keyframes oracle-pulse{0%,to{opacity:.3}50%{opacity:1}}.oracle-thinking .oracle-msg-text{padding:8px 13px}.oracle-error{font-size:12px;color:var(--error);padding:8px 12px;background:var(--error-dim);border-radius:6px}.oracle-starters{display:flex;flex-wrap:wrap;gap:7px;padding:4px 0 8px}.oracle-starter-chip{background:var(--bg);border:1px solid var(--border);border-radius:14px;padding:5px 12px;font-size:12px;color:var(--text-muted);cursor:pointer;font-family:inherit;transition:border-color var(--ease),color var(--ease),background var(--ease);text-align:left}.oracle-starter-chip:hover{border-color:var(--accent);color:var(--text);background:var(--accent-dim)}.oracle-resume-banner{display:flex;align-items:center;justify-content:space-between;gap:10px;background:var(--accent-dim);border:1px solid rgba(56,189,248,.2);border-radius:6px;padding:7px 11px;font-size:12px;color:var(--accent);margin-bottom:4px}.oracle-resume-clear{background:none;border:none;cursor:pointer;font-size:11px;color:var(--accent);font-family:inherit;text-decoration:underline;padding:0;flex-shrink:0}.oracle-resume-clear:hover{opacity:.7}.oracle-actions{padding:6px 16px 4px;display:flex;justify-content:flex-end;gap:4px}.oracle-restart-btn{font-size:12px;padding:5px 10px;color:var(--text-muted);margin-right:auto}.oracle-synthesize-btn{font-size:12px;padding:5px 12px;color:var(--accent)}.oracle-input-area{display:flex;gap:8px;padding:10px 16px 14px;border-top:1px solid var(--border);align-items:flex-end}.oracle-textarea{flex:1;background:var(--bg);border:1px solid var(--border);border-radius:var(--radius);padding:8px 11px;color:var(--text);font-family:var(--font-sans);font-size:13px;resize:none;outline:none;transition:border-color var(--ease),box-shadow var(--ease);min-height:52px}.oracle-textarea:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-dim)}.oracle-textarea::placeholder{color:var(--text-muted);opacity:.5}.oracle-send-btn{padding:8px 14px;flex-shrink:0}.oracle-artifact-card{background:var(--surface-hover);border:1px solid var(--accent);border-radius:8px;padding:12px 14px;display:flex;flex-direction:column;gap:8px;max-width:420px}.oracle-artifact-header{display:flex;align-items:center;gap:7px}.oracle-artifact-check{color:var(--accent);font-size:14px;font-weight:700}.oracle-artifact-title{font-size:14px;font-weight:600;color:var(--text)}.oracle-artifact-desc{font-size:12px;color:var(--text-muted);line-height:1.4}.oracle-artifact-tasks{list-style:none;padding:8px 0 0;margin:0;display:flex;flex-direction:column;gap:4px;border-top:1px solid var(--border)}.oracle-artifact-tasks li{display:flex;gap:6px;font-size:12px;color:var(--text-muted);line-height:1.4}.oracle-artifact-num{color:var(--accent);font-weight:600;flex-shrink:0}.oracle-artifact-building{font-style:italic;color:var(--text-muted)}.oracle-dots-inline:after{content:"";display:inline-block;animation:oracle-dots-anim 1.2s steps(4,end) infinite}@keyframes oracle-dots-anim{0%{content:""}25%{content:"."}50%{content:".."}75%{content:"..."}to{content:""}}.new-app-card{width:420px}.new-app-card-oracle{width:580px;max-height:88vh;display:flex;flex-direction:column}.new-app-tabs{display:flex;gap:2px;margin-bottom:20px;background:var(--bg);border-radius:var(--radius);padding:3px}.new-app-tab{flex:1;padding:7px 12px;border:none;background:transparent;color:var(--text-muted);font-size:12px;font-weight:600;border-radius:5px;cursor:pointer;transition:background var(--ease),color var(--ease)}.new-app-tab:hover{color:var(--text)}.new-app-tab.active{background:var(--surface-hover);color:var(--text)}.new-app-tab:disabled{opacity:.4;cursor:default}.new-app-error{margin-bottom:14px}.oracle-wrapper{display:flex;flex-direction:column;flex:1;min-height:0;overflow:hidden}.oracle-wrapper .oracle-chat{flex:1;min-height:0;max-height:440px;border:1px solid var(--border);border-radius:var(--radius);overflow:hidden}.new-app-actions-oracle{margin-top:12px}.oracle-confirm{display:flex;flex-direction:column;gap:0}.oracle-confirm-header{display:flex;align-items:center;gap:8px;font-size:13px;font-weight:600;color:var(--text);margin-bottom:14px}.oracle-confirm-check{display:flex;align-items:center;justify-content:center;width:20px;height:20px;background:var(--success);color:#000;border-radius:50%;font-size:11px;font-weight:800;flex-shrink:0}.oracle-plan-preview{background:var(--bg);border:1px solid var(--border);border-radius:var(--radius);padding:12px 14px;margin-bottom:18px;max-height:200px;overflow-y:auto}.oracle-plan-preview-label{font-size:10px;font-weight:700;color:var(--accent);letter-spacing:.07em;text-transform:uppercase;margin-bottom:8px}.oracle-plan-tasks{list-style:none;display:flex;flex-direction:column;gap:5px}.oracle-plan-tasks li{font-size:12px;color:var(--text-muted);display:flex;gap:7px;align-items:flex-start}.oracle-task-check{font-family:var(--font-mono);font-size:11px;color:var(--border-hover);flex-shrink:0;margin-top:1px}.oracle-open-questions{margin-top:12px;border-top:1px solid var(--border);padding-top:10px}.oracle-open-questions ul{list-style:none;display:flex;flex-direction:column;gap:4px}.oracle-open-questions li{font-size:12px;color:var(--text-muted)}.new-app-title{font-size:17px;font-weight:600;color:var(--text);margin:0 0 24px}.new-app-desc{resize:vertical;min-height:72px;font-family:inherit}.optional{font-size:11px;color:var(--text-muted);font-weight:400}.new-app-actions{display:flex;justify-content:flex-end;gap:8px;margin-top:20px}.framework-select{display:flex;gap:8px;margin-top:4px}.framework-option{flex:1;display:flex;align-items:center;gap:8px;padding:10px 12px;border:1px solid var(--border);border-radius:6px;cursor:pointer;background:var(--surface);transition:border-color .15s,background .15s;font-size:13px;color:var(--text)}.framework-option:hover{border-color:var(--accent)}.framework-option.selected{border-color:var(--accent);background:var(--accent-muted, color-mix(in srgb, var(--accent) 10%, transparent))}.framework-option input[type=radio]{accent-color:var(--accent)}.oracle-done-note{font-size:13px;color:var(--text-muted);line-height:1.55;margin:0 0 4px}.llm-modal{width:520px;max-height:80vh;overflow-y:auto;display:flex;flex-direction:column;gap:0}.llm-modal-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:20px}.llm-modal-title{font-size:17px;font-weight:600;color:var(--text);margin:0}.llm-loading{color:var(--text-muted);font-size:13px;padding:16px 0}.llm-list{display:flex;flex-direction:column;gap:4px;margin-bottom:12px}.llm-row{display:flex;flex-direction:column;gap:10px;padding:12px;border-radius:var(--radius);background:var(--bg);border:1px solid var(--border)}.llm-row-default{border-color:var(--accent)}.llm-row-header{display:flex;flex-direction:column;gap:4px}.llm-row-title{display:flex;align-items:center;gap:6px;flex-wrap:wrap}.llm-row-provider{font-size:13px;font-weight:600;color:var(--text)}.llm-row-meta{display:flex;align-items:center;gap:6px;overflow:hidden}.llm-row-model{font-size:12px;color:var(--accent);font-family:var(--font-mono);white-space:nowrap}.llm-meta-sep{font-size:11px;color:var(--text-muted);opacity:.5;flex-shrink:0}.llm-row-url,.llm-row-key{font-size:11px;color:var(--text-muted);font-family:var(--font-mono);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.llm-row-actions{display:flex;align-items:center;justify-content:space-between;gap:8px;padding-top:8px;border-top:1px solid var(--border)}.llm-role-btns{display:flex;align-items:center;gap:4px;flex-wrap:wrap}.llm-edit-btns{display:flex;align-items:center;gap:4px;flex-shrink:0}.llm-action-btn{font-size:11px;font-weight:600;padding:3px 9px;border-radius:var(--radius);border:1px solid var(--border);background:none;color:var(--text-muted);cursor:pointer;transition:color var(--ease),border-color var(--ease),background var(--ease);white-space:nowrap}.llm-action-btn:hover:not(:disabled){color:var(--text);background:var(--surface-hover)}.llm-action-btn:disabled{cursor:default;opacity:.7}.llm-action-btn-default-active{color:var(--accent);border-color:color-mix(in srgb,var(--accent) 40%,transparent)}.llm-action-btn-reviewer-active{color:#a78bfa;border-color:color-mix(in srgb,#a78bfa 40%,transparent)}.llm-action-btn-planner-active{color:#60a5fa;border-color:color-mix(in srgb,#60a5fa 40%,transparent)}.llm-action-btn-coder-active{color:#34d399;border-color:color-mix(in srgb,#34d399 40%,transparent)}.llm-action-btn-imagegen-active{color:#f97316;border-color:color-mix(in srgb,#f97316 40%,transparent)}.llm-edit-btn,.llm-delete-btn{font-size:12px;padding:3px 10px}.llm-delete-btn{color:var(--error)}.llm-add-btn{font-size:13px;padding:7px 12px;border:1px dashed var(--border);border-radius:var(--radius);width:100%;justify-content:center}.llm-delete-error{margin-bottom:8px}.llm-edit-panel{margin-top:16px;padding-top:16px;border-top:1px solid var(--border);display:flex;flex-direction:column;gap:14px}.llm-edit-title{font-size:14px;font-weight:600;color:var(--text);margin:0}.llm-key-row{display:flex;gap:8px}.llm-key-row .form-input{flex:1}.llm-load-btn{font-size:12px;padding:0 12px;flex-shrink:0;border:1px solid var(--border)}.llm-model-list{display:flex;flex-direction:column;gap:2px;max-height:180px;overflow-y:auto;border:1px solid var(--border);border-radius:var(--radius)}.llm-model-item{display:flex;align-items:center;justify-content:space-between;padding:7px 10px;background:none;border:none;text-align:left;cursor:pointer;color:var(--text-muted);transition:background var(--ease),color var(--ease);font-size:13px}.llm-model-item:hover,.llm-model-item.active{background:var(--surface-hover);color:var(--text)}.llm-model-item.active{color:var(--accent)}.llm-model-name{font-family:var(--font-mono)}.llm-model-size{font-size:11px;color:var(--text-muted);opacity:.7}.llm-default-check{display:flex;align-items:center;gap:8px;font-size:13px;color:var(--text-muted);cursor:pointer}.llm-edit-actions{display:flex;justify-content:flex-end;gap:8px}.llm-grok-hint{font-size:12px;color:var(--text-muted);background:var(--bg);border:1px solid var(--border);border-radius:var(--radius);padding:8px 12px;line-height:1.5;margin:0}.llm-grok-hint strong{color:var(--text);font-family:var(--font-mono);font-size:11px}.llm-row-reviewer{border-color:color-mix(in srgb,#a78bfa 50%,transparent)}.llm-row-planner{border-color:color-mix(in srgb,#60a5fa 50%,transparent)}.llm-row-coder{border-color:color-mix(in srgb,#34d399 50%,transparent)}.llm-row-imagegen{border-color:color-mix(in srgb,#f97316 50%,transparent)}.llm-role-badge{font-size:10px;font-weight:600;padding:1px 6px;border-radius:10px;text-transform:uppercase;letter-spacing:.04em}.llm-default-badge{background:color-mix(in srgb,var(--accent) 15%,transparent);color:var(--accent);border:1px solid color-mix(in srgb,var(--accent) 30%,transparent)}.llm-reviewer-badge{background:color-mix(in srgb,#a78bfa 15%,transparent);color:#a78bfa;border:1px solid color-mix(in srgb,#a78bfa 30%,transparent)}.llm-planner-badge{background:color-mix(in srgb,#60a5fa 15%,transparent);color:#60a5fa;border:1px solid color-mix(in srgb,#60a5fa 30%,transparent)}.llm-coder-badge{background:color-mix(in srgb,#34d399 15%,transparent);color:#34d399;border:1px solid color-mix(in srgb,#34d399 30%,transparent)}.llm-imagegen-badge{background:color-mix(in srgb,#f97316 15%,transparent);color:#f97316;border:1px solid color-mix(in srgb,#f97316 30%,transparent)}.llm-imagegen-hint{font-size:12px;color:var(--text-muted);margin:6px 0 8px;padding:0 2px;line-height:1.5}.llm-row-issue{border-color:color-mix(in srgb,#f59e0b 45%,transparent)}.llm-issue-badge{font-size:10px;font-weight:600;padding:1px 6px;border-radius:10px;background:color-mix(in srgb,#f59e0b 15%,transparent);color:#f59e0b;border:1px solid color-mix(in srgb,#f59e0b 30%,transparent);cursor:default}.llm-row-url-default{color:var(--accent);font-style:italic}.llm-model-switch-warning{background:color-mix(in srgb,#f59e0b 8%,transparent);border:1px solid color-mix(in srgb,#f59e0b 25%,transparent);border-radius:6px;padding:8px 12px;font-size:13px;color:#b45309;margin-bottom:12px;line-height:1.5}.llm-health-warning{background:color-mix(in srgb,#f59e0b 10%,transparent);border:1px solid color-mix(in srgb,#f59e0b 30%,transparent);border-radius:6px;padding:8px 12px;font-size:13px;color:#d97706;margin-bottom:12px;line-height:1.5}.agent-upgrade-card{width:360px;text-align:center}.agent-upgrade-icon{font-size:32px;margin-bottom:12px}.agent-upgrade-title{font-size:16px;font-weight:700;color:var(--text);margin:0 0 10px}.agent-upgrade-body{font-size:13px;color:var(--text-muted);line-height:1.6;margin:0 0 20px}.agent-upgrade-actions{display:flex;flex-direction:column;gap:8px}.agent-upgrade-btn{width:100%;justify-content:center;padding:10px;font-size:14px}.us-modal{width:520px;max-height:80vh;overflow-y:auto;display:flex;flex-direction:column;gap:0}.us-modal-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:20px}.us-modal-title{font-size:17px;font-weight:600;color:var(--text);margin:0}.us-close-btn{font-size:14px;padding:4px 8px;color:var(--text-muted)}.us-error{margin-bottom:12px}.us-section{display:flex;flex-direction:column;gap:16px}.us-row{display:flex;align-items:flex-start;justify-content:space-between;gap:16px;padding:14px 0;border-bottom:1px solid var(--border)}.us-row:last-child{border-bottom:none}.us-disabled{opacity:.45;pointer-events:none}.us-row-info{display:flex;flex-direction:column;gap:4px;flex:1;min-width:0}.us-row-label{font-size:14px;font-weight:600;color:var(--text)}.us-row-desc{font-size:12px;color:var(--text-muted);line-height:1.5}.us-toggle{position:relative;width:40px;height:22px;border-radius:11px;background:var(--border);border:none;cursor:pointer;flex-shrink:0;transition:background .2s;padding:0;margin-top:2px}.us-toggle:disabled{opacity:.5;cursor:not-allowed}.us-toggle-on{background:var(--accent)}.us-toggle-thumb{position:absolute;top:3px;left:3px;width:16px;height:16px;border-radius:50%;background:#fff;transition:transform .2s}.us-toggle-on .us-toggle-thumb{transform:translate(18px)}.us-verbosity-row{flex-direction:column;align-items:stretch}.us-verbosity-options{display:flex;flex-direction:column;gap:6px;margin-top:8px}.us-verbosity-option{display:flex;align-items:flex-start;gap:10px;padding:10px 12px;border-radius:var(--radius);border:1px solid var(--border);cursor:pointer;transition:border-color var(--ease),background var(--ease)}.us-verbosity-option input[type=radio]{margin-top:2px;flex-shrink:0;accent-color:var(--accent)}.us-verbosity-selected{border-color:var(--accent);background:color-mix(in srgb,var(--accent) 8%,var(--surface))}.us-verbosity-label{font-size:13px;font-weight:600;color:var(--text);flex-shrink:0;min-width:70px}.us-verbosity-desc{font-size:12px;color:var(--text-muted);line-height:1.4}.us-saving{font-size:12px;color:var(--text-muted);text-align:right;margin-top:8px}.us-agent-reqs{background:color-mix(in srgb,var(--surface) 60%,var(--border) 40%);border:1px solid var(--border);border-radius:var(--radius);padding:12px 14px;display:flex;flex-direction:column;gap:10px;margin-bottom:4px}.us-req-title{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:var(--text-muted)}.us-req-row{display:flex;align-items:center;gap:10px}.us-req-icon{font-size:13px;font-weight:700;width:16px;flex-shrink:0;text-align:center}.us-req-ok .us-req-icon{color:#22c55e}.us-req-error .us-req-icon{color:#ef4444}.us-req-warn .us-req-icon{color:var(--text-muted)}.us-req-info{flex:1;min-width:0;display:flex;flex-direction:column;gap:1px}.us-req-label{font-size:12px;font-weight:600;color:var(--text)}.us-req-detail{font-size:11px;color:var(--text-muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.us-req-error .us-req-detail{color:#ef4444}.us-req-btn{font-size:12px;padding:3px 8px;flex-shrink:0;color:var(--accent)}.support-chat{display:flex;flex-direction:column;height:100%;min-height:0}.support-messages{flex:1;overflow-y:auto;padding:16px 20px;display:flex;flex-direction:column;gap:10px;min-height:0}.support-intro{display:flex;flex-direction:column;gap:12px;padding:8px 0}.support-intro-text{font-size:13px;color:var(--text-muted);margin:0}.support-starters{display:flex;flex-wrap:wrap;gap:7px}.support-starter-chip{background:var(--bg);border:1px solid var(--border);border-radius:14px;padding:5px 12px;font-size:12px;color:var(--text-muted);cursor:pointer;font-family:inherit;transition:border-color var(--ease),color var(--ease),background var(--ease);text-align:left}.support-starter-chip:hover{border-color:var(--accent);color:var(--text);background:var(--accent-dim)}.support-msg{display:flex;flex-direction:column;max-width:90%}.support-msg-user{align-self:flex-end;align-items:flex-end}.support-msg-assistant{align-self:flex-start;align-items:flex-start}.support-msg-text{background:var(--surface-hover);border:1px solid var(--border);border-radius:8px;padding:10px 13px;font-size:13px;line-height:1.55;color:var(--text);white-space:pre-wrap;word-break:break-word}.support-msg-user .support-msg-text{background:var(--accent-dim);border-color:transparent}.support-cursor{display:inline-block;width:2px;height:13px;background:var(--accent);border-radius:1px;margin-left:2px;vertical-align:text-bottom;animation:support-blink .9s steps(2) infinite}@keyframes support-blink{0%,to{opacity:1}50%{opacity:0}}.support-dots:before{content:"● ● ●";color:var(--text-muted);font-size:10px;letter-spacing:4px;animation:support-pulse 1.4s ease infinite}@keyframes support-pulse{0%,to{opacity:.3}50%{opacity:1}}.support-thinking .support-msg-text{padding:8px 13px}.support-error{font-size:12px;color:var(--error);padding:8px 12px;background:var(--error-dim);border-radius:6px}.support-actions{padding:4px 16px;display:flex}.support-clear-btn{font-size:12px;padding:4px 10px;color:var(--text-muted)}.support-input-area{display:flex;gap:8px;padding:10px 16px 14px;border-top:1px solid var(--border);align-items:flex-end}.support-textarea{flex:1;background:var(--bg);border:1px solid var(--border);border-radius:var(--radius);padding:8px 11px;color:var(--text);font-family:var(--font-sans);font-size:13px;resize:none;outline:none;transition:border-color var(--ease),box-shadow var(--ease);min-height:52px}.support-textarea:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-dim)}.support-textarea::placeholder{color:var(--text-muted);opacity:.5}.support-textarea:disabled{opacity:.6}.support-send-btn{padding:8px 14px;flex-shrink:0}.help-modal-card{background:var(--surface);border:1px solid var(--border);border-radius:12px;box-shadow:0 24px 60px #0009;animation:slideUp .18s ease;display:flex;width:760px;max-width:calc(100vw - 32px);height:580px;max-height:calc(100vh - 80px);overflow:hidden}.help-sidebar{width:180px;flex-shrink:0;border-right:1px solid var(--border);display:flex;flex-direction:column;padding:20px 0 16px}.help-sidebar-title{font-size:11px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--text-muted);padding:0 16px 12px}.help-nav-item{background:none;border:none;text-align:left;padding:8px 16px;font-size:13px;color:var(--text-muted);cursor:pointer;transition:background var(--ease),color var(--ease);border-left:2px solid transparent}.help-nav-item:hover{background:var(--surface-hover);color:var(--text)}.help-nav-item.active{color:var(--text);border-left-color:var(--accent);background:var(--surface-hover)}.help-content{flex:1;overflow-y:auto;padding:28px 32px;position:relative}.help-close{position:absolute;top:16px;right:16px;background:none;border:none;color:var(--text-muted);font-size:14px;cursor:pointer;padding:4px 6px;border-radius:4px;transition:background var(--ease),color var(--ease)}.help-close:hover{background:var(--surface-hover);color:var(--text)}.help-content--chat{display:flex;flex-direction:column;overflow:hidden;padding:0}.help-content--chat .help-close{position:absolute;top:8px;right:8px;z-index:1}.help-section h2{font-size:17px;font-weight:700;color:var(--text);margin:0 0 14px}.help-section h3{font-size:13px;font-weight:600;color:var(--text);margin:20px 0 6px}.help-section p{font-size:13px;line-height:1.65;color:var(--text-muted);margin:0 0 10px}.help-section ul,.help-section ol{font-size:13px;line-height:1.65;color:var(--text-muted);margin:0 0 10px;padding-left:20px}.help-section li{margin-bottom:4px}.help-section code{font-family:monospace;font-size:12px;background:#ffffff0f;border:1px solid var(--border);border-radius:3px;padding:1px 5px;color:var(--text)}.help-pipeline{margin:16px 0}.help-pipeline-step{background:#ffffff08;border:1px solid var(--border);border-radius:8px;padding:12px 16px}.help-pipeline-step p{margin:6px 0 0}.help-pipeline-arrow{text-align:center;color:var(--text-muted);font-size:16px;line-height:1.4;margin:2px 0}.help-phase-label{display:inline-block;font-size:11px;font-weight:700;letter-spacing:.05em;text-transform:uppercase;color:var(--accent);background:#6366f11f;border:1px solid rgba(99,102,241,.25);border-radius:4px;padding:2px 7px}.upgrade-modal{width:480px;max-width:95vw}.upgrade-modal-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:20px}.upgrade-modal-title{font-size:16px;font-weight:700;color:var(--text);margin:0}.upgrade-error{margin-bottom:12px}.upgrade-trial-notice{background:#63b6ff1a;border:1px solid rgba(99,182,255,.25);border-radius:var(--radius);padding:8px 12px;font-size:12px;color:var(--accent);margin-bottom:16px;text-align:center}.upgrade-trial-expired{background:#f871711a;border-color:#f8717140;color:var(--error)}.upgrade-plans{display:flex;flex-direction:column;gap:12px;margin-bottom:16px}.upgrade-plan-card{border:1px solid var(--border);border-radius:var(--radius);padding:16px;transition:border-color var(--ease)}.upgrade-plan-card.upgrade-plan-active{border-color:var(--accent)}.upgrade-plan-header{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:10px;gap:8px}.upgrade-plan-name{font-size:14px;font-weight:600;color:var(--text);margin-bottom:2px}.upgrade-plan-price{font-size:18px;font-weight:700;color:var(--accent)}.upgrade-plan-period{font-size:12px;font-weight:400;color:var(--text-muted)}.upgrade-plan-yearly{font-size:11px;color:var(--text-muted);margin-top:2px}.upgrade-plan-savings{color:#34d399;font-weight:600}.upgrade-plan-badge{font-size:10px;font-weight:600;text-transform:uppercase;letter-spacing:.06em;color:var(--accent);background:#63b6ff1f;border:1px solid rgba(99,182,255,.3);border-radius:4px;padding:2px 7px;flex-shrink:0;margin-top:2px}.upgrade-plan-features{list-style:none;display:flex;flex-direction:column;gap:5px;margin:0 0 14px;padding:0}.upgrade-plan-features li{font-size:12px;color:var(--text-muted);padding-left:14px;position:relative}.upgrade-plan-features li:before{content:"▸";color:var(--accent);position:absolute;left:0}.upgrade-plan-btn{width:100%;justify-content:center;font-size:13px;padding:8px}.upgrade-footer{font-size:11px;color:var(--text-muted);text-align:center;margin:0}.header{height:var(--header-h);background:var(--surface);border-bottom:1px solid var(--border);display:flex;align-items:center;padding:0 16px;gap:10px;flex-shrink:0;position:relative;z-index:10}.header-logo{display:flex;align-items:center;gap:8px;text-decoration:none;flex-shrink:0}.header-logo-icon{width:28px;height:28px;border-radius:6px;display:flex;align-items:center;justify-content:center;flex-shrink:0;overflow:hidden}.header-logo-icon img{width:100%;height:100%;object-fit:cover}.header-logo-text{font-size:15px;font-weight:700;color:var(--text);letter-spacing:-.01em}.header-app-area{display:flex;align-items:center;gap:6px;margin-left:8px}.header-app-btn{font-size:13px;padding:5px 10px}.header-app-btn:disabled{opacity:.3;cursor:default}.app-selector-wrap{position:relative}.header-app-btn{display:flex;align-items:center;gap:6px}.app-selector-name{max-width:140px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.app-dropdown{position:absolute;top:calc(100% + 6px);left:0;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);min-width:200px;max-height:260px;overflow-y:auto;box-shadow:var(--shadow-sm);z-index:100}.app-dropdown-empty{padding:12px 14px;color:var(--text-muted);font-size:12px}.app-dropdown-item{display:flex;align-items:center;gap:8px;width:100%;padding:9px 14px;background:none;border:none;color:var(--text-muted);cursor:pointer;font-size:13px;text-align:left;transition:background var(--ease),color var(--ease)}.app-dropdown-item:hover,.app-dropdown-item.active{background:var(--surface-hover);color:var(--text)}.app-dropdown-name{flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.app-dropdown-port{font-size:11px;color:var(--text-muted);opacity:.6}.app-dropdown-item.locked{opacity:.45;cursor:not-allowed}.app-dropdown-item.locked:hover{background:none;color:var(--text-muted)}.app-dropdown-lock{font-size:11px;opacity:.7}.header-spacer{flex:1}.header-actions{display:flex;align-items:center;gap:8px}.btn-icon-label{font-size:12px;padding:5px 10px}.btn-icon-label:disabled{opacity:.3;cursor:default}.user-menu-wrap{position:relative}.user-btn{display:flex;align-items:center;gap:7px;font-size:13px;padding:4px 10px}.user-avatar{width:22px;height:22px;background:linear-gradient(135deg,var(--accent),#818cf8);border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:700;color:#0f172a;flex-shrink:0}.user-email{max-width:160px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.user-dropdown{position:absolute;top:calc(100% + 6px);right:0;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);min-width:140px;box-shadow:var(--shadow-sm);overflow:hidden;z-index:100}.user-dropdown-item{display:block;width:100%;padding:9px 14px;text-align:left;background:none;border:none;color:var(--text-muted);cursor:pointer;transition:background var(--ease),color var(--ease);font-size:13px}.user-dropdown-item:hover{background:var(--surface-hover);color:var(--text)}.user-dropdown-plan{display:flex;align-items:center;justify-content:space-between;padding:8px 14px 6px;border-bottom:1px solid var(--border);gap:8px}.user-plan-label{font-size:11px;color:var(--text-muted);font-weight:500}.user-plan-upgrade-link{background:none;border:none;font-size:11px;color:var(--accent);cursor:pointer;padding:0;font-weight:500}.user-plan-upgrade-link:hover{opacity:.8}.header-upgrade-btn{font-size:12px;padding:5px 10px}.theme-toggle-btn{font-size:15px;padding:5px 8px;border-color:transparent}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:var(--overlay-bg);-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:1000;animation:fadeIn .12s ease}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.modal-card{background:var(--surface);border:1px solid var(--border);border-radius:12px;padding:32px;width:380px;box-shadow:var(--shadow-lg);animation:slideUp .18s ease}@keyframes slideUp{0%{transform:translateY(12px);opacity:0}to{transform:translateY(0);opacity:1}}.modal-tabs{display:flex;border-bottom:1px solid var(--border);margin-bottom:28px}.modal-tab{background:none;border:none;border-bottom:2px solid transparent;margin-bottom:-1px;padding:8px 0;margin-right:22px;color:var(--text-muted);font-size:14px;font-weight:500;cursor:pointer;transition:color var(--ease),border-color var(--ease)}.modal-tab.active{color:var(--text);border-bottom-color:var(--accent)}.modal-tab:hover:not(.active){color:var(--text)}.modal-submit{width:100%;padding:10px;font-size:14px;font-weight:600;justify-content:center;margin-top:4px}.ollama-warning-bar{position:fixed;top:var(--header-h);left:0;right:0;z-index:200;display:flex;align-items:center;gap:8px;padding:7px 16px;background:#7a4f00;color:#ffe8a0;font-size:13px;border-bottom:1px solid #a06800}.ollama-warning-icon{flex-shrink:0;font-size:15px}.ollama-warning-text{flex:1;min-width:0}.ollama-warning-link{flex-shrink:0;font-size:12px;padding:3px 10px;border-color:#ffe8a0;color:#ffe8a0}.ollama-warning-link:hover{background:#ffe8a026}.ollama-warning-dismiss{flex-shrink:0;font-size:12px;padding:3px 7px;color:#ffe8a0;border-color:transparent;opacity:.7}.ollama-warning-dismiss:hover{opacity:1}.agent-phase-badge{display:inline-flex;align-items:center;gap:6px;padding:3px 10px;border-radius:20px;background:var(--surface);border:1px solid var(--border);font-size:12px;color:var(--text-muted);margin:2px 0}.agent-phase-icon{color:var(--accent);font-size:10px}.agent-phase-label{font-weight:500;color:var(--text)}.agent-phase-iter{font-size:11px;color:var(--text-muted);background:var(--bg);padding:1px 6px;border-radius:10px}.agent-tool-line{display:flex;align-items:center;gap:6px;font-size:12px;color:var(--text-muted);padding:2px 0}.agent-tool-icon{font-size:11px;color:var(--accent);width:14px;text-align:center}.agent-tool-name{font-family:var(--font-mono);font-size:12px;color:var(--text)}.agent-tool-detail{border:1px solid var(--border);border-radius:var(--radius);margin:2px 0;overflow:hidden}.agent-tool-detail-summary{display:flex;align-items:center;gap:8px;padding:6px 10px;background:var(--surface);cursor:pointer;font-size:12px;list-style:none}.agent-tool-detail-summary::-webkit-details-marker{display:none}.agent-tool-detail-path{font-family:var(--font-mono);font-size:11px;color:var(--text-muted)}.agent-tool-detail-pre{margin:0;padding:8px 10px;font-size:11px;font-family:var(--font-mono);background:var(--bg);white-space:pre-wrap;word-break:break-all;max-height:200px;overflow-y:auto;border-top:1px solid var(--border)}.agent-tool-output{color:var(--text-muted)}.agent-qa-badge{display:inline-flex;align-items:center;gap:6px;padding:3px 10px;border-radius:20px;font-size:12px;font-weight:500;margin:2px 0}.agent-qa-pass{background:color-mix(in srgb,#22c55e 15%,transparent);border:1px solid #22c55e44;color:#22c55e}.agent-qa-fail{background:color-mix(in srgb,var(--error) 15%,transparent);border:1px solid color-mix(in srgb,var(--error) 44%,transparent);color:var(--error)}.agent-qa-icon{font-size:12px}.agent-qa-count{font-size:11px;opacity:.8}.agent-qa-card{border:1px solid var(--border);border-radius:var(--radius);margin:2px 0;overflow:hidden}.agent-qa-card-summary{display:flex;align-items:center;gap:8px;padding:6px 12px;cursor:pointer;font-size:12px;font-weight:500;list-style:none;border-radius:var(--radius) var(--radius) 0 0}.agent-qa-card-summary::-webkit-details-marker{display:none}.agent-qa-card-summary.agent-qa-pass{background:color-mix(in srgb,#22c55e 12%,var(--surface));border-radius:var(--radius)}.agent-qa-card-summary.agent-qa-fail{background:color-mix(in srgb,var(--error) 12%,var(--surface));border-radius:var(--radius)}.agent-qa-output{margin:0;padding:8px 12px;font-size:11px;font-family:var(--font-mono);background:var(--bg);white-space:pre-wrap;word-break:break-all;max-height:200px;overflow-y:auto;border-top:1px solid var(--border)}.agent-qa-issues,.agent-qa-suggestions{margin:0;padding:8px 12px 8px 28px;font-size:12px;background:var(--bg);border-top:1px solid var(--border)}.agent-qa-issues li{color:var(--error);margin-bottom:2px}.agent-qa-suggestions li{color:var(--text-muted);margin-bottom:2px}.agent-retry-line{display:flex;align-items:baseline;gap:6px;font-size:12px;color:var(--text-muted);padding:2px 0}.agent-retry-icon{color:var(--accent)}.agent-retry-feedback{font-size:11px;color:var(--text-muted);opacity:.8;font-style:italic;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;max-width:400px}.agent-plan-summary-line{display:flex;align-items:center;gap:6px;font-size:12px;color:var(--text-muted);padding:2px 0}.agent-plan-icon{font-size:12px}.agent-plan-summary{color:var(--text);font-size:12px}.agent-plan-file-count{font-size:11px;color:var(--text-muted);background:var(--bg);padding:1px 6px;border-radius:10px;border:1px solid var(--border)}.agent-plan-card{border:1px solid var(--border);border-radius:var(--radius);margin:2px 0;overflow:hidden}.agent-plan-card-summary{display:flex;align-items:center;gap:8px;padding:8px 12px;background:var(--surface);cursor:pointer;font-size:12px;list-style:none;flex-wrap:wrap}.agent-plan-card-summary::-webkit-details-marker{display:none}.agent-plan-section{padding:6px 12px;border-top:1px solid var(--border);background:var(--bg)}.agent-plan-section-title{font-size:10px;font-weight:600;text-transform:uppercase;letter-spacing:.06em;color:var(--text-muted);margin-bottom:4px}.agent-plan-file-list{margin:0;padding:0 0 0 14px;font-size:12px;font-family:var(--font-mono)}.agent-plan-file-create{color:#22c55e}.agent-plan-file-modify{color:var(--accent)}.agent-plan-steps,.agent-plan-considerations{margin:0;padding:0 0 0 18px;font-size:12px;color:var(--text);line-height:1.6}.agent-plan-considerations{color:var(--text-muted)}.plans-panel{flex:1;overflow-y:auto;padding:14px;display:flex;flex-direction:column;gap:10px}.plans-loading,.plans-empty{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;gap:8px;padding:40px 24px}.plans-loading{font-size:13px;color:var(--text-muted)}.plans-empty-title{font-size:14px;font-weight:600;color:var(--text-muted)}.plans-empty-sub{font-size:12px;color:var(--text-muted);opacity:.6;max-width:220px;line-height:1.6}.plans-error{font-size:12px;color:var(--error);padding:8px 10px;background:var(--error-dim);border-radius:6px}.plans-refresh-btn{align-self:flex-end;font-size:11px;padding:4px 10px;color:var(--text-muted)}.plans-list{display:flex;flex-direction:column;gap:8px}.plan-card{border:1px solid var(--border);border-radius:var(--radius);overflow:hidden;background:var(--surface);transition:border-color var(--ease)}.plan-card:hover,.plan-card-open{border-color:var(--border-hover)}.plan-card-header{width:100%;display:flex;align-items:center;justify-content:space-between;gap:10px;padding:10px 12px;background:transparent;border:none;cursor:pointer;text-align:left;color:var(--text)}.plan-card-left{display:flex;flex-direction:column;gap:2px;min-width:0}.plan-card-title{font-size:13px;font-weight:600;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.plan-card-date{font-size:11px;color:var(--text-muted)}.plan-card-right{display:flex;align-items:center;gap:8px;flex-shrink:0}.plan-status-badge{font-size:10px;font-weight:700;padding:2px 7px;border-radius:10px;white-space:nowrap}.plan-status-pending{background:#64748b26;color:var(--text-muted)}.plan-status-in_progress{background:#38bdf81f;color:var(--accent)}.plan-status-complete{background:#34d3991f;color:var(--success)}.plan-progress-bar{width:48px;height:4px;background:var(--border);border-radius:2px;overflow:hidden}.plan-progress-fill{height:100%;background:var(--accent);border-radius:2px;transition:width .3s ease}.plan-card-chevron{font-size:10px;color:var(--text-muted)}.plan-card-body{border-top:1px solid var(--border);padding:12px 14px;display:flex;flex-direction:column;gap:12px}.plan-task-loading{font-size:12px;color:var(--text-muted)}.plan-task-list{list-style:none;display:flex;flex-direction:column;gap:6px}.plan-task{display:flex;gap:8px;align-items:flex-start;font-size:12px;color:var(--text);line-height:1.45}.plan-task-done{opacity:.45}.plan-task-done .plan-task-text{text-decoration:line-through}.plan-task-toggle{font-family:var(--font-mono);font-size:11px;color:var(--accent);flex-shrink:0;margin-top:1px;background:none;border:none;cursor:pointer;padding:0;line-height:inherit;transition:color var(--ease),opacity var(--ease)}.plan-task-toggle:hover{color:var(--accent-hover)}.plan-task-toggle:disabled{opacity:.4;cursor:default}.plan-task-done .plan-task-toggle{color:var(--success)}.plan-task-text{flex:1}.plan-resume-btn{align-self:flex-start;font-size:12px;padding:6px 14px}.plan-phase-group{display:flex;flex-direction:column;gap:4px}.plan-phase-header{display:flex;align-items:center;gap:6px;font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.05em;color:var(--text-muted);padding:4px 0 2px;border-bottom:1px solid var(--border);margin-bottom:2px}.plan-phase-dot{width:6px;height:6px;border-radius:50%;flex-shrink:0}.plan-phase-header--done .plan-phase-dot{background:var(--success)}.plan-phase-header--done{opacity:.5}.plan-phase-header--current .plan-phase-dot{background:var(--accent)}.plan-phase-header--current{color:var(--accent);border-color:var(--accent);opacity:.85}.plan-phase-header--pending .plan-phase-dot{background:var(--border-hover)}.plan-card-actions{display:flex;align-items:center;gap:8px;flex-wrap:wrap}.plan-archive-btn{font-size:11px;padding:4px 10px;color:var(--text-muted)}.plans-archive-section{margin-top:4px;border-top:1px solid var(--border);padding-top:8px}.plans-archive-toggle{display:flex;align-items:center;gap:6px;font-size:11px;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.04em;background:none;border:none;cursor:pointer;padding:4px 2px;width:100%;text-align:left;transition:color var(--ease)}.plans-archive-toggle:hover{color:var(--text)}.plans-archive-body{display:flex;flex-direction:column;gap:6px;margin-top:8px}.plans-archive-search{width:100%;padding:6px 10px;font-size:12px;background:var(--input-bg);border:1px solid var(--border);border-radius:var(--radius);color:var(--text);outline:none;box-sizing:border-box}.plans-archive-search:focus{border-color:var(--accent)}.plans-archive-empty{font-size:12px;color:var(--text-muted);text-align:center;padding:12px 0}.plans-archive-list{display:flex;flex-direction:column;gap:4px}.plans-archive-item{display:flex;align-items:center;justify-content:space-between;gap:8px;padding:8px 10px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius)}.plans-archive-item-info{display:flex;flex-direction:column;gap:2px;min-width:0}.plans-archive-item-title{font-size:12px;font-weight:600;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.plans-archive-item-meta{font-size:11px;color:var(--text-muted);display:flex;align-items:center;gap:4px}.plans-restore-btn{font-size:11px;padding:3px 10px;flex-shrink:0;color:var(--accent)}.plan-autorun-banner{display:flex;align-items:center;gap:8px;font-size:11px;color:var(--accent);background:#38bdf814;border:1px solid rgba(56,189,248,.2);border-radius:6px;padding:7px 10px}.plan-autorun-spinner{width:10px;height:10px;border:2px solid rgba(56,189,248,.3);border-top-color:var(--accent);border-radius:50%;animation:spin .8s linear infinite;flex-shrink:0}.oracle-modal-overlay{position:absolute;top:0;right:0;bottom:0;left:0;background:#060b14b3;display:flex;align-items:stretch;justify-content:stretch;z-index:100;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px)}.oracle-modal{display:flex;flex-direction:column;width:100%;height:100%;background:var(--surface);border-left:1px solid var(--border)}.oracle-modal-header{display:flex;align-items:center;justify-content:space-between;padding:10px 14px;border-bottom:1px solid var(--border);flex-shrink:0}.oracle-modal-title{display:flex;align-items:center;gap:8px;font-size:13px;font-weight:600;color:var(--text)}.oracle-modal-badge{font-size:10px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--accent);padding:1px 6px;background:var(--accent-dim);border-radius:3px}.oracle-modal-close{padding:3px 8px;font-size:13px;color:var(--text-muted)}.oracle-modal-body{flex:1;min-height:0;display:flex;flex-direction:column;overflow:hidden}.oracle-modal-artifact{flex:1;overflow-y:auto;padding:16px;display:flex;flex-direction:column;gap:14px}.oracle-artifact-prompt-label,.oracle-artifact-plan-label{font-size:10px;font-weight:700;letter-spacing:.07em;text-transform:uppercase;color:var(--accent);margin-bottom:6px}.oracle-artifact-prompt{background:var(--bg);border:1px solid var(--border);border-radius:var(--radius);padding:12px 14px;font-size:12px;line-height:1.6;color:var(--text);white-space:pre-wrap;word-break:break-word;max-height:220px;overflow-y:auto}.oracle-artifact-plan,.oracle-artifact-questions{background:var(--bg);border:1px solid var(--border);border-radius:var(--radius);padding:12px 14px}.oracle-artifact-tasks{list-style:none;display:flex;flex-direction:column;gap:5px}.oracle-artifact-tasks li,.oracle-artifact-questions li{font-size:12px;color:var(--text-muted);display:flex;gap:7px;align-items:flex-start}.oracle-artifact-questions ul{list-style:none;display:flex;flex-direction:column;gap:4px}.oracle-modal-error{font-size:12px;color:var(--error);padding:8px 10px;background:var(--error-dim);border-radius:6px}.oracle-artifact-actions{display:flex;align-items:center;gap:8px;padding-top:4px;flex-wrap:wrap}.oracle-artifact-actions .btn-primary{margin-left:auto}.oracle-save-plan-btn{font-size:12px;color:var(--accent)}.imgbrowser-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0009;display:flex;align-items:center;justify-content:center;z-index:200}.imgbrowser-modal{background:var(--surface);border:1px solid var(--border);border-radius:12px;width:min(900px,95vw);max-height:85vh;display:flex;flex-direction:column;overflow:hidden}.imgbrowser-header{display:flex;align-items:center;justify-content:space-between;padding:16px 20px 12px;border-bottom:1px solid var(--border);flex-shrink:0}.imgbrowser-title{font-size:16px;font-weight:600;margin:0}.imgbrowser-error{color:var(--error, #f87171);font-size:13px;padding:8px 20px}.imgbrowser-loading,.imgbrowser-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;flex:1;gap:8px;color:var(--text-muted);font-size:14px;padding:40px}.imgbrowser-empty-hint{font-size:12px;opacity:.7}.imgbrowser-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:12px;padding:16px 20px;overflow-y:auto}.imgbrowser-card{background:var(--surface-raised, rgba(255,255,255,.04));border:1px solid var(--border);border-radius:8px;overflow:hidden;display:flex;flex-direction:column}.imgbrowser-thumb{position:relative;aspect-ratio:1;overflow:hidden;cursor:pointer;background:#0003}.imgbrowser-thumb:hover .imgbrowser-thumb-media{opacity:.85;transform:scale(1.03)}.imgbrowser-thumb-media{width:100%;height:100%;object-fit:cover;transition:opacity .15s,transform .15s}.imgbrowser-type-badge{position:absolute;top:6px;right:6px;font-size:9px;font-weight:700;letter-spacing:.05em;padding:2px 5px;border-radius:4px}.imgbrowser-type-image{background:#0000008c;color:#e2e8f0}.imgbrowser-type-video{background:#f97316cc;color:#fff}.imgbrowser-card-meta{display:flex;align-items:baseline;justify-content:space-between;padding:6px 8px 2px;gap:4px}.imgbrowser-card-name{font-size:11px;color:var(--text-muted);overflow:hidden;text-overflow:ellipsis;white-space:nowrap;flex:1}.imgbrowser-card-size{font-size:10px;color:var(--text-muted);opacity:.6;flex-shrink:0}.imgbrowser-card-actions{display:flex;gap:4px;padding:4px 6px 8px}.imgbrowser-btn{font-size:11px;padding:3px 8px;flex:1}.imgbrowser-btn-delete{color:var(--error, #f87171)}.imgbrowser-lightbox{position:fixed;top:0;right:0;bottom:0;left:0;background:#000000d9;display:flex;align-items:center;justify-content:center;z-index:300}.imgbrowser-lightbox-inner{max-width:90vw;max-height:90vh;display:flex;flex-direction:column;align-items:center;gap:12px}.imgbrowser-lightbox-media{max-width:100%;max-height:80vh;border-radius:8px;object-fit:contain}.imgbrowser-lightbox-footer{display:flex;align-items:center;gap:10px;background:#00000080;border-radius:8px;padding:8px 14px;width:100%}.imgbrowser-lightbox-name{font-size:12px;color:#ffffffbf;flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.image-panel{display:flex;flex-direction:column;height:100%;overflow:hidden}.image-panel-top{display:flex;flex-direction:column;gap:8px;padding:12px 14px;border-bottom:1px solid var(--border);flex-shrink:0}.image-panel-model-row{display:flex;align-items:center;gap:8px}.image-panel-model-select{flex:1;font-size:13px}.image-panel-type-badge{flex-shrink:0;font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.04em;padding:2px 5px;border-radius:4px;border:1px solid currentColor}.image-panel-type-badge.supported{color:#22c55e}.image-panel-type-badge.unsupported{color:#ef4444}.image-panel-no-config{font-size:12px;color:var(--text-muted);line-height:1.5}.image-panel-form{display:flex;flex-direction:column;gap:6px}.image-panel-prompt{resize:vertical;font-size:13px;min-height:60px}.image-panel-generate-btn{align-self:flex-end}.image-panel-source-url{font-size:12px}.image-panel-duration-row{display:flex;align-items:center;gap:8px}.image-panel-duration-label{font-size:12px;color:var(--text-muted);white-space:nowrap}.image-panel-duration-input{width:64px;font-size:12px}.image-panel-video-note{font-size:11px;color:var(--text-muted);margin:0}.image-panel-polling{display:flex;align-items:center;gap:8px;font-size:12px;color:var(--text-muted);align-self:flex-end}.image-panel-spinner{width:12px;height:12px;border:2px solid var(--border);border-top-color:var(--accent, #6366f1);border-radius:50%;animation:image-panel-spin .7s linear infinite;flex-shrink:0}@keyframes image-panel-spin{to{transform:rotate(360deg)}}.image-panel-error{font-size:12px;color:var(--error, #f87171);padding:4px 0}.image-panel-upload-section{display:flex;flex-direction:column;gap:4px}.image-panel-upload-zone{border:1.5px dashed var(--border);border-radius:6px;padding:10px 12px;text-align:center;font-size:12px;color:var(--text-muted);cursor:pointer;transition:border-color .15s,background .15s;-webkit-user-select:none;user-select:none}.image-panel-upload-zone:hover,.image-panel-upload-zone:focus{border-color:var(--accent, #6366f1);outline:none}.image-panel-upload-zone.dragging{border-color:var(--accent, #6366f1);background:color-mix(in srgb,var(--accent, #6366f1) 8%,transparent)}.image-panel-file-input{display:none}.image-panel-upload-status{font-size:11px;color:var(--text-muted)}.image-panel-upload-status.error{color:var(--error, #f87171)}.image-panel-recent{display:flex;flex-direction:column;gap:8px;padding:12px 14px;flex:1;overflow-y:auto}.image-panel-recent-header{display:flex;align-items:center;justify-content:space-between}.image-panel-section-label{font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.06em;color:var(--text-muted)}.image-panel-browse-btn{font-size:11px;padding:2px 8px}.image-panel-muted{font-size:12px;color:var(--text-muted)}.image-panel-thumbs{display:grid;grid-template-columns:repeat(3,1fr);gap:6px}.image-panel-thumb{aspect-ratio:1;border-radius:6px;overflow:hidden;border:1px solid var(--border);background:none;padding:0;cursor:pointer;transition:opacity .15s}.image-panel-thumb:hover{opacity:.8}.image-panel-thumb-media{width:100%;height:100%;object-fit:cover}.chat-pane{height:100%;display:flex;flex-direction:column;background:var(--surface);overflow:hidden;position:relative}.pane-placeholder{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:10px;padding:40px 24px;text-align:center}.pane-placeholder-icon{font-size:32px;opacity:.3}.pane-placeholder-title{font-size:15px;font-weight:600;color:var(--text-muted)}.pane-placeholder-sub{font-size:12px;color:var(--text-muted);opacity:.6;max-width:220px;line-height:1.6}.chat-header{display:flex;align-items:center;gap:8px;padding:5px 14px;border-bottom:1px solid var(--border);flex-shrink:0}.chat-tabs{display:flex;gap:2px;background:var(--bg);border-radius:6px;padding:2px}.chat-tab{padding:4px 12px;border:none;background:transparent;color:var(--text-muted);font-size:12px;font-weight:600;border-radius:4px;cursor:pointer;transition:background var(--ease),color var(--ease);font-family:inherit}.chat-tab:hover{color:var(--text)}.chat-tab-active{background:var(--surface-hover);color:var(--text)}.chat-header-title{font-size:13px;font-weight:600;color:var(--text)}.chat-header-provider{font-size:11px;color:var(--text-muted);font-family:var(--font-mono);background:var(--bg);border:1px solid var(--border);border-radius:3px;padding:1px 6px}.chat-oracle-btn{font-size:11px;padding:3px 9px;color:var(--accent);border-color:var(--accent-dim);margin-left:auto}.chat-oracle-btn:hover{background:var(--accent-dim)}.chat-clear-btn{margin-left:0;font-size:11px;padding:2px 8px}.chat-messages{flex:1;overflow-y:auto;padding:14px;display:flex;flex-direction:column;gap:12px}.chat-empty{text-align:center;color:var(--text-muted);font-size:13px;margin:auto;padding:32px 24px;line-height:1.7}.chat-empty-hint{font-size:11px;opacity:.5}.chat-empty-cmd{font-family:var(--font-mono);color:var(--accent);opacity:1}.chat-message{display:flex}.chat-message-user{justify-content:flex-end}.chat-message-assistant{justify-content:flex-start}.chat-bubble{max-width:88%;display:flex;flex-direction:column;gap:8px}.chat-message-user .chat-bubble{background:var(--accent);border-radius:12px 12px 3px;padding:10px 14px}.chat-message-assistant .chat-bubble{background:var(--bg);border:1px solid var(--border);border-radius:12px 12px 12px 3px;padding:10px 14px}.chat-bubble-text{font-family:inherit;font-size:13px;line-height:1.6;white-space:pre-wrap;word-break:break-word;margin:0}.chat-message-user .chat-bubble-text{color:#060b14}.chat-message-assistant .chat-bubble-text{color:var(--text)}.chat-cursor{display:inline-block;width:2px;height:13px;background:var(--accent);margin-left:1px;vertical-align:text-bottom;animation:blink 1s step-end infinite}@keyframes blink{0%,to{opacity:1}50%{opacity:0}}.chat-changes{display:flex;flex-wrap:wrap;gap:4px}.chat-change-file{font-family:var(--font-mono);font-size:10.5px;padding:2px 6px;border-radius:3px;background:var(--surface);border:1px solid var(--border);color:var(--text-muted)}.chat-change-create{border-color:var(--success);color:var(--success)}.chat-change-modify{border-color:var(--accent);color:var(--accent)}.chat-change-delete{border-color:var(--error);color:var(--error)}.chat-no-changes{display:inline-flex;align-items:center;gap:4px;font-size:11px;color:var(--warning, #d97706);background:#d9770614;border:1px solid rgba(217,119,6,.25);border-radius:3px;padding:2px 7px;align-self:flex-start}.chat-rollback-btn{align-self:flex-start;font-size:11px;padding:2px 8px;color:var(--text-muted);border:1px solid var(--border);border-radius:3px}.chat-rollback-btn:hover{color:var(--text);border-color:var(--accent)}.chat-plan-run-pill{display:inline-flex;align-items:center;gap:6px;background:#38bdf81a;color:var(--accent);border:1px solid rgba(56,189,248,.25);border-radius:20px;font-size:12px;font-weight:600;padding:5px 12px;margin-left:auto}.chat-plan-run-icon{font-size:10px}.chat-error{background:#ef44441a;border:1px solid var(--error);border-radius:var(--radius);color:var(--error);font-size:12px;padding:8px 12px}.chat-activity-bubble{display:flex;align-items:center;gap:8px;padding:10px 14px!important}.chat-activity-text{font-size:13px;color:var(--text-muted);font-style:italic}.chat-activity-spinner,.chat-status-chip-spinner{flex-shrink:0;width:12px;height:12px;border:2px solid var(--border);border-top-color:var(--accent);border-radius:50%;animation:spin .7s linear infinite}.chat-status-chip{display:flex;align-items:center;gap:6px;font-size:11px;color:var(--text-muted);padding:3px 10px;border:1px solid var(--border);border-radius:20px;background:var(--bg);align-self:flex-start;margin-left:2px}.tool-call-list{display:flex;flex-direction:column;gap:4px}.tool-call-bubble{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-sm);overflow:hidden;font-size:12px}.tool-call-header{display:flex;align-items:center;gap:6px;width:100%;background:none;border:none;color:var(--text-muted);padding:6px 10px;cursor:pointer;text-align:left;transition:background var(--ease),color var(--ease)}.tool-call-header:hover:not(:disabled){background:var(--surface-hover);color:var(--text)}.tool-call-header:disabled{cursor:default}.tool-call-chevron{flex-shrink:0;font-size:10px;opacity:.6}.tool-call-name{font-family:var(--font-mono);font-size:11px;color:var(--accent);flex-shrink:0}.tool-call-args{font-family:var(--font-mono);font-size:11px;color:var(--text-muted);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.tool-call-bubble-success{border-color:var(--success)}.tool-call-bubble-success .tool-call-name{color:var(--success)}.tool-call-check{flex-shrink:0;font-size:13px;color:var(--success);line-height:1}.tool-call-spinner{flex-shrink:0;width:10px;height:10px;border:1.5px solid var(--border);border-top-color:var(--accent);border-radius:50%;animation:spin .7s linear infinite}.tool-call-output{font-family:var(--font-mono);font-size:11px;line-height:1.5;white-space:pre-wrap;word-break:break-all;color:var(--text-muted);padding:8px 10px;border-top:1px solid var(--border);margin:0;max-height:300px;overflow-y:auto}.chat-bubble-md{font-size:13px;line-height:1.65;color:var(--text);word-break:break-word}.chat-bubble-md p{margin:0 0 .75em}.chat-bubble-md p:last-child{margin-bottom:0}.chat-bubble-md h1,.chat-bubble-md h2,.chat-bubble-md h3,.chat-bubble-md h4{font-weight:600;margin:.9em 0 .4em;line-height:1.3}.chat-bubble-md h1{font-size:1.15em}.chat-bubble-md h2{font-size:1.05em}.chat-bubble-md h3{font-size:.97em}.chat-bubble-md h4{font-size:.9em;color:var(--text-muted)}.chat-bubble-md ul,.chat-bubble-md ol{margin:.4em 0 .75em;padding-left:1.4em}.chat-bubble-md li{margin:.2em 0}.chat-bubble-md code{font-family:var(--font-mono);font-size:.88em;background:#38bdf814;border:1px solid rgba(56,189,248,.15);border-radius:3px;padding:0 4px}.chat-bubble-md blockquote{border-left:3px solid var(--border-hover);margin:.5em 0;padding:2px 12px;color:var(--text-muted)}.chat-bubble-md a{color:var(--accent);text-decoration:none}.chat-bubble-md a:hover{text-decoration:underline}.code-fence{border:1px solid var(--border);border-radius:var(--radius-sm);overflow:hidden;margin:.5em 0}.code-fence[open]{border-color:var(--border-hover)}.code-fence-lang{display:flex;align-items:center;padding:4px 10px;font-family:var(--font-mono);font-size:11px;color:var(--text-muted);background:var(--surface);cursor:pointer;-webkit-user-select:none;user-select:none;list-style:none}.code-fence-lang::-webkit-details-marker{display:none}.code-fence-lang:before{content:"▸";margin-right:6px;font-size:10px;transition:transform var(--ease)}.code-fence[open] .code-fence-lang:before{content:"▾"}.code-fence pre{margin:0;padding:10px 12px;background:var(--bg);overflow-x:auto;max-height:400px;overflow-y:auto}.code-fence pre code{font-family:var(--font-mono);font-size:12px;line-height:1.55;color:var(--text);background:none;border:none;padding:0}.chat-input-area{display:flex;gap:8px;padding:10px 14px;border-top:1px solid var(--border);flex-shrink:0;align-items:flex-end}.chat-textarea{flex:1;background:var(--bg);border:1px solid var(--border);border-radius:var(--radius);color:var(--text);font-family:inherit;font-size:13px;line-height:1.5;padding:8px 10px;resize:none;transition:border-color var(--ease);min-height:60px;max-height:160px}.chat-textarea:focus{outline:none;border-color:var(--accent)}.chat-textarea:disabled{opacity:.5}.chat-send-col{display:flex;flex-direction:column;align-items:center;gap:4px;flex-shrink:0}.chat-timer{font-size:10px;font-family:var(--font-mono);letter-spacing:.03em}.chat-timer-live{color:var(--accent)}.chat-timer-done{color:var(--text-muted);opacity:.7}.chat-token-stats{font-size:10px;font-family:var(--font-mono);color:var(--success);opacity:.8;letter-spacing:.03em}.chat-token-remaining{font-size:10px;font-family:var(--font-mono);color:var(--text-muted);opacity:.7;letter-spacing:.03em;white-space:nowrap}.chat-budget-banner{display:flex;align-items:center;gap:.5rem;padding:.55rem .85rem;background:#fab4321a;border-top:1px solid rgba(250,180,50,.25);font-size:.8rem;color:#fac850}.chat-budget-icon{flex-shrink:0}.chat-send-btn{padding:8px 14px;font-size:13px;flex-shrink:0}.chat-header-agent-badge{font-size:10px;font-weight:600;padding:2px 7px;border-radius:10px;background:color-mix(in srgb,var(--accent) 15%,transparent);color:var(--accent);border:1px solid color-mix(in srgb,var(--accent) 30%,transparent);letter-spacing:.04em;text-transform:uppercase}.agent-activity-list{display:flex;flex-direction:column;gap:2px;padding:4px 0}.ollama-unavail-bar{display:flex;align-items:center;gap:8px;padding:8px 14px;background:#3d1f00;border-top:1px solid #7a3f00;color:#ffcf7a;font-size:.82rem;flex-shrink:0}.ollama-unavail-icon{flex-shrink:0;font-size:.95rem}.ollama-unavail-text{flex:1;min-width:0}.ollama-unavail-btn{flex-shrink:0;font-size:11px;padding:3px 10px;border-color:#ffcf7a;color:#ffcf7a}.ollama-unavail-btn:hover{background:#ffcf7a26}.chat-maintenance-banner{display:flex;align-items:center;gap:8px;padding:10px 14px;background:#fffbe6;border-top:1px solid #ffe58f;color:#7d4e00;font-size:.85rem;font-weight:500;flex-shrink:0}.chat-maintenance-icon{font-size:1rem;flex-shrink:0}.resume-dialog-overlay{position:absolute;top:0;right:0;bottom:0;left:0;z-index:50;display:flex;align-items:center;justify-content:center;background:#00000073}.resume-dialog{background:var(--surface);border:1px solid var(--border-hover);border-radius:10px;padding:22px 24px;width:320px;max-width:calc(100% - 32px);display:flex;flex-direction:column;gap:10px;box-shadow:0 8px 32px #0000004d}.resume-dialog-label{font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:var(--accent);margin:0}.resume-dialog-title{font-size:14px;font-weight:600;color:var(--text);margin:0}.resume-dialog-status{font-size:12px;color:var(--text-muted);margin:0}.resume-dialog-actions{display:flex;gap:8px;margin-top:4px}.resume-dialog-actions .btn{flex:1;font-size:13px}.cv-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:var(--overlay-bg);z-index:200;display:flex;align-items:stretch;justify-content:center;padding:24px}.cv-modal{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow-lg);display:flex;flex-direction:column;width:100%;max-width:1200px;overflow:hidden}.cv-header{display:flex;align-items:center;gap:8px;padding:10px 16px;border-bottom:1px solid var(--border);flex-shrink:0}.cv-header-title{font-size:14px;font-weight:600;color:var(--text);flex:1}.cv-dirty-dot{width:8px;height:8px;border-radius:50%;background:var(--accent);flex-shrink:0}.cv-saved-flash{font-size:12px;color:var(--success);flex-shrink:0}.cv-close-btn{background:none;border:none;color:var(--text-muted);font-size:18px;cursor:pointer;padding:2px 6px;border-radius:var(--radius-sm);line-height:1;transition:color var(--ease),background var(--ease)}.cv-close-btn:hover{color:var(--text);background:var(--surface-hover)}.cv-body{display:grid;grid-template-columns:220px 1fr;flex:1;overflow:hidden;min-height:0}.cv-tree{border-right:1px solid var(--border);overflow-y:auto;padding:8px 0}.cv-tree-loading,.cv-tree-empty{padding:16px;font-size:12px;color:var(--text-muted)}.cv-tree-dir{padding:3px 12px;font-size:11px;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em;margin-top:4px}.cv-tree-file{display:block;width:100%;text-align:left;background:none;border:none;padding:4px 12px 4px 20px;font-size:13px;color:var(--text);cursor:pointer;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;border-radius:0;transition:background var(--ease),color var(--ease);font-family:var(--font-mono)}.cv-tree-file:hover{background:var(--surface-hover)}.cv-tree-file.active{background:var(--accent-dim);color:var(--accent)}.cv-tree-file[data-depth="1"]{padding-left:28px}.cv-tree-file[data-depth="2"]{padding-left:40px}.cv-tree-file[data-depth="3"]{padding-left:52px}.cv-editor-pane{display:flex;flex-direction:column;overflow:hidden;min-height:0}.cv-editor-filename{padding:6px 14px;font-size:12px;font-family:var(--font-mono);color:var(--text-muted);border-bottom:1px solid var(--border);flex-shrink:0;background:var(--bg)}.cv-editor-loading,.cv-editor-placeholder{flex:1;display:flex;align-items:center;justify-content:center;font-size:13px;color:var(--text-muted)}.cv-textarea{flex:1;width:100%;background:var(--bg);color:var(--text);border:none;resize:none;padding:14px;font-family:var(--font-mono);font-size:13px;line-height:1.6;outline:none;-moz-tab-size:2;tab-size:2;min-height:0}.cv-editor-footer{display:flex;align-items:center;justify-content:flex-end;padding:8px 12px;border-top:1px solid var(--border);flex-shrink:0;gap:8px}.cv-save-btn{font-size:13px;padding:5px 16px}.dbv-modal{width:min(900px,95vw);height:min(600px,85vh)}.dbv-data-pane{overflow:hidden;display:flex;flex-direction:column}.dbv-table-wrap{flex:1;overflow:auto;padding:0}.dbv-table{width:max-content;min-width:100%;border-collapse:collapse;font-size:12px;font-family:var(--font-mono, monospace)}.dbv-table th,.dbv-table td{padding:5px 10px;border:1px solid var(--border, #333);text-align:left;white-space:nowrap;max-width:300px;overflow:hidden;text-overflow:ellipsis}.dbv-table th{background:var(--bg-secondary, #1e1e1e);color:var(--text-secondary, #aaa);font-weight:600;position:sticky;top:0;z-index:1}.dbv-table tbody tr:nth-child(2n){background:var(--bg-secondary, #1a1a1a)}.dbv-table tbody tr:hover{background:var(--bg-hover, #2a2a2a)}.dbv-null{color:var(--text-muted, #555);font-style:italic}.dbv-footer{display:flex;align-items:center;gap:12px;justify-content:space-between}.dbv-row-count{font-size:12px;color:var(--text-secondary, #aaa)}.dbv-pagination{display:flex;align-items:center;gap:8px;font-size:13px;color:var(--text-secondary, #aaa)}.preview-pane{height:100%;display:flex;flex-direction:column;background:var(--bg);position:relative}.preview-toolbar{height:38px;background:var(--surface);border-bottom:1px solid var(--border);display:flex;align-items:center;padding:0 12px;gap:8px;flex-shrink:0;z-index:1}.preview-toolbar-left{flex:1}.preview-url{font-family:var(--font-mono);font-size:12px;color:var(--text-muted);overflow:hidden;text-overflow:ellipsis;white-space:nowrap;-webkit-user-select:all;user-select:all}.preview-toolbar-center{display:flex;align-items:center;gap:6px;flex-shrink:0}.preview-toolbar-right{flex:1;display:flex;justify-content:flex-end}.preview-actions{display:flex;gap:4px}.preview-actions .btn-icon{font-size:14px;width:28px;height:28px;display:flex;align-items:center;justify-content:center;padding:0;border-radius:6px;transition:background .15s,transform .15s}.preview-actions .btn-icon:not(:disabled):hover{background:var(--surface-hover, rgba(255,255,255,.08));transform:scale(1.1)}.preview-actions .btn-icon:disabled{opacity:.3;cursor:default}.preview-actions .btn-icon.spinning{animation:spin .8s linear infinite}.preview-frame-wrap{flex:1;display:flex;flex-direction:column;overflow:hidden;position:relative}.preview-frame-wrap iframe{flex:1;width:100%;height:100%;border:none;background:#fff}.preview-loading-bar{position:absolute;top:0;left:0;right:0;height:3px;background:linear-gradient(90deg,transparent 0%,var(--accent, #6366f1) 40%,var(--accent-light, #818cf8) 60%,transparent 100%);background-size:200% 100%;animation:loadbar 1.2s ease-in-out infinite;z-index:10}@keyframes loadbar{0%{background-position:200% 0}to{background-position:-200% 0}}.pane-placeholder{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:8px;color:var(--text-muted);text-align:center;padding:32px}.pane-placeholder-icon{font-size:40px;opacity:.5}.pane-placeholder-title{font-size:15px;font-weight:600;color:var(--text);margin:4px 0 0}.pane-placeholder-sub{font-size:13px;margin:0;max-width:240px;line-height:1.5}.preview-spinner{display:block;width:36px;height:36px;border:3px solid var(--border);border-top-color:var(--accent, #6366f1);border-radius:50%;animation:spin .9s linear infinite;margin-bottom:4px}.footer-wrap{display:flex;flex-direction:column;flex-shrink:0}.footer{height:var(--footer-h);background:var(--surface);border-top:1px solid var(--border);display:flex;align-items:center;padding:0 14px;gap:8px;font-size:12px}.footer-item{color:var(--text-muted)}.footer-sep{color:var(--border)}.footer-status{display:flex;align-items:center;gap:5px}.status-dot{width:7px;height:7px;border-radius:50%;flex-shrink:0}.status-dot.stopped{background:var(--text-muted)}.status-dot.running{background:var(--success);box-shadow:0 0 6px var(--success)}.status-dot.starting,.status-dot.restarting{background:var(--accent);animation:pulse 1s infinite}.status-dot.error{background:var(--error)}@keyframes pulse{0%,to{opacity:1}50%{opacity:.4}}.footer-spacer{flex:1}.footer-action-btn{font-size:11px;padding:2px 8px}.footer-action-btn.btn-stop{color:var(--error)}.footer-logs-btn{font-size:11px;padding:2px 8px;border-radius:3px}.footer-logs-btn:disabled{opacity:.3;cursor:default}.footer-logs-btn.active{color:var(--accent)}.log-panel{background:#0a0f1a;border-top:1px solid var(--border);display:flex;flex-direction:column;height:220px}.log-panel-header{display:flex;align-items:center;justify-content:space-between;padding:6px 14px;border-bottom:1px solid var(--border);flex-shrink:0}.log-panel-title{font-size:12px;font-weight:600;color:var(--text-muted);font-family:var(--font-mono)}.log-panel-close{font-size:11px;padding:2px 6px}.log-panel-body{flex:1;overflow-y:auto;padding:8px 14px;font-family:var(--font-mono);font-size:11.5px;line-height:1.6}.log-line{color:var(--text-muted);white-space:pre-wrap;word-break:break-all}.log-line:hover{color:var(--text)}.log-empty{color:var(--text-muted);font-size:12px;opacity:.5}.loading-screen{height:100%;display:flex;align-items:center;justify-content:center;background:var(--bg)}.loading-spinner{width:28px;height:28px;border:2px solid var(--border);border-top-color:var(--accent);border-radius:50%;animation:spin .7s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.auth-page{height:100%;display:flex;overflow:hidden}.auth-brand{width:38%;min-width:280px;background:linear-gradient(160deg,#0d1a2e,#060b14 60%);border-right:1px solid var(--border);display:flex;flex-direction:column;justify-content:center;padding:56px 48px}.auth-brand-logo{display:flex;flex-direction:column;align-items:flex-start;gap:16px;margin-bottom:28px}.auth-brand-icon{width:220px;height:220px;border-radius:16px;display:flex;align-items:center;justify-content:center;overflow:hidden}.auth-brand-icon img{width:100%;height:100%;object-fit:cover}.auth-brand-title{font-size:26px;font-weight:700;color:#f59e0b;letter-spacing:-.02em}.auth-brand-tagline{font-size:15px;color:var(--text-muted);line-height:1.65;margin-bottom:36px}.auth-brand-features{list-style:none;display:flex;flex-direction:column;gap:14px}.auth-brand-features li{display:flex;align-items:flex-start;gap:10px;font-size:13px;color:var(--text-muted);line-height:1.5}.auth-brand-features li:before{content:"▸";color:var(--accent);flex-shrink:0;margin-top:1px}.auth-form-area{flex:1;display:flex;align-items:center;justify-content:center;padding:40px;background:var(--bg)}.auth-card{width:100%;max-width:380px}.auth-maintenance-banner{display:flex;align-items:flex-start;gap:12px;background:#7a2d00;border:1px solid #a33c00;border-radius:8px;padding:14px 16px;margin-bottom:20px}.auth-maintenance-banner-icon{font-size:20px;flex-shrink:0;margin-top:1px}.auth-maintenance-banner-title{font-size:14px;font-weight:600;color:#fed7aa;margin-bottom:3px}.auth-maintenance-banner-msg{font-size:13px;color:#fdba74;line-height:1.4}.auth-tabs{display:flex;border-bottom:1px solid var(--border);margin-bottom:28px}.auth-tab{background:none;border:none;border-bottom:2px solid transparent;margin-bottom:-1px;padding:9px 0;margin-right:22px;color:var(--text-muted);font-size:14px;font-weight:500;cursor:pointer;transition:color var(--ease),border-color var(--ease)}.auth-tab.active{color:var(--text);border-bottom-color:var(--accent)}.auth-tab:hover:not(.active){color:var(--text)}.auth-submit{width:100%;justify-content:center;padding:10px;font-size:14px;font-weight:600;margin-top:4px;border-radius:var(--radius)}.main-layout{height:100%;display:grid;grid-template-rows:var(--header-h) 1fr var(--footer-h);overflow:hidden}.content-area{display:grid;grid-template-columns:380px 1fr;overflow:hidden;border-top:0}.left-pane{overflow:hidden;border-right:1px solid var(--border)}.right-pane{overflow:hidden}html:has(.mt-page),body:has(.mt-page){overflow:auto;height:auto}.mt-page{min-height:100vh;background:var(--bg);color:var(--text);font-family:var(--font-mono);padding:24px;box-sizing:border-box}.mt-header{max-width:900px;margin:0 auto 32px}.mt-header h1{font-size:1.4rem;color:var(--accent);margin:0 0 4px}.mt-header p{color:var(--text-muted);font-size:.85rem;margin:0}.mt-cost-warning{background:#fbbf241a;border:1px solid rgba(251,191,36,.4);color:#fbbf24;border-radius:var(--radius);padding:10px 14px;font-size:.82rem;margin-top:12px}.mt-sidecar-badge{display:inline-flex;align-items:center;gap:6px;font-size:.78rem;padding:4px 10px;border-radius:20px;border:1px solid var(--border);margin-top:10px}.mt-sidecar-badge.up{border-color:var(--success);color:var(--success)}.mt-sidecar-badge.down{border-color:var(--error);color:var(--error)}.mt-sidecar-badge.checking{color:var(--text-muted)}.mt-dot{width:7px;height:7px;border-radius:50%;background:currentColor}.mt-list{max-width:900px;margin:0 auto;display:flex;flex-direction:column;gap:10px}.mt-group-label{font-size:.72rem;text-transform:uppercase;letter-spacing:.08em;color:var(--text-muted);margin:16px 0 4px}.mt-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:14px 16px;cursor:pointer;display:flex;align-items:center;justify-content:space-between;transition:border-color .15s}.mt-card:hover{border-color:var(--accent)}.mt-card.needs-sidecar.sidecar-down{opacity:.45;cursor:not-allowed}.mt-card-left{display:flex;flex-direction:column;gap:3px}.mt-card-title{font-size:.9rem;font-weight:600}.mt-card-desc{font-size:.78rem;color:var(--text-muted)}.mt-card-tags{display:flex;gap:6px;align-items:center}.mt-tag{font-size:.68rem;padding:2px 7px;border-radius:4px;border:1px solid var(--border);color:var(--text-muted)}.mt-tag.api-key{border-color:#fbbf2466;color:#fbbf24}.mt-tag.sidecar-tag{border-color:#38bdf866;color:var(--accent)}.mt-tag.ui-only{border-color:#34d39966;color:var(--success)}.mt-result-badge{font-size:.72rem;padding:2px 8px;border-radius:10px;font-weight:700}.mt-result-badge.pass{background:#34d39926;color:var(--success)}.mt-result-badge.fail{background:#f8717126;color:var(--error)}.mt-detail{max-width:900px;margin:0 auto}.mt-back{background:none;border:none;color:var(--accent);cursor:pointer;font-family:var(--font-mono);font-size:.85rem;padding:0;margin-bottom:16px;display:flex;align-items:center;gap:6px}.mt-back:hover{opacity:.7}.mt-detail-title{font-size:1.1rem;font-weight:700;margin-bottom:4px}.mt-detail-desc{color:var(--text-muted);font-size:.83rem;margin-bottom:20px}.mt-field{margin-bottom:14px}.mt-field label{display:block;font-size:.78rem;color:var(--text-muted);margin-bottom:4px}.mt-field input,.mt-field select,.mt-field textarea{width:100%;box-sizing:border-box;background:var(--bg);border:1px solid var(--border);border-radius:var(--radius);color:var(--text);font-family:var(--font-mono);font-size:.83rem;padding:7px 10px;outline:none}.mt-field input:focus,.mt-field select:focus,.mt-field textarea:focus{border-color:var(--accent)}.mt-field textarea{resize:vertical;min-height:70px}.mt-run-row{display:flex;gap:10px;align-items:center;margin-bottom:16px;flex-wrap:wrap}.mt-log{background:#020509;border:1px solid var(--border);border-radius:var(--radius);padding:14px;min-height:180px;max-height:480px;overflow-y:auto;font-size:.78rem;line-height:1.55;white-space:pre-wrap;word-break:break-all}.mt-log-line{margin:0}.mt-log-line.dim{color:var(--text-muted)}.mt-log-line.ok{color:var(--success)}.mt-log-line.err{color:var(--error)}.mt-log-line.warn{color:#fbbf24}.mt-log-line.info{color:var(--accent)}.mt-verdict-row{display:flex;gap:10px;margin-top:14px}.mt-instructions{background:#38bdf80d;border:1px solid rgba(56,189,248,.2);border-radius:var(--radius);padding:12px 14px;font-size:.8rem;color:var(--text-muted);margin-bottom:16px;line-height:1.6}.mt-instructions b{color:var(--text)}.mt-spinner{display:inline-block;width:10px;height:10px;border:2px solid var(--border);border-top-color:var(--accent);border-radius:50%;animation:mt-spin .7s linear infinite;margin-right:6px}@keyframes mt-spin{to{transform:rotate(360deg)}}.admin-page{min-height:100vh;background:var(--bg-primary);color:var(--text-primary);padding:2rem;box-sizing:border-box}.admin-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:2rem}.admin-header-left{display:flex;align-items:center;gap:1rem}.admin-title{font-size:1.5rem;font-weight:700;margin:0}.admin-back-btn{font-size:.85rem}.admin-error{margin-bottom:1rem}.admin-stats{display:flex;gap:1.5rem;margin-bottom:2rem;flex-wrap:wrap}.admin-stat{background:var(--bg-secondary);border:1px solid var(--border);border-radius:8px;padding:1rem 1.5rem;display:flex;flex-direction:column;gap:.25rem;min-width:120px}.admin-stat-value{font-size:1.75rem;font-weight:700;color:var(--text-primary);line-height:1}.admin-stat-label{font-size:.75rem;color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em}.admin-toolbar{display:flex;align-items:center;gap:1rem;margin-bottom:1rem}.admin-search{max-width:320px;flex:1}.admin-count{font-size:.85rem;color:var(--text-muted);white-space:nowrap}.admin-loading{color:var(--text-muted);padding:2rem 0;text-align:center}.admin-table-wrap{overflow-x:auto;border:1px solid var(--border);border-radius:8px}.admin-table{width:100%;border-collapse:collapse;font-size:.875rem}.admin-table th{text-align:left;padding:.65rem 1rem;background:var(--bg-secondary);color:var(--text-muted);font-weight:600;font-size:.75rem;text-transform:uppercase;letter-spacing:.05em;border-bottom:1px solid var(--border);white-space:nowrap}.admin-table td{padding:.65rem 1rem;border-bottom:1px solid var(--border);vertical-align:middle}.admin-table tr:last-child td{border-bottom:none}.admin-table tbody tr:hover{background:var(--bg-hover, rgba(255,255,255,.03))}.admin-row-super{background:#fac8500f}.admin-td-email{font-family:monospace;font-size:.85rem}.admin-td-date{color:var(--text-muted);white-space:nowrap}.admin-td-center{text-align:center}.admin-plan-badge{display:inline-block;padding:.2em .6em;border-radius:4px;font-size:.75rem;font-weight:600;text-transform:capitalize}.admin-plan-basic{background:#64a0ff26;color:#6aa0ff}.admin-plan-agent{background:#78dc8c26;color:#78dc8c}.admin-plan-pro{background:#c878ff26;color:#c878ff}.admin-plan-trial{background:#ffc85026;color:#fac850}.admin-plan-free{background:#a0a0a01f;color:var(--text-muted)}.admin-td-subs{display:flex;flex-wrap:wrap;gap:.35rem}.admin-no-sub{color:var(--text-muted)}.admin-sub-chip{display:inline-block;padding:.15em .5em;border-radius:4px;font-size:.7rem;font-weight:600}.admin-sub-active{background:#78dc8c26;color:#78dc8c}.admin-sub-canceled{background:#ff646426;color:#ff6464}.admin-sub-past_due{background:#ffc85026;color:#fac850}.admin-super-btn{font-size:1.1rem;padding:.25rem .5rem;color:var(--text-muted);transition:color .15s}.admin-super-btn:hover{color:var(--text-primary)}.admin-super-on{color:#fac850!important}.sdm-panel{background:var(--bg-secondary);border:1px solid var(--border);border-radius:10px;padding:1.5rem;margin-bottom:2rem}.sdm-title{font-size:1rem;font-weight:700;margin:0 0 .35rem}.sdm-subtitle{font-size:.8rem;color:var(--text-muted);margin:0 0 1.25rem}.sdm-msg{margin-bottom:1rem;font-size:.85rem}.sdm-success{color:#78dc8c;background:#78dc8c1a;border:1px solid rgba(120,220,140,.25);border-radius:6px;padding:.5rem .75rem}.sdm-cards{display:flex;gap:1rem;flex-wrap:wrap}.sdm-card{flex:1;min-width:220px;background:var(--bg-primary);border:2px solid var(--border);border-radius:8px;padding:1rem 1.25rem;text-align:left;cursor:pointer;transition:border-color .15s,background .15s;color:var(--text-primary)}.sdm-card:hover:not(.sdm-card--disabled){border-color:var(--text-muted)}.sdm-card--active{border-color:var(--accent, #6aa0ff);background:#6aa0ff0d}.sdm-card--disabled{opacity:.5;cursor:not-allowed}.sdm-card-header{display:flex;align-items:center;gap:.5rem;margin-bottom:.65rem}.sdm-card-name{font-weight:700;font-size:.95rem}.sdm-badge{font-size:.65rem;font-weight:700;padding:.15em .5em;border-radius:4px;text-transform:uppercase;letter-spacing:.04em}.sdm-badge--current{background:#6aa0ff2e;color:#6aa0ff}.sdm-badge--disabled{background:#a0a0a026;color:var(--text-muted)}.sdm-card-meta{display:grid;grid-template-columns:auto 1fr;gap:.2rem .6rem;align-items:center}.sdm-meta-label{font-size:.72rem;color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em;white-space:nowrap}.sdm-meta-value{font-size:.8rem;font-family:monospace;color:var(--text-primary);word-break:break-all}.sdm-muted{color:var(--text-muted);font-family:inherit}.sdm-model-select{font-size:.8rem;padding:.2rem .4rem;height:auto}.sdm-actions{margin-top:1.25rem;display:flex;align-items:center;gap:.75rem}.sdm-confirm{display:flex;align-items:center;gap:.75rem;flex-wrap:wrap}.sdm-confirm-msg{font-size:.85rem;color:var(--text-muted)}.sdm-divider{border:none;border-top:1px solid var(--border);margin:1.5rem 0 1.25rem}.sdm-token-section{display:flex;flex-direction:column;gap:.5rem}.sdm-token-title{font-size:.9rem;font-weight:700;margin:0}.sdm-token-fields{display:flex;gap:1rem;flex-wrap:wrap;margin-top:.5rem}.sdm-token-field{flex:1;min-width:180px;margin:0}.sdm-token-label{display:block;font-size:.75rem;color:var(--text-muted);margin-bottom:.35rem}.sdm-token-save{align-self:flex-start;margin-top:.5rem}.sdm-model-section{display:flex;flex-direction:column;gap:.25rem}.sdm-model-row{display:flex;align-items:center;gap:.75rem;flex-wrap:wrap}.sdm-model-select-lg{flex:1;min-width:260px;font-size:.875rem}.sdm-muted-model{font-family:inherit;color:var(--text-muted);font-size:.8rem}.sa-overlay{z-index:2000}.sa-card{width:340px;text-align:center}.sa-card-positive .sa-icon{color:#4ade80}.sa-icon{font-size:28px;margin-bottom:10px;color:#f59e0b}.sa-title{font-size:15px;font-weight:700;color:var(--text);margin:0 0 8px}.sa-body{font-size:13px;color:var(--text-muted);line-height:1.6;margin:0 0 18px}.sa-actions{display:flex;flex-direction:column;gap:8px}.sa-btn{width:100%;justify-content:center;padding:9px;font-size:13px}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{--bg: #060b14;--surface: #0d1520;--surface-hover: #12202e;--border: #1a2d45;--border-hover: #254060;--accent: #38bdf8;--accent-dim: rgba(56, 189, 248, .12);--accent-hover: #7dd3fc;--text: #e2e8f0;--text-muted: #64748b;--error: #f87171;--error-dim: rgba(248, 113, 113, .1);--success: #34d399;--font-sans: "Outfit", -apple-system, sans-serif;--font-mono: "JetBrains Mono", "Fira Code", monospace;--radius: 8px;--radius-sm: 4px;--ease: .15s ease;--header-h: 52px;--footer-h: 36px;--bg-primary: var(--bg);--bg-secondary: var(--surface);--text-primary: var(--text);--bg-hover: var(--surface-hover);--shadow-sm: 0 4px 12px rgba(0,0,0,.35);--shadow-lg: 0 12px 40px rgba(0,0,0,.55);--overlay-bg: rgba(6,11,20,.75)}[data-theme=light]{--bg: #f1f5f9;--surface: #ffffff;--surface-hover: #f8fafc;--border: #e2e8f0;--border-hover: #cbd5e1;--accent: #0ea5e9;--accent-dim: rgba(14, 165, 233, .12);--accent-hover: #0284c7;--text: #0f172a;--text-muted: #64748b;--error: #dc2626;--error-dim: rgba(220, 38, 38, .08);--success: #059669;--shadow-sm: 0 4px 12px rgba(0,0,0,.1);--shadow-lg: 0 12px 40px rgba(0,0,0,.15);--overlay-bg: rgba(15,23,42,.5)}html,body,#root{height:100%;background:var(--bg);color:var(--text);font-family:var(--font-sans);font-size:14px;line-height:1.5;-webkit-font-smoothing:antialiased;overflow:hidden}button,input{font-family:inherit;font-size:inherit}.form-group{margin-bottom:18px}.form-label{display:block;font-size:11px;font-weight:600;color:var(--text-muted);letter-spacing:.07em;text-transform:uppercase;margin-bottom:7px}.form-input{width:100%;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:9px 13px;color:var(--text);outline:none;transition:border-color var(--ease),box-shadow var(--ease)}.form-input:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-dim)}.form-input::placeholder{color:var(--text-muted);opacity:.5}.form-error{background:var(--error-dim);border:1px solid var(--error);border-radius:var(--radius-sm);padding:9px 13px;color:var(--error);font-size:13px;margin-bottom:14px}.btn{display:inline-flex;align-items:center;gap:6px;padding:6px 12px;border-radius:var(--radius-sm);border:1px solid transparent;font-weight:500;cursor:pointer;transition:background var(--ease),border-color var(--ease),color var(--ease);white-space:nowrap;text-decoration:none}.btn-primary{background:var(--accent);color:var(--bg);border-color:var(--accent)}.btn-primary:hover:not(:disabled){background:var(--accent-hover);border-color:var(--accent-hover)}.btn-ghost{background:transparent;color:var(--text-muted);border-color:var(--border)}.btn-ghost:hover{color:var(--text);border-color:var(--border-hover);background:var(--surface-hover)}.btn-icon{background:transparent;border:none;color:var(--text-muted);padding:4px 6px;border-radius:var(--radius-sm);cursor:pointer;transition:color var(--ease),background var(--ease);display:inline-flex;align-items:center}.btn-icon:hover{color:var(--text);background:var(--surface-hover)}.btn:disabled{opacity:.45;cursor:not-allowed}
