.board-canvas{background-color:#fafaf7;background-image:radial-gradient(#00000012 1px,#0000 1px);background-position:0 0;background-repeat:repeat,repeat,repeat,repeat;background-size:22px 22px;background-attachment:scroll,scroll,scroll,scroll;background-origin:padding-box,padding-box,padding-box,padding-box;background-clip:border-box,border-box,border-box,border-box;flex:1;height:100%;position:relative;overflow:hidden}.panzoom-viewport{cursor:grab;-webkit-user-select:none;user-select:none;width:100%;height:100%;position:relative;overflow:hidden}.panzoom-viewport.panzoom-dragging{cursor:grabbing}.panzoom-world{transform-origin:0 0;will-change:transform;position:absolute;top:0;left:0}.panzoom-controls{z-index:4;-webkit-backdrop-filter:saturate(160%)blur(8px);background:#ffffffeb;border:1px solid #e4e4e7;border-radius:999px;align-items:center;gap:2px;padding:4px;display:inline-flex;position:absolute;bottom:16px;right:16px;box-shadow:0 4px 14px #0000000f}.panzoom-btn{color:#3f3f46;font-variant-numeric:tabular-nums;cursor:pointer;background:0 0;border:none;border-radius:9999px;justify-content:center;align-items:center;min-width:28px;height:28px;padding:0 8px;font-size:14px;font-weight:500;transition:background .12s,color .12s;display:inline-flex}.panzoom-btn:hover{color:#0a0a0a;background:#f4f4f5}.panzoom-readout{letter-spacing:-.01em;min-width:44px;font-size:12px}.panzoom-sep{background:#e4e4e7;width:1px;height:16px;margin:0 4px}.board{box-sizing:border-box;grid-template-rows:auto 1fr auto;grid-template-columns:minmax(260px,1fr) minmax(600px,2.6fr) minmax(260px,1fr);gap:16px;width:100%;height:100%;padding:48px;display:grid;position:relative}.preview-fullscreen-btn{z-index:5;color:#44403c;cursor:pointer;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);background:#ffffffeb;border:1px solid #d6d3d1;border-radius:6px;align-items:center;gap:6px;padding:6px 10px;font-family:JetBrains Mono,monospace;font-size:11px;transition:all .2s cubic-bezier(.25,1,.5,1);display:inline-flex;position:absolute;top:10px;right:10px;box-shadow:0 2px 6px #00000014}.preview-fullscreen-btn:hover{background:#fff;border-color:#78716c;transform:translateY(-1px)}.fullscreen-overlay{z-index:9999;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);background:#0a0a0aeb;flex-direction:column;align-items:stretch;padding:32px;animation:.18s ease-out both fade-in;display:flex;position:fixed;inset:0}@keyframes fade-in{0%{opacity:0}to{opacity:1}}.fullscreen-bar{color:#fafaf7;letter-spacing:.08em;text-transform:uppercase;justify-content:space-between;align-items:center;gap:12px;margin-bottom:16px;font-family:JetBrains Mono,monospace;font-size:11px;display:flex}.fullscreen-bar a,.fullscreen-bar button{color:#fafaf7;cursor:pointer;font-family:inherit;font-size:inherit;letter-spacing:inherit;text-transform:inherit;background:#ffffff1a;border:1px solid #fff3;border-radius:6px;padding:6px 12px;text-decoration:none;transition:all .2s cubic-bezier(.25,1,.5,1)}.fullscreen-bar a:hover,.fullscreen-bar button:hover{background:#ffffff2e;border-color:#ffffff59}.fullscreen-bar .spacer{flex:1}.fullscreen-stage{flex:1;justify-content:center;align-items:center;width:100%;height:100%;min-height:0;display:flex}.fullscreen-preview{background:#fff;border-radius:4px;display:block;overflow:hidden;box-shadow:0 20px 60px #0006}.fullscreen-preview iframe{border:none;width:100%;height:100%;display:block}.board:before{content:"";pointer-events:none;opacity:.35;background-image:url("data:image/svg+xml;utf8,%3Csvg xmlns='http://www.w3.org/2000/svg' width='120' height='120'%3E%3Cfilter id='n'%3E%3CfeTurbulence baseFrequency='0.9' numOctaves='2' stitchTiles='stitch'/%3E%3CfeColorMatrix values='0 0 0 0 0.3  0 0 0 0 0.25  0 0 0 0 0.2  0 0 0 0.04 0'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");position:absolute;inset:0}.board-zone{z-index:1;flex-direction:column;justify-content:flex-start;align-items:center;gap:14px;display:flex;position:relative}.zone-top-left{grid-area:1/1;align-items:flex-start}.zone-top{flex-flow:wrap;grid-area:1/2;justify-content:center}.zone-top-right{grid-area:1/3;align-items:flex-end}.zone-left{grid-area:2/1;align-items:flex-start}.zone-right{grid-area:2/3;align-items:flex-end}.zone-bottom-left{grid-area:3/1;align-items:flex-start}.zone-bottom{flex-flow:wrap;grid-area:3/2;justify-content:center}.zone-bottom-right{grid-area:3/3;align-items:flex-end}.board-center{z-index:0;grid-area:2/2;justify-content:center;align-items:center;min-width:0;min-height:0;display:flex;position:relative}.preview-holder{background:#fafaf7;border-radius:2px;width:100%;max-height:78vh;padding:10px;position:relative;overflow:hidden;box-shadow:0 2px 4px #0000000f,0 14px 30px #00000014,0 30px 50px #0000000a}.preview-holder iframe{background:#fff;border:none;width:100%;height:100%;display:block}.preview-holder-empty{color:#a1a1aa;background:#fff;flex-direction:column;justify-content:center;align-items:center;width:100%;height:100%;font-family:Caveat,cursive;font-size:20px;display:flex}.film-strip{-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);z-index:2;background:#ffffffb3;border:1px solid #e7e5e4;border-radius:8px;grid-area:4/1/auto/-1;gap:6px;padding:12px;display:flex;overflow-x:auto;box-shadow:0 1px 2px #0000000a}.film-cell{min-width:90px;transition:all .3s var(--ease);background:#fafaf7;border:1px solid #e7e5e4;border-radius:4px;flex-direction:column;flex:1;gap:2px;padding:6px 10px;display:flex}.film-cell.running{background:#fff6a8;border-color:#eab308;animation:1s ease-in-out infinite film-pulse}.film-cell.done{background:#dcfce7;border-color:#16a34a}.film-cell.error{background:#fee2e2;border-color:#dc2626}.film-cell-name{letter-spacing:.05em;text-transform:uppercase;color:#44403c;font-family:JetBrains Mono,monospace;font-size:10px}.film-cell-time{color:#78716c;font-family:JetBrains Mono,monospace;font-size:9px}@keyframes film-pulse{0%,to{opacity:1}50%{opacity:.65}}.note-wrap{--rot:0deg;transform-origin:50% 0;will-change:transform, opacity;transition:transform .25s var(--ease), box-shadow .25s var(--ease), z-index 0s;z-index:1;animation:.52s cubic-bezier(.2,.8,.2,1.1) both drop-in}.note-wrap:hover{transform:rotate(calc(var(--rot) * .3)) translateY(-3px) scale(1.02);z-index:10}@keyframes drop-in{0%{opacity:0;transform:scale(.7)translateY(-30px)rotate(0)}80%{transform:scale(1.02) translateY(2px) rotate(var(--rot));opacity:1}to{transform:scale(1) translateY(0) rotate(var(--rot));opacity:1}}.board-zone>.note-wrap+.note-wrap{margin-top:-10px}.zone-top>.note-wrap+.note-wrap,.zone-bottom>.note-wrap+.note-wrap{margin-top:0;margin-left:-12px}.board-error{z-index:20;position:absolute;top:12px;right:12px}.note-wrap:focus-within{z-index:20}@keyframes gi-pulse{0%,to{opacity:.85}50%{opacity:.55}}:root{--bg:#fff;--surface:#fafafa;--surface-hover:#f4f4f5;--ink:#0a0a0a;--ink-soft:#18181b;--muted:#71717a;--muted-soft:#a1a1aa;--border:#e4e4e7;--border-strong:#d4d4d8;--accent:#0a0a0a;--accent-hover:#262626;--danger:#dc2626;--success:#16a34a;--radius-sm:6px;--radius-md:10px;--radius-lg:16px;--radius-pill:9999px;--space-1:4px;--space-2:8px;--space-3:12px;--space-4:16px;--space-5:24px;--space-6:32px;--space-7:48px;--space-8:64px;--shadow-sm:0 1px 2px #0000000a;--shadow-md:0 4px 12px #0000000f;--shadow-lg:0 12px 32px #00000014;--font-sans:"Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif;--font-mono:ui-monospace, "SF Mono", Menlo, Consolas, monospace;--ease:cubic-bezier(.25, 1, .5, 1)}*{box-sizing:border-box;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;margin:0;padding:0}html,body,#root{height:100%}body{background:var(--bg);color:var(--ink);font-family:var(--font-sans);letter-spacing:-.005em;font-size:15px;line-height:1.5}button{cursor:pointer;color:inherit;background:0 0;border:none;font-family:inherit}textarea,input{font-family:inherit;font-size:inherit;color:inherit;background:0 0;border:none;outline:none}a{color:inherit;text-decoration:none}.app{flex-direction:column;height:100dvh;min-height:100vh;max-height:100dvh;display:flex;overflow:hidden}.app-header{padding:14px var(--space-5);border-bottom:1px solid var(--border);-webkit-backdrop-filter:saturate(180%)blur(10px);z-index:10;background:#ffffffd9;justify-content:space-between;align-items:center;display:flex;position:sticky;top:0}.app-brand{letter-spacing:-.025em;cursor:pointer;color:var(--ink);padding:2px 0;font-family:Space Grotesk,Inter,system-ui,sans-serif;font-size:18px;font-weight:700;line-height:1}.app-brand:hover{color:var(--accent,var(--ink))}.app-back{border-radius:var(--radius-pill);color:var(--muted);cursor:pointer;transition:all .15s var(--ease);background:0 0;border:none;align-items:center;gap:6px;padding:6px 10px 6px 6px;font-family:inherit;font-size:12.5px;font-weight:500;display:inline-flex}.app-back:hover{color:var(--ink);background:var(--surface)}.app-back-arrow{transition:transform .15s var(--ease);font-size:14px;line-height:1}.app-back:hover .app-back-arrow{transform:translate(-2px)}.app-context-sep{background:var(--border);width:1px;height:16px;margin:0 4px;display:inline-block}.app-context-title{letter-spacing:-.01em;color:var(--ink);text-overflow:ellipsis;white-space:nowrap;max-width:420px;font-family:Space Grotesk,Inter,system-ui,sans-serif;font-size:14px;font-weight:600;line-height:1.2;overflow:hidden}.app-nav{color:var(--muted);align-items:center;gap:10px;font-size:12.5px;font-weight:500;display:flex}.app-nav-label{letter-spacing:.02em}.app-nav-step{align-items:center;gap:6px;display:inline-flex}.app-nav-sep{background:var(--border);width:14px;height:1px}.step-dot{background:var(--border-strong);border-radius:50%;width:6px;height:6px}.step-dot.step-past{background:var(--muted-soft)}.step-dot.step-active{background:var(--ink);box-shadow:0 0 0 3px #0a0a0a14}.app-main{flex:1;min-height:0;display:flex;overflow:hidden}.brief{padding:var(--space-8) var(--space-6);justify-content:center;align-items:center;gap:var(--space-6);scrollbar-width:none;-ms-overflow-style:none;flex-direction:column;flex:1;min-height:0;display:flex;overflow-y:auto}.brief::-webkit-scrollbar{width:0;height:0;display:none}.brief h1{letter-spacing:-.03em;text-align:center;max-width:640px;font-size:40px;font-weight:700;line-height:1.05}.brief p{color:var(--muted);text-align:center;max-width:560px}.brief-form{gap:var(--space-4);flex-direction:column;width:100%;max-width:720px;display:flex}.brief-input-wrap{border:1px solid var(--border);border-radius:var(--radius-lg);background:var(--bg);width:100%;transition:border-color .2s var(--ease), box-shadow .2s var(--ease), background .2s var(--ease);position:relative}.brief-input-wrap:focus-within{border-color:var(--ink);box-shadow:0 0 0 3px #0a0a0a14}.brief-input-wrap-dragover{border-color:var(--ink);background:#f8f8f8}.brief-input{width:100%;min-height:120px;padding:var(--space-5);padding-bottom:calc(var(--space-5) + 32px);resize:vertical;color:inherit;background:0 0;border:none;outline:none;font-family:inherit;font-size:16px}.brief-attach-btn{border:1px solid var(--border);border-radius:var(--radius-pill);background:var(--bg);color:var(--muted);cursor:pointer;transition:all .15s var(--ease);align-items:center;gap:4px;padding:6px 8px;display:inline-flex;position:absolute;bottom:10px;left:10px}.brief-attach-btn:hover:not(:disabled){border-color:var(--ink);color:var(--ink)}.brief-attach-btn:disabled{opacity:.4;cursor:not-allowed}.brief-attach-count{text-align:center;min-width:14px;color:var(--bg);background:var(--ink);letter-spacing:0;border-radius:9999px;padding:0 4px;font-size:10px;font-weight:600;line-height:14px;display:inline-block}.brief-examples{gap:var(--space-2);flex-wrap:wrap;justify-content:center;display:flex}.brief-examples button{padding:var(--space-2) var(--space-4);border:1px solid var(--border);border-radius:var(--radius-pill);background:var(--bg);color:var(--muted);transition:all .2s var(--ease);font-size:13px}.brief-examples button:hover{border-color:var(--ink);color:var(--ink)}.brief-examples button:disabled{opacity:.5;cursor:progress}.brief-examples-regen{justify-content:center;align-items:center;width:30px;height:30px;display:inline-flex;padding:0!important}.icon-spin{animation:.8s linear infinite icon-spin-anim}@keyframes icon-spin-anim{to{transform:rotate(360deg)}}.brief-assets{gap:var(--space-2);flex-direction:column;display:flex}.brief-asset{align-items:center;gap:var(--space-3);padding:var(--space-2);border:1px solid var(--border);border-radius:var(--radius-md);background:var(--bg);display:flex}.brief-asset-thumb{background:var(--surface);border-radius:var(--radius-sm);flex:none;justify-content:center;align-items:center;width:56px;height:56px;display:flex;overflow:hidden}.brief-asset-thumb img{object-fit:cover;width:100%;height:100%}.brief-asset-ext{color:var(--muted);text-transform:uppercase;letter-spacing:.08em;font-family:ui-monospace,SFMono-Regular,Menlo,Consolas,monospace;font-size:10px}.brief-asset-body{gap:var(--space-1);flex-direction:column;flex:1;min-width:0;display:flex}.brief-asset-filename{color:var(--muted);white-space:nowrap;text-overflow:ellipsis;font-size:12px;overflow:hidden}.brief-asset-note{width:100%;padding:var(--space-1) var(--space-2);border:1px solid var(--border);border-radius:var(--radius-sm);background:var(--bg);transition:border-color .15s var(--ease);font-size:13px}.brief-asset-note:focus{border-color:var(--ink);outline:none}.brief-asset-remove{border:1px solid var(--border);background:var(--bg);width:24px;height:24px;color:var(--muted);cursor:pointer;transition:all .15s var(--ease);border-radius:50%;flex:none;justify-content:center;align-items:center;font-size:14px;line-height:1;display:flex}.brief-asset-remove:hover{border-color:var(--ink);color:var(--ink)}.advanced{gap:var(--space-2);flex-direction:column;display:flex}.advanced-toggle{align-self:center;align-items:center;gap:var(--space-2);padding:var(--space-1) var(--space-3);color:var(--muted);cursor:pointer;transition:color .15s var(--ease);background:0 0;border:none;font-size:12px;display:inline-flex}.advanced-toggle:hover{color:var(--ink)}.advanced-chevron{text-align:center;width:10px;font-size:10px;display:inline-block}.advanced-summary{color:var(--muted)}.advanced-summary-value{color:var(--ink);font-family:ui-monospace,SFMono-Regular,Menlo,Consolas,monospace;font-size:11px}.model-picker{gap:var(--space-2);padding:var(--space-4);border:1px solid var(--border);border-radius:var(--radius-lg);background:var(--bg);flex-direction:column;display:flex}.model-picker-label{align-items:baseline;gap:var(--space-2);text-transform:uppercase;letter-spacing:.08em;color:var(--ink);font-size:12px;font-weight:600;display:flex}.model-picker-hint{letter-spacing:.02em;text-transform:none;color:var(--muted);font-size:11px;font-weight:500}.model-presets{gap:var(--space-2);flex-wrap:wrap;display:flex}.model-chip{padding:var(--space-2) var(--space-3);border:1px solid var(--border);border-radius:var(--radius-pill);background:var(--bg);color:var(--muted);cursor:pointer;transition:all .15s var(--ease);font-size:12px;font-weight:500}.model-chip:hover{border-color:var(--ink);color:var(--ink)}.model-chip-active{background:var(--ink);color:#fff;border-color:var(--ink)}.model-custom{width:100%;padding:var(--space-2) var(--space-3);border:1px solid var(--border);border-radius:var(--radius-md);background:var(--bg);transition:border-color .15s var(--ease), box-shadow .15s var(--ease);font-family:ui-monospace,SFMono-Regular,Menlo,Consolas,monospace;font-size:12px}.model-custom:focus{border-color:var(--ink);outline:none;box-shadow:0 0 0 3px #0a0a0a0f}.brief-submit{padding:var(--space-3) var(--space-6);background:var(--ink);color:#fff;border-radius:var(--radius-pill);letter-spacing:.02em;transition:transform .2s var(--ease), background .2s var(--ease);align-self:center;font-size:14px;font-weight:600}.brief-submit:hover:not(:disabled){background:var(--accent-hover);transform:scale(.98)}.brief-submit:disabled{opacity:.5;cursor:not-allowed}.quest{padding:var(--space-7) var(--space-6) 120px;scrollbar-width:none;-ms-overflow-style:none;flex:1;align-self:stretch;width:100%;min-height:0;overflow-y:auto}.quest::-webkit-scrollbar{width:0;height:0;display:none}.quest>*{max-width:760px;margin-left:auto;margin-right:auto}.quest-loader{max-width:640px;padding:120px var(--space-6) 120px;scrollbar-width:none;-ms-overflow-style:none;text-align:center;align-self:stretch;align-items:center;gap:var(--space-5);flex-direction:column;flex:1;width:100%;min-height:0;margin:0 auto;display:flex;overflow-y:auto}.quest-loader::-webkit-scrollbar{width:0;height:0;display:none}.quest-loader-spinner{border:2px solid var(--border);border-top-color:var(--ink);border-radius:50%;width:28px;height:28px;animation:.9s linear infinite quest-spin}@keyframes quest-spin{to{transform:rotate(360deg)}}.quest-loader-eyebrow{text-transform:uppercase;letter-spacing:.14em;color:var(--muted);font-size:11px;font-weight:600}.quest-loader-msg{letter-spacing:-.01em;color:var(--ink);min-height:2.6em;animation:quest-fade .45s var(--ease) both;font-size:22px;font-weight:500;line-height:1.3}@keyframes quest-fade{0%{opacity:0;transform:translateY(4px)}to{opacity:1;transform:none}}.quest-loader-sub{color:var(--muted);font-size:13px}.quest-loader-actions{gap:var(--space-3);margin-top:var(--space-2);display:flex}.session-loader{justify-content:center;align-items:center;gap:var(--space-3);color:var(--muted);flex-direction:column;flex:1;display:flex}.session-loader-spinner{border:2px solid var(--border);border-top-color:var(--ink);border-radius:50%;width:22px;height:22px;animation:.9s linear infinite quest-spin}.session-loader-text{letter-spacing:.01em;font-size:13px}.quest-title{letter-spacing:-.02em;margin-bottom:var(--space-6);font-size:30px;font-weight:700;line-height:1.15}.quest-item{padding:var(--space-6) 0;border-bottom:1px solid var(--border)}.quest-item:last-of-type{border-bottom:none}.quest-label{letter-spacing:-.01em;margin-bottom:var(--space-2);font-size:18px;font-weight:600}.quest-help{color:var(--muted);margin-bottom:var(--space-4);font-size:13px}.choices{gap:var(--space-2);flex-wrap:wrap;display:flex}.choice-btn{align-items:center;gap:var(--space-2);padding:var(--space-2) var(--space-4);border:1px solid var(--border);border-radius:var(--radius-pill);background:var(--bg);color:var(--ink);transition:all .2s var(--ease);text-align:left;max-width:100%;font-size:14px;display:inline-flex}.choice-btn:hover{border-color:var(--ink)}.choice-btn.selected{background:var(--ink);color:#fff;border-color:var(--ink)}.choice-btn.decide{color:var(--muted);font-style:italic}.choice-card{gap:var(--space-3);padding:var(--space-3);border:1px solid var(--border);border-radius:var(--radius-md);background:var(--bg);transition:all .2s var(--ease);cursor:pointer;text-align:left;min-width:160px;max-width:280px;font:inherit;color:inherit;flex-direction:column;display:flex}.choice-card:hover{border-color:var(--ink)}.choice-card.selected{border-color:var(--ink);box-shadow:0 0 0 3px #0a0a0a14}.choice-card-label{font-size:14px;font-weight:600}.choice-grid{gap:var(--space-3);flex-wrap:wrap;display:flex}.other-input,.free-input{width:100%;padding:var(--space-3) var(--space-4);border:1px solid var(--border);border-radius:var(--radius-md);background:var(--bg);transition:border-color .2s var(--ease);font-size:14px}.other-input:focus,.free-input:focus{border-color:var(--ink)}.free-input{resize:vertical;min-height:80px}.quest-footer{background:var(--bg);border-top:1px solid var(--border);padding:var(--space-4) var(--space-6);justify-content:space-between;align-items:center;gap:var(--space-4);display:flex;position:fixed;bottom:0;left:0;right:0}.quest-footer .spacer{flex:1}.btn-primary{padding:var(--space-3) var(--space-5);background:var(--ink);color:#fff;border-radius:var(--radius-pill);transition:all .2s var(--ease);font-size:14px;font-weight:600}.btn-primary:hover:not(:disabled){background:var(--accent-hover);transform:scale(.98)}.btn-primary:disabled{opacity:.5;cursor:not-allowed}.btn-secondary{padding:var(--space-3) var(--space-5);background:var(--bg);color:var(--muted);border:1px solid var(--border);border-radius:var(--radius-pill);transition:all .2s var(--ease);font-size:14px;font-weight:500}.btn-secondary:hover{color:var(--ink);border-color:var(--ink)}.workspace{flex:1;grid-template-rows:auto minmax(0,1fr);grid-template-columns:340px minmax(0,1fr);height:100%;min-height:0;display:grid;overflow:hidden}.workspace>.edit-panel{grid-area:2/1}.workspace>.canvas,.workspace>.board-canvas{grid-area:2/2}.edit-panel{border-right:1px solid var(--border);background:var(--bg);flex-direction:column;height:100%;min-height:0;display:flex}.edit-panel-body{min-height:0;padding:var(--space-5);gap:var(--space-4);scrollbar-width:thin;scrollbar-color:var(--border-strong) transparent;flex-direction:column;flex:1;display:flex;overflow:hidden auto}.edit-panel-body::-webkit-scrollbar{width:8px}.edit-panel-body::-webkit-scrollbar-track{background:0 0}.edit-panel-body::-webkit-scrollbar-thumb{background:var(--border-strong);border-radius:4px}.edit-panel-body::-webkit-scrollbar-thumb:hover{background:var(--muted-soft)}.edit-panel-section h3{text-transform:uppercase;letter-spacing:.1em;color:var(--muted);margin-bottom:var(--space-2);font-size:11px;font-weight:600}.edit-panel-brief{color:var(--ink);padding:var(--space-3);background:var(--surface);border-radius:var(--radius-md);border:1px solid var(--border);overflow-wrap:anywhere;word-break:break-word;white-space:pre-wrap;max-height:220px;font-size:13px;line-height:1.45;overflow-y:auto}.edit-panel-section{min-width:0}.edit-panel-stages{flex-direction:column;gap:6px;display:flex}.ep-stage{align-items:center;gap:var(--space-2);border-radius:var(--radius-sm);padding:6px 8px;font-size:12px;display:flex}.ep-stage-dot{background:var(--border-strong);width:8px;height:8px;transition:background .2s var(--ease);border-radius:50%;flex-shrink:0}.ep-stage.running .ep-stage-dot{background:var(--ink);animation:1s ease-in-out infinite ep-pulse}.ep-stage.done .ep-stage-dot{background:var(--success)}.ep-stage.error .ep-stage-dot{background:var(--danger)}.ep-stage-name{text-transform:capitalize;color:var(--ink);flex:1;font-weight:500}.ep-stage.pending .ep-stage-name{color:var(--muted-soft)}.ep-stage-time{font-family:var(--font-mono);color:var(--muted);font-size:11px}@keyframes ep-pulse{0%,to{opacity:1}50%{opacity:.4}}.progress{flex:1;grid-template-columns:320px 1fr;gap:0;min-height:0;display:grid}.progress-timeline{border-right:1px solid var(--border);padding:var(--space-6);background:var(--surface);overflow-y:auto}.progress-timeline h2{text-transform:uppercase;letter-spacing:.08em;color:var(--muted);margin-bottom:var(--space-4);font-size:13px;font-weight:600}.stage{align-items:center;gap:var(--space-3);padding:var(--space-3) 0;border-bottom:1px solid var(--border);font-size:14px;display:flex}.stage-dot{background:var(--border-strong);width:10px;height:10px;transition:background .2s var(--ease);border-radius:50%;flex-shrink:0}.stage.running .stage-dot{background:var(--ink);animation:1s ease-in-out infinite pulse}.stage.done .stage-dot{background:var(--success)}.stage.error .stage-dot{background:var(--danger)}.stage-name{text-transform:capitalize;flex:1;font-weight:500}.stage-time{font-family:var(--font-mono);color:var(--muted);font-size:12px}@keyframes pulse{0%,to{opacity:1}50%{opacity:.55}}.progress-preview{flex-direction:column;flex:1;min-width:0;display:flex}.preview-frame-wrap{padding:var(--space-5);background:var(--surface);flex:1;justify-content:stretch;align-items:stretch;min-height:0;display:flex}.preview-frame{border:1px solid var(--border);border-radius:var(--radius-lg);background:var(--bg);box-shadow:var(--shadow-md);flex:1}.preview-empty{color:var(--muted);flex:1;justify-content:center;align-items:center;font-size:14px;display:flex}.critique{padding:var(--space-4) var(--space-6);border-top:1px solid var(--border);background:var(--bg);align-items:center;gap:var(--space-4);flex-wrap:wrap;display:flex}.critique-score{letter-spacing:-.02em;font-size:24px;font-weight:700}.critique-dim{color:var(--muted);flex-direction:column;gap:2px;font-size:11px;display:flex}.critique-dim-name{text-transform:uppercase;letter-spacing:.05em}.critique-dim-bar{border-radius:var(--radius-pill);background:var(--border);width:60px;height:3px;overflow:hidden}.critique-dim-bar>div{background:var(--ink);height:100%}.result{flex:1;grid-template-columns:1fr 360px;min-height:0;display:grid}.result-preview{padding:var(--space-5);background:var(--surface);gap:var(--space-4);flex-direction:column;display:flex;overflow:hidden}.result-preview-frame{border:1px solid var(--border);border-radius:var(--radius-lg);background:var(--bg);box-shadow:var(--shadow-md);flex:1;overflow:hidden}.result-preview iframe{border:none;width:100%;height:100%}.result-actions{gap:var(--space-2);justify-content:flex-end;display:flex}.result-sidebar{border-left:1px solid var(--border);padding:var(--space-6);gap:var(--space-5);background:var(--bg);flex-direction:column;display:flex;overflow-y:auto}.result-sidebar h3{text-transform:uppercase;letter-spacing:.08em;color:var(--muted);font-size:12px;font-weight:600}.iterate-panel{flex-direction:column;gap:8px;display:flex}.iterate-hint{color:var(--muted);margin:0 0 2px;font-size:12px;line-height:1.4}.iterate-input-wrap{border:1px solid var(--border);border-radius:var(--radius-md);background:var(--bg);transition:border-color .2s var(--ease), box-shadow .2s var(--ease);flex-direction:column;display:flex;position:relative}.iterate-input-wrap:focus-within{border-color:var(--ink);box-shadow:0 0 0 3px #0a0a0a0d}.iterate-input-wrap.is-busy{opacity:.92}.iterate-input{border-radius:var(--radius-md) var(--radius-md) 0 0;width:100%;min-height:86px;font:inherit;resize:vertical;color:inherit;background:0 0;border:0;outline:none;padding:12px 14px 0;font-size:14px}.iterate-input::placeholder{color:var(--muted-soft)}.iterate-input:disabled{cursor:not-allowed}.iterate-input-foot{border-top:1px solid #0000;justify-content:space-between;align-items:center;gap:10px;padding:8px 10px 8px 14px;display:flex}.iterate-shortcut{color:var(--muted-soft);align-items:center;gap:4px;font-size:11px;display:inline-flex}.iterate-shortcut kbd{font:inherit;border:1px solid var(--border);background:var(--surface);color:var(--muted);border-radius:3px;padding:1px 5px;font-family:ui-monospace,SFMono-Regular,Menlo,monospace;font-size:10px}.iterate-send{border-radius:var(--radius-pill);background:var(--ink);color:var(--bg);font:inherit;letter-spacing:.01em;cursor:pointer;transition:opacity .15s var(--ease), background .15s var(--ease);border:0;align-items:center;gap:6px;padding:6px 12px;font-size:12px;font-weight:600;display:inline-flex}.iterate-send:hover:not(:disabled){opacity:.92}.iterate-send:disabled{opacity:.35;cursor:not-allowed}.iterate-send-spinner{border:1.5px solid;border-right-color:#0000;border-radius:50%;width:11px;height:11px;animation:.7s linear infinite iterate-send-spin;display:inline-block}@keyframes iterate-send-spin{to{transform:rotate(360deg)}}.iterate-progress{border:1px solid var(--border);border-radius:var(--radius-md);background:var(--surface);flex-direction:column;gap:10px;padding:16px;display:flex}.iterate-progress-head{align-items:center;gap:10px;display:flex}.iterate-progress-spinner{border:2px solid var(--border-strong,var(--border));border-top-color:var(--ink);border-radius:50%;width:16px;height:16px;animation:.7s linear infinite iterate-send-spin}.iterate-progress-title{letter-spacing:.01em;color:var(--ink);font-size:13px;font-weight:600}.iterate-progress-stage{color:var(--ink);min-height:20px;padding-left:26px;font-size:14px;line-height:1.4}.iterate-progress-bar{background:var(--border);border-radius:2px;height:3px;position:relative;overflow:hidden}.iterate-progress-bar-fill{background:var(--ink);border-radius:2px;width:35%;animation:1.6s ease-in-out infinite iterate-bar-slide;position:absolute;inset:0 auto 0 0}@keyframes iterate-bar-slide{0%{width:35%;left:-35%}50%{width:45%;left:30%}to{width:35%;left:100%}}.iterate-progress-hint{color:var(--muted);margin:0;font-size:11px;line-height:1.4}.version-list{gap:var(--space-2);flex-direction:column;display:flex}.version-item{padding:var(--space-3);border:1px solid var(--border);border-radius:var(--radius-md);cursor:pointer;transition:all .2s var(--ease);text-align:left;color:inherit;background:var(--bg);flex-direction:column;gap:4px;font-family:inherit;font-size:13px;display:flex}.version-item:hover{border-color:var(--ink)}.version-item.current{border-color:var(--ink);background:var(--surface)}.version-item-head{justify-content:space-between;align-items:baseline;display:flex}.version-item-v{font-size:13px;font-weight:700}.version-item-tag{color:var(--muted);text-transform:uppercase;letter-spacing:.05em;font-size:11px}.version-item-prompt{color:var(--muted);font-size:12px;line-height:1.4}.asset-drop{border:2px dashed var(--border-strong);border-radius:var(--radius-md);padding:var(--space-5);align-items:center;gap:var(--space-2);cursor:pointer;transition:all .2s var(--ease);text-align:center;flex-direction:column;display:flex}.asset-drop:hover{border-color:var(--ink);background:var(--surface)}.asset-drop input[type=file]{display:none}.asset-drop-hint{color:var(--muted);font-size:12px}.asset-list{gap:var(--space-2);margin-top:var(--space-3);flex-direction:column;display:flex}.asset-item{align-items:center;gap:var(--space-3);padding:var(--space-2) var(--space-3);border:1px solid var(--border);border-radius:var(--radius-sm);font-size:13px;display:flex}.asset-item img{object-fit:cover;border-radius:var(--radius-sm);width:40px;height:40px}.asset-item-name{text-overflow:ellipsis;white-space:nowrap;flex:1;overflow:hidden}.asset-item-remove{color:var(--muted);padding:var(--space-1) var(--space-2);font-size:12px}.asset-item-remove:hover{color:var(--danger)}.muted{color:var(--muted);font-size:13px}.small{font-size:12px}.mono{font-family:var(--font-mono)}.spacer{flex:1}.error-banner{color:var(--danger);border-radius:var(--radius-md);padding:var(--space-3) var(--space-4);background:#fef2f2;border:1px solid #fecaca;font-size:14px}.home{width:100%;max-width:720px;padding:var(--space-7) var(--space-5) var(--space-8);gap:var(--space-5);scrollbar-width:none;-ms-overflow-style:none;flex-direction:column;flex:1;align-self:stretch;min-height:0;margin:0 auto;display:flex;overflow-y:auto}.home::-webkit-scrollbar{width:0;height:0;display:none}.home-top{justify-content:space-between;align-items:flex-start;gap:var(--space-5);display:flex}.home-title-group{flex-direction:column;gap:4px;min-width:0;display:flex}.home-title{letter-spacing:-.02em;color:var(--ink);font-size:22px;font-weight:600;line-height:1.15}.home-sub{color:var(--muted);font-size:14px;line-height:1.45}.home-new{flex:none;align-items:center;gap:6px;padding:9px 16px;font-size:13.5px;font-weight:500;display:inline-flex}.home-new-plus{opacity:.8;font-size:15px;font-weight:400;line-height:1}.home-skeleton{flex-direction:column;gap:10px;display:flex}.home-skel-row{border-radius:var(--radius-md);background:linear-gradient(90deg, var(--surface) 0%, var(--surface-hover) 50%, var(--surface) 100%);background-size:200% 100%;height:64px;animation:1.4s ease-in-out infinite skel-pulse}@keyframes skel-pulse{0%{background-position:100% 0}to{background-position:-100% 0}}.home-empty{align-items:center;gap:var(--space-3);padding:var(--space-8) var(--space-5);text-align:center;color:var(--muted);flex-direction:column;display:flex}.home-empty-dot{background:var(--border-strong);width:8px;height:8px;margin-bottom:var(--space-1);border-radius:50%}.home-empty-title{color:var(--ink);letter-spacing:-.01em;font-size:15px;font-weight:500}.home-empty-sub{color:var(--muted);max-width:320px;font-size:13.5px}.home-empty .btn-primary{margin-top:var(--space-3);align-items:center;gap:6px;padding:9px 16px;font-size:13.5px;display:inline-flex}.home-list{flex-direction:column;gap:8px;list-style:none;display:flex}.home-card{align-items:center;gap:var(--space-4);border:1px solid var(--border);border-radius:var(--radius-md);background:var(--bg);cursor:pointer;transition:background .15s var(--ease), border-color .15s var(--ease);padding:14px 16px;display:flex}.home-card:hover{background:var(--surface);border-color:var(--border-strong)}.home-card:hover .home-card-delete{opacity:1;transform:translate(0)}.home-card-link{min-width:0;color:inherit;flex:1;align-items:center;text-decoration:none;display:flex}.home-card-link:hover,.home-card-link:focus,.home-card-link:visited{color:inherit;text-decoration:none}.home-card-left{flex-direction:column;flex:1;gap:4px;min-width:0;display:flex}.home-card-title{color:var(--ink);letter-spacing:-.01em;white-space:nowrap;text-overflow:ellipsis;font-size:14.5px;font-weight:500;overflow:hidden}.home-card-meta{color:var(--muted);font-variant-numeric:tabular-nums;align-items:center;gap:8px;font-size:12.5px;display:flex}.home-card-status{color:var(--ink-soft);font-weight:500}.home-card-dot{color:var(--muted-soft);margin:0 -2px}.home-card-link-out{border-radius:var(--radius-sm);width:32px;height:32px;color:var(--muted);transition:background .15s var(--ease), color .15s var(--ease);flex-shrink:0;justify-content:center;align-items:center;text-decoration:none;display:inline-flex}.home-card-link-out:hover,.home-card-link-out:focus{background:var(--surface-strong,#0000000d);color:var(--ink);text-decoration:none}.home-card-rename-input{font:inherit;color:var(--ink);letter-spacing:-.01em;border:1px solid var(--border-strong,#c7cad3);border-radius:var(--radius-sm);background:var(--bg);outline:none;width:100%;margin:-4px -8px;padding:4px 8px;font-size:14.5px;font-weight:500;transition:border-color .12s,box-shadow .12s}.home-card-rename-input:focus{border-color:#4f6cff;box-shadow:0 0 0 3px #4f6cff26}.home-card-rename-hint{color:var(--muted);font-size:12px;font-style:italic}.home-card-score{color:var(--muted);font-feature-settings:"tnum"}.home-card-delete{width:28px;height:28px;color:var(--muted-soft);border-radius:var(--radius-sm);opacity:0;transition:opacity .15s var(--ease), transform .15s var(--ease), background .15s var(--ease), color .15s var(--ease);background:0 0;flex:none;justify-content:center;align-items:center;display:flex;transform:translate(4px)}.home-card-delete:hover{color:var(--danger);background:#fef2f2}.kebab-root{flex:none;position:relative}.kebab-btn{width:28px;height:28px;color:var(--muted-soft);border-radius:var(--radius-sm);cursor:pointer;opacity:0;transition:opacity .15s var(--ease), transform .15s var(--ease), background .15s var(--ease), color .15s var(--ease);background:0 0;border:none;justify-content:center;align-items:center;display:flex;transform:translate(4px)}.home-card:hover .kebab-btn,.kebab-btn-open{opacity:1;transform:translate(0)}.kebab-btn:hover:not(:disabled){background:var(--surface-hover);color:var(--ink)}.kebab-btn:disabled{opacity:.4;cursor:not-allowed}.kebab-menu{z-index:50;background:var(--bg);border:1px solid var(--border);border-radius:var(--radius-md);min-width:148px;animation:kebab-in .12s var(--ease) both;flex-direction:column;gap:2px;padding:4px;display:flex;position:absolute;top:calc(100% + 4px);right:0;box-shadow:0 10px 24px #00000014,0 2px 6px #0000000d}@keyframes kebab-in{0%{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:translateY(0)}}.kebab-item{color:var(--ink);text-align:left;border-radius:calc(var(--radius-sm) - 2px);cursor:pointer;transition:background .1s var(--ease), color .1s var(--ease);background:0 0;border:none;align-items:center;gap:8px;padding:7px 10px;font-size:13px;display:inline-flex}.kebab-item:hover{background:var(--surface-hover)}.kebab-item svg{opacity:.7;flex:none}.kebab-item-danger{color:var(--danger)}.kebab-item-danger:hover{background:#fef2f2}.kebab-item-danger svg{opacity:1}.dot{border-radius:50%;flex:none;width:6px;height:6px;display:inline-block}.dot-muted{background:var(--muted-soft)}.dot-loading{background:#6366f1}.dot-action{background:#f59e0b}.dot-success{background:#10b981}.dot-error{background:var(--danger)}.dot-pulse{animation:1.6s ease-in-out infinite dot-pulse;position:relative}@keyframes dot-pulse{0%,to{box-shadow:0 0 #6366f180}50%{box-shadow:0 0 0 4px #6366f100}}.banner-error{color:var(--danger);border-radius:var(--radius-md);background:#fef2f2;border:1px solid #fecaca;padding:10px 14px;font-size:13.5px}.brief-back{color:var(--muted);cursor:pointer;margin-bottom:var(--space-4);transition:color .15s var(--ease);background:0 0;border:none;align-self:flex-start;align-items:center;gap:4px;padding:0;font-size:13px;display:inline-flex}.brief-back:hover{color:var(--ink)}.app-header-l{align-items:center;gap:var(--space-6);display:flex}.app-top-nav{align-items:center;gap:var(--space-2);display:flex}.app-top-link{border-radius:var(--radius-pill);color:var(--muted);cursor:pointer;transition:all .15s var(--ease);background:0 0;border:none;padding:6px 12px;font-size:13px;font-weight:500}.app-top-link:hover{color:var(--ink);background:var(--surface)}.app-top-link-active{color:var(--ink);background:var(--surface-hover)}.sdks{width:100%;max-width:1280px;padding:var(--space-7) var(--space-5) var(--space-8);scrollbar-width:none;flex:1;margin:0 auto;overflow-y:auto}.sdks::-webkit-scrollbar{display:none}.sdks-top{justify-content:space-between;align-items:flex-start;gap:var(--space-5);margin-bottom:var(--space-6);display:flex}.sdks-title{letter-spacing:-.02em;color:var(--ink);margin-bottom:6px;font-size:28px;font-weight:600}.sdks-sub{color:var(--muted);max-width:560px;font-size:14px;line-height:1.5}.sdks-skeleton{gap:var(--space-5);grid-template-columns:repeat(auto-fill,minmax(340px,1fr));display:grid}.sdks-skel-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);height:440px;animation:1.5s ease-in-out infinite pulse}.sdks-empty{padding:var(--space-8) var(--space-5);text-align:center;color:var(--muted)}.sdks-empty-sub{color:var(--muted-soft);margin-top:8px;font-size:13px}.sdks-empty code{font-family:var(--font-mono);background:var(--surface);border:1px solid var(--border);border-radius:4px;padding:1px 6px;font-size:12px}.sdks-grid{gap:var(--space-5);grid-template-columns:repeat(auto-fill,minmax(360px,1fr));display:grid}.sdk-card{background:var(--bg);border:1px solid var(--border);border-radius:var(--radius-lg);transition:all .2s var(--ease);flex-direction:column;display:flex;overflow:hidden}.sdk-card:hover{border-color:var(--border-strong);box-shadow:var(--shadow-sm)}.sdk-card-on{border-color:var(--ink);box-shadow:0 0 0 1px var(--ink), var(--shadow-sm)}.sdk-card-preview{aspect-ratio:16/9;background:var(--surface);border-bottom:1px solid var(--border);position:relative;overflow:hidden}.sdk-card-preview-img{object-fit:cover;width:100%;height:100%;display:block}.sdk-card-preview-placeholder{color:var(--muted-soft);justify-content:center;align-items:center;font-size:13px;display:flex;position:absolute;inset:0}.sdk-card-preview-dots{border-radius:var(--radius-pill);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);background:#0006;gap:6px;padding:4px 8px;display:flex;position:absolute;bottom:10px;left:50%;transform:translate(-50%)}.sdk-card-preview-dot{cursor:pointer;width:6px;height:6px;transition:background .15s var(--ease);background:#ffffff80;border:none;border-radius:50%;padding:0}.sdk-card-preview-dot.active,.sdk-card-preview-dot:hover{background:#fff}.sdk-card-body{padding:var(--space-5);gap:var(--space-3);flex-direction:column;flex:1;display:flex}.sdk-card-head{justify-content:space-between;align-items:center;gap:var(--space-3);display:flex}.sdk-card-head-l{flex-direction:column;gap:2px;display:flex}.sdk-card-name{color:var(--ink);letter-spacing:-.01em;font-size:16px;font-weight:600}.sdk-card-kind{text-transform:uppercase;letter-spacing:.06em;color:var(--muted-soft);font-size:11px;font-weight:500}.sdk-toggle{cursor:pointer;flex-shrink:0;width:36px;height:20px;position:relative}.sdk-toggle input{opacity:0;width:0;height:0;position:absolute}.sdk-toggle-track{background:var(--border-strong);transition:background .2s var(--ease);border-radius:20px;position:absolute;inset:0}.sdk-toggle-track:before{content:"";width:16px;height:16px;transition:transform .2s var(--ease);background:#fff;border-radius:50%;position:absolute;top:2px;left:2px;box-shadow:0 1px 3px #00000026}.sdk-toggle input:checked+.sdk-toggle-track{background:var(--ink)}.sdk-toggle input:checked+.sdk-toggle-track:before{transform:translate(16px)}.sdk-card-one-liner{color:var(--ink-soft);font-size:13.5px;line-height:1.5}.sdk-card-caption{color:var(--muted);padding:var(--space-3);background:var(--surface);border-radius:var(--radius-md);border:1px solid var(--border);font-size:12px;line-height:1.45}.sdk-card-details{color:var(--muted);font-size:12.5px}.sdk-card-details summary{cursor:pointer;color:var(--ink-soft);-webkit-user-select:none;user-select:none;padding:4px 0;font-weight:500;list-style:none}.sdk-card-details summary::-webkit-details-marker{display:none}.sdk-card-details summary:before{content:"▸";transition:transform .15s var(--ease);margin-right:6px;font-size:10px;display:inline-block}.sdk-card-details[open] summary:before{transform:rotate(90deg)}.sdk-card-details ul{padding-left:var(--space-5);flex-direction:column;gap:3px;margin-top:4px;display:flex}.sdk-card-details li{line-height:1.5}.sdk-card-state{color:var(--muted);align-self:flex-start;align-items:center;gap:6px;font-size:12px;display:inline-flex}.sdk-card-state-dot{background:var(--muted-soft);border-radius:50%;width:6px;height:6px}.sdk-card-state-ok .sdk-card-state-dot{background:var(--success)}.sdk-card-state-warn .sdk-card-state-dot{background:#eab308}.sdk-card-state-bad .sdk-card-state-dot{background:var(--danger)}.sdk-creds-summary{padding-top:var(--space-3);border-top:1px solid var(--border);flex-direction:column;gap:6px;display:flex}.sdk-creds-row{justify-content:space-between;align-items:center;gap:var(--space-3);font-size:12.5px;display:flex}.sdk-creds-key{color:var(--muted);font-family:var(--font-mono);font-size:11.5px}.sdk-creds-val{color:var(--ink-soft);font-family:var(--font-mono);white-space:nowrap;text-overflow:ellipsis;max-width:55%;font-size:11.5px;overflow:hidden}.sdk-edit-btn{padding:8px var(--space-4);margin-top:var(--space-2);align-self:stretch;font-size:12.5px}.sdk-creds-form{gap:var(--space-3);padding-top:var(--space-3);border-top:1px solid var(--border);flex-direction:column;display:flex}.sdk-creds-field{flex-direction:column;gap:4px;display:flex}.sdk-creds-label{font-size:11.5px;font-family:var(--font-mono);color:var(--muted)}.sdk-req{color:var(--danger);margin-left:3px}.sdk-creds-input{background:var(--bg);border:1px solid var(--border);border-radius:var(--radius-sm);font-family:var(--font-mono);color:var(--ink);transition:border-color .15s var(--ease);padding:8px 10px;font-size:12.5px}.sdk-creds-input:focus{border-color:var(--ink);outline:none}.sdk-creds-actions{gap:var(--space-2);margin-top:var(--space-2);justify-content:flex-end;display:flex}.sdk-creds-actions .btn-primary,.sdk-creds-actions .btn-secondary{padding:8px var(--space-4);font-size:12.5px}.imagery-option{cursor:pointer;align-items:flex-start;gap:10px;padding:8px 0;display:flex}.imagery-option input[type=radio]{cursor:pointer;margin-top:3px}.imagery-option-body{flex:1}.imagery-option-title{color:#1a1a1a;margin-bottom:2px;font-size:13px;font-weight:600}.imagery-option-hint{color:#777;font-size:11px;line-height:1.3}.canvas{--canvas-code-bg:#fff;--canvas-code-head-bg:#f6f7fa;--canvas-code-ink:#1a1d24;--canvas-code-muted:#6b6b73;--canvas-code-border:#e1e3eb;--canvas-code-accent:#2453d3;--canvas-mono:ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, monospace;background:var(--bg);flex-direction:column;flex:1;min-width:0;height:100%;min-height:0;display:flex;overflow:hidden}.canvas-tabs{background:var(--surface);border-bottom:1px solid var(--border);flex-shrink:0;align-items:stretch;height:38px;display:flex}.canvas-tab{border:0;border-right:1px solid var(--border);color:var(--muted);cursor:pointer;background:0 0;align-items:center;gap:8px;padding:0 14px;font-size:12px;display:flex}.canvas-tab:hover{background:var(--surface-hover);color:var(--ink)}.canvas-tab-active{background:var(--bg);color:var(--ink);border-bottom:2px solid var(--ink);margin-bottom:-1px}.canvas-tab-label{letter-spacing:.01em;font-weight:600}.canvas-tab-sub{color:var(--muted-soft);font-family:var(--canvas-mono);font-size:11px}.canvas-body{flex-direction:column;flex:1;min-height:0;display:flex;overflow:hidden}.canvas-empty{color:var(--muted);text-align:center;padding:40px;font-size:13px}.canvas-empty-compact{padding:16px 12px;font-size:12px}.canvas-files{background:var(--bg);flex:1;grid-template-columns:220px 1fr;min-height:0;display:grid}.canvas-files-tree{background:var(--bg);border-right:1px solid var(--border);font-family:var(--canvas-mono);padding:10px 0;font-size:12px;overflow-y:auto}.canvas-files-main{background:var(--canvas-code-bg);min-width:0;min-height:0;overflow:auto}.canvas-tree-inner{flex-direction:column;display:flex}.canvas-tree-row{cursor:pointer;-webkit-user-select:none;user-select:none;color:var(--ink);white-space:nowrap;text-overflow:ellipsis;align-items:center;gap:5px;padding:3px 10px;display:flex;overflow:hidden}.canvas-tree-row:hover{background:var(--surface-hover)}.canvas-tree-row-active{color:var(--ink);background:#0a0a0a14;font-weight:500}.canvas-tree-chevron{width:12px;color:var(--muted-soft);font-size:9px}.canvas-tree-dir{color:var(--ink);font-weight:500}.canvas-tree-file-name{text-overflow:ellipsis;flex:1;min-width:0;overflow:hidden}@keyframes canvas-flash{0%{background:#7aa2ff66}to{background:0 0}}.canvas-tree-row-flash{animation:1.6s ease-out canvas-flash}.canvas-tree-empty{color:var(--muted-soft);padding:20px 14px;font-size:11px;line-height:1.5}.canvas-code{background:var(--canvas-code-bg);min-height:100%;color:var(--canvas-code-ink);flex-direction:column;display:flex}.canvas-code-head{background:var(--canvas-code-head-bg);border-bottom:1px solid var(--canvas-code-border);font-family:var(--canvas-mono);z-index:1;justify-content:space-between;align-items:center;padding:8px 14px;font-size:12px;display:flex;position:sticky;top:0}.canvas-code-path{color:var(--canvas-code-accent)}.canvas-code-meta{color:var(--canvas-code-muted)}.canvas-code-body{font-family:var(--canvas-mono);color:var(--canvas-code-ink);min-height:100%;margin:0;padding:10px 0;font-size:12px;line-height:1.6;overflow-x:auto}.canvas-code-line{gap:16px;padding:0 12px;display:flex}.canvas-code-line:hover{background:#00000009}.canvas-code-gutter{text-align:right;width:36px;color:var(--canvas-code-muted);-webkit-user-select:none;user-select:none;flex-shrink:0;font-size:11px}.canvas-code-text{white-space:pre}.canvas-terminal{font-family:var(--canvas-mono);background:var(--canvas-code-bg);color:var(--canvas-code-ink);flex:1;padding:14px 18px 24px;font-size:12px;line-height:1.5;overflow-y:auto}.canvas-terminal-block{border-left:2px solid var(--canvas-code-border);margin-bottom:16px;padding-left:10px}.canvas-terminal-cmd{align-items:center;gap:8px;margin-bottom:4px;font-weight:500;display:flex}.canvas-terminal-prompt{color:var(--canvas-code-accent)}.canvas-terminal-exit{text-transform:uppercase;letter-spacing:.05em;border-radius:3px;padding:1px 6px;font-size:10px;font-weight:600}.canvas-terminal-exit-ok{color:#1f7a4a;background:#2e9b6624}.canvas-terminal-exit-fail{color:#b03b32;background:#d2453a24}.canvas-terminal-out{color:var(--canvas-code-muted);white-space:pre-wrap;word-break:break-word;max-height:300px;margin:0;padding:4px 0;overflow:auto}.canvas-preview{flex-direction:column;flex:1;min-height:0;display:flex}.canvas-preview-toolbar{background:var(--surface);border-bottom:1px solid var(--border);flex-shrink:0;align-items:center;gap:8px;padding:8px 14px;display:flex}.canvas-preview-toolbar .canvas-preview-url{text-overflow:ellipsis;white-space:nowrap;flex:1;min-width:0;overflow:hidden}.canvas-preview-toolbar .btn-secondary,.canvas-preview-toolbar .btn-primary{border-radius:3px;flex-shrink:0;height:26px;padding:0 10px;font-size:11px}.canvas-preview-mode-pill{text-transform:uppercase;letter-spacing:.04em;border:1px solid var(--border);background:var(--surface-hover);color:var(--muted);border-radius:999px;flex-shrink:0;padding:2px 8px;font-size:10px;font-weight:600}.canvas-preview-mode-pill-live{color:#1c6e1c;background:#228b221f;border-color:#228b2266}.canvas-preview-mode-pill-mock{color:#965a00;background:#b46e001f;border-color:#b46e0066}.canvas-preview-settings{background:var(--surface);border-bottom:1px solid var(--border);flex-direction:column;flex-shrink:0;gap:12px;padding:12px 14px;display:flex}.canvas-preview-settings-row{flex-direction:column;gap:10px;display:flex}.canvas-preview-settings-toggle{cursor:pointer;align-items:flex-start;gap:10px;font-size:12px;display:flex}.canvas-preview-settings-toggle>span{flex-direction:column;gap:2px;display:flex}.canvas-preview-settings-label{flex-direction:column;gap:4px;font-size:12px;display:flex}.canvas-preview-settings-sub{color:var(--muted);font-size:11px;font-weight:400}.canvas-preview-settings-input{font-family:var(--canvas-mono);border:1px solid var(--border);background:var(--bg);border-radius:4px;padding:6px 8px;font-size:12px}.canvas-preview-settings-error{color:#b00020;background:#b0002014;border:1px solid #b0002033;border-radius:4px;padding:6px 8px;font-size:12px}.canvas-preview-settings-actions{justify-content:flex-end;gap:8px;display:flex}.canvas-preview-url{font-family:var(--canvas-mono);color:var(--muted);font-size:11px}.canvas-preview-note{color:var(--muted);background:var(--surface);border-bottom:1px solid var(--border);flex-shrink:0;padding:6px 14px;font-size:11px}.canvas-preview-note code{font-family:var(--canvas-mono);background:var(--surface-hover);border-radius:2px;padding:1px 5px;font-size:11px}.canvas-preview-frame{background:#fff;border:0;flex:1;width:100%}.canvas-activity{padding:4px 2px 8px;font-size:11.5px;line-height:1.4;overflow-y:auto}.canvas-activity-compact{max-height:260px;font-size:11px}.canvas-activity-row{color:var(--ink);border-radius:3px;align-items:center;gap:6px;padding:3px 6px;display:flex}.canvas-activity-row:hover{background:var(--surface-hover)}.canvas-activity-stage{color:var(--ink);border-top:1px dashed var(--border);margin-top:3px;padding:6px 6px 4px;font-weight:600}.canvas-activity-stage:first-child{border-top:0;margin-top:0}.canvas-activity-tone-success{color:#178f4b}.canvas-activity-tone-error{color:#c83c3c}.canvas-activity-thought{color:var(--muted);background:#7aa2ff14;border-left:2px solid #5b82d4;margin:4px 0;padding:6px 8px;font-style:italic;line-height:1.5;display:block}.canvas-activity-kind{opacity:.8;margin-right:4px}.canvas-activity-text{color:var(--muted)}.canvas-activity-name{font-family:var(--canvas-mono);color:#3a5dbd;flex-shrink:0;min-width:82px;font-size:10.5px}.activity-name-write_file,.activity-name-edit_file,.activity-name-multi_edit,.activity-name-replace_lines,.activity-name-insert_at_line{color:#178f4b}.activity-name-run_typecheck,.activity-name-run_build,.activity-name-run_command{color:#a86a0a}.activity-name-done{color:var(--ink);font-weight:700}.canvas-activity-arg{text-overflow:ellipsis;white-space:nowrap;min-width:0;color:var(--muted);flex:1;overflow:hidden}.canvas-activity-path{color:var(--ink);cursor:pointer;font-family:var(--canvas-mono);font-size:10.5px;-webkit-text-decoration:underline #0000;text-decoration:underline #0000}.canvas-activity-path:hover{text-decoration-color:#3a5dbd}.canvas-activity-cmd{font-family:var(--canvas-mono);color:var(--muted);font-size:10.5px}.canvas-activity-exit{border-radius:2px;flex-shrink:0;padding:1px 5px;font-size:10px;font-weight:600}.canvas-activity-exit-ok{color:#178f4b;background:#4cc38a29}.canvas-activity-exit-fail{color:#c83c3c;background:#ff6b6b24}.production-progress-head{justify-content:space-between;align-items:center;gap:8px;margin-bottom:8px;display:flex}.production-progress-head h3{margin:0}.production-progress-hint{color:var(--muted);margin:0 0 10px;font-size:12px;line-height:1.45}.production-pill{letter-spacing:.04em;text-transform:uppercase;border-radius:10px;align-items:center;gap:5px;height:20px;padding:0 8px;font-size:10px;font-weight:600;display:inline-flex}.production-pill-pulse{background:currentColor;border-radius:50%;width:5px;height:5px;animation:1.2s ease-in-out infinite s2-pulse;display:inline-block}@keyframes s2-pulse{0%,to{opacity:1;transform:scale(1)}50%{opacity:.4;transform:scale(.7)}}.production-pill-idle{background:var(--surface-hover);color:var(--muted)}.production-pill-run{color:#3a5dbd;background:#7aa2ff24}.production-pill-ok{color:#178f4b;background:#178f4b24}.production-pill-err{color:#c83c3c;background:#c83c3c24}.production-current{border:1px solid var(--border);background:var(--surface);border-radius:6px;align-items:center;gap:8px;margin-bottom:10px;padding:8px 10px;display:flex}.production-current-dot{background:var(--muted-soft);border-radius:50%;flex-shrink:0;width:7px;height:7px}.production-current-dot.production-dot-pulse{background:#3a5dbd;animation:1.2s ease-in-out infinite s2-pulse}.production-current-text{color:var(--ink);text-overflow:ellipsis;white-space:nowrap;font-size:12px;overflow:hidden}.production-summary{flex-wrap:wrap;gap:6px;margin-bottom:10px;display:flex}.production-chip{border:1px solid var(--border);background:var(--bg);border-radius:4px;flex-direction:column;min-width:46px;padding:5px 8px;display:inline-flex}.production-chip-label{color:var(--muted-soft);text-transform:uppercase;letter-spacing:.08em;font-size:9px}.production-chip-value{font-size:12px;font-family:var(--canvas-mono);color:var(--ink);font-weight:600}.production-chip-success .production-chip-value{color:#178f4b}.production-chip-error .production-chip-value{color:#c83c3c}.production-activity-wrap{border:1px solid var(--border);background:var(--bg);border-radius:6px;margin-bottom:8px;overflow:hidden}.production-error{color:#c83c3c;background:#c83c3c14;border:1px solid #c83c3c40;border-radius:4px;padding:8px 10px;font-size:12px}.deploy-progress{color:#4b5563;word-break:break-all;padding:4px 2px;font-size:11px;line-height:1.4}.deploy-progress code{color:#111;font-family:SF Mono,Menlo,monospace;font-size:10px}.deploy-error{color:#c83c3c;word-break:break-word;background:#c83c3c14;border:1px solid #c83c3c40;border-radius:4px;padding:8px 10px;font-size:11px;line-height:1.4}.deploy-live{background:#10a34a0d;border:1px solid #10a34a4d;border-radius:6px;flex-direction:column;gap:6px;padding:10px 12px;display:flex}.deploy-live-eyebrow{letter-spacing:.1em;text-transform:uppercase;color:#0f7a36;font-size:10px;font-weight:700}.deploy-live-url{color:#0f7a36;word-break:break-all;font-family:SF Mono,Menlo,monospace;font-size:11px;line-height:1.45;text-decoration:underline}.deploy-live-actions{align-items:center;gap:10px;margin-top:2px;display:flex}.deploy-live-btn{flex-shrink:0;height:auto;padding:4px 10px;font-size:11px;width:auto!important}.deploy-live-meta{color:#6b7280;font-variant-numeric:tabular-nums;font-size:10px}.production-stage-error{background:#c83c3c0f;border:1px solid #c83c3c47;border-radius:6px;margin:8px 0 12px;padding:10px 12px}.production-stage-error-eyebrow{letter-spacing:.1em;text-transform:uppercase;color:#c83c3c;margin-bottom:4px;font-size:10px;font-weight:700}.production-stage-error-msg{color:#1f2937;word-break:break-word;font-size:12px;line-height:1.45}.production-stage-error-hint{color:#4b5563;margin:8px 0 0;font-size:11px;line-height:1.5}.production-stage-error-hint a{color:#c83c3c;text-decoration:underline}.production-stage-error-hint code{background:#f0f2f5;border-radius:3px;padding:1px 5px;font-family:SF Mono,Menlo,monospace;font-size:10px}.connector-approval-backdrop{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:1000;background:#0a0c128c;justify-content:center;align-items:center;padding:24px;display:flex;position:fixed;inset:0}.connector-approval-modal{background:#fff;border-radius:10px;width:100%;max-width:880px;max-height:90vh;padding:20px 24px;overflow-y:auto;box-shadow:0 24px 60px #0a0c1240}.connector-approval-head h3{margin:0 0 4px;font-size:16px;font-weight:600}.connector-approval-head p{color:#555;margin:0 0 16px;font-size:13px;line-height:1.5}.muted-inline{color:#888}.connector-approval-docs{background:#f9f9fb;border:1px dashed #c6c9d0;border-radius:6px;margin-bottom:12px;padding:12px 14px}.connector-approval-docs-label{color:#222;flex-direction:column;gap:6px;font-size:12px;font-weight:500;display:flex}.connector-approval-docs-input{resize:vertical;background:#fff;border:1px solid #d4d7de;border-radius:4px;width:100%;min-height:90px;padding:8px 10px;font-family:SF Mono,Menlo,monospace;font-size:12px;line-height:1.45}.connector-approval-docs-input:focus{outline-offset:-1px;outline:2px solid #0a84ff59}.connector-approval-docs-actions{justify-content:space-between;align-items:center;gap:10px;margin-top:8px;display:flex}.connector-approval-eval-summary{color:#5a6170;font-variant-numeric:tabular-nums;font-size:11px}.connector-approval-eval-note{color:#374151;margin:8px 0 0;font-size:11px;line-height:1.45}.connector-approval-unused{color:#4b5563;margin-top:8px;font-size:11px}.connector-approval-unused summary{cursor:pointer;color:#6b7280}.connector-approval-unused ul{margin:6px 0 0 16px;padding:0;line-height:1.5}.connector-approval-group{border-top:1px solid #eceff3;margin-top:14px;padding-top:10px}.connector-approval-group-head{justify-content:space-between;align-items:center;gap:10px;margin-bottom:8px;display:flex}.connector-approval-group-sub{color:#6b7280;margin-left:8px;font-size:11px}.connector-approval-pill{letter-spacing:.03em;text-transform:uppercase;border-radius:9999px;padding:2px 8px;font-size:10px;font-weight:600;display:inline-block}.connector-approval-pill-recommended{color:#0f7a36;background:#10a34a1f;border:1px solid #10a34a4d}.connector-approval-pill-optional{color:#4b5563;background:#f0f2f5;border:1px solid #d4d7de}.connector-approval-row-resolved{background:#10a34a0d;border-color:#16a34a}.connector-approval-resolved-tag{color:#0f7a36;letter-spacing:.02em;background:#10a34a26;border-radius:9999px;margin-left:auto;padding:2px 8px;font-size:10px;font-weight:600}.connector-approval-reasoning{color:#6b7280;font-size:11px;font-style:italic;line-height:1.4}.connector-approval-resolved-notes{color:#0f7a36;font-size:11px;line-height:1.4}.apis-tab{background:#fff;flex:1;min-height:0;padding:20px 24px;overflow-y:auto}.apis-tab-empty{color:#6b7280;flex-direction:column;justify-content:center;align-items:center;gap:12px;padding:48px 24px;font-size:13px;display:flex}.apis-tab-eyebrow{letter-spacing:.1em;text-transform:uppercase;color:#9ca3af;font-size:10px;font-weight:700}.apis-tab-error{color:#c83c3c}.apis-tab-head{border-bottom:1px solid #eceff3;justify-content:space-between;align-items:flex-start;gap:16px;margin-bottom:16px;padding-bottom:12px;display:flex}.apis-tab-head h3{margin:0 0 4px;font-size:15px;font-weight:600}.apis-tab-head p{color:#6b7280;margin:0;font-size:12px;line-height:1.5}.apis-tab-actions{flex-shrink:0;gap:8px;display:flex}.apis-tab-sections{flex-direction:column;gap:18px;display:flex}.apis-tab-section h4{color:#374151;align-items:center;gap:8px;margin:0 0 8px;font-size:12px;font-weight:600;display:flex}.apis-tab-section-count{color:#9ca3af;font-size:10px;font-weight:500}.apis-tab-section ul{flex-direction:column;gap:6px;margin:0;padding:0;list-style:none;display:flex}.apis-tab-row{background:#fff;border:1px solid #e4e7ec;border-radius:6px;padding:10px 12px}.apis-tab-row-wired{background:#10a34a0a;border-color:#16a34a}.apis-tab-row-mock{background:#fafbfc;border-color:#e4e7ec}.apis-tab-row-head{align-items:center;gap:8px;margin-bottom:4px;display:flex}.apis-tab-row-meta{color:#6b7280;flex-direction:column;gap:2px;padding-left:0;font-size:11px;line-height:1.45;display:flex}.apis-tab-row-url{color:#0f7a36;font-family:SF Mono,Menlo,monospace;font-size:10px}.apis-tab-status{letter-spacing:.03em;text-transform:uppercase;border-radius:9999px;margin-left:auto;padding:2px 8px;font-size:10px;font-weight:600}.apis-tab-status-wired{color:#0f7a36;background:#10a34a1f;border:1px solid #10a34a4d}.apis-tab-status-mock{color:#6b7280;background:#f0f2f5;border:1px solid #d4d7de}.apis-tab-status-overridden{color:#8a6d3b;background:#fff3cd;border:1px solid #f0d690;margin-left:6px}.apis-tab-row-overridden{border-left:3px solid #f0ad4e}.apis-tab-overrides{background:#fffbf3;border:1px dashed #e4e7ec;border-radius:6px;margin-top:10px;padding:0;font-size:12px}.apis-tab-overrides[open]{background:#fff}.apis-tab-overrides>summary{cursor:pointer;-webkit-user-select:none;user-select:none;color:#8a6d3b;letter-spacing:.02em;align-items:center;gap:10px;padding:8px 12px;font-size:11.5px;font-weight:600;list-style:none;display:flex}.apis-tab-overrides>summary::-webkit-details-marker{display:none}.apis-tab-overrides>summary:before{content:"▸";color:#b78b3e;font-size:10px;transition:transform .12s;display:inline-block}.apis-tab-overrides[open]>summary:before{transform:rotate(90deg)}.apis-tab-overrides-hint{color:#9ca3af;letter-spacing:0;margin-left:auto;font-size:11px;font-weight:400}.apis-tab-overrides-list{grid-template-columns:140px 1fr;gap:4px 12px;margin:0;padding:0 12px 10px;display:grid}.apis-tab-overrides-list dt{color:#4b5563;padding-top:3px;font-size:11px;font-weight:500}.apis-tab-overrides-list dd{color:#1f2937;min-width:0;margin:0;font-size:11.5px}.apis-tab-overrides-list code{color:#0f7a36;background:#0f7a3614;border-radius:3px;padding:1px 5px;font-family:SF Mono,Menlo,monospace;font-size:11.5px}.apis-tab-overrides-was{-webkit-text-decoration:line-through #8a6d3b99;text-decoration:line-through #8a6d3b99;color:#8a6d3b!important;background:#8c6d3b1f!important}.apis-tab-overrides-now{font-weight:600;color:#0f7a36!important;background:#10a34a24!important}.apis-tab-overrides-arrow{color:#9ca3af;font-size:11px}.apis-tab-overrides-params{flex-direction:column;gap:2px;margin:0;padding:0;list-style:none;display:flex}.apis-tab-overrides-params li{color:#1f2937;font-size:11.5px;line-height:1.5}.apis-tab-overrides-param-type{color:#6b7280;font-family:SF Mono,Menlo,monospace;font-size:11px}.apis-tab-overrides-param-desc{color:#6b7280;font-style:italic}.apis-tab-overrides-body{color:#1f2937;white-space:pre-wrap;word-break:break-word;background:#f6f7fa;border:1px solid #eceff3;border-radius:4px;max-height:160px;margin:0;padding:6px 8px;font-family:SF Mono,Menlo,monospace;font-size:11px;overflow-y:auto}.apis-tab-overrides-notes{color:#4b5563;font-style:italic;line-height:1.5}@media (width<=720px){.apis-tab-overrides-list{grid-template-columns:1fr}.apis-tab-overrides-list dt{color:#6b7280;padding-top:6px}}.apis-tab-cancel-wrap{border-top:1px solid #eceff3;justify-content:flex-end;padding:12px 24px;display:flex}.apis-tab .connector-approval-backdrop{-webkit-backdrop-filter:none;backdrop-filter:none;background:0 0;padding:0;display:block;position:static}.apis-tab .connector-approval-modal{width:auto;max-width:none;max-height:none;box-shadow:none;border-radius:0;padding:0}.connector-approval-global{background:#f6f7fa;border-radius:6px;flex-direction:column;gap:6px;margin-bottom:12px;padding:12px 14px;display:flex}.connector-approval-global label{color:#222;flex-direction:column;gap:4px;font-size:12px;font-weight:500;display:flex}.connector-approval-global input{border:1px solid #d4d7de;border-radius:4px;padding:6px 8px;font-family:inherit;font-size:13px}.connector-approval-global-hint{color:#6b7280;font-size:11px}.connector-approval-bulk{gap:8px;margin-bottom:8px;display:flex}.connector-approval-bulk-btn{cursor:pointer;color:#333;background:#fff;border:1px solid #d4d7de;border-radius:4px;padding:4px 10px;font-size:11px}.connector-approval-bulk-btn:hover:not(:disabled){background:#f0f2f5}.connector-approval-list{flex-direction:column;gap:6px;margin:0 0 12px;padding:0;list-style:none;display:flex}.connector-approval-row{background:#fff;border:1px solid #e4e7ec;border-radius:6px;flex-direction:column;gap:6px;padding:10px 12px;transition:border-color .12s,background .12s;display:flex}.connector-approval-row-on{background:#0a84ff0a;border-color:#0a84ff}.connector-approval-check{cursor:pointer;align-items:center;gap:8px;font-size:12px;display:flex}.connector-approval-check input[type=checkbox]{margin:0}.connector-approval-method{color:#fff;letter-spacing:.04em;background:#111;border-radius:3px;padding:2px 6px;font-size:10px;font-weight:600}.connector-approval-path{color:#222;font-family:SF Mono,Menlo,monospace;font-size:12px}.connector-approval-meta{flex-direction:column;gap:2px;padding-left:24px;display:flex}.connector-approval-type{color:#0a84ff;font-family:SF Mono,Menlo,monospace;font-size:11px}.connector-approval-desc{color:#6b7280;font-size:11px;line-height:1.4}.connector-approval-base{border:1px solid #d4d7de;border-radius:4px;margin-left:24px;padding:5px 8px;font-family:inherit;font-size:12px}.connector-approval-base:disabled{color:#9ca3af;background:#f6f7fa}.connector-approval-error{color:#c83c3c;background:#c83c3c14;border:1px solid #c83c3c40;border-radius:4px;margin:8px 0 0;padding:8px 10px;font-size:12px}.connector-approval-actions{border-top:1px solid #eceff3;justify-content:flex-end;gap:10px;margin-top:12px;padding-top:14px;display:flex}.connector-approval-overrides{background:#fafbfc;border:1px solid #e4e7ec;border-radius:6px;margin:8px 0 0 24px;padding:0;font-size:12px}.connector-approval-overrides[open]{background:#fff}.connector-approval-overrides>summary{cursor:pointer;-webkit-user-select:none;user-select:none;color:#4b5563;align-items:center;gap:10px;padding:8px 12px;font-weight:500;list-style:none;display:flex}.connector-approval-overrides>summary::-webkit-details-marker{display:none}.connector-approval-overrides>summary:before{content:"▸";color:#9ca3af;font-size:10px;transition:transform .12s;display:inline-block}.connector-approval-overrides[open]>summary:before{transform:rotate(90deg)}.connector-approval-overrides-pill{color:#8a6d3b;letter-spacing:.02em;background:#fff3cd;border-radius:999px;margin-left:auto;padding:2px 8px;font-size:10px;font-weight:600}.connector-approval-overrides-hint{color:#9ca3af;margin-left:auto;font-size:11px;font-weight:400}.connector-approval-row-overridden{border-left:3px solid #f0ad4e}.connector-approval-overrides[open]>:not(summary){padding:0 12px}.connector-approval-overrides[open]>:last-child{padding-bottom:12px}.connector-approval-overrides-grid{grid-template-columns:minmax(80px,.6fr) minmax(140px,1.4fr) minmax(120px,1fr);gap:10px 12px;padding-top:10px;display:grid}.connector-approval-overrides-grid>label{flex-direction:column;gap:4px;min-width:0;display:flex}.connector-approval-overrides-grid>label>span{color:#4b5563;font-size:11px;font-weight:500}.connector-approval-overrides-grid input[type=text],.connector-approval-overrides-grid select{box-sizing:border-box;background:#fff;border:1px solid #d4d7de;border-radius:4px;width:100%;padding:6px 8px;font-family:inherit;font-size:12px}.connector-approval-overrides-grid input[type=text]:focus,.connector-approval-overrides-grid select:focus{border-color:#0a84ff;outline:none;box-shadow:0 0 0 3px #0a84ff26}.connector-approval-overrides-grid input[type=text]:disabled,.connector-approval-overrides-grid select:disabled{color:#9ca3af;cursor:not-allowed;background:#f6f7fa}.connector-approval-override-method{text-transform:uppercase;font-family:SF Mono,Menlo,monospace}.connector-approval-override-path,.connector-approval-override-envelope{font-family:SF Mono,Menlo,monospace}.connector-approval-overrides-section{border-top:1px dashed #eceff3;margin-top:12px;padding-top:10px!important}.connector-approval-overrides-section-head{justify-content:space-between;align-items:center;margin-bottom:8px;display:flex}.connector-approval-overrides-section-head>span{color:#374151;letter-spacing:.02em;font-size:11px;font-weight:600}.connector-approval-add-qparam{color:#374151;cursor:pointer;background:#fff;border:1px solid #d4d7de;border-radius:4px;padding:3px 10px;font-size:11px;font-weight:500}.connector-approval-add-qparam:hover:not(:disabled){color:#0a84ff;border-color:#0a84ff}.connector-approval-add-qparam:disabled{opacity:.5;cursor:not-allowed}.connector-approval-empty-hint{color:#9ca3af;margin:0 0 8px;font-size:11px;font-style:italic}.connector-approval-qparam-row{grid-template-columns:1.4fr .8fr auto 1.6fr auto;align-items:center;gap:6px;margin-bottom:6px;display:grid}.connector-approval-qparam-row input[type=text],.connector-approval-qparam-row select{box-sizing:border-box;background:#fff;border:1px solid #d4d7de;border-radius:4px;min-width:0;padding:5px 7px;font-family:inherit;font-size:11.5px}.connector-approval-qparam-row input[type=text]:focus,.connector-approval-qparam-row select:focus{border-color:#0a84ff;outline:none;box-shadow:0 0 0 2px #0a84ff26}.connector-approval-qparam-row input[type=text]:disabled,.connector-approval-qparam-row select:disabled{color:#9ca3af;background:#f6f7fa}.connector-approval-qparam-name{font-family:SF Mono,Menlo,monospace}.connector-approval-qparam-required{color:#6b7280;white-space:nowrap;cursor:pointer;align-items:center;gap:4px;font-size:11px;display:inline-flex}.connector-approval-qparam-required input[type=checkbox]{margin:0}.connector-approval-qparam-desc{color:#4b5563}.connector-approval-qparam-remove{color:#9ca3af;cursor:pointer;background:0 0;border:1px solid #0000;border-radius:4px;width:24px;height:24px;padding:0;font-size:16px;line-height:1}.connector-approval-qparam-remove:hover:not(:disabled){color:#c83c3c;background:#c83c3c0f;border-color:#fca5a5}.connector-approval-qparam-remove:disabled{opacity:.4;cursor:not-allowed}.connector-approval-override-body-label,.connector-approval-override-notes-label{flex-direction:column;gap:4px;margin-top:12px;display:flex}.connector-approval-override-body-label>span,.connector-approval-override-notes-label>span{color:#4b5563;font-size:11px;font-weight:500}.connector-approval-override-body,.connector-approval-override-notes{resize:vertical;background:#fff;border:1px solid #d4d7de;border-radius:4px;min-height:44px;padding:6px 8px;font-family:SF Mono,Menlo,monospace;font-size:11.5px}.connector-approval-override-body:focus,.connector-approval-override-notes:focus{border-color:#0a84ff;outline:none;box-shadow:0 0 0 3px #0a84ff26}.connector-approval-override-body:disabled,.connector-approval-override-notes:disabled{color:#9ca3af;background:#f6f7fa}@media (width<=720px){.connector-approval-overrides-grid{grid-template-columns:1fr}.connector-approval-qparam-row{grid-template-columns:1.2fr .8fr auto;grid-auto-flow:dense}.connector-approval-qparam-desc{grid-column:1/-1}}.capability-report{background:#f6f7fa;border-radius:6px;margin-top:14px;padding:12px 12px 10px}.capability-report-head{justify-content:space-between;align-items:baseline;margin-bottom:8px;display:flex}.capability-report-head h4{color:#222;margin:0;font-size:12px;font-weight:600}.capability-report-count{color:#6b7280;font-size:11px}.capability-report-list{flex-direction:column;gap:6px;margin:0;padding:0;list-style:none;display:flex}.capability-row{background:#fff;border-left:2px solid #d4d7de;border-radius:3px;padding:6px 8px}.capability-row-success{border-left-color:#16a34a}.capability-row-error{border-left-color:#dc2626}.capability-row-warn{border-left-color:#d97706}.capability-row-muted{opacity:.7;border-left-color:#d4d7de}.capability-row-head{align-items:center;gap:6px;display:flex}.capability-row-icon{text-align:center;width:12px;font-size:11px;font-weight:600;display:inline-block}.capability-row-success .capability-row-icon{color:#16a34a}.capability-row-error .capability-row-icon{color:#dc2626}.capability-row-warn .capability-row-icon{color:#d97706}.capability-row-muted .capability-row-icon{color:#9ca3af}.capability-row-label{color:#222;flex:1;font-size:12px;font-weight:500}.capability-row-dur{color:#6b7280;font-variant-numeric:tabular-nums;font-size:10px}.capability-row-summary{color:#4b5563;margin:4px 0 0 18px;font-size:11px;line-height:1.45}.capability-row-error>.capability-row-summary,.capability-row-error>.capability-row-meta{color:#991b1b}.capability-row-meta{color:#6b7280;font-variant-numeric:tabular-nums;gap:10px;margin:4px 0 0 18px;font-size:10px;display:flex}.capability-report-skipped{color:#6b7280;margin:8px 0 0;font-size:11px;font-style:italic}.v2-phase-strip{color:var(--muted);flex-wrap:wrap;align-items:center;row-gap:4px;margin:8px 0 6px;padding:6px 0;font-size:11px;display:flex}.v2-phase-strip-item{align-items:center;gap:4px;display:inline-flex}.v2-phase-dot{background:var(--border-strong);border-radius:50%;flex-shrink:0;width:7px;height:7px;display:inline-block}.v2-phase-dot-done{background:#16a34a}.v2-phase-dot-active{background:var(--ink);box-shadow:0 0 0 3px #0a0a0a14}.v2-phase-dot-pending{background:#d4d7de}.v2-phase-label{font-size:11px;font-weight:500}.v2-phase-sep{background:#e4e7ec;width:12px;height:1px;margin:0 6px;display:inline-block}.v2-planner-passes{flex-wrap:wrap;gap:6px;margin:4px 0 8px;display:flex}.v2-planner-pass{border:1px solid #e4e7ec;border-radius:9999px;align-items:center;gap:4px;padding:2px 8px;font-size:10px;font-weight:500;display:inline-flex}.v2-planner-pass-dot{background:#d4d7de;border-radius:50%;width:5px;height:5px;display:inline-block}.v2-planner-pass-done{color:#0f7a36;background:#10a34a0f;border-color:#10a34a4d}.v2-planner-pass-done .v2-planner-pass-dot{background:#16a34a}.v2-planner-pass-pending{color:#6b7280}.v2-task-counter{background:#f6f7fa;border-radius:6px;margin:8px 0;padding:8px 10px}.v2-task-counter-head{justify-content:space-between;align-items:baseline;margin-bottom:4px;font-size:11px;display:flex}.v2-task-counter-label{color:#374151;font-weight:500}.v2-task-counter-pct{color:#16a34a;font-variant-numeric:tabular-nums;font-weight:600}.v2-task-counter-bar{background:#e4e7ec;border-radius:2px;height:4px;overflow:hidden}.v2-task-counter-bar-fill{background:linear-gradient(90deg,#16a34a,#22c55e);height:100%;transition:width .3s ease-out;display:block}.build-report{background:#f6f7fa;border-radius:6px;margin-top:14px;padding:12px}.deploy-modal-overlay{z-index:200;background:#0f0f1473;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.deploy-modal{background:#fff;border-radius:8px;flex-direction:column;width:min(520px,100vw - 32px);max-height:calc(100vh - 64px);display:flex;overflow:hidden;box-shadow:0 10px 40px #0003}.deploy-modal-head{border-bottom:1px solid #eee;justify-content:space-between;align-items:center;padding:14px 18px;display:flex}.deploy-modal-head h3{margin:0;font-size:14px;font-weight:600}.deploy-modal-close{cursor:pointer;color:#888;background:0 0;border:0;padding:0 4px;font-size:22px;line-height:1}.deploy-modal-close:hover{color:#222}.deploy-modal-body{flex-direction:column;gap:14px;padding:16px 18px;display:flex;overflow:auto}.deploy-modal-hint{color:#555;margin:0;font-size:12px;line-height:1.5}.deploy-modal-row{flex-direction:column;gap:6px;display:flex}.deploy-modal-row-toggle{background:#f6f7fa;border-radius:6px;flex-direction:row;align-items:flex-start;gap:10px;padding:10px}.deploy-modal-row-toggle input[type=checkbox]{margin-top:2px}.deploy-modal-row-toggle>span,.deploy-modal-label{flex-direction:column;font-size:12px;display:flex}.deploy-modal-sub{color:#6b6b73;margin-top:2px;font-size:11px}.deploy-modal-input{border:1px solid #d4d6de;border-radius:5px;outline:none;padding:7px 9px;font-family:ui-monospace,monospace;font-size:12px}.deploy-modal-input:focus{border-color:#4f6cff;box-shadow:0 0 0 3px #4f6cff26}.deploy-subdomain-row{gap:4px}.deploy-subdomain-input{background:#fff;border:1px solid #d4d6de;border-radius:5px;align-items:stretch;font-family:ui-monospace,monospace;font-size:12px;transition:border-color .12s,box-shadow .12s;display:flex;overflow:hidden}.deploy-subdomain-input:focus-within{border-color:#4f6cff;box-shadow:0 0 0 3px #4f6cff26}.deploy-subdomain-input-locked{background:#f6f7fa}.deploy-subdomain-input-ok{border-color:#2e9b66}.deploy-subdomain-input-ok:focus-within{box-shadow:0 0 0 3px #2e9b662e}.deploy-subdomain-input-bad{border-color:#d2453a}.deploy-subdomain-input-bad:focus-within{box-shadow:0 0 0 3px #d2453a2e}.deploy-subdomain-input-warn{border-color:#c08a2c}.deploy-subdomain-input-checking{border-color:#c5cad6}.deploy-subdomain-text{font:inherit;color:inherit;background:0 0;border:0;outline:none;flex:1;min-width:0;padding:7px 9px}.deploy-subdomain-text:disabled{color:#555;cursor:not-allowed}.deploy-subdomain-suffix{color:#5b5e6a;white-space:nowrap;background:#f6f7fa;border-left:1px solid #e1e3eb;align-items:center;padding:0 10px;display:flex}.deploy-subdomain-glyph{flex-shrink:0;justify-content:center;align-items:center;width:22px;font-size:13px;font-weight:600;line-height:1;display:inline-flex}.deploy-subdomain-glyph-ok{color:#2e9b66}.deploy-subdomain-glyph-bad{color:#d2453a}.deploy-subdomain-glyph-warn{color:#c08a2c}.deploy-subdomain-glyph-locked{font-size:11px}.deploy-subdomain-spinner{border:2px solid #d4d6de;border-top-color:#4f6cff;border-radius:50%;width:12px;height:12px;animation:.65s linear infinite deploy-subdomain-spin}@keyframes deploy-subdomain-spin{to{transform:rotate(360deg)}}.deploy-subdomain-status{align-items:center;gap:6px;min-height:14px;font-size:11px;display:flex}.deploy-subdomain-status-checking{color:#6b6b73}.deploy-subdomain-status-ok{color:#2e9b66}.deploy-subdomain-status-bad{color:#d2453a}.deploy-subdomain-status-warn{color:#c08a2c}.deploy-subdomain-status-locked{color:#6b6b73;justify-content:space-between}.deploy-subdomain-link{color:#4f6cff;font:inherit;cursor:pointer;background:0 0;border:0;padding:0;text-decoration:underline}.deploy-subdomain-link:hover{color:#3a55e0}.deploy-modal-details{background:#fafbfc;border:1px solid #eef0f3;border-radius:5px;padding:8px 10px;font-size:11px}.deploy-modal-details summary{cursor:pointer;color:#444;font-weight:500}.deploy-modal-endpoints{flex-direction:column;gap:4px;margin:8px 0 0;padding:0;list-style:none;display:flex}.deploy-modal-endpoints li{font-size:11px}.deploy-modal-endpoints code{background:#eef1f6;border-radius:3px;padding:1px 5px;font-family:ui-monospace,monospace}.deploy-modal-base-hint{color:#6b6b73;font-size:10px}.deploy-modal-endpoint-list{border-top:1px solid #eee;flex-direction:column;gap:6px;padding-top:12px;display:flex}.deploy-modal-endpoint-list-head{color:#444;text-transform:uppercase;letter-spacing:.04em;margin-bottom:4px;font-size:11px;font-weight:600}.deploy-endpoint-row{cursor:pointer;align-items:center;gap:8px;padding:4px 0;display:flex}.deploy-endpoint-disabled .deploy-endpoint-row{cursor:not-allowed;opacity:.6}.deploy-endpoint-meta{flex-wrap:wrap;align-items:baseline;gap:6px;display:flex}.deploy-endpoint-status{color:#6b6b73;font-size:10px;font-style:italic}.deploy-modal-foot{background:#fafbfc;border-top:1px solid #eee;justify-content:flex-end;gap:8px;padding:12px 18px;display:flex}.deploy-modal-error{color:#b21d18;background:#fff5f5;border:1px solid #f3c4c0;border-radius:5px;margin:0 18px;padding:8px 10px;font-size:12px}.failure-report-panel{background:#fff5f5;border:1px solid #f3c4c0;border-radius:6px;margin-top:14px;padding:12px 14px}.failure-report-head-row{border-bottom:1px solid #f3c4c0;justify-content:space-between;align-items:baseline;margin-bottom:10px;padding-bottom:8px;display:flex}.failure-report-title{color:#b21d18;text-transform:uppercase;letter-spacing:.04em;font-size:12px;font-weight:600}.failure-report-summary{color:#6b6b73;font-size:11px}.failure-report-list{flex-direction:column;gap:10px;margin:0;padding:0;list-style:none;display:flex}.failure-report-item{background:#fff;border:1px solid #f0d8d6;border-radius:4px;padding:8px 10px}.failure-report-head{align-items:center;gap:8px;margin-bottom:4px;display:flex}.failure-severity{text-transform:uppercase;letter-spacing:.04em;border-radius:3px;padding:2px 6px;font-size:10px;font-weight:600}.failure-severity-critical{color:#fff;background:#b21d18}.failure-severity-high{color:#fff;background:#d97706}.failure-severity-warning{color:#443a07;background:#facc15}.failure-severity-low{color:#374151;background:#e5e7eb}.failure-report-category{color:#444;font-size:11px;font-weight:500}.failure-report-message{color:#1d1d1f;margin-bottom:6px;font-size:12px;line-height:1.45}.failure-report-message-preview{display:block}.failure-report-trace{color:#4a1f1d;white-space:pre-wrap;word-break:break-word;background:#fbf2f1;border:1px solid #f0d8d6;border-radius:4px;max-height:320px;margin:0 0 4px;padding:8px 10px;font-family:ui-monospace,SFMono-Regular,Menlo,monospace;font-size:11px;line-height:1.45;overflow:auto}.failure-report-toggle{color:#b21d18;cursor:pointer;text-underline-offset:2px;background:0 0;border:0;align-items:center;margin-top:4px;padding:2px 0;font-size:11px;font-weight:500;-webkit-text-decoration:underline dotted;text-decoration:underline dotted;display:inline-flex}.failure-report-toggle:hover{color:#7e1410}.failure-report-affected{flex-wrap:wrap;align-items:center;gap:4px;margin-top:4px;font-size:10px;display:flex}.failure-report-label{color:#6b6b73;margin-right:2px}.failure-report-chip{background:#f1f3f5;border-radius:3px;padding:1px 5px;font-family:ui-monospace,monospace;font-size:10px}.failure-report-more{color:#6b6b73;font-size:10px}.failure-report-action{color:#444;border-top:1px dashed #f0d8d6;margin-top:6px;padding-top:6px;font-size:11px}.follow-up-composer{border:1px solid var(--border);background:var(--bg);border-radius:8px;flex-direction:column;gap:8px;margin-top:14px;padding:12px;display:flex}.follow-up-label{color:var(--ink);text-transform:uppercase;letter-spacing:.04em;font-size:11px;font-weight:600}.follow-up-input{resize:vertical;border:1px solid var(--border);width:100%;min-height:64px;color:var(--ink);transition:border-color .15s var(--ease), box-shadow .15s var(--ease);background:#fff;border-radius:6px;padding:8px 10px;font-family:inherit;font-size:12px;line-height:1.45}.follow-up-input:focus{border-color:var(--ink);outline:none;box-shadow:0 0 0 2px #0a0a0a0f}.follow-up-input:disabled{opacity:.6;cursor:not-allowed}.follow-up-actions{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:8px;display:flex}.follow-up-hint{color:var(--muted);font-size:10px;line-height:1.3}.follow-up-buttons{gap:6px;display:flex}.follow-up-btn-secondary{padding:var(--space-2) var(--space-3);font-size:11px}.follow-up-composer .btn-primary{padding:var(--space-2) var(--space-4);font-size:12px}.build-report-head{justify-content:space-between;align-items:baseline;margin-bottom:8px;display:flex}.build-report-head h4{margin:0;font-size:12px;font-weight:600}.build-report-verdict{text-transform:uppercase;letter-spacing:.04em;border-radius:9999px;padding:2px 8px;font-size:10px;font-weight:600}.build-report-verdict-success{color:#0f7a36;background:#10a34a1f}.build-report-verdict-error{color:#c83c3c;background:#c83c3c1f}.build-report-verdict-muted{color:#6b7280;background:#eceff3}.build-report-counts{flex-wrap:wrap;gap:6px;margin-bottom:8px;display:flex}.build-report-chip{background:#fff;border:1px solid #e4e7ec;border-radius:4px;flex-direction:column;align-items:center;min-width:48px;padding:4px 10px;font-size:10px;display:inline-flex}.build-report-chip-label{color:#9ca3af;letter-spacing:.03em;text-transform:uppercase}.build-report-chip-value{color:#111;font-variant-numeric:tabular-nums;font-size:12px;font-weight:600}.build-report-chip-success .build-report-chip-value{color:#16a34a}.build-report-chip-error .build-report-chip-value{color:#dc2626}.build-report-chip-warn .build-report-chip-value{color:#d97706}.build-report-bar{background:#e4e7ec;border-radius:2px;height:4px;margin-bottom:10px;overflow:hidden}.build-report-bar-fill{background:linear-gradient(90deg,#16a34a,#22c55e);height:100%;display:block}.build-report-stages{flex-direction:column;gap:3px;margin:0 0 8px;padding:0;list-style:none;display:flex}.build-report-stage-row{justify-content:space-between;font-size:11px;display:flex}.build-report-stage-label{color:#374151}.build-report-stage-dur{color:#6b7280;font-variant-numeric:tabular-nums}.build-report-verdicts summary{cursor:pointer;color:#6b7280;padding:4px 0;font-size:11px}.build-report-verdicts ul{flex-direction:column;gap:3px;margin:4px 0 0;padding:0;list-style:none;display:flex}.build-report-verdict-row{border-left:2px solid #d4d7de;padding:4px 8px;font-size:11px}.build-report-verdict-pass{border-left-color:#16a34a}.build-report-verdict-fail{background:#c83c3c0a;border-left-color:#dc2626}.build-report-verdict-head{align-items:center;gap:6px;display:flex}.build-report-verdict-icon{font-weight:600}.build-report-verdict-pass .build-report-verdict-icon{color:#16a34a}.build-report-verdict-fail .build-report-verdict-icon{color:#dc2626}.build-report-verdict-id{color:#4b5563;font-family:SF Mono,Menlo,monospace;font-size:10px}.build-report-verdict-summary{color:#374151;text-overflow:ellipsis;white-space:nowrap;flex:1;overflow:hidden}.build-report-verdict-refine{color:#991b1b;margin:2px 0 0 18px;font-size:10px;line-height:1.4}.build-report-issues{color:#991b1b;margin-top:8px;font-size:11px}.build-report-issues ul{margin:4px 0 0 16px;padding:0}.build-report-issue-severity{text-transform:uppercase;font-size:9px;font-weight:600}.plan-tab{background:#fff;flex:1;min-height:0;padding:20px 28px;overflow-y:auto}.plan-tab-empty{color:#6b7280;text-align:center;flex-direction:column;justify-content:center;align-items:center;gap:12px;padding:48px 24px;font-size:13px;display:flex}.plan-tab-error{color:#c83c3c}.plan-tab-eyebrow{letter-spacing:.1em;text-transform:uppercase;color:#9ca3af;font-size:10px;font-weight:700}.plan-tab-head{border-bottom:1px solid #eceff3;align-items:center;gap:12px;margin-bottom:16px;padding-bottom:12px;display:flex}.plan-tab-head h2{letter-spacing:-.01em;margin:0;font-family:Space Grotesk,Inter,system-ui,sans-serif;font-size:18px;font-weight:600}.plan-tab-version{color:#9ca3af;font-family:SF Mono,Menlo,monospace;font-size:10px}.plan-tab-refresh{margin-left:auto}.plan-tab-section{margin:16px 0 20px}.plan-tab-section h3{color:#111;margin:0 0 8px;font-size:13px;font-weight:600}.plan-tab-prose p{color:#374151;margin:0 0 8px;font-size:13px;line-height:1.5}.plan-tab-table{border-collapse:collapse;width:100%;font-size:12px}.plan-tab-table th,.plan-tab-table td{text-align:left;vertical-align:top;border-bottom:1px solid #eceff3;padding:6px 8px}.plan-tab-table th{color:#6b7280;text-transform:uppercase;letter-spacing:.04em;font-size:10px;font-weight:600}.plan-tab-table code{color:#111;background:#f6f7fa;border-radius:3px;padding:1px 5px;font-family:SF Mono,Menlo,monospace;font-size:11px}.plan-tab-chip{color:#4b5563;background:#eef1f5;border-radius:9999px;margin:2px 3px 2px 0;padding:1px 7px;font-family:SF Mono,Menlo,monospace;font-size:10px;display:inline-block}.plan-tab-method{color:#fff;letter-spacing:.04em;background:#111;border-radius:3px;padding:1px 6px;font-size:9px;font-weight:600;display:inline-block}.plan-tab-muted{color:#9ca3af;font-size:11px}.plan-tab-phase{border-top:1px solid #eceff3;padding:6px 0}.plan-tab-phase summary{cursor:pointer;align-items:baseline;gap:8px;padding:4px 0;display:flex}.plan-tab-phase-label{color:#111;font-size:12px;font-weight:600}.plan-tab-phase-count{color:#9ca3af;font-size:10px}.plan-tab-task-list{flex-direction:column;gap:2px;margin:4px 0 0;padding:0 0 0 8px;list-style:none;display:flex}.plan-tab-task{border-left:2px solid #0000;border-radius:3px;padding:3px 6px;font-size:11px}.plan-tab-task-completed{opacity:.75;border-left-color:#16a34a}.plan-tab-task-in_progress{border-left-color:var(--ink);background:#00000005}.plan-tab-task-blocked{background:#d977060a;border-left-color:#d97706}.plan-tab-task-failed{background:#dc26260a;border-left-color:#dc2626}.plan-tab-task-head{align-items:center;gap:6px;display:flex}.plan-tab-task-icon{text-align:center;color:#6b7280;width:10px;display:inline-block}.plan-tab-task-completed .plan-tab-task-icon{color:#16a34a}.plan-tab-task-blocked .plan-tab-task-icon{color:#d97706}.plan-tab-task-failed .plan-tab-task-icon{color:#dc2626}.plan-tab-task-id{color:#6b7280;font-family:SF Mono,Menlo,monospace;font-size:10px}.plan-tab-task-path{color:#111;font-family:SF Mono,Menlo,monospace;font-size:10px}.plan-tab-task-intent{color:#4b5563;margin:2px 0 0 18px;line-height:1.4}.plan-tab-task-block{color:#991b1b;margin:2px 0 0 18px;font-size:10px;font-style:italic}.plan-tab-coverage{color:#4b5563;font-size:12px;line-height:1.6}.plan-tab-coverage-unmapped{color:#dc2626;margin-top:4px}.canvas-preview-frame-wrap{background:#fff;flex:1;min-height:0;display:flex;position:relative}.canvas-preview-frame-wrap .canvas-preview-frame{flex:1}.canvas-preview-overlay{z-index:2;background:#fffffff5;justify-content:center;align-items:center;padding:24px;display:flex;position:absolute;inset:0}.canvas-preview-overlay-faint{background:#fff9}.canvas-preview-overlay-card{text-align:center;flex-direction:column;align-items:center;gap:12px;max-width:360px;display:flex}.canvas-preview-spinner{border:2px solid var(--border);border-top-color:var(--ink);border-radius:50%;width:24px;height:24px;animation:.9s linear infinite canvas-spin}@keyframes canvas-spin{to{transform:rotate(360deg)}}.canvas-preview-overlay-msg{color:var(--ink);font-size:13px;font-weight:500}.canvas-preview-overlay-sub{color:var(--muted);font-size:11px;line-height:1.5}.canvas-preview-overlay-sub code{font-family:var(--canvas-mono);background:var(--surface-hover);border-radius:2px;padding:1px 5px;font-size:11px}.canvas-preview-fail{color:#c83c3c;text-align:center;max-width:360px;font-size:13px;line-height:1.5}.canvas-preview-issue-list{font-family:var(--canvas-mono);color:var(--muted);background:var(--surface-hover);text-align:left;border-radius:4px;max-width:480px;margin:8px 0 0;padding:8px 12px;font-size:11px;list-style:inside}.canvas-preview-issue-list li{word-break:break-word;margin:4px 0}.resume-banner{background:#c83c3c0f;border-bottom:1px solid #c83c3c33;flex-shrink:0;grid-area:1/1/auto/-1;justify-content:space-between;align-items:center;gap:16px;padding:10px 16px;display:flex}.resume-banner-body{min-width:0}.resume-banner-eyebrow{letter-spacing:.1em;text-transform:uppercase;color:#c83c3c;margin-bottom:2px;font-size:10px;font-weight:700}.resume-banner-msg{color:var(--ink);white-space:normal;overflow-wrap:anywhere;word-break:break-word;font-size:13px;line-height:1.4}.resume-banner-hint{color:var(--muted);margin-top:4px;font-size:12px;line-height:1.4}.resume-banner-actions{flex-shrink:0;align-items:center;gap:8px;display:flex}.resume-banner-actions .btn-primary,.resume-banner-actions .btn-secondary{height:30px;padding:0 14px;font-size:12px}.resume-banner-error{background:#b21d1814;border-bottom-color:#b21d184d}.resume-banner-error .resume-banner-eyebrow{color:#b21d18}.canvas-tabs{justify-content:space-between;align-items:stretch;gap:0;display:flex}.canvas-tabs-list{scrollbar-width:none;flex:1;align-items:stretch;min-width:0;display:flex;overflow-x:auto}.canvas-tabs-list::-webkit-scrollbar{display:none}.canvas-tabs-actions{border-left:1px solid var(--border);flex-shrink:0;align-items:center;gap:6px;padding:0 12px;display:flex}.canvas-header-primary{letter-spacing:.02em;white-space:nowrap;border-radius:4px;height:26px;padding:0 12px;font-size:11px;font-weight:600}.canvas-header-primary:disabled{opacity:.7;cursor:wait}.canvas-deploy-live-pill{color:#178f4b;letter-spacing:.02em;background:#178f4b1a;border-radius:12px;align-items:center;gap:6px;max-width:280px;height:24px;padding:0 10px;font-size:11px;font-weight:600;text-decoration:none;display:inline-flex;overflow:hidden}.canvas-deploy-live-pill:hover{background:#178f4b29}.canvas-deploy-live-dot{background:#178f4b;border-radius:50%;flex-shrink:0;width:6px;height:6px;box-shadow:0 0 0 3px #178f4b2e}.canvas-deploy-live-url{font-family:var(--canvas-mono);color:#13703b;opacity:.85;text-overflow:ellipsis;white-space:nowrap;max-width:200px;overflow:hidden}.canvas-deploy-error-tip{color:#c83c3c;cursor:help;padding:0 4px;font-size:14px}.canvas-kebab{position:relative}.canvas-kebab-btn{width:26px;height:26px;color:var(--muted);border:1px solid var(--border);cursor:pointer;background:0 0;border-radius:4px;justify-content:center;align-items:center;padding:0;transition:all .15s;display:inline-flex}.canvas-kebab-btn:hover,.canvas-kebab-btn-open{background:var(--surface-hover);color:var(--ink);border-color:var(--border-strong)}.canvas-kebab-menu{background:var(--bg);border:1px solid var(--border);z-index:40;border-radius:6px;flex-direction:column;min-width:220px;padding:4px;display:flex;position:absolute;top:calc(100% + 6px);right:0;box-shadow:0 8px 24px #0000001a}.canvas-kebab-item{color:var(--ink);text-align:left;cursor:pointer;background:0 0;border:0;border-radius:4px;align-items:center;gap:8px;padding:8px 10px;font-family:inherit;font-size:13px;text-decoration:none;display:flex}.canvas-kebab-item:hover:not(.canvas-kebab-item-disabled){background:var(--surface-hover)}.canvas-kebab-item-disabled{color:var(--muted-soft);cursor:not-allowed}.canvas-kebab-item-danger{color:#c83c3c}.canvas-kebab-item-danger:hover{background:#c83c3c0f}.canvas-kebab-icon{opacity:.7;width:14px;display:inline-flex}.brands{flex:1;width:100%;min-height:0;padding:32px 24px 80px;overflow-y:auto}.brands-inner{width:100%;max-width:960px;margin:0 auto}.brands-top{justify-content:space-between;align-items:flex-start;margin-bottom:24px;display:flex}.brands-title{letter-spacing:-.01em;margin:0;font-size:28px}.brands-sub{color:var(--muted);max-width:540px;margin:6px 0 0;font-size:14px}.brands-create{gap:8px;margin-bottom:20px;display:flex}.brands-create input{border:1px solid var(--border);font:inherit;border-radius:6px;flex:1;padding:9px 12px}.brands-create input:focus{border-color:var(--ink);outline:none}.brands-skeleton{flex-direction:column;gap:8px;display:flex}.brands-skel-row{background:var(--surface);border-radius:8px;height:88px;animation:1.5s ease-in-out infinite brand-pulse}@keyframes brand-pulse{0%,to{opacity:1}50%{opacity:.55}}.brands-empty{border:1px dashed var(--border);text-align:center;color:var(--muted);border-radius:8px;padding:32px 24px}.brands-empty-title{color:var(--ink);margin-bottom:4px;font-size:16px;font-weight:600}.brands-empty-sub{max-width:420px;margin:0 auto;font-size:13px;line-height:1.5}.brands-list{flex-direction:column;gap:8px;margin:0;padding:0;list-style:none;display:flex}.brand-card{border:1px solid var(--border);cursor:pointer;background:var(--bg);border-radius:8px;padding:14px 16px;transition:border-color .15s,transform .15s}.brand-card:hover{border-color:var(--border-strong)}.brand-card-head{justify-content:space-between;align-items:center;gap:12px;display:flex}.brand-card-title-row{align-items:baseline;gap:8px;display:flex}.brand-card-title{font-size:16px;font-weight:600}.brand-card-default-pill{color:#178f4b;letter-spacing:.05em;text-transform:uppercase;background:#178f4b1f;border-radius:10px;padding:2px 7px;font-size:10px;font-weight:700}.brand-card-version{font-family:var(--canvas-mono,ui-monospace, monospace);color:var(--muted-soft);font-size:10px}.brand-card-actions{gap:6px;display:flex}.brand-card-btn{border:1px solid var(--border);cursor:pointer;height:24px;color:var(--ink);background:0 0;border-radius:4px;padding:0 10px;font-size:11px}.brand-card-btn:hover:not(:disabled){background:var(--surface-hover)}.brand-card-btn-danger{color:#c83c3c;border-color:#c83c3c4d}.brand-card-btn-danger:hover:not(:disabled){background:#c83c3c14}.brand-card-meta{color:var(--ink-soft);margin-top:6px;font-size:13px}.brand-card-muted{color:var(--muted-soft);font-style:italic}.brand-card-stats{color:var(--muted);gap:14px;margin-top:10px;font-size:11px;display:flex}.brand-card-stats strong{color:var(--ink);font-weight:600}.brand-card-palette{gap:4px;margin-top:8px;display:flex}.brand-card-swatch{border:1px solid #0000000f;border-radius:3px;width:16px;height:16px}.brand-detail{flex:1;width:100%;min-height:0;overflow-y:auto}.brand-detail-inner{width:100%;max-width:960px;margin:0 auto;padding:0 28px 96px}.brand-detail-top{background:var(--bg);z-index:5;border-bottom:1px solid var(--border);flex-direction:column;gap:10px;margin-bottom:24px;padding:18px 0 14px;display:flex;position:sticky;top:0}.brand-detail-back{color:var(--muted);cursor:pointer;letter-spacing:.02em;background:0 0;border:0;align-self:flex-start;padding:0;font-size:12px}.brand-detail-back:hover{color:var(--ink)}.brand-detail-title-row{flex-wrap:wrap;align-items:baseline;gap:10px;display:flex}.brand-detail-title-row h1{letter-spacing:-.01em;margin:0;font-size:24px}.brand-detail-version{font-family:var(--canvas-mono,ui-monospace, monospace);color:var(--muted-soft);font-size:11px}.brand-detail-status{color:var(--muted);align-items:center;gap:10px;font-size:11px;display:flex}.brand-completeness-bar{background:var(--surface-hover);border-radius:2px;width:220px;height:4px;overflow:hidden}.brand-completeness-fill{background:linear-gradient(90deg,#6cf 0%,#178f4b 100%);height:100%;transition:width .3s}.brand-saving-hint{color:var(--muted-soft);font-style:italic}.brand-detail-loading{text-align:center;color:var(--muted);padding:60px 0}.brand-detail-body{flex-direction:column;gap:14px;display:flex}.brand-section{border:1px solid var(--border);background:var(--bg);border-radius:10px;padding:20px 22px}.brand-section-head{border-bottom:1px solid var(--border);margin-bottom:16px;padding-bottom:12px}.brand-section-head h2{letter-spacing:.08em;text-transform:uppercase;color:var(--ink);margin:0;font-size:12px;font-weight:600}.brand-section-hint{color:var(--muted);margin:4px 0 0;font-size:12px}.brand-section-body{flex-direction:column;gap:14px;display:flex}.brand-autofill{border:1px dashed var(--border);background:var(--surface);border-radius:10px;flex-direction:column;gap:10px;margin-bottom:18px;padding:14px 16px;display:flex}.brand-autofill-head{align-items:center;gap:8px;display:flex}.brand-autofill-title{letter-spacing:.06em;text-transform:uppercase;color:var(--ink);font-size:12px;font-weight:600}.brand-autofill-sub{color:var(--muted);margin:0;font-size:12px}.brand-autofill-row{flex-wrap:wrap;gap:8px;display:flex}.brand-autofill-input{border:1px solid var(--border);min-width:240px;font:inherit;background:var(--bg);border-radius:6px;flex:1;padding:8px 10px;font-size:13px}.brand-autofill-input:focus{border-color:var(--ink);outline:none}.brand-autofill-btn{background:var(--ink);height:36px;color:var(--bg);letter-spacing:.02em;cursor:pointer;border:0;border-radius:6px;align-items:center;gap:6px;padding:0 16px;font-size:12px;font-weight:600;display:inline-flex}.brand-autofill-btn:disabled{opacity:.55;cursor:not-allowed}.brand-autofill-status{color:var(--muted);font-size:12px}.brand-autofill-status.is-error{color:#c83c3c}.brand-bulk-status{color:var(--muted);background:var(--surface);border-radius:4px;padding:6px 10px;font-size:12px}.brand-theme-picker{grid-template-columns:repeat(3,1fr);gap:8px;display:grid}.brand-theme-option{border:1px solid var(--border);cursor:pointer;background:var(--bg);border-radius:8px;align-items:flex-start;gap:8px;padding:10px 12px;transition:border-color .12s,background .12s;display:flex}.brand-theme-option:hover{border-color:var(--ink)}.brand-theme-option.is-active{border-color:var(--ink);box-shadow:0 0 0 2px #0a0a0a0f}.brand-theme-option input[type=radio]{accent-color:var(--ink);margin-top:2px}.brand-theme-option-body{flex-direction:column;gap:2px;display:flex}.brand-theme-option-title{color:var(--ink);font-size:13px;font-weight:600}.brand-theme-option-sub{color:var(--muted);font-size:11px;line-height:1.4}.brand-theme-option.is-light-preview.is-active{background:#fafafa}.brand-theme-option.is-dark-preview.is-active{background:#1a1a1a}.brand-theme-option.is-dark-preview.is-active .brand-theme-option-title{color:#fff}.brand-theme-option.is-dark-preview.is-active .brand-theme-option-sub{color:#ffffffa6}@media (width<=600px){.brand-theme-picker{grid-template-columns:1fr}}.brand-autofill-spinner{border:1.5px solid;border-right-color:#0000;border-radius:50%;width:12px;height:12px;animation:.7s linear infinite brand-pulse-spin;display:inline-block}@keyframes brand-pulse-spin{to{transform:rotate(360deg)}}.brand-field{flex-direction:column;gap:4px;display:flex}.brand-field-label{letter-spacing:.06em;text-transform:uppercase;color:var(--muted);font-size:11px}.brand-field-input{border:1px solid var(--border);font:inherit;background:var(--bg);color:var(--ink);resize:vertical;border-radius:5px;padding:8px 10px;font-size:13px}.brand-field-input:focus{border-color:var(--ink);outline:none}.brand-chips{border:1px solid var(--border);background:var(--bg);border-radius:5px;flex-wrap:wrap;gap:4px;min-height:36px;padding:6px;display:flex}.brand-chip{background:var(--surface);border:1px solid var(--border);border-radius:12px;align-items:center;gap:4px;padding:2px 8px;font-size:12px;display:inline-flex}.brand-chip-remove{color:var(--muted);cursor:pointer;background:0 0;border:0;padding:0 2px;font-size:14px;line-height:1}.brand-chip-remove:hover{color:var(--ink)}.brand-chip-input{min-width:120px;font:inherit;background:0 0;border:0;outline:none;flex:1;font-size:12px}.brand-textlist{flex-direction:column;gap:4px;margin:0;padding:0;list-style:none;display:flex}.brand-textlist-row{align-items:flex-start;gap:4px;display:flex}.brand-textlist-input{border:1px solid var(--border);font:inherit;resize:vertical;border-radius:4px;flex:1;padding:6px 8px;font-size:12px}.brand-textlist-remove{border:1px solid var(--border);cursor:pointer;width:28px;height:28px;color:var(--muted);background:0 0;border-radius:4px;flex-shrink:0}.brand-textlist-remove:hover{background:var(--surface-hover);color:var(--ink)}.brand-palette-editor,.brand-typo-editor{flex-direction:column;gap:6px;display:flex}.brand-palette-row,.brand-typo-row{align-items:center;gap:6px;display:flex}.brand-palette-swatch{border:1px solid var(--border);cursor:pointer;border-radius:4px;width:36px;height:32px;padding:0}.brand-palette-hex{width:90px;font-family:var(--canvas-mono,ui-monospace, monospace);text-transform:uppercase;border:1px solid var(--border);border-radius:4px;padding:6px 8px;font-size:12px}.brand-palette-role,.brand-palette-name{border:1px solid var(--border);border-radius:4px;flex:1;padding:6px 8px;font-size:12px}.brand-palette-remove{border:1px solid var(--border);cursor:pointer;width:28px;height:28px;color:var(--muted);background:0 0;border-radius:4px;flex-shrink:0}.brand-palette-remove:hover{color:#c83c3c;background:#c83c3c0f}.brand-typo-row select,.brand-typo-row input{border:1px solid var(--border);border-radius:4px;padding:6px 8px;font-size:12px}.brand-assets,.brand-fonts{flex-direction:column;gap:10px;display:flex}.brand-asset-toolbar,.brand-font-toolbar{flex-wrap:wrap;align-items:center;gap:6px;display:flex}.brand-asset-toolbar select,.brand-font-toolbar select,.brand-font-toolbar input{border:1px solid var(--border);border-radius:4px;padding:6px 8px;font-size:12px}.brand-asset-list,.brand-font-list{flex-direction:column;gap:6px;margin:0;padding:0;list-style:none;display:flex}.brand-asset-item,.brand-font-item{border:1px solid var(--border);border-radius:6px;align-items:center;gap:12px;padding:8px 10px;display:flex}.brand-asset-thumb{border:1px solid var(--border);background:var(--surface);border-radius:4px;flex-shrink:0;width:56px;height:56px;overflow:hidden}.brand-asset-thumb img{object-fit:contain;width:100%;height:100%}.brand-asset-thumb-fallback{width:100%;height:100%;color:var(--muted-soft);text-transform:uppercase;letter-spacing:.05em;justify-content:center;align-items:center;font-size:9px;display:flex}.brand-asset-meta{flex:1;min-width:0}.brand-asset-kind{letter-spacing:.06em;text-transform:uppercase;color:var(--muted);font-size:10px}.brand-asset-name{font-family:var(--canvas-mono,ui-monospace, monospace);color:var(--ink);margin-top:2px;font-size:12px}.brand-asset-desc{color:var(--muted);margin-top:2px;font-size:11px;line-height:1.4}.brand-font-family{font-size:13px;font-weight:600}.brand-font-meta{color:var(--muted);margin-top:2px;font-size:11px}.brand-font-url{font-family:var(--canvas-mono,ui-monospace, monospace);color:var(--muted-soft);margin-top:2px;font-size:10px;display:inline-block}.brand-empty-row{color:var(--muted);background:var(--surface);text-align:center;border-radius:4px;padding:12px;font-size:12px}.brief-brand-pill{border:1px solid var(--border);border-radius:var(--radius-pill);background:var(--bg);color:var(--muted);cursor:pointer;transition:color .15s var(--ease);align-items:center;gap:6px;max-width:60%;padding:6px 8px 6px 10px;font-size:12px;display:inline-flex;position:absolute;bottom:10px;right:10px}.brief-brand-pill:hover,.brief-brand-pill.is-active{color:var(--ink)}.brief-brand-pill-select{appearance:none;font:inherit;color:inherit;cursor:pointer;text-overflow:ellipsis;white-space:nowrap;background:0 0;border:0;outline:none;max-width:180px;padding:0;font-size:12px;overflow:hidden}.tasks-tab{height:100%;color:var(--ink,#1a1a1a);padding:18px 24px 32px;font-size:13px;overflow-y:auto}.tasks-tab-empty,.tasks-tab-empty-filter{color:var(--muted,#666);padding:32px 24px;font-size:13px}.tasks-tab-eyebrow{text-transform:uppercase;letter-spacing:.08em;color:var(--muted,#666);margin-bottom:8px;font-size:11px}.tasks-tab-head{background:var(--bg,#fff);z-index:1;margin-bottom:12px;padding:4px 0 12px;position:sticky;top:0}.tasks-tab-head-row{justify-content:space-between;align-items:baseline;gap:12px;margin-bottom:8px;display:flex}.tasks-tab-head h2{margin:0;font-size:16px;font-weight:600}.tasks-tab-pct{color:var(--accent,#3b82f6);font-variant-numeric:tabular-nums;font-size:18px;font-weight:600}.tasks-tab-progress{background:var(--surface,#f4f4f5);border-radius:3px;height:6px;margin-bottom:12px;overflow:hidden}.tasks-tab-progress-fill{background:var(--accent,#3b82f6);border-radius:3px;height:100%;transition:width .3s;display:block}.tasks-tab-counts{flex-wrap:wrap;gap:6px;display:flex}.tasks-tab-chip{border:1px solid var(--border,#e5e7eb);background:var(--bg,#fff);color:var(--ink,#1a1a1a);cursor:pointer;border-radius:999px;align-items:center;gap:6px;padding:4px 10px;font-family:inherit;font-size:12px;transition:all .15s;display:inline-flex}.tasks-tab-chip:hover{border-color:var(--ink,#1a1a1a)}.tasks-tab-chip-active{background:var(--ink,#1a1a1a);color:var(--bg,#fff);border-color:var(--ink,#1a1a1a)}.tasks-tab-chip-label{text-transform:uppercase;letter-spacing:.04em;opacity:.85;font-size:11px}.tasks-tab-chip-value{font-variant-numeric:tabular-nums;font-weight:600}.tasks-tab-chip-success .tasks-tab-chip-value{color:#15803d}.tasks-tab-chip-active .tasks-tab-chip-value{color:var(--accent,#3b82f6)}.tasks-tab-chip-warning .tasks-tab-chip-value{color:#b45309}.tasks-tab-chip-error .tasks-tab-chip-value{color:#b91c1c}.tasks-tab-chip.tasks-tab-chip-active .tasks-tab-chip-value{color:inherit}.tasks-tab-phase{border:1px solid var(--border,#e5e7eb);background:var(--bg,#fff);border-radius:8px;margin-bottom:10px;overflow:hidden}.tasks-tab-phase>summary{cursor:pointer;background:var(--surface,#fafafa);justify-content:space-between;align-items:center;gap:8px;padding:8px 12px;font-weight:500;list-style:none;display:flex}.tasks-tab-phase>summary::-webkit-details-marker{display:none}.tasks-tab-phase-label{text-transform:uppercase;letter-spacing:.06em;color:var(--muted,#666);font-size:12px}.tasks-tab-phase-count{font-variant-numeric:tabular-nums;color:var(--muted,#666);font-size:12px}.tasks-tab-list{margin:0;padding:4px 0;list-style:none}.tasks-tab-item{border-top:1px solid var(--border,#f1f1f1);position:relative}.tasks-tab-item:first-child{border-top:none}.tasks-tab-item-summary{cursor:pointer;border-radius:4px;grid-template-columns:24px 70px 90px minmax(0,1.4fr) minmax(0,2fr);align-items:baseline;gap:8px;padding:6px 12px;font-size:12px;list-style:none;display:grid}.tasks-tab-item-summary:hover{background:var(--surface,#fafafa)}.tasks-tab-item-summary::-webkit-details-marker{display:none}.tasks-tab-item[open]>.tasks-tab-item-details>.tasks-tab-item-summary{background:var(--surface,#fafafa)}.tasks-tab-icon{text-align:center;color:var(--muted,#999);font-size:14px;line-height:1}.tasks-tab-item-completed .tasks-tab-icon{color:#16a34a}.tasks-tab-item-in_progress .tasks-tab-icon{color:var(--accent,#3b82f6);animation:1.5s ease-in-out infinite tasks-tab-pulse}.tasks-tab-item-blocked .tasks-tab-icon{color:#d97706}.tasks-tab-item-failed .tasks-tab-icon{color:#dc2626}@keyframes tasks-tab-pulse{0%,to{opacity:1}50%{opacity:.45}}.tasks-tab-id code{color:var(--muted,#666);font-size:11px}.tasks-tab-kind code{text-transform:uppercase;letter-spacing:.04em;color:var(--muted,#666);background:var(--surface,#f4f4f5);border-radius:999px;padding:1px 6px;font-size:10px}.tasks-tab-path code{color:var(--ink,#1a1a1a);word-break:break-all;font-size:11px}.tasks-tab-intent{color:var(--muted,#555);text-overflow:ellipsis;white-space:nowrap;font-size:12px;line-height:1.4;overflow:hidden}.tasks-tab-item[open] .tasks-tab-intent{white-space:normal}.tasks-tab-item-body{color:var(--ink,#1a1a1a);flex-direction:column;gap:10px;padding:8px 16px 14px 44px;font-size:12px;line-height:1.5;display:flex}.tasks-tab-section{flex-direction:column;gap:4px;display:flex}.tasks-tab-section-label{text-transform:uppercase;letter-spacing:.06em;color:var(--muted,#777);font-size:10px;font-weight:600}.tasks-tab-section-value{flex-wrap:wrap;align-items:baseline;gap:6px;display:flex}.tasks-tab-dep-pill{background:var(--surface,#f4f4f5);color:var(--ink,#1a1a1a);border:1px solid var(--border,#e5e7eb);border-radius:999px;padding:2px 8px;font-size:11px}.tasks-tab-acceptance{flex-direction:column;gap:4px;margin:0;padding:0;list-style:none;display:flex}.tasks-tab-acceptance>li{color:var(--ink,#1a1a1a);padding-left:16px;font-size:12px;line-height:1.5;position:relative}.tasks-tab-acceptance>li:before{content:"✓";color:var(--muted,#999);font-size:11px;position:absolute;top:0;left:0}.tasks-tab-item-completed .tasks-tab-acceptance>li:before{color:#16a34a}.tasks-tab-summary-text{color:var(--muted,#555);font-style:italic}.tasks-tab-meta{color:var(--muted,#777);font-variant-numeric:tabular-nums;font-size:11px}.tasks-tab-block{color:#92400e;background:#d9770614;border-left:2px solid #d97706;border-radius:0 4px 4px 0;margin-top:4px;padding:6px 10px;font-size:11px}.tasks-tab-item-completed .tasks-tab-path code{color:var(--muted,#666)}.tasks-tab-item-pending{opacity:.65}.app-header-r{align-items:center;gap:var(--space-2);display:flex}.usage-wrap{display:inline-flex;position:relative}.usage-btn{border:1px solid var(--border);background:var(--surface,#fff);width:26px;height:26px;color:var(--muted);cursor:pointer;transition:all .15s var(--ease);border-radius:50%;justify-content:center;align-items:center;padding:0;font-family:Space Grotesk,Inter,serif;font-size:13px;font-style:italic;font-weight:600;line-height:1;display:inline-flex}.usage-btn:hover{border-color:var(--border-strong);color:var(--ink);background:#fff}.usage-btn-active,.usage-btn-active:hover{border-color:var(--ink);background:var(--ink);color:#fff}.usage-btn-glyph{display:inline-block;transform:translateY(-.5px)}.usage-popover{width:460px;max-width:calc(100vw - var(--space-5) * 2);border:1px solid var(--border);z-index:100;max-height:min(70vh,640px);color:var(--ink);animation:usage-pop-in .12s var(--ease) both;background:#fff;border-radius:14px;font-size:12.5px;position:absolute;top:calc(100% + 10px);right:0;overflow:auto;box-shadow:0 1px 2px #0f0f0f0a,0 12px 32px #0f0f0f1f}@keyframes usage-pop-in{0%{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:translateY(0)}}.usage-pop-head{border-bottom:1px solid var(--border);justify-content:space-between;align-items:baseline;gap:var(--space-3);padding:14px 16px 10px;display:flex}.usage-pop-title{letter-spacing:-.01em;font-family:Space Grotesk,Inter,system-ui,sans-serif;font-size:14px;font-weight:600}.usage-pop-sub{color:var(--muted);font-variant-numeric:tabular-nums;font-size:11.5px}.usage-pop-state{text-align:center;color:var(--muted);padding:24px 16px;font-size:12.5px}.usage-pop-error{color:#b3261e}.usage-pop-body{padding:8px 4px 12px}.usage-mode{padding:8px 12px 4px}.usage-mode-head{justify-content:space-between;align-items:baseline;padding:6px 4px 8px;display:flex}.usage-mode-title{letter-spacing:.06em;text-transform:uppercase;color:var(--muted);font-family:Space Grotesk,Inter,system-ui,sans-serif;font-size:11.5px;font-weight:600}.usage-mode-meta{color:var(--muted);font-variant-numeric:tabular-nums;font-size:11px}.usage-table{border-collapse:collapse;font-variant-numeric:tabular-nums;width:100%}.usage-table th{color:var(--muted);text-align:left;border-bottom:1px solid var(--border);text-transform:uppercase;letter-spacing:.04em;padding:6px 8px;font-size:11px;font-weight:500}.usage-table th.usage-num{text-align:right}.usage-row td{border-bottom:1px dashed var(--border);vertical-align:middle;padding:7px 8px}.usage-row:last-child td{border-bottom:none}.usage-row-clickable{cursor:pointer}.usage-row-clickable:hover td{background:#0f0f0f06}.usage-stage-name{color:var(--ink);align-items:center;gap:6px;max-width:200px;font-size:12.5px;display:flex}.usage-caret{width:10px;color:var(--muted);flex-shrink:0;font-size:10px;display:inline-block}.usage-num{text-align:right;white-space:nowrap;padding-left:6px;font-size:12px}.usage-num-input{color:#1f6feb}.usage-num-cache{color:#8957e5}.usage-num-output{color:#1a7f37}.usage-num-cost{color:var(--ink);font-weight:500}.usage-row-agent td{border-bottom:1px dashed var(--border);background:#0f0f0f04}td.usage-agent-name{color:var(--muted);padding-left:22px;font-size:11.5px;position:relative}.usage-agent-rail{background:var(--border);width:1px;position:absolute;top:0;bottom:0;left:12px}.usage-agent-calls{color:var(--muted-soft,var(--muted));font-variant-numeric:tabular-nums;margin-left:6px;font-size:10.5px}.usage-row-total td{border-top:1px solid var(--border);background:0 0;border-bottom:none;font-weight:600}.usage-err-badge{color:#b3261e;background:#fdecea;border-radius:8px;justify-content:center;align-items:center;min-width:16px;height:16px;margin-left:4px;padding:0 5px;font-size:10px;font-weight:600;display:inline-flex}.usage-pop-foot{border-top:1px solid var(--border);color:var(--muted);align-items:center;gap:12px;padding:10px 16px 12px;font-size:11px;display:flex}.usage-foot-key{vertical-align:middle;border-radius:2px;width:8px;height:8px;margin-left:4px;margin-right:4px;display:inline-block}.usage-foot-key:first-child{margin-left:0}.usage-foot-key-input{background:#1f6feb}.usage-foot-key-cache{background:#8957e5}.usage-foot-key-output{background:#1a7f37}.deploy-panel-head{justify-content:space-between;align-items:center;margin-bottom:10px;display:flex}.deploy-stage-strip{align-items:center;gap:4px;margin:6px 0 12px;display:flex}.deploy-stage-item{align-items:center;gap:4px;display:inline-flex}.deploy-stage-dot{border-radius:50%;width:7px;height:7px;display:inline-block}.deploy-stage-dot-done{background:#178f4b}.deploy-stage-dot-active{background:#3a5dbd;animation:1.2s ease-in-out infinite s2-pulse;box-shadow:0 0 0 3px #3a5dbd26}.deploy-stage-dot-pending{background:var(--border-strong)}.deploy-stage-label{color:var(--muted);letter-spacing:.02em;font-size:11px}.deploy-stage-sep{background:var(--border);width:12px;height:1px;margin:0 2px}.deploy-upload-progress{background:var(--surface-hover);border-radius:6px;margin:0 0 4px;padding:8px 10px}.deploy-upload-head{color:var(--ink);justify-content:space-between;align-items:center;margin-bottom:5px;font-size:11px;display:flex}.deploy-upload-pct{font-variant-numeric:tabular-nums;font-weight:600}.deploy-upload-bar{background:var(--border);border-radius:999px;width:100%;height:4px;overflow:hidden}.deploy-upload-bar-fill{height:100%;transition:width .18s var(--ease);background:#3a5dbd;display:block}.deploy-upload-path{color:var(--muted);white-space:nowrap;text-overflow:ellipsis;margin-top:6px;font-family:ui-monospace,SFMono-Regular,Menlo,monospace;font-size:10px;overflow:hidden}.deploy-error{background:#fff5f5;border:1px solid #f3c4c0;border-radius:6px;margin-top:4px;padding:10px 12px}.deploy-error-eyebrow{text-transform:uppercase;letter-spacing:.04em;color:#b21d18;margin-bottom:4px;font-size:10px;font-weight:600}.deploy-error-msg{color:#4a1f1d;word-break:break-word;font-size:12px;line-height:1.45}.deploy-result{flex-direction:column;gap:8px;display:flex}.deploy-result-url{border:1px solid var(--border);background:var(--bg);color:var(--ink);transition:border-color .15s var(--ease), background .15s var(--ease);border-radius:6px;align-items:center;gap:8px;padding:8px 10px;font-size:12px;text-decoration:none;display:flex}.deploy-result-url:hover{border-color:var(--ink);background:var(--surface-hover)}.deploy-result-url-label{text-transform:uppercase;letter-spacing:.04em;color:var(--muted);font-size:10px;font-weight:600}.deploy-result-url-value{white-space:nowrap;text-overflow:ellipsis;flex:1;font-family:ui-monospace,SFMono-Regular,Menlo,monospace;font-size:11px;overflow:hidden}.deploy-result-meta{color:var(--muted);align-items:center;gap:6px;font-size:11px;display:flex}.deploy-result-meta-sep{opacity:.5}.deploy-result-actions{gap:6px;margin-top:4px;display:flex}.deploy-result-actions .btn-primary,.deploy-result-actions .btn-secondary{padding:var(--space-2) var(--space-3);flex:1;font-size:12px}.edit-panel-meta{padding:var(--space-3);border:1px solid var(--border);border-radius:var(--radius-md);background:var(--surface);flex-direction:column;gap:6px;display:flex}.edit-panel-meta-row{align-items:baseline;gap:10px;font-size:12px;display:flex}.edit-panel-meta-label{text-transform:uppercase;letter-spacing:.08em;color:var(--muted);min-width:60px;font-size:10px;font-weight:600}.edit-panel-meta-value{color:var(--ink);overflow-wrap:anywhere;flex:1}.edit-panel-score-value{font-size:16px;font-weight:700}.edit-panel-versions{flex-wrap:wrap;flex:1;gap:4px;display:flex}.edit-panel-version-chip{background:var(--bg);border:1px solid var(--border);color:var(--muted);cursor:pointer;transition:border-color .15s var(--ease), color .15s var(--ease);border-radius:999px;padding:2px 7px;font-size:10px;font-weight:600}.edit-panel-version-chip:hover{border-color:var(--ink);color:var(--ink)}.edit-panel-version-chip.is-current{background:var(--ink);border-color:var(--ink);color:#fff;cursor:default}.bottom-composer{border-top:1px solid var(--border);background:var(--bg);padding:var(--space-3) var(--space-4) var(--space-4);flex-direction:column;flex:none;gap:6px;display:flex}.bottom-composer-input{resize:vertical;border:1px solid var(--border);border-radius:var(--radius-md);background:var(--bg);width:100%;min-height:56px;max-height:200px;color:var(--ink);transition:border-color .15s var(--ease), box-shadow .15s var(--ease);padding:8px 10px;font-family:inherit;font-size:13px;line-height:1.45}.bottom-composer-input:focus{border-color:var(--ink);outline:none;box-shadow:0 0 0 2px #0a0a0a0f}.bottom-composer-input:disabled{opacity:.55;cursor:not-allowed}.bottom-composer-foot{justify-content:space-between;align-items:center;gap:8px;display:flex}.bottom-composer-hint{color:var(--muted);align-items:center;gap:4px;font-size:10px;display:inline-flex}.bottom-composer-hint kbd{border:1px solid var(--border);background:var(--surface);color:var(--muted);border-radius:3px;padding:1px 5px;font-family:ui-monospace,SFMono-Regular,Menlo,monospace;font-size:10px}.bottom-composer-send{background:var(--ink);color:#fff;border-radius:var(--radius-pill);transition:opacity .15s var(--ease), transform .15s var(--ease);align-items:center;gap:6px;padding:6px 12px;font-size:12px;font-weight:600;display:inline-flex}.bottom-composer-send:hover:not(:disabled){transform:scale(.98)}.bottom-composer-send:disabled{opacity:.35;cursor:not-allowed}.bottom-composer-busy{border:1px dashed var(--border);border-radius:var(--radius-md);background:var(--surface);color:var(--muted);align-items:center;gap:10px;min-width:0;padding:10px 12px;font-size:12px;display:flex;overflow:hidden}.bottom-composer-spinner{border:2px solid var(--border);border-top-color:var(--ink);box-sizing:border-box;border-radius:50%;flex-shrink:0;width:14px;height:14px;animation:.85s linear infinite quest-spin}.bottom-composer-busy-label{min-width:0;color:var(--ink);white-space:nowrap;text-overflow:ellipsis;flex:1;line-height:1.4;overflow:hidden}.bottom-composer-stop{border-radius:var(--radius-pill);color:#b54327;cursor:pointer;transition:background .15s var(--ease), color .15s var(--ease), border-color .15s var(--ease);white-space:nowrap;background:0 0;border:1px solid #d97560;flex-shrink:0;align-items:center;gap:5px;padding:4px 10px;font-size:11px;font-weight:600;display:inline-flex}.bottom-composer-stop:hover:not(:disabled){color:#fff;background:#b54327;border-color:#b54327}.bottom-composer-stop:disabled{opacity:.55;cursor:not-allowed}.turn-list{flex-direction:column;gap:14px;padding:4px 0 8px;display:flex}.turn{flex-direction:column;gap:8px;display:flex}.turn-eyebrow{letter-spacing:.08em;text-transform:uppercase;color:var(--muted);font-size:10px;font-weight:600}.turn-system{border-radius:var(--radius-md);background:var(--surface);border:1px dashed var(--border);color:var(--muted);padding:8px 12px;font-size:12px}.turn-system.turn-tone-success{color:#1f7a3a;background:#5fa8720f;border-color:#5fa872}.turn-system.turn-tone-warning{color:#8a5e10;background:#c89a3b0f;border-color:#c89a3b}.turn-system.turn-tone-error{color:#8b3318;background:#c5694e0f;border-color:#c5694e}.turn-action{border:1px solid var(--border);background:var(--bg);border-radius:12px;overflow:hidden}.turn-user{border-bottom:1px solid var(--border);background:#0f0f0f06;flex-direction:column;gap:4px;padding:10px 12px 8px;display:flex}.turn-user-label{color:var(--ink);letter-spacing:-.01em;font-family:ui-monospace,SFMono-Regular,Menlo,monospace;font-size:11px;font-weight:600}.turn-user-text{color:var(--ink);white-space:pre-wrap;word-break:break-word;font-size:13px;line-height:1.45}.turn-user-meta{color:var(--muted);align-items:center;gap:6px;margin-top:2px;font-size:11px;display:inline-flex}.turn-status{border-radius:var(--radius-pill);text-transform:uppercase;letter-spacing:.04em;align-items:center;gap:5px;padding:1px 8px 2px;font-size:10.5px;font-weight:600;display:inline-flex}.turn-status-running{color:#fff;background:#1f6feb}.turn-status-done{color:#fff;background:#1a7f37}.turn-status-cancelled{background:var(--muted);color:#fff}.turn-status-failed{color:#fff;background:#b3261e}.turn-status-pulse{background:currentColor;border-radius:50%;width:6px;height:6px;animation:1.1s ease-in-out infinite turn-pulse}@keyframes turn-pulse{0%,to{opacity:1}50%{opacity:.35}}.turn-user-dur{font-variant-numeric:tabular-nums}.turn-live{padding:10px 12px 12px}.turn-summary{color:var(--muted);flex-wrap:wrap;align-items:center;gap:6px;padding:8px 12px 10px;font-size:12px;display:flex}.turn-summary-chip{border-radius:var(--radius-pill);background:var(--surface);border:1px solid var(--border);font-variant-numeric:tabular-nums;color:var(--ink);align-items:center;padding:2px 8px;font-size:11px;display:inline-flex}.turn-summary-chip-ok{color:#1a7f37;background:#1a7f3714;border-color:#1a7f3766}.turn-summary-chip-fail{color:#b3261e;background:#b3261e14;border-color:#b3261e66}.turn-summary-detail{color:var(--muted);word-break:break-word;font-size:11px}.turn-summary-link{color:#1f6feb;word-break:break-all;font-size:11.5px;text-decoration:none}.turn-summary-link:hover{text-decoration:underline}.turn-slash-result{color:var(--muted);padding:6px 12px 10px;font-size:12px}.turn-composer{border-top:1px solid var(--border);background:var(--bg);padding:var(--space-3) var(--space-4) var(--space-4);flex-direction:column;flex:none;gap:6px;display:flex;position:relative}.turn-composer-input{resize:vertical;border:1px solid var(--border);border-radius:var(--radius-md);background:var(--bg);width:100%;min-height:56px;max-height:200px;color:var(--ink);transition:border-color .15s var(--ease), box-shadow .15s var(--ease);padding:8px 10px;font-family:inherit;font-size:13px;line-height:1.45}.turn-composer-input:focus{border-color:var(--ink);outline:none;box-shadow:0 0 0 2px #0a0a0a0f}.turn-composer-input:disabled{opacity:.55;cursor:not-allowed}.turn-composer-foot{justify-content:space-between;align-items:center;gap:8px;display:flex}.turn-composer-hint{color:var(--muted);align-items:center;gap:4px;font-size:10px;display:inline-flex}.turn-composer-hint kbd{border:1px solid var(--border);background:var(--surface);color:var(--muted);border-radius:3px;padding:1px 5px;font-family:ui-monospace,SFMono-Regular,Menlo,monospace;font-size:10px}.turn-composer-send{background:var(--ink);color:#fff;border-radius:var(--radius-pill);transition:opacity .15s var(--ease), transform .15s var(--ease);align-items:center;gap:6px;padding:6px 12px;font-size:12px;font-weight:600;display:inline-flex}.turn-composer-send:hover:not(:disabled){transform:scale(.98)}.turn-composer-send:disabled{opacity:.35;cursor:not-allowed}.turn-composer-busy{border:1px dashed var(--border);border-radius:var(--radius-md);background:var(--surface);color:var(--muted);align-items:center;gap:10px;padding:14px 12px;font-size:12px;display:flex}.turn-composer-spinner{border:2px solid var(--border);border-top-color:var(--ink);border-radius:50%;width:14px;height:14px;animation:.85s linear infinite quest-spin}.turn-composer-busy-label{color:var(--ink);flex:1}.turn-composer-stop{border-radius:var(--radius-pill);color:#b54327;cursor:pointer;transition:background .15s var(--ease), color .15s var(--ease), border-color .15s var(--ease);background:0 0;border:1px solid #d97560;align-items:center;gap:5px;padding:4px 10px;font-size:11px;font-weight:600;display:inline-flex}.turn-composer-stop:hover:not(:disabled){color:#fff;background:#b54327;border-color:#b54327}.turn-composer-stop:disabled{opacity:.55;cursor:not-allowed}.turn-ac{bottom:calc(100% - 4px);left:var(--space-4);right:var(--space-4);border:1px solid var(--border);border-radius:var(--radius-md);z-index:20;background:#fff;flex-direction:column;gap:2px;max-height:240px;padding:4px;display:flex;position:absolute;overflow:auto;box-shadow:0 1px 2px #0f0f0f0a,0 8px 24px #0f0f0f1a}.turn-ac-item{text-align:left;cursor:pointer;color:var(--ink);transition:background .1s var(--ease);background:0 0;border:none;border-radius:6px;align-items:center;gap:10px;padding:6px 8px;font-family:inherit;display:flex}.turn-ac-item:hover,.turn-ac-item-active{background:var(--surface)}.turn-ac-item-disabled{opacity:.45;cursor:not-allowed}.turn-ac-cmd{color:var(--ink);flex-shrink:0;min-width:100px;font-family:ui-monospace,SFMono-Regular,Menlo,monospace;font-size:12px;font-weight:600}.turn-ac-desc{color:var(--muted);white-space:nowrap;text-overflow:ellipsis;flex:1;font-size:11.5px;overflow:hidden}.canvas-deploy-spinner{vertical-align:-1px;border:1.5px solid #fff6;border-top-color:#fff;border-radius:50%;width:10px;height:10px;margin-right:6px;animation:.85s linear infinite quest-spin;display:inline-block}.turn-edit{padding-bottom:4px}.turn-edit-typing{background:var(--surface);border-radius:var(--radius-md);border:1px solid var(--border);align-items:center;gap:4px;width:fit-content;margin-top:8px;padding:8px 12px;display:inline-flex}.turn-edit-typing>span{background:var(--muted);border-radius:50%;width:6px;height:6px;animation:1.2s ease-in-out infinite chat-typing;display:inline-block}.turn-edit-typing>span:nth-child(2){animation-delay:.18s}.turn-edit-typing>span:nth-child(3){animation-delay:.36s}@keyframes chat-typing{0%,60%,to{opacity:.25;transform:translateY(0)}30%{opacity:1;transform:translateY(-2px)}}.turn-edit-reply{background:var(--surface);border-radius:var(--radius-md);border:1px solid var(--border);margin-top:8px;padding:10px 12px}.turn-edit-reply-label{text-transform:uppercase;letter-spacing:.04em;color:var(--muted);margin-bottom:4px;font-size:10px;font-weight:600}.turn-edit-reply-text{color:var(--ink);white-space:pre-wrap;word-break:break-word;font-size:13px;line-height:1.45}.turn-edit-reply-error{background:#fbf2f1;border-color:#f0d8d6}.turn-edit-reply-error .turn-edit-reply-label{color:#b21d18}.turn-edit-reply-error .turn-edit-reply-text{color:#4a1f1d}
