@import"https://fonts.googleapis.com/css2?family=Fraunces:opsz,wght@9..144,400;9..144,600;9..144,800&family=JetBrains+Mono:wght@400;500;700&display=swap";:root{--bg: #0d0d0f;--bg-elev: #16161a;--bg-card: #1c1c21;--border: #2a2a32;--border-bright: #3a3a44;--fg: #f5f5f0;--fg-dim: #8a8a92;--fg-mute: #5a5a62;--accent: #d4ff3a;--accent-dim: #9bc100;--danger: #ff5c5c;--success: #4ade80;--tool: #c084fc;--agent: #60a5fa}:root[data-theme=light]{--bg: #ffffff;--bg-elev: #f7f7f5;--bg-card: #f0f0ec;--border: #e0e0d8;--border-bright: #cccac0;--fg: #1a1a1a;--fg-dim: #6a6a62;--fg-mute: #9a9a92;--accent: #5d8600;--accent-dim: #7aa300;--danger: #dc2626;--success: #16a34a;--tool: #9333ea;--agent: #2563eb}*{box-sizing:border-box}html,body{margin:0;padding:0;background:var(--bg);color:var(--fg);font-family:-apple-system,Segoe UI,PingFang SC,Microsoft YaHei,sans-serif;font-size:14px;line-height:1.6;background-image:radial-gradient(ellipse at 20% 0%,rgba(212,255,58,.04),transparent 50%),radial-gradient(ellipse at 80% 100%,rgba(192,132,252,.03),transparent 50%);background-attachment:fixed}body:before{content:"";position:fixed;top:0;right:0;bottom:0;left:0;pointer-events:none;z-index:1;opacity:.025;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='200' height='200'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='3'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E")}#root{position:relative;z-index:2}.font-display{font-family:Fraunces,PingFang SC,serif;font-optical-sizing:auto}.font-mono{font-family:JetBrains Mono,monospace}.app-shell{max-width:1400px;margin:0 auto;padding:0}.app-header{display:flex;align-items:center;justify-content:space-between;padding:28px 40px;border-bottom:1px solid var(--border);position:sticky;top:0;background:#0d0d0fd9;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);z-index:10}.app-logo{font-family:Fraunces,serif;font-weight:800;font-size:22px;letter-spacing:-.02em}.app-logo .dot{color:var(--accent)}.app-nav{display:flex;gap:4px}.nav-tab{font-family:JetBrains Mono,monospace;font-size:11px;letter-spacing:.08em;text-transform:uppercase;padding:8px 14px;color:var(--fg-dim);background:none;border:1px solid transparent;border-radius:4px;cursor:pointer;transition:all .2s}.nav-tab:hover{color:var(--fg);border-color:var(--border)}.nav-tab.active{color:var(--accent);border-color:var(--border-bright);background:var(--bg-elev)}.status-pill{font-family:JetBrains Mono,monospace;font-size:11px;display:flex;align-items:center;gap:6px;color:var(--fg-dim)}.status-dot{width:7px;height:7px;border-radius:50%;background:var(--success);animation:pulse 2s ease-in-out infinite}.status-dot.off{background:var(--danger);animation:none}@keyframes pulse{0%,to{opacity:1;box-shadow:0 0 #4ade8066}50%{opacity:.6;box-shadow:0 0 0 6px #4ade8000}}.workspace{display:grid;grid-template-columns:380px 1fr;gap:0;min-height:calc(100vh - 73px)}@media (max-width: 900px){.workspace{grid-template-columns:1fr}}.control-panel{border-right:1px solid var(--border);padding:32px 28px;background:#16161a66}.section-label{font-family:JetBrains Mono,monospace;font-size:10px;letter-spacing:.15em;text-transform:uppercase;color:var(--fg-mute);margin-bottom:10px;display:flex;align-items:center;gap:8px}.section-label .num{color:var(--accent);font-weight:700}.section-block{margin-bottom:32px}.field{width:100%;background:var(--bg);border:1px solid var(--border);color:var(--fg);padding:10px 12px;font-size:13px;font-family:inherit;border-radius:4px;outline:none;transition:border-color .15s}.field:focus{border-color:var(--accent-dim)}.field::placeholder{color:var(--fg-mute)}textarea.field{resize:vertical;min-height:70px;line-height:1.5}.upload-zone{border:1px dashed var(--border-bright);border-radius:6px;padding:20px;text-align:center;cursor:pointer;transition:all .2s;position:relative;overflow:hidden}.upload-zone:hover{border-color:var(--accent-dim);background:#d4ff3a08}.upload-zone.has-img{padding:0;border-style:solid}.upload-preview{width:100%;max-height:180px;object-fit:cover;border-radius:6px;display:block}.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:11px 18px;font-size:13px;font-weight:600;font-family:inherit;border:none;border-radius:4px;cursor:pointer;transition:all .15s;letter-spacing:.01em}.btn-primary{background:var(--accent);color:var(--bg)}.btn-primary:hover:not(:disabled){background:#e4ff5e;transform:translateY(-1px)}.btn-primary:disabled{background:var(--border);color:var(--fg-mute);cursor:not-allowed}.btn-ghost{background:transparent;color:var(--fg-dim);border:1px solid var(--border)}.btn-ghost:hover{color:var(--fg);border-color:var(--border-bright)}.btn-sm{padding:6px 12px;font-size:11px}.btn-block{width:100%}.output-panel{padding:32px 40px;overflow-y:auto}.timeline{background:var(--bg-card);border:1px solid var(--border);border-radius:6px;padding:0;min-height:280px;max-height:460px;overflow-y:auto}.timeline-empty{display:flex;align-items:center;justify-content:center;min-height:280px;color:var(--fg-mute);font-size:13px;text-align:center;flex-direction:column;gap:8px}.timeline-row{display:flex;gap:12px;padding:12px 16px;border-bottom:1px solid var(--border);animation:fadeIn .3s ease}.timeline-row:last-child{border-bottom:none}@keyframes fadeIn{0%{opacity:0;transform:translate(-8px)}to{opacity:1;transform:translate(0)}}.timeline-icon{width:24px;height:24px;border-radius:4px;display:flex;align-items:center;justify-content:center;font-size:11px;flex-shrink:0;font-family:JetBrains Mono,monospace;font-weight:700}.tl-agent{background:#60a5fa26;color:var(--agent)}.tl-tool{background:#c084fc26;color:var(--tool)}.tl-media{background:#4ade8026;color:var(--success)}.tl-system{background:#8a8a9226;color:var(--fg-dim)}.timeline-text{font-size:13px;color:var(--fg);padding-top:3px}.timeline-text.agent{color:var(--agent);font-weight:500}.media-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:12px;margin-top:16px}.media-card{background:var(--bg-card);border:1px solid var(--border);border-radius:6px;overflow:hidden;transition:border-color .15s}.media-card:hover{border-color:var(--border-bright)}.media-card img{width:100%;height:140px;object-fit:cover;display:block;background:var(--bg)}.media-card video{width:100%;height:140px;object-fit:cover;display:block;background:#000}.media-card{position:relative}.video-badge{position:absolute;top:8px;right:8px;background:#000000b3;color:#fff;font-size:10px;padding:2px 6px;border-radius:4px;pointer-events:none}.media-meta{padding:8px 10px;display:flex;align-items:center;justify-content:space-between}.slot-badge{font-family:JetBrains Mono,monospace;font-size:9px;font-weight:700;padding:2px 6px;border-radius:3px;background:var(--accent);color:var(--bg);letter-spacing:.05em}.media-actions{display:flex;gap:8px;font-size:11px}.media-actions a{color:var(--fg-dim);text-decoration:none;cursor:pointer}.media-actions a:hover{color:var(--fg)}.media-actions a.danger:hover{color:var(--danger)}.material-tabs{display:flex;gap:6px;margin-bottom:16px;flex-wrap:wrap}.material-tab{display:inline-flex;align-items:center;gap:4px;padding:6px 14px;border-radius:20px;font-size:13px;cursor:pointer;border:1px solid var(--border);background:var(--bg-card);color:var(--fg-dim);transition:all .15s;-webkit-user-select:none;user-select:none}.material-tab:hover{border-color:var(--fg-mute);color:var(--fg)}.material-tab.active{background:var(--accent);border-color:var(--accent);color:#fff}.tab-count{font-size:10px;background:#fff3;padding:1px 5px;border-radius:8px;margin-left:2px}.material-tab:not(.active) .tab-count{background:var(--border)}.material-category-tag{font-size:10px;padding:1px 6px;border-radius:3px;background:var(--border);color:var(--fg-dim);white-space:nowrap}.progress-track{height:3px;background:var(--border);border-radius:2px;overflow:hidden;margin-top:12px}.progress-fill{height:100%;background:var(--accent);border-radius:2px;transition:width .4s ease}.card-section{border-top:1px solid var(--border);padding:32px 40px}.card-section h2{font-family:Fraunces,serif;font-weight:600;font-size:20px;margin:0 0 20px;letter-spacing:-.01em}.vendor-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:14px}.vendor-card{background:var(--bg-card);border:1px solid var(--border);border-radius:6px;padding:16px}.vendor-name{font-weight:600;font-size:14px}.vendor-meta{font-family:JetBrains Mono,monospace;font-size:11px;color:var(--fg-mute);margin-bottom:10px}.cred-status{font-size:12px;margin-bottom:10px}.cred-ok{color:var(--success)}.cred-no{color:var(--danger)}.add-vendor-form{background:var(--bg-card);border:1px solid var(--border);border-radius:6px;padding:16px;margin-bottom:14px}.add-vendor-form .form-row{display:flex;gap:10px;margin-bottom:10px}.add-vendor-form .form-row:last-child{margin-bottom:0}.add-vendor-form .field{flex:1;font-size:12px}.slot-row{display:flex;align-items:center;gap:12px;margin-bottom:8px;flex-wrap:wrap}.slot-key{min-width:110px;font-family:JetBrains Mono,monospace;font-size:12px;color:var(--fg-dim)}.slot-binding{display:flex;align-items:center;gap:6px;flex:1;min-width:200px}.slot-label{font-size:11px;color:var(--fg-mute);white-space:nowrap}select.field{-webkit-appearance:none;-moz-appearance:none;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='6' viewBox='0 0 10 6'%3E%3Cpath fill='%238a8a92' d='M0 0l5 6 5-6z'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 12px center;padding-right:30px}.hint{font-size:12px;color:var(--fg-dim);margin-top:6px}.hint-accent{color:var(--accent)}.error-msg{font-size:12px;color:var(--danger);margin-top:8px}.saved-msg{font-size:12px;color:var(--success);margin-bottom:10px}.divider-label{font-family:JetBrains Mono,monospace;font-size:10px;letter-spacing:.15em;text-transform:uppercase;color:var(--fg-mute);margin:24px 0 12px;display:flex;align-items:center;gap:12px}.divider-label:after{content:"";flex:1;height:1px;background:var(--border)}.app-layout{display:flex;height:100vh;overflow:hidden}.sidebar{width:260px;flex-shrink:0;background:var(--bg-elev);border-right:1px solid var(--border);display:flex;flex-direction:column;transition:width .2s}.sidebar.collapsed{width:0;overflow:hidden}.sidebar-header{padding:16px 18px;border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between}.sidebar-logo{font-family:Fraunces,serif;font-weight:800;font-size:18px;letter-spacing:-.02em}.sidebar-logo .dot{color:var(--accent)}.new-chat-btn{display:flex;align-items:center;gap:8px;width:calc(100% - 36px);margin:12px 18px;padding:10px 14px;background:var(--accent);color:var(--bg);border:none;border-radius:6px;font-size:13px;font-weight:600;cursor:pointer;transition:opacity .15s}.new-chat-btn:hover{opacity:.85}.nav-list{flex:1;padding:8px 12px;overflow-y:auto}.nav-section-label{font-family:JetBrains Mono,monospace;font-size:9px;letter-spacing:.15em;text-transform:uppercase;color:var(--fg-mute);padding:16px 8px 6px}.nav-item{display:flex;align-items:center;gap:10px;padding:9px 12px;border-radius:6px;font-size:13px;color:var(--fg-dim);cursor:pointer;transition:all .12s;text-decoration:none}.nav-item:hover{background:var(--bg-card);color:var(--fg)}.nav-item.active{background:var(--bg-card);color:var(--accent)}.nav-icon{font-size:15px;width:20px;text-align:center}.history-item{padding:8px 12px;border-radius:6px;font-size:12px;color:var(--fg-dim);cursor:pointer;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;transition:all .12s;position:relative;display:flex;align-items:center}.history-item:hover{background:var(--bg-card);color:var(--fg)}.history-item .h-status{font-size:9px;float:right;opacity:.6}.history-item-content{flex:1;overflow:hidden;text-overflow:ellipsis}.history-item-delete{display:none;background:none;border:none;color:var(--fg-dim);cursor:pointer;padding:2px 4px;font-size:12px;line-height:1;border-radius:3px;transition:all .12s;flex-shrink:0}.history-item:hover .history-item-delete{display:block}.history-item-delete:hover{background:var(--danger);color:#fff}.history-item-confirm{display:flex;gap:4px;flex-shrink:0}.confirm-yes,.confirm-no{background:none;border:none;cursor:pointer;padding:2px 6px;font-size:12px;line-height:1;border-radius:3px;transition:all .12s}.confirm-yes{color:var(--success)}.confirm-yes:hover{background:var(--success);color:#fff}.confirm-no{color:var(--fg-dim)}.confirm-no:hover{background:var(--fg-dim);color:var(--bg)}.sidebar-footer{padding:12px 18px;border-top:1px solid var(--border);display:flex;align-items:center;justify-content:space-between}.theme-toggle{background:none;border:1px solid var(--border);color:var(--fg-dim);padding:5px 8px;border-radius:4px;cursor:pointer;font-size:14px}.theme-toggle:hover{color:var(--fg);border-color:var(--border-bright)}.main-area{flex:1;display:flex;flex-direction:column;overflow:hidden}.main-header{padding:14px 24px;border-bottom:1px solid var(--border);display:flex;align-items:center;gap:12px}.collapse-btn{background:none;border:none;color:var(--fg-dim);cursor:pointer;font-size:18px;padding:4px}.mode-badge{font-family:JetBrains Mono,monospace;font-size:11px;padding:3px 10px;border-radius:12px;background:var(--bg-card);color:var(--accent);border:1px solid var(--border)}.chat-container{display:flex;flex-direction:column;height:100%;flex:1}.chat-container.empty{justify-content:center}.chat-stream{flex:1;overflow-y:auto;padding:24px 0}.chat-container.empty .chat-stream{flex:0;overflow:visible}.chat-inner{max-width:720px;margin:0 auto;padding:0 24px}.welcome-screen{text-align:center;color:var(--fg-mute);padding:0 0 24px}.welcome-icon{font-size:48px;margin-bottom:16px;opacity:.4}.welcome-title{font-size:24px;margin-bottom:8px;color:var(--fg)}.welcome-desc{font-size:14px;margin-bottom:24px}.chat-input-area{padding:0 24px 24px}.msg-user{display:flex;justify-content:flex-end;align-items:center;gap:10px;margin-bottom:20px}.msg-user .bubble{background:var(--bg-card);padding:10px 14px;border-radius:14px 14px 4px;max-width:80%;font-size:14px}.msg-user .msg-avatar{flex-shrink:0}.msg-row{display:flex;gap:12px;margin-bottom:14px;animation:fadeIn .3s ease}.msg-avatar{width:28px;height:28px;border-radius:6px;display:flex;align-items:center;justify-content:center;font-size:11px;font-family:JetBrains Mono,monospace;font-weight:700;flex-shrink:0}.msg-avatar svg{display:block}.tl-user{background:#4ade8026;color:var(--success)}.tool-steps-panel{background:var(--bg-card);border:1px solid var(--border);border-radius:8px;margin-bottom:8px;overflow:hidden;font-size:12px}.tool-steps-header{display:flex;align-items:center;gap:8px;padding:7px 10px;cursor:pointer;-webkit-user-select:none;user-select:none}.tool-steps-header:hover{background:#ffffff08}.tool-steps-toggle{color:var(--hint);width:12px}.tool-steps-title{color:var(--tool);font-weight:600}.tool-steps-summary{color:var(--hint);margin-left:auto}.tool-steps-list{padding:4px 10px 8px;display:flex;flex-direction:column;gap:4px}.tool-step-item{display:flex;align-items:center;gap:8px;padding:3px 0;color:var(--hint)}.tool-step-idx{width:16px;height:16px;border-radius:50%;background:#c084fc26;color:var(--tool);display:flex;align-items:center;justify-content:center;font-size:10px;flex-shrink:0}.tool-step-name{color:var(--fg);font-weight:500}.tool-step-input{color:var(--hint);font-size:11px;flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.tool-step-status{width:14px;text-align:center}.tool-step-item.done .tool-step-status{color:var(--success)}.tool-step-item.failed .tool-step-status{color:#f87171}.tool-step-item.running .tool-step-status{color:var(--tool);animation:thinking-pulse 1s infinite}.msg-content{flex:1;padding-top:3px}.msg-content.agent{color:var(--agent);font-weight:500}.msg-content .msg-img{max-width:200px;border-radius:6px;margin-top:6px}.msg-content .msg-video{max-width:300px;border-radius:6px;margin-top:6px;background:#000}.thinking-indicator{display:flex;align-items:center;gap:4px;padding:4px 0}.thinking-dot{font-size:8px;color:var(--fg-mute);animation:thinking-pulse 1.4s infinite}.thinking-dot:nth-child(2){animation-delay:.2s}.thinking-dot:nth-child(3){animation-delay:.4s}@keyframes thinking-pulse{0%,80%,to{opacity:.3;transform:scale(.8)}40%{opacity:1;transform:scale(1.2)}}.thinking-text{font-size:12px;color:var(--fg-mute);margin-left:4px}.product-preview{display:flex;gap:8px;margin-bottom:10px;flex-wrap:wrap}.product-preview-item{position:relative;display:inline-block;border-radius:8px;overflow:hidden;border:2px solid var(--border);transition:border-color .12s}.product-preview-item:hover{border-color:var(--accent-dim)}.product-preview-img{width:64px;height:64px;object-fit:cover;display:block}.product-preview-delete{display:none;position:absolute;top:2px;right:2px;width:20px;height:20px;background:var(--danger);color:#fff;border:none;border-radius:50%;cursor:pointer;font-size:10px;line-height:20px;text-align:center;padding:0;transition:all .12s}.product-preview-item:hover .product-preview-delete{display:block}.product-preview-delete:hover{background:#f33;transform:scale(1.1)}.chat-input-area{padding:16px 24px 20px;background:var(--bg)}.chat-input-inner{max-width:720px;margin:0 auto}.input-box{background:var(--bg-elev);border:1px solid var(--border);border-radius:16px;padding:12px 16px;transition:border-color .15s}.input-box:focus-within{border-color:var(--accent-dim)}.input-box textarea{width:100%;border:none;background:transparent;color:var(--fg);font-size:14px;font-family:inherit;line-height:1.5;resize:none;outline:none;min-height:24px;max-height:120px;padding:0;margin-bottom:8px}.input-box textarea::placeholder{color:var(--fg-mute)}.input-preview{display:inline-flex;align-items:center;gap:8px;margin-bottom:10px;padding:4px;background:var(--bg-card);border-radius:8px;position:relative}.input-preview img{width:48px;height:48px;object-fit:cover;border-radius:6px;display:block}.input-preview-delete{position:absolute;top:-6px;right:-6px;width:18px;height:18px;background:var(--danger);color:#fff;border:none;border-radius:50%;cursor:pointer;font-size:10px;line-height:18px;text-align:center;padding:0;display:flex;align-items:center;justify-content:center}.input-preview-delete:hover{background:#f33}.input-materials-preview{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:10px}.input-material-chip{position:relative;width:48px;height:48px}.input-material-chip img{width:48px;height:48px;object-fit:cover;border-radius:6px;border:2px solid var(--accent);display:block}.input-bottom{display:flex;align-items:center;justify-content:space-between}.input-left-actions{display:flex;align-items:center;gap:4px}.input-action-btn{width:32px;height:32px;border:none;background:transparent;cursor:pointer;font-size:16px;display:flex;align-items:center;justify-content:center;border-radius:8px;transition:background .15s;color:var(--fg-dim)}.input-action-btn:hover{background:var(--bg-card);color:var(--fg)}.mode-selector{display:flex;gap:6px;margin-bottom:10px;flex-wrap:wrap}.mode-chip{font-size:11px;padding:5px 12px;border-radius:14px;border:1px solid var(--border);background:var(--bg-elev);color:var(--fg-dim);cursor:pointer;transition:all .12s}.mode-chip:hover{color:var(--fg)}.mode-chip.active{background:var(--accent);color:var(--bg);border-color:var(--accent)}.input-row{display:flex;gap:10px;align-items:flex-end}.input-row textarea{flex:1;background:var(--bg-card);border:1px solid var(--border);color:var(--fg);padding:12px 14px;border-radius:8px;font-size:14px;font-family:inherit;resize:none;min-height:60px;max-height:160px;overflow-y:auto;outline:none;line-height:1.5;transition:height .1s}.send-btn{width:36px;height:36px;border-radius:10px;background:var(--accent);color:var(--bg);border:none;font-size:18px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .15s;flex-shrink:0}.send-btn:hover:not(:disabled){transform:scale(1.05);box-shadow:0 2px 8px #0003}.send-btn:disabled{background:var(--border);color:var(--fg-mute);cursor:not-allowed}.upload-chip{display:inline-flex;align-items:center;gap:4px;font-size:11px;padding:5px 10px;border-radius:14px;border:1px solid var(--border);color:var(--fg-dim);cursor:pointer}.upload-chip:hover{color:var(--fg)}.upload-chip.has-file{color:var(--success);border-color:var(--success)}.view-page{padding:32px 40px;max-width:1000px;margin:0 auto;width:100%;height:100%;overflow-y:auto}.blueprint-confirm{background:var(--bg-card);border:1px solid var(--border);border-radius:12px;padding:24px;margin:16px 0}.blueprint-header{margin-bottom:20px}.blueprint-title{display:flex;align-items:center;gap:12px;margin-bottom:8px}.blueprint-title h3{margin:0;font-size:18px}.blueprint-icon{font-size:24px}.blueprint-meta{display:flex;gap:12px;font-size:12px;color:var(--fg-dim)}.blueprint-product{font-weight:500;color:var(--fg)}.blueprint-seeds{margin-bottom:20px}.blueprint-seeds h4{margin:0 0 12px;font-size:14px;color:var(--fg-dim)}.seed-tags{display:flex;flex-wrap:wrap;gap:8px}.seed-tag{padding:6px 12px;background:var(--bg-elev);border:1px solid var(--border);border-radius:16px;font-size:12px;color:var(--accent)}.blueprint-screens{margin-bottom:20px}.blueprint-screens h4{margin:0 0 12px;font-size:14px;color:var(--fg-dim)}.screen-card{background:var(--bg-elev);border:1px solid var(--border);border-radius:8px;margin-bottom:8px;cursor:pointer;transition:all .15s}.screen-card:hover{border-color:var(--accent-dim)}.screen-card.expanded{border-color:var(--accent)}.screen-header{display:flex;align-items:center;gap:12px;padding:12px 16px}.screen-id{display:flex;align-items:center;gap:8px;min-width:60px}.screen-number{font-family:JetBrains Mono,monospace;font-size:14px;font-weight:700;color:var(--accent)}.screen-icon{font-size:18px}.screen-info{flex:1;min-width:0}.screen-question{font-size:13px;font-weight:500;color:var(--fg);margin-bottom:4px}.screen-job{font-size:11px;color:var(--fg-dim);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.screen-density{font-family:JetBrains Mono,monospace;font-size:10px;text-transform:uppercase;letter-spacing:.1em}.screen-details{padding:12px 16px 16px;border-top:1px solid var(--border);margin-top:8px}.detail-row{display:flex;margin-bottom:8px;font-size:12px}.detail-label{color:var(--fg-dim);min-width:80px;flex-shrink:0}.detail-value{color:var(--fg)}.detail-tags{display:flex;flex-wrap:wrap;gap:6px}.detail-tag{padding:2px 8px;background:var(--bg);border-radius:4px;font-size:11px;color:var(--fg-dim)}.blueprint-risks{margin-bottom:20px;padding:16px;background:#ffc8000d;border:1px solid rgba(255,200,0,.2);border-radius:8px}.blueprint-risks h4{margin:0 0 12px;font-size:14px;color:#fc0}.risk-item{font-size:12px;color:var(--fg-dim);margin-bottom:8px}.blueprint-feedback{margin-bottom:16px}.blueprint-feedback textarea{width:100%;padding:12px;background:var(--bg);border:1px solid var(--border);border-radius:8px;color:var(--fg);font-size:13px;font-family:inherit;resize:vertical;outline:none}.blueprint-feedback textarea:focus{border-color:var(--accent-dim)}.blueprint-actions{display:flex;gap:12px;justify-content:flex-end}.view-page h1{font-family:Fraunces,serif;font-weight:600;font-size:24px;margin:0 0 24px}.history-list-item{display:flex;align-items:center;gap:14px;padding:14px 16px;background:var(--bg-card);border:1px solid var(--border);border-radius:8px;margin-bottom:10px;cursor:pointer;transition:border-color .12s}.history-list-item:hover{border-color:var(--border-bright)}.hli-info{flex:1}.hli-title{font-size:14px;font-weight:500;margin-bottom:2px}.hli-meta{font-size:11px;color:var(--fg-mute);font-family:JetBrains Mono,monospace}.hli-status{font-size:10px;padding:3px 8px;border-radius:4px;font-family:JetBrains Mono,monospace}.hli-status.done{background:#4ade8026;color:var(--success)}.hli-status.failed{background:#ff5c5c26;color:var(--danger)}.hli-status.running,.hli-status.queued{background:#d4ff3a26;color:var(--accent)}.main-content{display:flex;flex:1;overflow:hidden}.chat-column{flex:1;display:flex;flex-direction:column;overflow:hidden;min-width:0}.output-panel{width:340px;flex-shrink:0;border-left:1px solid var(--border);background:var(--bg-elev);overflow-y:auto;padding:0}.output-panel-header{padding:16px 18px 10px;border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between;position:sticky;top:0;background:var(--bg-elev);z-index:2}.output-card{padding:14px 18px;border-bottom:1px solid var(--border)}.output-card-img{width:100%;border-radius:6px;margin-bottom:8px;display:block}.output-card .slot-badge{margin-bottom:6px;display:"inline-block"}.output-prompt{font-size:11px;color:var(--fg-dim);line-height:1.5;padding:8px 10px;background:var(--bg-card);border-radius:4px;cursor:pointer;border:1px dashed var(--border);transition:border-color .12s;word-break:break-word}.output-prompt:hover{border-color:var(--accent-dim)}.output-prompt-edit{width:100%;background:var(--bg);border:1px solid var(--accent-dim);color:var(--fg);padding:8px;font-size:11px;font-family:inherit;border-radius:4px;resize:vertical;outline:none}.output-panel.collapsed{width:40px}.output-panel.collapsed .output-card,.output-panel.collapsed .output-panel-header span:first-child,.output-panel.collapsed .output-panel-header .hint{display:none}.upload-plus-btn{width:44px;height:44px;border-radius:8px;background:var(--bg-card);border:1px solid var(--border);color:var(--fg-dim);font-size:18px;cursor:pointer;display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:all .12s}.upload-plus-btn:hover{color:var(--fg);border-color:var(--border-bright)}.lightbox{position:fixed;top:0;right:0;bottom:0;left:0;background:#000000d9;display:flex;align-items:center;justify-content:center;z-index:100;cursor:pointer;animation:fadeIn .2s}.lightbox-img{max-width:90vw;max-height:85vh;border-radius:8px;box-shadow:0 8px 32px #0006}.lightbox-hint{position:absolute;bottom:20px;color:#ffffff80;font-size:12px}.output-card-img{cursor:zoom-in}.material-picker{background:var(--bg-elev);border:1px solid var(--border);border-radius:12px;padding:20px;max-width:600px;max-height:70vh;overflow-y:auto;cursor:default}.material-picker-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:10px}.material-pick-item{cursor:pointer;border:2px solid transparent;border-radius:6px;overflow:hidden;transition:border-color .12s;position:relative}.material-pick-item:hover{border-color:var(--accent)}.material-pick-item.selected{border-color:var(--accent);box-shadow:0 0 0 1px var(--accent)}.material-pick-item img{width:100%;height:100px;object-fit:cover;display:block}.material-pick-check{position:absolute;top:4px;right:4px;width:20px;height:20px;background:var(--accent);color:#fff;border-radius:50%;font-size:12px;line-height:20px;text-align:center}.canvas-view{display:flex;height:100%;overflow:hidden;outline:none}.canvas-assets-panel{width:250px;flex-shrink:0;background:var(--bg-elev);border-right:1px solid var(--border);display:flex;flex-direction:column;overflow:hidden}.canvas-assets-header{padding:16px;border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between}.canvas-assets-header h3{margin:0;font-size:16px}.canvas-search-input{margin:12px 16px;padding:8px 12px;background:var(--bg);border:1px solid var(--border);border-radius:4px;color:var(--fg);font-size:12px;outline:none}.canvas-search-input:focus{border-color:var(--accent-dim)}.canvas-assets-grid{flex:1;overflow-y:auto;padding:12px;display:grid;grid-template-columns:repeat(2,1fr);gap:8px;align-content:start}.canvas-asset-item{position:relative;cursor:pointer;border-radius:6px;overflow:hidden;border:1px solid var(--border);transition:all .15s}.canvas-asset-item:hover{border-color:var(--accent-dim);transform:scale(1.02)}.canvas-asset-item img{width:100%;height:80px;object-fit:cover;display:block}.canvas-asset-item .slot-badge{position:absolute;top:4px;right:4px;font-size:8px;padding:1px 4px}.canvas-container{flex:1;display:flex;flex-direction:column;overflow:hidden;position:relative}.canvas-toolbar{padding:8px 16px;background:var(--bg-elev);border-bottom:1px solid var(--border);display:flex;align-items:center;gap:12px;flex-shrink:0}.canvas-main-area{flex:1;overflow:hidden;position:relative}.canvas-area{width:100%;height:100%;position:relative;overflow:hidden;background:var(--bg);background-image:radial-gradient(circle at 1px 1px,var(--border) 1px,transparent 0);background-size:20px 20px;cursor:grab}.canvas-area:active{cursor:grabbing}.canvas-item{position:absolute;background:var(--bg-card);border:2px solid var(--border);border-radius:8px;overflow:hidden;cursor:move;box-shadow:0 2px 8px #0003;transition:box-shadow .15s,border-color .15s}.canvas-item:hover{box-shadow:0 4px 16px #0000004d}.canvas-item.selected{border-color:var(--accent);box-shadow:0 0 0 2px var(--accent),0 4px 16px #0000004d}.canvas-item img{width:100%;height:100%;object-fit:cover;display:block}.canvas-item-prompt{position:absolute;bottom:0;left:0;right:0;padding:6px 8px;background:#000000b3;color:var(--fg);font-size:10px;line-height:1.4;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.canvas-prompt-panel{background:var(--bg-elev);border-top:1px solid var(--border);padding:16px;min-height:120px;flex-shrink:0}.canvas-prompt-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:12px}.canvas-prompt-header .font-display{font-size:14px}.canvas-prompt-actions{display:flex;gap:8px}.canvas-prompt-content{padding:12px;background:var(--bg-card);border:1px dashed var(--border);border-radius:6px;color:var(--fg-dim);font-size:12px;line-height:1.6;cursor:pointer;transition:border-color .15s;word-break:break-word;max-height:80px;overflow-y:auto}.canvas-prompt-content:hover{border-color:var(--accent-dim)}.canvas-prompt-edit{width:100%;padding:12px;background:var(--bg);border:1px solid var(--accent-dim);border-radius:6px;color:var(--fg);font-size:12px;font-family:inherit;line-height:1.6;resize:vertical;outline:none;min-height:80px}.canvas-prompt-edit:focus{border-color:var(--accent)}.canvas-empty-hint{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);text-align:center;color:var(--fg-mute);pointer-events:none}.canvas-empty-hint .icon{font-size:48px;margin-bottom:16px;opacity:.3}.canvas-empty-hint .text{font-size:14px}
