@import"https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700&display=swap";:root{--bg: oklch(.14 .02 270);--bg-2: oklch(.16 .02 270);--panel: oklch(.19 .025 270);--panel-2: oklch(.22 .025 270);--edge: oklch(.32 .03 270);--edge-soft: oklch(.26 .025 270);--ink: oklch(.96 .01 270);--muted: oklch(.68 .02 270);--muted-2: oklch(.5 .02 270);--accent: oklch(.78 .16 65);--accent-2: oklch(.7 .18 290);--accent-3: oklch(.75 .16 200);--danger: oklch(.7 .18 25);--ok: oklch(.75 .18 145)}*{box-sizing:border-box;margin:0;padding:0}html,body,#root{height:100%}body{background:var(--bg);color:var(--ink);font-family:Inter,system-ui,-apple-system,BlinkMacSystemFont,sans-serif;font-feature-settings:"cv11","ss01";-webkit-font-smoothing:antialiased;overflow:hidden}button{font-family:inherit;cursor:pointer}input,textarea,select{font-family:inherit}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-thumb{background:var(--edge);border-radius:4px}::-webkit-scrollbar-thumb:hover{background:color-mix(in oklch,var(--edge) 70%,white)}::-webkit-scrollbar-track{background:transparent}.aurora-stage{position:fixed;top:0;right:0;bottom:0;left:0;overflow:hidden;z-index:0;pointer-events:none}.aurora{position:absolute;border-radius:50%;filter:blur(80px);opacity:.32;animation:float 22s ease-in-out infinite}.aurora-a{width:480px;height:480px;background:var(--accent);top:-120px;left:-100px}.aurora-b{width:520px;height:520px;background:var(--accent-2);bottom:-160px;right:-120px;animation-delay:-7s}.aurora-c{width:380px;height:380px;background:var(--accent-3);top:40%;left:40%;opacity:.2;animation-delay:-14s}@keyframes float{0%,to{transform:translate(0) scale(1)}33%{transform:translate(40px,-30px) scale(1.05)}66%{transform:translate(-30px,40px) scale(.95)}}.app{position:relative;z-index:1;display:grid;grid-template-columns:280px 1fr;height:100vh;width:100vw}.app.no-sidebar{grid-template-columns:1fr}.sidebar{background:color-mix(in oklch,var(--panel) 70%,transparent);-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border-right:1px solid var(--edge-soft);display:flex;flex-direction:column;overflow:hidden}.sidebar-header{display:flex;align-items:center;gap:10px;padding:18px 18px 14px;border-bottom:1px solid var(--edge-soft)}.brand-logo{width:36px;height:36px;border-radius:10px;background:linear-gradient(135deg,var(--accent),var(--accent-2));display:flex;align-items:center;justify-content:center;font-weight:700;color:#190900;color:oklch(.16 .04 60);font-size:16px;flex-shrink:0;box-shadow:0 4px 16px -4px color-mix(in oklch,var(--accent) 60%,transparent)}.brand-title{font-size:16px;font-weight:650;letter-spacing:-.01em}.brand-sub{font-size:11px;color:var(--muted);margin-top:1px}.sidebar-scroll{flex:1;overflow-y:auto;padding:12px 10px}.sidebar-section-header{display:flex;align-items:center;justify-content:space-between;padding:6px 8px;font-size:11px;text-transform:uppercase;letter-spacing:.08em;color:var(--muted-2);font-weight:600;margin-top:4px}.icon-btn{background:transparent;border:none;color:var(--muted);width:26px;height:26px;border-radius:7px;display:inline-flex;align-items:center;justify-content:center;transition:background .15s,color .15s}.icon-btn:hover{background:#ffffff12;color:var(--ink)}.project-row{display:flex;align-items:center;gap:8px;padding:9px 10px;border-radius:10px;font-size:13.5px;color:var(--ink);cursor:pointer;transition:background .15s}.project-row:hover{background:#ffffff0a}.project-row.active{background:color-mix(in oklch,var(--accent) 14%,transparent);border:1px solid color-mix(in oklch,var(--accent) 32%,var(--edge));padding:8px 9px}.project-row-name{flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;font-weight:500}.project-row-actions{display:flex;gap:2px;opacity:0;transition:opacity .15s}.project-row:hover .project-row-actions{opacity:1}.chat-list{margin:4px 0 8px 8px;border-left:1px solid var(--edge-soft);padding-left:8px;display:flex;flex-direction:column;gap:1px}.chat-row{display:flex;align-items:center;gap:7px;padding:7px 9px;border-radius:8px;font-size:12.5px;color:var(--muted);cursor:pointer;transition:background .12s,color .12s}.chat-row:hover{background:#ffffff0a;color:var(--ink)}.chat-row.active{background:color-mix(in oklch,var(--accent) 12%,transparent);border:1px solid color-mix(in oklch,var(--accent) 28%,var(--edge));padding:6px 8px;color:var(--ink)}.chat-row-title{flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.chat-row-actions{display:flex;gap:2px;opacity:0;transition:opacity .15s}.chat-row:hover .chat-row-actions{opacity:1}.chat-row .live-dot{width:7px;height:7px;border-radius:50%;background:var(--accent);box-shadow:0 0 8px var(--accent);flex-shrink:0;animation:pulse 1.4s ease-in-out infinite}@keyframes pulse{0%,to{opacity:1;transform:scale(1)}50%{opacity:.5;transform:scale(.85)}}.new-btn{display:flex;align-items:center;gap:8px;padding:9px 12px;border-radius:10px;border:1px solid color-mix(in oklch,var(--accent) 35%,var(--edge));background:color-mix(in oklch,var(--accent) 14%,var(--panel));color:var(--ink);font-size:13px;font-weight:600;width:100%;transition:background .15s}.new-btn:hover{background:color-mix(in oklch,var(--accent) 22%,var(--panel))}.sidebar-footer{padding:10px 14px;border-top:1px solid var(--edge-soft);display:flex;align-items:center;justify-content:space-between;font-size:12.5px;color:var(--muted)}.logout-btn{background:transparent;border:1px solid var(--edge);color:var(--muted);border-radius:8px;padding:5px 10px;font-size:12px;transition:background .15s,color .15s}.logout-btn:hover{background:#ffffff0f;color:var(--ink)}.main{display:flex;flex-direction:column;min-height:0;position:relative}.main-header{display:flex;align-items:center;justify-content:space-between;padding:14px 24px;border-bottom:1px solid var(--edge-soft);background:color-mix(in oklch,var(--panel) 50%,transparent);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px)}.main-title{font-size:15px;font-weight:600;display:flex;align-items:center;gap:10px}.main-subtitle{font-size:12px;color:var(--muted)}.messages{flex:1;overflow-y:auto;padding:28px 0}.messages-inner{max-width:780px;margin:0 auto;padding:0 24px;display:flex;flex-direction:column;gap:22px}.msg-row{display:flex;gap:12px}.msg-row.user{justify-content:flex-end}.msg-row.assistant{justify-content:flex-start}.msg-user-bubble{max-width:78%;background:linear-gradient(180deg,color-mix(in oklch,var(--accent) 22%,var(--panel)),color-mix(in oklch,var(--accent) 10%,var(--panel)));border:1px solid color-mix(in oklch,var(--accent) 30%,var(--edge));border-radius:16px 16px 4px;padding:11px 14px;font-size:14px;line-height:1.55;white-space:pre-wrap;word-break:break-word}.msg-assistant-block{max-width:100%;display:flex;flex-direction:column;gap:10px}.assistant-text{font-size:14.5px;line-height:1.65;color:var(--ink);word-break:break-word}.assistant-text>:first-child{margin-top:0}.assistant-text>:last-child{margin-bottom:0}.assistant-text p{margin:0 0 .7em}.assistant-text strong{font-weight:650}.assistant-text ul,.assistant-text ol{margin:0 0 .7em;padding-left:1.4em}.assistant-text li{margin:.15em 0}.assistant-text h1,.assistant-text h2,.assistant-text h3{font-size:15px;font-weight:650;margin:.6em 0 .3em}.assistant-text a{color:var(--accent);text-decoration:underline}.assistant-text code{font-family:ui-monospace,SFMono-Regular,Menlo,monospace;font-size:12.5px;background:#ffffff0d;border:1px solid var(--edge-soft);border-radius:5px;padding:1px 5px}.assistant-text pre{background:var(--bg-2);border:1px solid var(--edge-soft);border-radius:10px;padding:12px 14px;margin:0 0 .7em;overflow-x:auto}.assistant-text pre code{background:none;border:none;padding:0;font-size:12.5px;line-height:1.55}.thinking-block{border-left:2px solid color-mix(in oklch,var(--accent-2) 50%,var(--edge));padding:8px 12px;background:color-mix(in oklch,var(--accent-2) 8%,transparent);border-radius:0 10px 10px 0;font-size:13px;color:var(--muted);font-style:italic;white-space:pre-wrap}.thinking-block .label{font-style:normal;font-size:11px;text-transform:uppercase;color:var(--accent-2);font-weight:600;letter-spacing:.06em;margin-bottom:4px;display:flex;align-items:center;gap:6px}.tool-chip{display:inline-flex;align-items:center;gap:9px;font-size:13px;color:var(--ink);background:#ffffff0a;border:1px solid var(--edge-soft);border-radius:10px;padding:7px 12px}.tool-chip .tool-icon{width:22px;height:22px;border-radius:6px;background:color-mix(in oklch,var(--accent-3) 30%,var(--panel));display:inline-flex;align-items:center;justify-content:center;color:var(--accent-3)}.tool-chip .tool-desc{color:var(--muted);font-size:12.5px}.tool-result{font-size:12.5px;color:var(--muted);border-left:2px solid var(--edge);padding:4px 10px;margin-left:6px;white-space:pre-wrap;word-break:break-word;max-height:120px;overflow:hidden;position:relative}.tool-result.ok{border-left-color:var(--ok)}.tool-result.err{border-left-color:var(--danger);color:color-mix(in oklch,var(--danger) 70%,var(--ink))}.status-row{display:flex;align-items:center;gap:9px;font-size:13px;color:var(--muted)}.spinner{width:13px;height:13px;border:2px solid color-mix(in oklch,var(--accent) 30%,transparent);border-top-color:var(--accent);border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.error-block{background:color-mix(in oklch,var(--danger) 12%,var(--panel));border:1px solid color-mix(in oklch,var(--danger) 35%,var(--edge));color:color-mix(in oklch,var(--danger) 60%,var(--ink));padding:10px 13px;border-radius:10px;font-size:13px}.composer-wrap{padding:14px 24px 18px;display:flex;justify-content:center;background:linear-gradient(180deg,transparent,color-mix(in oklch,var(--bg) 90%,transparent) 35%)}.composer{width:100%;max-width:780px;background:color-mix(in oklch,var(--panel) 90%,transparent);border:1px solid var(--edge);border-radius:18px;padding:10px 12px 10px 14px;display:flex;flex-direction:column;gap:8px;transition:border-color .15s,box-shadow .2s}.composer.focus{border-color:color-mix(in oklch,var(--accent) 55%,var(--edge));box-shadow:0 0 0 3px color-mix(in oklch,var(--accent) 18%,transparent)}.composer.dragover{border-color:var(--accent);background:color-mix(in oklch,var(--accent) 14%,var(--panel))}.composer-files{display:flex;flex-wrap:wrap;gap:6px}.composer-file{display:inline-flex;align-items:center;gap:6px;background:var(--bg-2);border:1px solid var(--edge-soft);border-radius:8px;padding:4px 8px;font-size:12px;color:var(--muted)}.composer-file button{background:transparent;border:none;color:var(--muted-2);display:inline-flex;align-items:center;padding:0}.composer-file button:hover{color:var(--danger)}.composer textarea{background:transparent;border:none;outline:none;color:var(--ink);font-size:14.5px;line-height:1.5;resize:none;min-height:28px;max-height:240px;padding:4px 0;width:100%}.composer-toolbar{display:flex;align-items:center;justify-content:space-between;gap:8px}.composer-tools{display:flex;gap:4px}.composer-send{background:linear-gradient(135deg,var(--accent),var(--accent-2));color:#1e0d01;border:none;border-radius:12px;padding:8px 16px;font-weight:600;font-size:13.5px;display:inline-flex;align-items:center;gap:6px;transition:transform .1s,box-shadow .2s,opacity .2s}.composer-send:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 8px 24px -8px color-mix(in oklch,var(--accent) 60%,transparent)}.composer-send:disabled{opacity:.4;cursor:not-allowed}.composer-stop{background:color-mix(in oklch,var(--danger) 20%,var(--panel));border:1px solid color-mix(in oklch,var(--danger) 45%,var(--edge));color:color-mix(in oklch,var(--danger) 60%,var(--ink));border-radius:12px;padding:7px 14px;font-size:13px;font-weight:600;display:inline-flex;gap:6px;align-items:center}.empty-state{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:40px 20px;text-align:center;color:var(--muted);gap:14px}.empty-state .big-logo{width:64px;height:64px;border-radius:16px;background:linear-gradient(135deg,var(--accent),var(--accent-2));display:flex;align-items:center;justify-content:center;font-weight:700;font-size:26px;color:#1e0d01;box-shadow:0 12px 40px -10px color-mix(in oklch,var(--accent) 60%,transparent)}.empty-state h2{color:var(--ink);font-size:22px;font-weight:650}.empty-state p{font-size:14px;max-width:420px;line-height:1.55}.login-page{position:relative;z-index:1;display:flex;align-items:center;justify-content:center;min-height:100vh;padding:24px}.login-card{width:100%;max-width:380px;background:color-mix(in oklch,var(--panel) 80%,transparent);-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border:1px solid var(--edge);border-radius:20px;padding:32px 28px;box-shadow:0 30px 80px -20px #0009}.login-brand{display:flex;flex-direction:column;align-items:center;gap:12px;margin-bottom:26px}.login-brand .big-logo{width:60px;height:60px;border-radius:16px;background:linear-gradient(135deg,var(--accent),var(--accent-2));display:flex;align-items:center;justify-content:center;font-weight:700;font-size:24px;color:#1e0d01;box-shadow:0 14px 40px -12px color-mix(in oklch,var(--accent) 60%,transparent)}.login-brand h1{font-size:22px;font-weight:650;letter-spacing:-.01em}.login-brand .tagline{font-size:13px;color:var(--muted)}.login-card label{font-size:11px;color:var(--muted);text-transform:uppercase;letter-spacing:.08em;font-weight:600;display:block;margin-bottom:6px}.login-card input{width:100%;background:#00000047;border:1px solid var(--edge);border-radius:12px;padding:11px 14px;color:var(--ink);font-size:14px;outline:none;margin-bottom:14px;transition:border-color .15s,box-shadow .2s}.login-card input:focus{border-color:color-mix(in oklch,var(--accent) 55%,var(--edge));box-shadow:0 0 0 3px color-mix(in oklch,var(--accent) 18%,transparent)}.login-card button.primary{width:100%;background:linear-gradient(135deg,var(--accent),var(--accent-2));color:#1e0d01;border:none;border-radius:12px;padding:12px;font-weight:650;font-size:14px;margin-top:8px;transition:transform .1s,box-shadow .2s,opacity .2s}.login-card button.primary:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 8px 24px -8px color-mix(in oklch,var(--accent) 60%,transparent)}.login-card button.primary:disabled{opacity:.5;cursor:wait}.login-error{background:color-mix(in oklch,var(--danger) 12%,var(--panel));border:1px solid color-mix(in oklch,var(--danger) 35%,var(--edge));color:color-mix(in oklch,var(--danger) 60%,var(--ink));padding:9px 12px;border-radius:10px;font-size:13px;margin-bottom:14px}.modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#0000008c;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);display:flex;align-items:center;justify-content:center;z-index:100;padding:20px}.modal{background:var(--panel);border:1px solid var(--edge);border-radius:16px;padding:22px 22px 18px;width:100%;max-width:420px;box-shadow:0 30px 80px -20px #0009}.modal h3{font-size:16px;font-weight:650;margin-bottom:14px}.modal label{font-size:11px;color:var(--muted);text-transform:uppercase;letter-spacing:.08em;font-weight:600;display:block;margin-bottom:6px}.modal input,.modal textarea{width:100%;background:#00000047;border:1px solid var(--edge);border-radius:10px;padding:10px 12px;color:var(--ink);font-size:14px;outline:none;margin-bottom:12px}.modal input:focus,.modal textarea:focus{border-color:color-mix(in oklch,var(--accent) 55%,var(--edge))}.modal-actions{display:flex;justify-content:flex-end;gap:8px;margin-top:6px}.btn-ghost{background:transparent;border:1px solid var(--edge);color:var(--ink);border-radius:10px;padding:8px 14px;font-size:13px}.btn-ghost:hover{background:#ffffff0a}.btn-primary{background:linear-gradient(135deg,var(--accent),var(--accent-2));color:#1e0d01;border:none;border-radius:10px;padding:8px 16px;font-weight:600;font-size:13px}.fade-in{animation:fadeIn .25s ease-out}@keyframes fadeIn{0%{opacity:0;transform:translateY(4px)}to{opacity:1;transform:translateY(0)}}.live-tag{display:inline-flex;align-items:center;gap:6px;background:color-mix(in oklch,var(--accent) 14%,transparent);border:1px solid color-mix(in oklch,var(--accent) 35%,var(--edge));color:var(--accent);border-radius:999px;padding:3px 10px;font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.06em}.activity{background:color-mix(in oklch,var(--panel) 70%,transparent);border:1px solid var(--edge-soft);border-radius:12px;overflow:hidden;margin-bottom:6px}.activity.streaming{border-color:color-mix(in oklch,var(--accent) 35%,var(--edge));background:color-mix(in oklch,var(--accent) 8%,var(--panel))}.activity-header{display:flex;align-items:center;gap:8px;width:100%;padding:9px 12px;background:transparent;border:none;color:var(--ink);font-size:12.5px;font-weight:600;text-align:left;cursor:pointer}.activity-header:hover{background:#ffffff0a}.activity-running{display:inline-flex;align-items:center;gap:7px;color:var(--accent)}.activity-done{display:inline-flex;align-items:center;gap:7px;color:var(--muted)}.activity-body{border-top:1px solid var(--edge-soft);padding:6px 4px 8px;display:flex;flex-direction:column;gap:2px;max-height:480px;overflow-y:auto}.activity-step{padding:0 8px}.activity-step.pending{opacity:.85}.activity-step .step-row{display:flex;align-items:center;gap:8px;width:100%;padding:6px 8px;background:transparent;border:none;border-radius:7px;color:var(--ink);font-size:12.5px;text-align:left;cursor:pointer}.activity-step .step-row:hover{background:#ffffff0d}.step-icon{flex-shrink:0;width:22px;height:22px;border-radius:6px;display:inline-flex;align-items:center;justify-content:center;background:#ffffff0d;color:var(--muted)}.step-icon.thinking{background:color-mix(in oklch,var(--accent-2) 22%,transparent);color:var(--accent-2)}.step-icon.tool-read{background:color-mix(in oklch,var(--accent-3) 22%,transparent);color:var(--accent-3)}.step-icon.tool-write{background:color-mix(in oklch,var(--ok) 22%,transparent);color:var(--ok)}.step-icon.tool-edit{background:color-mix(in oklch,var(--accent) 22%,transparent);color:var(--accent)}.step-icon.tool-bash{background:#ffffff14;color:var(--ink)}.step-icon.tool-web{background:color-mix(in oklch,var(--accent-3) 22%,transparent);color:var(--accent-3)}.step-icon.tool-search{background:color-mix(in oklch,var(--accent-2) 22%,transparent);color:var(--accent-2)}.step-title{font-weight:600;flex-shrink:0;color:var(--ink)}.step-sub{flex:1;min-width:0;color:var(--muted);overflow:hidden;text-overflow:ellipsis;white-space:nowrap;font-size:12px}.step-status{flex-shrink:0;display:inline-flex;align-items:center}.step-status .ok-icon{color:var(--ok)}.step-status .err-icon{color:var(--danger)}.step-chev{flex-shrink:0;color:var(--muted-2)}.step-detail{padding:6px 8px 10px 38px;font-size:12.5px;color:var(--muted);display:flex;flex-direction:column;gap:7px}.thinking-detail{font-style:italic;white-space:pre-wrap;line-height:1.55;padding-top:0}.step-input-label,.step-result-label{font-size:10.5px;text-transform:uppercase;letter-spacing:.06em;color:var(--muted-2);font-weight:600;margin-bottom:3px}.step-output{background:#00000052;border:1px solid var(--edge-soft);border-radius:8px;padding:8px 10px;font-family:ui-monospace,SFMono-Regular,Menlo,monospace;font-size:11.5px;line-height:1.5;color:var(--ink);white-space:pre-wrap;word-break:break-word;max-height:320px;overflow-y:auto;margin:0}.step-output.err{border-color:color-mix(in oklch,var(--danger) 40%,var(--edge));color:color-mix(in oklch,var(--danger) 60%,var(--ink))}.step-output.code,.step-output.diff{white-space:pre;overflow-x:auto}.step-output.diff{color:var(--ink)}.step-output.diff:first-line{color:var(--danger)}.step-output.diff{background:linear-gradient(90deg,transparent 0,transparent 100%)}.ask-block{background:color-mix(in oklch,var(--accent) 10%,var(--panel));border:1px solid color-mix(in oklch,var(--accent) 28%,var(--edge));border-radius:14px;padding:12px 14px;display:flex;flex-direction:column;gap:9px}.ask-question{font-size:13.5px;font-weight:600;color:var(--ink);line-height:1.45}.ask-options{display:flex;flex-wrap:wrap;gap:7px}.ask-btn{background:#ffffff0a;border:1px solid color-mix(in oklch,var(--accent) 35%,var(--edge));color:var(--ink);border-radius:999px;padding:7px 14px;font-size:13px;font-weight:500;transition:background .15s,border-color .15s,transform .05s}.ask-btn:hover{background:color-mix(in oklch,var(--accent) 18%,var(--panel));border-color:color-mix(in oklch,var(--accent) 55%,var(--edge))}.ask-btn:active{transform:translateY(1px)}.app.with-preview{grid-template-columns:260px 1fr var(--preview-w, 1fr)}.app.with-preview.chat-collapsed{grid-template-columns:260px 1fr}.app.with-preview.chat-collapsed>.main{display:none}.preview-pane{position:relative;display:flex;flex-direction:column;background:color-mix(in oklch,var(--panel) 60%,transparent);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border-left:1px solid var(--edge-soft);min-width:0}.preview-resizer{position:absolute;left:-3px;top:0;bottom:0;width:8px;z-index:5;cursor:col-resize;touch-action:none}.preview-resizer:after{content:"";position:absolute;left:3px;top:0;bottom:0;width:2px;background:transparent;transition:background .15s}.preview-resizer:hover:after,.preview-resizer:active:after{background:color-mix(in oklch,var(--accent) 70%,transparent)}.preview-header{display:flex;align-items:center;gap:8px;padding:10px 12px;border-bottom:1px solid var(--edge-soft);background:color-mix(in oklch,var(--panel) 80%,transparent)}.preview-controls{display:flex;gap:2px}.preview-url{flex:1;background:#00000052;border:1px solid var(--edge);border-radius:8px;padding:6px 10px;color:var(--ink);font-size:12.5px;font-family:ui-monospace,monospace;outline:none;min-width:0}.preview-url:focus{border-color:color-mix(in oklch,var(--accent) 55%,var(--edge))}.preview-frame{flex:1;width:100%;border:none;background:#fff}.preview-empty{flex:1;display:flex;flex-direction:column;align-items:stretch;justify-content:center;padding:30px 28px;color:var(--muted);gap:8px;text-align:left}.preview-empty>svg{align-self:center;opacity:.5}.preview-empty h3{color:var(--ink);font-size:16px;font-weight:650;text-align:center}.preview-empty p{font-size:13px;line-height:1.5;text-align:center}.preview-cmd{display:flex;flex-direction:column;gap:4px;margin-top:14px}.preview-cmd label{font-size:11px;color:var(--muted);text-transform:uppercase;letter-spacing:.08em;font-weight:600}.preview-cmd textarea{background:#00000052;border:1px solid var(--edge);border-radius:10px;padding:9px 11px;color:var(--ink);font-size:12.5px;font-family:ui-monospace,monospace;outline:none;resize:vertical}.preview-cmd code{font-family:ui-monospace,monospace;background:#ffffff0d;padding:1px 4px;border-radius:4px;font-size:11px}.preview-footer{display:flex;align-items:center;gap:8px;padding:8px 12px;border-top:1px solid var(--edge-soft);font-size:12px;color:var(--muted)}.preview-port{flex:1;font-family:ui-monospace,monospace;font-size:11.5px;color:var(--muted-2)}.preview-sharelabel{flex-shrink:0;font-size:11px;color:var(--muted-2);text-transform:uppercase;letter-spacing:.04em}.preview-shareurl{flex:1;min-width:0;background:var(--surface-2, rgba(255,255,255,.04));border:1px solid var(--edge-soft);border-radius:7px;padding:5px 9px;font-family:ui-monospace,monospace;font-size:11.5px;color:var(--muted);outline:none}.preview-shareurl:focus{border-color:color-mix(in oklch,var(--accent) 55%,var(--edge));color:var(--ink)}.ghost-mini{background:transparent;border:1px solid var(--edge);color:var(--muted);border-radius:7px;padding:4px 9px;font-size:11.5px;display:inline-flex;align-items:center;gap:4px}.ghost-mini:hover{background:#ffffff0d;color:var(--ink)}.ghost-mini.danger{color:color-mix(in oklch,var(--danger) 65%,var(--ink));border-color:color-mix(in oklch,var(--danger) 40%,var(--edge))}.ghost-mini.danger:hover{background:color-mix(in oklch,var(--danger) 12%,transparent)}.preview-logs{max-height:180px;overflow:auto;background:#0006;border-top:1px solid var(--edge-soft);padding:8px 12px;font-size:11.5px;color:var(--muted);font-family:ui-monospace,monospace;white-space:pre-wrap;word-break:break-all}.spin{animation:spin .8s linear infinite}.main-header-actions{display:flex;align-items:center;gap:8px}.speed-picker{display:flex;gap:2px;padding:3px;background:#00000047;border:1px solid var(--edge);border-radius:10px}.speed-opt{display:inline-flex;align-items:center;gap:5px;background:transparent;border:none;color:var(--muted);padding:5px 10px;border-radius:7px;font-size:11.5px;font-weight:600;transition:background .15s,color .15s}.speed-opt:hover:not(.active){color:var(--ink);background:#ffffff0a}.speed-opt.active{background:linear-gradient(135deg,color-mix(in oklch,var(--accent) 30%,var(--panel)),color-mix(in oklch,var(--accent-2) 30%,var(--panel)));color:var(--ink);box-shadow:0 1px 2px #0000004d}@media(max-width:768px){.speed-opt span:not(.sr-only){display:none}}.mobile-toggle{display:none}@media(max-width:768px){.app{grid-template-columns:1fr}.sidebar{position:fixed;top:0;right:0;bottom:0;left:0;z-index:50;transform:translate(-100%);transition:transform .25s ease}.sidebar.open{transform:translate(0)}.mobile-toggle{display:inline-flex;align-items:center;justify-content:center;width:36px;height:36px;border-radius:9px;background:var(--panel);border:1px solid var(--edge);color:var(--ink)}}.apps-overview{flex:1;overflow-y:auto;padding:40px 32px 60px}.apps-overview-head{max-width:1000px;margin:0 auto 26px}.apps-overview-head h2{font-size:22px;font-weight:700;letter-spacing:-.01em}.apps-overview-head p{margin-top:6px;font-size:13.5px;color:var(--muted);max-width:560px}.apps-grid{max-width:1000px;margin:0 auto;display:grid;grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:16px}.app-card{display:flex;flex-direction:column;gap:10px;background:var(--panel);border:1px solid var(--edge-soft);border-radius:14px;padding:16px;min-height:132px;transition:border-color .15s,transform .15s,box-shadow .15s}.app-card:hover{border-color:color-mix(in oklch,var(--accent) 40%,var(--edge));transform:translateY(-2px);box-shadow:0 10px 30px #00000047}.app-card-top{display:flex;align-items:center;gap:8px}.app-card-name{flex:1;font-weight:600;font-size:14.5px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.app-badge{flex-shrink:0;font-size:10.5px;font-weight:600;padding:2px 8px;border-radius:999px;text-transform:uppercase;letter-spacing:.03em}.app-badge.live{color:var(--ok);background:color-mix(in oklch,var(--ok) 14%,transparent);border:1px solid color-mix(in oklch,var(--ok) 35%,transparent)}.app-badge.empty{color:var(--muted-2);background:#ffffff0a;border:1px solid var(--edge-soft)}.app-card-desc{flex:1;font-size:12.5px;color:var(--muted);line-height:1.45;display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden}.app-card-actions{display:flex;gap:8px;margin-top:auto}.app-btn{display:inline-flex;align-items:center;gap:6px;cursor:pointer;font-size:12.5px;font-weight:500;padding:7px 12px;border-radius:9px;border:1px solid var(--edge);background:transparent;color:var(--ink);text-decoration:none;transition:background .15s,border-color .15s}.app-btn:hover{background:#ffffff0d}.app-btn.primary{background:color-mix(in oklch,var(--accent) 18%,transparent);border-color:color-mix(in oklch,var(--accent) 45%,var(--edge));color:var(--ink)}.app-btn.primary:hover{background:color-mix(in oklch,var(--accent) 28%,transparent)}.app-card--new{align-items:center;justify-content:center;gap:10px;border-style:dashed;cursor:pointer;color:var(--muted)}.app-card--new:hover{color:var(--ink);border-color:color-mix(in oklch,var(--accent) 50%,var(--edge))}.app-card-newicon{width:42px;height:42px;display:grid;place-items:center;border-radius:12px;background:color-mix(in oklch,var(--accent) 16%,transparent);color:var(--accent)}.app-card-newlabel{font-size:13px;font-weight:600}.app-livedot{width:7px;height:7px;border-radius:50%;background:var(--ok);flex-shrink:0;box-shadow:0 0 0 3px color-mix(in oklch,var(--ok) 18%,transparent)}@media(max-width:640px){.apps-overview{padding:24px 16px 50px}.apps-grid{grid-template-columns:1fr}}.trash-modal{max-width:540px;width:92vw}.trash-head{display:flex;align-items:center;justify-content:space-between}.trash-head h3{font-size:17px;font-weight:700}.trash-sub{font-size:12.5px;color:var(--muted);margin:4px 0 14px}.trash-empty{padding:28px 8px;text-align:center;color:var(--muted-2);font-size:13px}.trash-list{display:flex;flex-direction:column;gap:8px;max-height:56vh;overflow-y:auto}.trash-item{display:flex;align-items:center;gap:12px;background:var(--panel-2);border:1px solid var(--edge-soft);border-radius:11px;padding:11px 13px}.trash-item-info{flex:1;min-width:0}.trash-item-name{font-weight:600;font-size:13.5px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.trash-item-desc{font-size:12px;color:var(--muted);margin-top:2px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.trash-item-actions{display:flex;gap:7px;flex-shrink:0}.app-btn.danger{color:color-mix(in oklch,var(--danger) 75%,var(--ink));border-color:color-mix(in oklch,var(--danger) 38%,var(--edge))}.app-btn.danger:hover{background:color-mix(in oklch,var(--danger) 14%,transparent)}.app-btn:disabled{opacity:.5;cursor:default}@media(max-width:520px){.trash-item{flex-direction:column;align-items:stretch}.trash-item-actions{justify-content:flex-end}}.sidebar-collapse-btn{flex-shrink:0}.sidebar-expand-btn{position:absolute;top:12px;left:12px;z-index:10;display:none;align-items:center;justify-content:center;width:36px;height:36px;border-radius:9px;background:var(--panel);border:1px solid var(--edge);color:var(--ink);cursor:pointer;transition:background .15s,border-color .15s}.sidebar-expand-btn:hover{background:var(--panel-2);border-color:color-mix(in oklch,var(--accent) 45%,var(--edge))}@media(min-width:769px){.app.sidebar-collapsed{grid-template-columns:1fr}.app.sidebar-collapsed.with-preview{grid-template-columns:1fr var(--preview-w, 1fr)}.app.sidebar-collapsed.with-preview.chat-collapsed{grid-template-columns:1fr}.app.sidebar-collapsed .sidebar{display:none}.app.sidebar-collapsed .sidebar-expand-btn{display:inline-flex}}.longchat-tip{display:flex;align-items:center;gap:12px;margin:0 16px 8px;padding:9px 12px;background:color-mix(in oklch,var(--accent) 12%,var(--panel));border:1px solid color-mix(in oklch,var(--accent) 35%,var(--edge));border-radius:11px;font-size:12.5px;color:var(--ink)}.longchat-tip-text{flex:1;line-height:1.4;color:var(--muted)}.longchat-tip-btn{flex-shrink:0;cursor:pointer;font-size:12px;font-weight:600;padding:6px 12px;border-radius:8px;border:1px solid color-mix(in oklch,var(--accent) 45%,var(--edge));background:color-mix(in oklch,var(--accent) 20%,transparent);color:var(--ink)}.longchat-tip-btn:hover{background:color-mix(in oklch,var(--accent) 30%,transparent)}.longchat-tip-x{flex-shrink:0;cursor:pointer;width:24px;height:24px;border-radius:7px;border:none;background:transparent;color:var(--muted-2);font-size:18px;line-height:1}.longchat-tip-x:hover{background:#ffffff0f;color:var(--ink)}.sidebar-search-trigger{display:flex;align-items:center;gap:8px;width:100%;padding:8px 10px;margin-bottom:8px;cursor:pointer;background:var(--panel-2);border:1px solid var(--edge-soft);border-radius:9px;color:var(--muted);font-size:12.5px;text-align:left}.sidebar-search-trigger:hover{border-color:color-mix(in oklch,var(--accent) 40%,var(--edge));color:var(--ink)}.sidebar-search-trigger span{flex:1}.sidebar-search-trigger kbd{font-size:10.5px;padding:1px 5px;border-radius:5px;background:var(--bg-2);border:1px solid var(--edge-soft);color:var(--muted-2)}.search-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;z-index:200;background:#00000073;-webkit-backdrop-filter:blur(3px);backdrop-filter:blur(3px);display:flex;align-items:flex-start;justify-content:center;padding-top:12vh}.search-palette{width:min(620px,92vw);max-height:70vh;display:flex;flex-direction:column;background:var(--panel);border:1px solid var(--edge);border-radius:14px;box-shadow:0 24px 70px #00000080;overflow:hidden}.search-inputrow{display:flex;align-items:center;gap:10px;padding:12px 14px;border-bottom:1px solid var(--edge-soft)}.search-inputicon{color:var(--muted-2);flex-shrink:0}.search-input{flex:1;background:transparent;border:none;outline:none;color:var(--ink);font-size:15px;font-family:inherit}.search-results{overflow-y:auto;padding:6px}.search-group-title{font-size:10.5px;text-transform:uppercase;letter-spacing:.05em;color:var(--muted-2);padding:10px 10px 5px}.search-empty{padding:8px 12px;font-size:12.5px;color:var(--muted-2)}.search-item{display:flex;align-items:center;gap:10px;width:100%;text-align:left;padding:8px 10px;border-radius:9px;border:none;background:transparent;color:var(--ink);cursor:pointer}.search-item:hover{background:color-mix(in oklch,var(--accent) 12%,transparent)}.search-item-ic{color:var(--muted);flex-shrink:0}.search-item-main{flex:1;font-size:13.5px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.search-item-col{flex:1;min-width:0;display:flex;flex-direction:column;gap:1px}.search-item-snippet{font-size:13px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.search-item-sub{font-size:11.5px;color:var(--muted-2);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.search-badge{flex-shrink:0;font-size:10px;font-weight:600;padding:1px 7px;border-radius:999px;color:var(--ok);background:color-mix(in oklch,var(--ok) 14%,transparent)}.search-foot{padding:8px 14px;border-top:1px solid var(--edge-soft);font-size:11px;color:var(--muted-2)}.search-foot kbd{font-family:inherit;padding:1px 5px;border-radius:4px;background:var(--bg-2);border:1px solid var(--edge-soft)}.preview-stage{flex:1;min-height:0;display:flex}.preview-stage>.preview-frame{flex:1;width:100%;height:100%}.preview-stage.mobile{justify-content:center;align-items:stretch;overflow:auto;background:color-mix(in oklch,var(--bg) 55%,#000);padding:14px}.preview-stage.mobile>.preview-frame{flex:0 0 auto;width:390px;max-width:100%;height:100%;border-radius:16px;border:1px solid var(--edge);box-shadow:0 10px 40px #00000073}.icon-btn.active{background:color-mix(in oklch,var(--accent) 22%,transparent);color:var(--ink)}.retry-row{display:flex;align-items:center;gap:12px;margin:8px 0 4px;padding:10px 12px;border-radius:10px;background:color-mix(in oklch,var(--danger) 8%,var(--panel));border:1px solid color-mix(in oklch,var(--danger) 28%,var(--edge));font-size:12.5px;color:var(--muted)}.retry-row span{flex:1}.retry-btn{display:inline-flex;align-items:center;gap:6px;flex-shrink:0;cursor:pointer;font-size:12.5px;font-weight:600;padding:6px 12px;border-radius:8px;border:1px solid var(--edge);background:var(--panel-2);color:var(--ink)}.retry-btn:hover{background:color-mix(in oklch,var(--accent) 16%,var(--panel-2));border-color:color-mix(in oklch,var(--accent) 45%,var(--edge))}.versions-modal{max-width:560px;width:92vw}.versions-head{display:flex;align-items:center;justify-content:space-between}.versions-head h3{font-size:17px;font-weight:700}.versions-sub{font-size:12.5px;color:var(--muted);margin:4px 0 14px}.versions-empty{padding:26px 8px;text-align:center;color:var(--muted-2);font-size:13px}.versions-list{display:flex;flex-direction:column;gap:8px;max-height:56vh;overflow-y:auto}.versions-item{display:flex;align-items:center;gap:12px;background:var(--panel-2);border:1px solid var(--edge-soft);border-radius:11px;padding:11px 13px}.versions-item-info{flex:1;min-width:0}.versions-item-when{font-weight:600;font-size:13.5px;display:flex;align-items:center;gap:8px}.versions-badge{font-size:10px;font-weight:600;padding:1px 7px;border-radius:999px;color:var(--accent);background:color-mix(in oklch,var(--accent) 16%,transparent)}.versions-item-label{font-size:12px;color:var(--muted);margin-top:2px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.composer-thumb{position:relative;width:46px;height:46px;border-radius:8px;overflow:hidden;border:1px solid var(--edge);flex-shrink:0}.composer-thumb img{width:100%;height:100%;object-fit:cover;display:block}.composer-thumb-x{position:absolute;top:2px;right:2px;width:16px;height:16px;padding:0;display:grid;place-items:center;border:none;border-radius:50%;background:#0009;color:#fff;cursor:pointer}.composer-thumb-x:hover{background:#000000d9}.trash-group{font-size:10.5px;text-transform:uppercase;letter-spacing:.05em;color:var(--muted-2);padding:6px 2px 2px}.trash-group:first-child{padding-top:0}.dialog-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;z-index:400;background:#00000080;-webkit-backdrop-filter:blur(3px);backdrop-filter:blur(3px);display:flex;align-items:center;justify-content:center;padding:20px}.dialog-box{width:min(420px,94vw);background:var(--panel);border:1px solid var(--edge);border-radius:14px;box-shadow:0 24px 70px #00000080;padding:22px}.dialog-title{font-size:16px;font-weight:700;margin-bottom:8px}.dialog-msg{font-size:13.5px;color:var(--muted);line-height:1.5}.dialog-input{width:100%;margin-top:14px;padding:10px 12px;font-size:14px;font-family:inherit;background:var(--panel-2);border:1px solid var(--edge);border-radius:9px;color:var(--ink);outline:none}.dialog-input:focus{border-color:color-mix(in oklch,var(--accent) 55%,var(--edge))}.dialog-actions{display:flex;justify-content:flex-end;gap:10px;margin-top:20px}.btn-primary.btn-danger{background:color-mix(in oklch,var(--danger) 88%,#000);border-color:transparent;color:#fff}.btn-primary.btn-danger:hover{background:var(--danger)}.toast-stack{position:fixed;left:50%;bottom:24px;transform:translate(-50%);z-index:500;display:flex;flex-direction:column;gap:8px;align-items:center;pointer-events:none}.toast{pointer-events:auto;display:flex;align-items:center;gap:14px;background:var(--panel-2);border:1px solid var(--edge);border-radius:11px;padding:10px 12px 10px 16px;box-shadow:0 12px 40px #00000073;font-size:13.5px;color:var(--ink);max-width:92vw}.toast-msg{white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.toast-action{flex-shrink:0;cursor:pointer;font-size:13px;font-weight:600;padding:5px 12px;border-radius:8px;border:1px solid color-mix(in oklch,var(--accent) 45%,var(--edge));background:color-mix(in oklch,var(--accent) 20%,transparent);color:var(--ink)}.toast-action:hover{background:color-mix(in oklch,var(--accent) 32%,transparent)}.toast-x{flex-shrink:0;width:22px;height:22px;display:grid;place-items:center;border:none;background:transparent;color:var(--muted-2);font-size:17px;cursor:pointer;border-radius:6px}.toast-x:hover{background:#ffffff0f;color:var(--ink)}@media(max-width:768px){.preview-resizer{display:none}.app.with-preview,.app.with-preview.chat-collapsed{grid-template-columns:1fr}.app.with-preview>.main{display:none}}
