@import"https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700;800&display=swap";:root,[data-theme=dark]{--bg: #09090b;--surface: #111113;--surface-2: #18181b;--surface-3: #27272a;--border: #27272a;--border-subtle: #1f1f23;--text: #fafafa;--text-secondary: #a1a1aa;--text-tertiary: #52525b;--accent: #d4d4d8;--accent-hover: #e4e4e7;--accent-dim: rgba(212, 212, 216, .12);--accent-text: #09090b;--orange: #f59e0b;--green: #22c55e;--blue: #3b82f6;--pink: #ec4899;--cyan: #06b6d4;--settings-bg: #212124;color-scheme:dark}[data-theme=light]{--bg: #ffffff;--surface: #f4f4f5;--surface-2: #e4e4e7;--surface-3: #d4d4d8;--border: #d4d4d8;--border-subtle: #e4e4e7;--text: #09090b;--text-secondary: #52525b;--text-tertiary: #a1a1aa;--accent: #27272a;--accent-hover: #18181b;--accent-dim: rgba(39, 39, 42, .1);--accent-text: #fafafa;--orange: #d97706;--green: #16a34a;--blue: #2563eb;--pink: #db2777;--cyan: #0891b2;--settings-bg: #e8e8eb;color-scheme:light}*{margin:0;padding:0;box-sizing:border-box}html{scroll-behavior:smooth}html,body,#root{height:100%;overflow:hidden}body{font-family:Inter,-apple-system,BlinkMacSystemFont,sans-serif;background:var(--bg);color:var(--text);line-height:1.6;-webkit-font-smoothing:antialiased}.btn-primary{display:inline-flex;align-items:center;gap:8px;padding:14px 24px;background:var(--accent);color:#fff;text-decoration:none;font-size:15px;font-weight:600;border-radius:10px;transition:all .2s;border:none;cursor:pointer}.landing-page{height:100%;overflow-y:auto;--bg: #09090b;--surface: #111113;--surface-2: #18181b;--surface-3: #27272a;--border: #27272a;--border-subtle: #1f1f23;--text: #fafafa;--text-secondary: #a1a1aa;--text-tertiary: #52525b;--accent: #d4d4d8;--accent-hover: #e4e4e7;--accent-dim: rgba(212, 212, 216, .12);--accent-text: #09090b;--orange: #f59e0b;--green: #22c55e;--blue: #3b82f6;--pink: #ec4899;--cyan: #06b6d4;background:var(--bg);color:var(--text);color-scheme:dark}.nav{position:fixed;top:0;left:0;right:0;display:flex;align-items:center;justify-content:space-between;padding:16px 32px;background:transparent;border-bottom:1px solid transparent;z-index:100;transition:background .3s,border-color .3s}.nav.scrolled{background:#09090bcc;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border-bottom-color:var(--border-subtle)}.nav-logo,.nav-right{flex:1}.nav-right{justify-content:flex-end}.nav-logo{display:flex;align-items:center;gap:10px;text-decoration:none;color:var(--text);font-weight:600;font-size:18px}.nav-logo img{width:32px;height:32px;border-radius:8px}.nav-center{display:flex;gap:32px}.nav-center a{color:var(--text-secondary);text-decoration:none;font-size:14px;font-weight:500;transition:color .15s}.nav-center a:hover{color:var(--text)}.nav-right{display:flex;align-items:center;gap:16px}.nav-link{color:var(--text-secondary);text-decoration:none;font-size:14px;font-weight:500;transition:color .15s}.nav-link:hover{color:var(--text)}.nav-cta{display:inline-flex;align-items:center;padding:8px 16px;background:var(--accent);color:var(--accent-text, #09090b);text-decoration:none;font-size:14px;font-weight:500;border-radius:8px;transition:all .15s}.nav-cta:hover{opacity:.85}.nav-mobile{display:none;width:40px;height:40px;background:transparent;border:1px solid var(--border);border-radius:8px;color:var(--text);cursor:pointer;align-items:center;justify-content:center}.nav-mobile svg{width:20px;height:20px}.hero{min-height:100vh;display:flex;flex-direction:row;align-items:center;justify-content:space-between;padding:0 80px;gap:40px;max-width:1400px;margin:0 auto}.hero-text{flex:1;text-align:left}.hero-visual{flex:1;display:flex;align-items:center;justify-content:center}.hero-icosahedron-wrap{position:relative;width:100%;max-width:500px;aspect-ratio:1}.hero-beam-canvas{position:fixed;top:0;left:0;width:100vw;height:100vh;mix-blend-mode:screen;pointer-events:none;z-index:0}.hero-icosahedron{position:relative;width:100%;height:100%;z-index:1}.hero h1{font-size:clamp(32px,4vw,64px);font-weight:800;line-height:1.08;letter-spacing:-.035em;margin-bottom:24px;color:#fff;white-space:nowrap}.hero-sub{font-size:18px;color:var(--text-secondary);max-width:520px;margin:0 0 40px;line-height:1.7}.hero-actions{display:flex;gap:12px}.btn-primary{position:relative;display:inline-flex;align-items:center;gap:8px;padding:14px 24px;background:linear-gradient(135deg,#a1a1aa,#71717a,#a1a1aa);background-size:200% 200%;background-position:0% 50%;color:#09090b;text-decoration:none;font-size:15px;font-weight:600;border-radius:10px;transition:background-position .6s ease,transform .2s;border:none;cursor:pointer;overflow:hidden}.btn-primary svg{width:18px;height:18px}.btn-primary:hover{opacity:.85}.btn-primary.large{padding:16px 32px;font-size:16px}.btn-ghost{display:inline-flex;align-items:center;padding:14px 24px;background:transparent;color:var(--text-secondary);text-decoration:none;font-size:15px;font-weight:500;border-radius:10px;border:1px solid var(--border);transition:all .2s}.btn-ghost:hover{color:var(--text);border-color:var(--text-tertiary)}.integrations{padding:48px 24px;text-align:center;border-top:1px solid var(--border-subtle);border-bottom:1px solid var(--border-subtle)}.integrations p{font-size:13px;color:var(--text-tertiary);text-transform:uppercase;letter-spacing:.1em;margin-bottom:24px}.integrations-track{display:flex;justify-content:center;gap:32px 48px;flex-wrap:wrap;max-width:1300px;margin:0 auto}.integration{display:flex;align-items:center;gap:8px;font-size:14px;font-weight:500;color:var(--text-tertiary);transition:color .2s}.integration img,.integration svg{width:18px;height:18px;opacity:.5;transition:opacity .2s}.integration:hover{color:var(--text)}.integration:hover img,.integration:hover svg{opacity:.8}.scroll-hint{display:inline-flex;flex-direction:column;align-items:center;gap:8px;margin-top:32px;color:var(--text-tertiary);text-decoration:none;font-size:13px;transition:color .2s}.scroll-hint:hover{color:var(--text-secondary)}.scroll-hint svg{width:20px;height:20px;animation:bounce 2.5s cubic-bezier(.4,0,.2,1) infinite}@keyframes bounce{0%,to{transform:translateY(0)}50%{transform:translateY(4px)}}.section-label{display:inline-block;padding:6px 12px;background:var(--accent-dim);color:var(--accent);font-size:12px;font-weight:600;text-transform:uppercase;letter-spacing:.05em;border-radius:6px;margin-bottom:16px}.comparison{padding:100px 48px;max-width:800px;margin:0 auto}.comparison-grid{display:grid;grid-template-columns:1fr 1fr;gap:24px;margin-top:48px}.comparison-col{display:flex;flex-direction:column;gap:1px;background:#ffffff0a;border:1px solid rgba(255,255,255,.06)}.comparison-col.bedrock{border-color:#ffffff1f}.comparison-header{display:flex;align-items:center;gap:8px;padding:14px 20px;font-size:14px;font-weight:600;letter-spacing:.02em;color:var(--text-tertiary);background:#ffffff05}.comparison-header.terminal{font-family:SF Mono,Fira Code,Cascadia Code,monospace;color:var(--text-secondary);background:#0000004d}.terminal-prompt{opacity:.5}.terminal-cursor{width:8px;height:14px;background:var(--text-secondary);animation:blink 1s step-end infinite}@keyframes blink{50%{opacity:0}}.comparison-header.bedrock{color:var(--text-primary)}.comparison-ico{opacity:.6}.comparison-row{display:flex;align-items:center;justify-content:space-between;padding:12px 20px;font-size:14px;background:#ffffff03}.comparison-row.pass span{color:var(--text-secondary)}.comparison-row.pass svg{color:#ffffff80}.comparison-row.fail span{color:var(--text-tertiary)}.comparison-row.fail svg{color:#ffffff26}.comparison-col.bedrock .comparison-row.pass svg{color:#fffc}.use-cases{padding:120px 24px;max-width:1100px;margin:0 auto;scroll-margin-top:70px}.section-header{text-align:center;margin-bottom:64px}.section-header h2{font-size:clamp(32px,5vw,48px);font-weight:700;line-height:1.15;letter-spacing:-.02em}.carousel-container{display:flex;align-items:center;gap:24px;max-width:900px;margin:0 auto}.carousel-btn{width:48px;height:48px;background:var(--surface-2);border:1px solid var(--border);border-radius:50%;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .2s;flex-shrink:0;color:var(--text-secondary)}.carousel-btn:hover{background:var(--surface-3);border-color:var(--text-tertiary);color:var(--text)}.carousel-btn svg{width:20px;height:20px}.carousel-wrapper{flex:1;overflow:hidden;position:relative}.carousel-track{display:flex;transition:transform .5s ease}.carousel-card{width:100%;flex-shrink:0;background:var(--surface);border:1px solid var(--border-subtle);border-radius:20px;overflow:hidden}.carousel-card-visual{height:200px;display:flex;align-items:center;justify-content:center;position:relative;overflow:hidden}.carousel-card-visual.brain{background:linear-gradient(135deg,#d4d4d814,#71717a0a)}.carousel-card-visual.code{background:linear-gradient(135deg,#22c55e1a,#06b6d40d)}.carousel-card-visual.team{background:linear-gradient(135deg,#ec48991a,#f973160d)}.carousel-card-visual.content{background:linear-gradient(135deg,#f973161a,#eab3080d)}.carousel-card-visual.future{background:linear-gradient(135deg,#a1a1aa14,#d4d4d80a)}.carousel-card-visual.business{background:linear-gradient(135deg,#22c55e1a,#10b9810d)}.carousel-icon-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:16px}.carousel-icon-item{width:56px;height:56px;background:var(--surface);border:1px solid var(--border);border-radius:14px;display:flex;align-items:center;justify-content:center}.carousel-icon-item svg{width:24px;height:24px;color:var(--accent)}.carousel-code-preview{background:var(--surface);border:1px solid var(--border);border-radius:12px;padding:20px 24px;font-family:SF Mono,Monaco,Consolas,monospace;font-size:14px;line-height:1.8}.code-line{white-space:nowrap}.code-keyword{color:var(--pink)}.code-var{color:var(--text)}.code-fn{color:var(--blue)}.code-num{color:var(--orange)}.code-comment{color:var(--text-tertiary)}.carousel-avatars{display:flex;gap:-8px}.carousel-avatar{width:52px;height:52px;border:3px solid var(--surface);border-radius:50%;display:flex;align-items:center;justify-content:center;font-weight:600;font-size:18px;color:#fff;margin-left:-12px}.carousel-avatar:first-child{margin-left:0}.carousel-avatar.purple{background:#63c}.carousel-avatar.pink{background:#c36}.carousel-avatar.blue{background:#39c}.carousel-avatar.orange{background:#cc8033}.carousel-media-stack{display:flex;gap:12px}.media-item{width:64px;height:64px;background:var(--surface);border:1px solid var(--border);border-radius:14px;display:flex;align-items:center;justify-content:center}.media-item svg{width:28px;height:28px}.media-item.image svg{color:var(--pink)}.media-item.video svg{color:var(--blue)}.media-item.audio svg{color:var(--orange)}.carousel-timeline{display:flex;gap:8px;align-items:center}.timeline-item{padding:10px 20px;background:var(--surface);border:1px solid var(--border);border-radius:8px;font-size:13px;font-weight:600;color:var(--text-tertiary)}.timeline-item.done{background:var(--accent-dim);border-color:var(--accent);color:var(--accent)}.timeline-item.current{background:var(--accent);border-color:var(--accent);color:#fff}.carousel-metrics{display:flex;gap:32px}.metric{display:flex;flex-direction:column;align-items:center;gap:4px}.metric-value{font-size:32px;font-weight:700;color:var(--green)}.metric-label{font-size:13px;color:var(--text-tertiary);text-transform:uppercase;letter-spacing:.05em}.carousel-card-content{padding:28px}.carousel-card-content h3{font-size:22px;font-weight:700;margin-bottom:10px}.carousel-card-content p{font-size:15px;color:var(--text-secondary);line-height:1.7}.carousel-dots{display:flex;justify-content:center;gap:10px;margin-top:32px}.carousel-dot{width:10px;height:10px;background:var(--surface-3);border-radius:50%;cursor:pointer;transition:all .2s;border:none}.carousel-dot:hover{background:var(--text-tertiary)}.carousel-dot.active{background:var(--accent);width:28px;border-radius:5px}.memory-section{max-width:800px;margin:0 auto;padding:100px 48px;text-align:center}.memory-content h2{font-size:clamp(32px,4vw,56px);font-weight:800;line-height:1.1;letter-spacing:-.035em;color:var(--text-primary);margin-bottom:24px}.memory-content p{font-size:20px;line-height:1.6;color:var(--text-secondary);max-width:540px;margin:0 auto}.statemap-section{display:flex;align-items:center;gap:64px;max-width:1100px;margin:0 auto;padding:100px 48px}.statemap-content{flex:1;min-width:0}.statemap-content h2{font-size:clamp(24px,3vw,32px);font-weight:700;letter-spacing:-.02em;margin-bottom:16px;line-height:1.3}.statemap-content p{font-size:16px;color:var(--text-secondary);line-height:1.7}.statemap-visual{flex:1;min-width:0}.state-constellation{width:100%;height:100%;min-height:260px}@media(max-width:768px){.statemap-section{flex-direction:column;padding:80px 24px;gap:40px}}.cta{padding:120px 24px;text-align:center;position:relative;overflow:hidden}.cta-content{position:relative;z-index:1}.cta h2{font-size:clamp(32px,5vw,48px);font-weight:800;letter-spacing:-.02em;margin-bottom:16px}.cta p{font-size:18px;color:var(--text-secondary);margin-bottom:32px}.footer{border-top:1px solid var(--border-subtle);padding:64px 32px 32px}.footer-main{display:flex;justify-content:space-between;max-width:1100px;margin:0 auto 48px}.footer-brand p{color:var(--text-tertiary);font-size:14px;margin-top:12px}.footer-logo{display:flex;align-items:center;gap:10px;text-decoration:none;color:var(--text);font-weight:600;font-size:16px}.footer-logo img{width:28px;height:28px;border-radius:6px}.footer-links{display:flex;gap:80px}.footer-col h4{font-size:13px;font-weight:600;color:var(--text);margin-bottom:16px}.footer-col a{display:block;font-size:14px;color:var(--text-tertiary);text-decoration:none;margin-bottom:10px;transition:color .15s}.footer-col a:hover{color:var(--text)}.footer-bottom{max-width:1100px;margin:0 auto;padding-top:32px;border-top:1px solid var(--border-subtle);text-align:center}.footer-bottom p{font-size:13px;color:var(--text-tertiary)}.footer-bottom a{color:var(--accent);text-decoration:none}@media(max-width:768px){.nav-center,.nav-right{display:none}.nav-mobile{display:flex}.carousel-btn{display:none}.carousel-container{padding:0 20px}.memory-section{padding:80px 20px}.hero{padding:0 20px;min-height:100vh;flex-direction:column;text-align:center}.hero-text{text-align:center}.hero-sub{font-size:16px;margin:0 auto 40px}.hero-actions{flex-direction:column;width:100%;max-width:280px;margin:0 auto}.hero-actions a{width:100%;justify-content:center}.hero-visual{order:-1}.hero-icosahedron-wrap{max-width:300px}.footer-main{flex-direction:column;gap:48px}.footer-links{flex-direction:column;gap:32px}}.pricing-main{min-height:100vh;display:flex;flex-direction:column;align-items:center;justify-content:center;position:relative;padding:60px 0}.hex-shimmer{position:absolute;inset:0;width:100%;height:100%;pointer-events:none;z-index:-1}.pricing-hero{padding:80px 24px 24px;text-align:center;position:relative;z-index:1;max-width:700px;margin:0 auto}.pricing-hero h1{font-size:clamp(32px,5vw,48px);font-weight:800;letter-spacing:-.03em;margin-bottom:12px}.pricing-label{font-size:12px;font-weight:600;letter-spacing:1px;text-transform:uppercase;color:var(--text-tertiary);margin-bottom:12px}.pricing-sub{font-size:17px;color:var(--text-secondary);line-height:1.6}.pricing-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;width:100%;max-width:1060px;padding:0 24px 24px;align-items:stretch;position:relative;z-index:1}.pricing-card{position:relative;background:#ffffff06;border:1px solid rgba(255,255,255,.06);border-radius:0;padding:28px;display:flex;flex-direction:column;transition:border-color .25s,background .25s}.pricing-card:hover{border-color:#ffffff1f;background:#ffffff0a}.pricing-card.popular{border-color:#ffffff26;background:#ffffff0a}.pricing-badge{position:absolute;top:-14px;left:50%;transform:translate(-50%);width:150px;height:28px}.pricing-badge-shape{position:absolute;inset:0;width:100%;height:100%;fill:var(--bg-primary, #1a1a1a);stroke:#ffffff40;stroke-width:1}.pricing-badge-text{position:relative;display:flex;align-items:center;justify-content:center;width:100%;height:100%;color:var(--text-primary);font-size:11px;font-weight:600;letter-spacing:.5px;text-transform:uppercase;white-space:nowrap}.pricing-card-icon{width:40px;height:40px;margin-bottom:14px;color:var(--text-secondary)}.pricing-card h2{font-size:20px;font-weight:700;margin-bottom:4px;letter-spacing:-.01em}.pricing-tagline{font-size:13px;color:var(--text-tertiary);margin-bottom:12px;line-height:1.4}.pricing-price{display:flex;align-items:baseline;gap:3px;margin-bottom:6px}.pricing-amount{font-size:38px;font-weight:800;letter-spacing:-.03em}.pricing-period{font-size:15px;color:var(--text-tertiary)}.pricing-tokens{font-size:13px;font-weight:500;color:var(--text-tertiary);margin-bottom:24px}.pricing-divider{height:1px;background:#ffffff0f;margin-bottom:16px}.pricing-features{list-style:none;padding:0;margin:0 0 24px;display:flex;flex-direction:column;gap:10px;flex:1}.pricing-features li{display:flex;align-items:center;gap:10px;font-size:14px;color:var(--text-secondary)}.pricing-features li svg{width:14px;height:14px;color:var(--text-tertiary);flex-shrink:0}.pricing-btn{width:100%;padding:11px 24px;background:#ffffff0f;border:1px solid rgba(255,255,255,.1);border-radius:10px;color:var(--text-primary);font-size:14px;font-weight:600;cursor:pointer;transition:all .2s;text-align:center}.pricing-btn:hover{background:#ffffff1a;border-color:#ffffff29}.pricing-btn:disabled{opacity:.5;cursor:not-allowed}.pricing-footer{display:flex;align-items:center;justify-content:center;gap:20px;padding:16px 24px;font-size:13px;color:var(--text-tertiary);border-top:1px solid rgba(255,255,255,.04)}.pricing-footer a{color:var(--text-tertiary);text-decoration:none}.pricing-footer a:hover{color:var(--text-secondary)}@media(max-width:768px){.pricing-grid{grid-template-columns:1fr;max-width:400px}}.invite-page{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:120px 24px 80px}.invite-container{max-width:460px;width:100%;text-align:center}.invite-logo{width:48px;height:48px;margin-bottom:32px}.invite-container h1{font-size:28px;font-weight:700;margin-bottom:12px}.invite-subtitle{color:var(--text-secondary);font-size:15px;margin-bottom:32px}.invite-progress{display:flex;align-items:center;justify-content:center;gap:0;margin-bottom:32px}.invite-progress-step{display:flex;align-items:center;gap:8px;color:var(--text-tertiary);font-size:13px;font-weight:500}.invite-progress-step.active{color:var(--text)}.invite-progress-step.done{color:var(--accent)}.invite-progress-dot{width:8px;height:8px;border-radius:50%;background:var(--surface-3);flex-shrink:0}.invite-progress-step.active .invite-progress-dot{background:var(--accent);box-shadow:0 0 0 3px var(--accent-dim)}.invite-progress-step.done .invite-progress-dot{background:var(--accent)}.invite-progress-line{width:40px;height:1px;background:var(--border);margin:0 12px}.invite-form{text-align:left}.invite-field{margin-bottom:20px}.invite-field label{display:block;font-size:14px;font-weight:500;margin-bottom:8px;color:var(--text)}.invite-field .optional{color:var(--text-tertiary);font-weight:400}.invite-field input,.invite-field textarea{width:100%;padding:12px 14px;background:var(--surface);border:1px solid var(--border);border-radius:8px;font-size:15px;color:var(--text);transition:border-color .15s}.invite-field input:focus,.invite-field textarea:focus{outline:none;border-color:var(--accent)}.invite-field input::placeholder,.invite-field textarea::placeholder{color:var(--text-tertiary)}.invite-field textarea{resize:vertical;min-height:80px}.invite-use-cases{display:flex;flex-direction:column;gap:8px}.invite-use-case-btn{width:100%;padding:14px 16px;background:var(--surface);border:1px solid var(--border);border-radius:10px;font-size:14px;color:var(--text);text-align:left;cursor:pointer;transition:border-color .15s,background .15s}.invite-use-case-btn:hover{border-color:var(--text-tertiary);background:var(--surface-2)}.invite-use-case-btn.selected{border-color:var(--accent);background:var(--accent-dim)}.invite-next{width:100%;justify-content:center;margin-top:8px;gap:8px}.invite-next:disabled{opacity:.6;cursor:not-allowed}.invite-form-nav{display:flex;align-items:center;justify-content:space-between;margin-top:8px}.invite-back{font-size:14px;color:var(--text-secondary);padding:10px 16px}.invite-back:hover{color:var(--text)}.invite-form-nav .invite-next{width:auto;flex:0 0 auto}.invite-success{padding:40px 0}.invite-success-icon{width:64px;height:64px;background:var(--accent-dim);border-radius:50%;display:flex;align-items:center;justify-content:center;margin:0 auto 24px;color:var(--accent)}.invite-success h1{margin-bottom:8px}.invite-success p{color:var(--text-secondary);line-height:1.5}.auth-page{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:20px}.auth-container{width:100%;max-width:420px}.auth-header{text-align:center;margin-bottom:32px}.auth-logo{width:64px;height:64px;border-radius:12px;margin-bottom:16px}.auth-title{font-size:28px;font-weight:700;margin-bottom:8px}.auth-subtitle{color:var(--text-secondary);font-size:15px}.auth-card{background:var(--surface);border:1px solid var(--border);border-radius:16px;padding:32px}.form-group{margin-bottom:20px}.form-label{display:block;font-size:14px;font-weight:500;margin-bottom:8px}.form-input{width:100%;background:var(--bg);border:1px solid var(--border);border-radius:10px;padding:14px 16px;color:var(--text);font-size:16px;transition:all .2s}.form-input:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-dim)}.form-input::placeholder{color:var(--text-tertiary)}.code-inputs{display:flex;gap:8px;justify-content:center}.code-input{width:48px;height:56px;background:var(--bg);border:1px solid var(--border);border-radius:10px;text-align:center;font-size:24px;font-weight:700;color:var(--text);transition:all .2s}.code-input:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-dim)}.btn{width:100%;padding:14px 24px;border-radius:10px;font-size:16px;font-weight:600;cursor:pointer;border:none;transition:all .2s;display:flex;align-items:center;justify-content:center;gap:8px}.btn:disabled{opacity:.5;cursor:not-allowed}.btn:hover:not(:disabled){filter:brightness(1.1);transform:translateY(-1px)}.back-link{display:flex;align-items:center;gap:6px;color:var(--text-secondary);font-size:14px;cursor:pointer;margin-bottom:20px;transition:color .15s;background:none;border:none;padding:0}.back-link:hover{color:var(--text)}.sent-to-email{background:var(--accent-dim);border-radius:8px;padding:12px 16px;margin-bottom:20px;font-size:14px;text-align:center}.sent-to-email strong{color:var(--accent)}.email-shortcuts{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:20px;justify-content:center}.email-shortcut{display:flex;align-items:center;gap:6px;padding:8px 12px;background:var(--surface-2);border:1px solid var(--border);border-radius:8px;font-size:13px;color:var(--text-secondary);cursor:pointer;transition:all .15s;text-decoration:none}.email-shortcut:hover{background:var(--surface-3);color:var(--text);border-color:var(--accent)}.resend-link{text-align:center;margin-top:20px}.resend-link button{color:var(--accent);background:none;border:none;font-size:14px;cursor:pointer;padding:0}.resend-link button:hover{text-decoration:underline}.auth-message{padding:12px 16px;border-radius:8px;font-size:14px;margin-bottom:16px}.auth-message.error{background:#ef44441a;border:1px solid rgba(239,68,68,.3);color:#ef4444}.auth-message.success{background:#22c55e1a;border:1px solid rgba(34,197,94,.3);color:#22c55e}.spinner{width:18px;height:18px;border:2px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:spin .8s linear infinite}.skeleton{background:linear-gradient(90deg,var(--surface-2) 25%,var(--surface-3) 50%,var(--surface-2) 75%);background-size:200% 100%;animation:skeleton-shimmer 1.5s infinite;border-radius:6px}.skeleton-text{height:14px;border-radius:4px}.skeleton-text.large{height:20px}.skeleton-text.small{height:10px}.skeleton-circle{border-radius:50%}.skeleton-text-60{width:60%;height:14px}.modal-overlay{position:fixed;inset:0;background:#000c;display:flex;align-items:center;justify-content:center;z-index:1000;padding:20px;animation:modalOverlayIn .15s ease-out}.modal{background:var(--surface);border:1px solid var(--border);border-radius:20px;width:100%;max-width:440px;position:relative;animation:modalIn .2s cubic-bezier(.16,1,.3,1)}@keyframes modalIn{0%{opacity:0;transform:scale(.95) translateY(10px)}to{opacity:1;transform:scale(1) translateY(0)}}@keyframes modalOverlayIn{0%{opacity:0}to{opacity:1}}.modal-close{position:absolute;top:16px;right:16px;width:32px;height:32px;background:transparent;border:none;color:var(--text-tertiary);cursor:pointer;display:flex;align-items:center;justify-content:center;border-radius:8px;transition:all .15s}.modal-close:hover{color:var(--text);background:var(--surface-2)}.modal-header{padding:32px 32px 24px;text-align:center}.modal-icon{width:64px;height:64px;background:linear-gradient(135deg,var(--accent),var(--pink));border-radius:16px;display:flex;align-items:center;justify-content:center;margin:0 auto 16px}.modal-icon svg{width:32px;height:32px;color:#fff}.modal-title{font-size:24px;font-weight:700;margin-bottom:8px}.modal-subtitle{font-size:15px;color:var(--text-secondary)}.modal-body{padding:0 32px 32px}.delete-modal{max-width:400px;text-align:center;padding:32px}.delete-modal h2{margin-bottom:8px}.delete-modal-icon{width:64px;height:64px;border-radius:50%;background:var(--error);display:flex;align-items:center;justify-content:center;margin:0 auto 20px}.delete-modal-icon svg{width:32px;height:32px;color:var(--error);filter:brightness(.7)}.delete-modal-name{font-size:16px;font-weight:600;color:var(--text);margin-bottom:12px}.delete-modal-warning{font-size:14px;color:var(--text-secondary);line-height:1.5;margin-bottom:24px}.delete-modal-actions{display:flex;gap:12px;justify-content:center}.delete-modal-actions .btn{flex:1;max-width:140px}.search-overlay{position:fixed;inset:0;background:#0009;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:5000;display:flex;align-items:flex-start;justify-content:center;padding-top:15vh}.search-modal{width:560px;max-width:90vw;background:var(--surface);border:1px solid var(--border);border-radius:16px;overflow:hidden;box-shadow:0 16px 48px #00000080;animation:search-in .12s ease}@keyframes search-in{0%{opacity:0;transform:translateY(-8px) scale(.98)}to{opacity:1;transform:translateY(0) scale(1)}}.search-input-row{display:flex;align-items:center;gap:12px;padding:16px 20px;border-bottom:1px solid var(--border);color:var(--text-secondary)}.search-input{flex:1;background:transparent;border:none;font-size:16px;color:var(--text);outline:none;font-family:inherit}.search-input::placeholder{color:var(--text-tertiary)}.search-kbd{padding:2px 8px;background:var(--bg);border:1px solid var(--border);border-radius:6px;font-size:11px;font-weight:600;color:var(--text-tertiary);font-family:inherit}.search-results{max-height:400px;overflow-y:auto;padding:8px}.search-result{display:flex;align-items:center;gap:12px;width:100%;padding:10px 12px;background:transparent;border:none;border-radius:10px;cursor:pointer;transition:background .1s;text-align:left;font-family:inherit;color:var(--text)}.search-result:hover,.search-result.selected{background:var(--surface-2)}.search-result-info{flex:1;min-width:0;display:flex;flex-direction:column;gap:2px}.search-result-name{font-size:14px;font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.search-result-snippet{font-size:12px;color:var(--text-tertiary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.search-result-type{font-size:11px;color:var(--text-tertiary);flex-shrink:0;text-transform:capitalize}.search-empty{padding:32px;text-align:center;font-size:14px;color:var(--text-tertiary)}.file-link-popup{position:fixed;bottom:24px;right:24px;z-index:1000;animation:fileLinkSlideUp .2s ease-out}@keyframes fileLinkSlideUp{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.file-link-popup-content{background:var(--surface);border:1px solid var(--border);border-radius:12px;padding:16px 20px;box-shadow:0 8px 32px #00000026;max-width:320px}.file-link-popup-content p{margin:0 0 12px;font-size:14px;color:var(--text);line-height:1.4}.file-link-popup-actions{display:flex;gap:8px;justify-content:flex-end}.file-link-popup-yes,.file-link-popup-no{padding:6px 16px;border-radius:8px;font-size:13px;font-weight:500;cursor:pointer;border:1px solid var(--border);transition:all .15s}.file-link-popup-yes{background:var(--accent);color:#fff;border-color:transparent}.file-link-popup-no{background:var(--surface);color:var(--text-secondary)}.share-modal{background:var(--surface, #1a1a1a);border:1px solid var(--border, #333);border-radius:16px;width:100%;max-width:440px;padding:28px;position:relative;animation:modalIn .15s ease-out}.share-modal-close{position:absolute;top:16px;right:16px;background:none;border:none;color:var(--text-tertiary, #666);cursor:pointer;padding:4px;border-radius:6px;display:flex;align-items:center}.share-modal-close:hover{color:var(--text-primary, #fff);background:var(--surface-hover, #2a2a2a)}.share-modal-title{font-size:18px;font-weight:600;color:var(--text-primary, #fff);margin:0 0 20px}.share-modal-input-row{display:flex;gap:8px;align-items:center}.share-modal-input{flex:1;min-width:0;background:var(--surface-hover, #222);border:1px solid var(--border, #333);border-radius:8px;color:var(--text-primary, #fff);padding:10px 12px;font-size:14px;outline:none}.share-modal-input:focus{border-color:var(--accent, #638cff)}.share-modal-input::placeholder{color:var(--text-tertiary, #555)}.share-modal-btn{flex-shrink:0;background:var(--accent, #638cff);color:#fff;border:none;border-radius:8px;padding:10px 20px;font-size:14px;font-weight:500;cursor:pointer;white-space:nowrap}.share-modal-btn:hover{opacity:.9}.share-modal-btn:disabled{opacity:.4;cursor:not-allowed}.share-modal-error{color:#ef4444;font-size:13px;margin:10px 0 0}.share-modal-list{margin-top:24px}.share-modal-list-label{font-size:12px;font-weight:500;text-transform:uppercase;letter-spacing:.04em;color:var(--text-tertiary, #666);margin-bottom:8px}.share-modal-person{display:flex;align-items:center;gap:10px;padding:10px 0;border-bottom:1px solid var(--border, #2a2a2a)}.share-modal-person:last-child{border-bottom:none}.share-modal-person-avatar{width:32px;height:32px;border-radius:50%;background:var(--accent, #638cff);color:#fff;display:flex;align-items:center;justify-content:center;font-size:13px;font-weight:600;flex-shrink:0}.share-modal-person-info{flex:1;min-width:0;display:flex;flex-direction:column}.share-modal-person-name{font-size:14px;font-weight:500;color:var(--text-primary, #fff);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.share-modal-person-email{font-size:12px;color:var(--text-tertiary, #666);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.share-modal-person-role{font-size:12px;color:var(--text-tertiary, #666);flex-shrink:0}.share-modal-remove{background:none;border:none;color:var(--text-tertiary, #555);cursor:pointer;padding:4px;border-radius:4px;display:flex;align-items:center;flex-shrink:0}.share-modal-remove:hover{color:#ef4444;background:#ef44441a}.share-modal-empty{color:var(--text-tertiary, #555);font-size:13px;text-align:center;margin:24px 0 0}.app-layout{display:flex;height:100vh;background:var(--bg);overflow:hidden}.app-sidebar{width:220px;background:var(--surface);border-right:1px solid var(--border-subtle);display:flex;flex-direction:column;flex-shrink:0;transition:width .2s ease}.app-sidebar.collapsed{width:60px}.app-sidebar.collapsed .sidebar-icons{flex-direction:column;padding:12px;min-height:auto}.app-sidebar.collapsed .sidebar-bottom,.app-sidebar.collapsed .sidebar-user{justify-content:center}.sidebar-header{display:flex;align-items:center;gap:8px;padding:16px;border-bottom:1px solid var(--border-subtle)}.sidebar-icons{display:flex;align-items:center;justify-content:center;gap:4px;padding:12px;min-height:56px;border-bottom:1px solid var(--border-subtle);box-sizing:border-box}.sidebar-icon-btn{width:32px;height:32px;background:transparent;border:none;border-radius:6px;cursor:pointer;color:var(--text-secondary);display:flex;align-items:center;justify-content:center;transition:all .15s}.sidebar-icon-btn:hover{background:var(--surface-2);color:var(--text)}.sidebar-icon-btn.active{background:var(--accent);color:#fff}.sidebar-icon-btn.app-live.unseen{color:#22c55e}.sidebar-icon-btn.app-live.unseen:hover{background:#22c55e26;color:#22c55e}.sidebar-icon-btn svg{width:16px;height:16px}.sidebar-bottom{margin-top:auto;border-top:1px solid var(--border-subtle);display:flex;align-items:center}.sidebar-bottom .sidebar-user{flex:1;min-width:0}.sidebar-user{padding:16px;display:flex;align-items:center;gap:10px;cursor:pointer;transition:background .15s;background:transparent;border:none;width:100%;text-align:left}.sidebar-bottom:hover{background:var(--surface-2)}.sidebar-download-btn{display:flex;align-items:center;justify-content:center;width:36px;height:36px;border-radius:8px;color:var(--text-secondary);background:var(--surface-2);border:1px solid var(--border-subtle);flex-shrink:0;margin-right:14px;transition:background .15s,color .15s;cursor:pointer}.sidebar-download-btn:hover{background:var(--surface-3, var(--hover));color:var(--text)}.sidebar-user-avatar{width:32px;height:32px;background:#000;border-radius:8px;display:flex;align-items:center;justify-content:center;font-weight:600;font-size:14px;color:#fff;flex-shrink:0}.sidebar-user-name{font-size:14px;font-weight:500;color:var(--text)}.app-main{flex:1;display:flex;flex-direction:column;overflow:hidden}.app-topbar{height:57px;background:var(--surface);border-bottom:none;display:flex;align-items:flex-end;padding:0 16px;justify-content:space-between;position:relative;z-index:10}.topbar-actions{display:flex;align-items:center;height:100%;gap:4px;flex-shrink:0}.topbar-action-btn{width:34px;height:34px;border-radius:8px;border:none;background:transparent;color:var(--text-secondary);display:flex;align-items:center;justify-content:center;cursor:pointer;transition:background .15s,color .15s}.topbar-action-btn svg{transform:rotate(-90deg)}.topbar-action-btn:hover,.topbar-action-btn.active{background:var(--surface-2);color:var(--text)}.control-panel-wrapper{position:relative}.control-panel-card{position:absolute;top:calc(100% + 8px);right:0;width:240px;background:var(--surface-2);border:1px solid var(--border);border-radius:12px;padding:16px;display:flex;flex-direction:column;gap:14px;z-index:100;box-shadow:0 8px 24px #0000004d}.control-panel-section{display:flex;flex-direction:column;gap:6px}.control-panel-label{font-size:11px;font-weight:500;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px}.control-panel-select{width:100%;padding:8px 28px 8px 10px;background:var(--surface);border:1px solid var(--border);border-radius:8px;color:var(--text);font-size:13px;font-family:inherit;cursor:pointer;outline:none;appearance:none;-webkit-appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%23a1a1aa' stroke-width='2'%3E%3Cpath d='m6 9 6 6 6-6'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 8px center}.control-panel-select:hover{border-color:var(--text-secondary)}.control-panel-select:focus{border-color:var(--accent)}.topbar-project-name{font-size:13px;font-weight:500;color:var(--text);max-width:160px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.topbar-action-btn{display:flex;align-items:center;gap:6px}.project-switcher{width:280px;padding:8px;gap:4px}.project-switcher-teams{display:flex;gap:4px;padding:4px;border-bottom:1px solid var(--border);margin-bottom:4px}.project-switcher-team{padding:4px 10px;border:none;background:transparent;color:var(--text-secondary);font-size:12px;font-weight:500;border-radius:6px;cursor:pointer;font-family:inherit}.project-switcher-team:hover{background:var(--hover);color:var(--text)}.project-switcher-team.active{background:var(--surface);color:var(--text)}.project-switcher-list{display:flex;flex-direction:column;gap:1px;max-height:300px;overflow-y:auto}.project-switcher-item{display:flex;align-items:center;gap:4px;border-radius:8px;padding:2px}.project-switcher-item:hover{background:var(--hover)}.project-switcher-item:hover .project-switcher-actions{opacity:1}.project-switcher-item.active{background:var(--surface)}.project-switcher-item.active .project-switcher-name{color:var(--accent);font-weight:500}.project-switcher-name{flex:1;min-width:0;padding:6px 8px;background:none;border:none;color:var(--text);font-size:13px;font-family:inherit;cursor:pointer;text-align:left;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;border-radius:6px}.project-switcher-name:hover{color:var(--text)}.project-switcher-rename-input{flex:1;min-width:0;padding:5px 8px;background:var(--surface);border:1px solid var(--accent);border-radius:6px;color:var(--text);font-size:13px;font-family:inherit;outline:none}.project-switcher-actions{display:flex;gap:2px;opacity:0;transition:opacity .1s;flex-shrink:0}.project-switcher-action{display:flex;align-items:center;justify-content:center;width:28px;height:28px;background:none;border:none;color:var(--text-tertiary);cursor:pointer;border-radius:6px;font-family:inherit}.project-switcher-action:hover{background:var(--surface);color:var(--text)}.project-switcher-action-danger:hover{color:var(--danger, #ef4444);background:#ef44441a}.project-switcher-new{display:flex;align-items:center;gap:8px;padding:8px 10px;background:none;border:none;border-top:1px solid var(--border);color:var(--text-secondary);font-size:13px;font-family:inherit;cursor:pointer;border-radius:0 0 8px 8px;margin-top:4px;width:100%}.project-switcher-new:hover{color:var(--text);background:var(--hover)}.topbar-action-btn.has-notif{position:relative}.topbar-action-btn.has-notif svg{transform:none}.notif-badge{position:absolute;top:4px;right:4px;min-width:16px;height:16px;border-radius:8px;background:var(--accent);color:#fff;font-size:10px;font-weight:600;display:flex;align-items:center;justify-content:center;padding:0 4px;line-height:1}.notif-panel{width:280px;padding:0;gap:0}.notif-panel-header{display:flex;align-items:center;justify-content:space-between;padding:12px 14px;border-bottom:1px solid var(--border);font-size:13px;font-weight:500;color:var(--text)}.notif-clear-btn{background:none;border:none;color:var(--text-tertiary);font-size:12px;font-family:inherit;cursor:pointer;padding:2px 6px;border-radius:4px}.notif-clear-btn:hover{color:var(--text-secondary);background:var(--hover)}.notif-panel-list{max-height:300px;overflow-y:auto}.notif-item{display:flex;flex-direction:column;gap:2px;padding:10px 14px;width:100%;background:none;border:none;border-bottom:1px solid var(--border);text-align:left;cursor:pointer;font-family:inherit;color:var(--text-secondary)}.notif-item:last-child{border-bottom:none}.notif-item:hover{background:var(--hover)}.notif-item.unread{background:#6366f10f}.notif-item.unread:hover{background:#6366f11a}.notif-item-project{font-size:13px;font-weight:500;color:var(--text)}.notif-item-message{font-size:12px;color:var(--text-secondary)}.notif-item-time{font-size:11px;color:var(--text-tertiary);margin-top:2px}.page-content{flex:1;padding:20px 24px 24px;overflow:hidden;min-height:0;display:flex;flex-direction:column}.page-content-chat{display:flex;flex-direction:column;overflow:hidden;padding-top:0;padding-bottom:0;position:relative}.artifacts-button-wrapper{position:absolute;top:8px;right:8px;z-index:10}.artifacts-toggle-btn{width:36px;height:36px;border-radius:10px;background:var(--surface-1);border:1px solid var(--border);color:var(--text-secondary);display:flex;align-items:center;justify-content:center;cursor:pointer;transition:background .15s,color .15s,border-color .15s}.artifacts-toggle-btn:hover,.artifacts-toggle-btn.active{background:var(--surface-2);color:var(--text);border-color:var(--border-strong)}.artifacts-popover{position:absolute;top:calc(100% + 8px);right:0;width:320px;background:var(--surface-1);border:1px solid var(--border);border-radius:12px;box-shadow:0 8px 32px #0000004d;overflow:hidden}.artifacts-popover-title{padding:14px 16px 10px;font-size:14px;font-weight:600;color:var(--text)}.artifacts-popover-empty{padding:32px 16px;text-align:center;color:var(--text-tertiary);font-size:13px}.artifacts-popover-list{display:flex;flex-direction:column;padding:0 8px 8px;gap:2px;max-height:320px;overflow-y:auto}.artifacts-popover-item{display:flex;align-items:center;gap:12px;padding:10px 12px;border-radius:8px;border:1px solid var(--border);background:transparent;cursor:pointer;text-align:left;color:var(--text-secondary);transition:background .15s}.artifacts-popover-item:hover{background:var(--surface-2)}.artifacts-popover-item-icon{width:40px;height:40px;border-radius:8px;background:var(--surface-2);display:flex;align-items:center;justify-content:center;flex-shrink:0;color:var(--text-tertiary)}.artifacts-popover-item-info{flex:1;min-width:0;display:flex;flex-direction:column;gap:2px}.artifacts-popover-item-name{font-size:13px;font-weight:500;color:var(--text);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.artifacts-popover-item-type{font-size:11px;color:var(--text-tertiary)}.page-header-wrapper{position:relative}.page-header{position:sticky;top:0;background:var(--bg);padding-bottom:24px;border-bottom:1px solid var(--border);margin-bottom:24px;z-index:10}.projects-page{flex:1;padding:20px 24px 24px;overflow-y:auto}.projects-header{padding-bottom:24px;border-bottom:1px solid var(--border);margin-bottom:24px}.projects-header-row{display:flex;align-items:center;justify-content:space-between;gap:16px}.projects-title{font-size:28px;font-weight:600;margin:0}.projects-subtitle{color:var(--text-secondary);font-size:14px;display:flex;align-items:center;gap:6px;margin-top:4px}.projects-subtitle svg{width:14px;height:14px}.projects-header-actions{display:flex;align-items:center;gap:12px}.projects-action-btn{width:40px;height:40px;background:var(--surface-2);border:1px solid var(--border);border-radius:10px;cursor:pointer;color:var(--text-secondary);display:flex;align-items:center;justify-content:center;transition:all .15s}.projects-action-btn:hover{background:var(--surface-3);color:var(--text);border-color:var(--text-tertiary)}.projects-action-btn svg{width:18px;height:18px}.projects-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:16px}.project-card{display:flex;align-items:center;gap:16px;padding:20px;background:var(--surface);border:1px solid var(--border);border-radius:14px;cursor:pointer;transition:all .2s ease;position:relative}.project-card:hover{border-color:var(--accent);background:var(--surface-2);transform:translateY(-2px);box-shadow:0 8px 24px #00000026}.project-card-icon{width:52px;height:52px;background:var(--accent);border-radius:12px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.project-card-icon svg{width:26px;height:26px;color:#fff}.project-card-info{flex:1;min-width:0}.project-card-name{font-size:16px;font-weight:600;color:var(--text);display:block}.project-card-desc{font-size:13px;color:var(--text-tertiary);margin-top:4px;display:block}.project-card-actions{display:flex;gap:4px;opacity:0;transition:opacity .15s}.project-card:hover .project-card-actions{opacity:1}.project-card-action-btn{width:32px;height:32px;background:var(--surface);border:1px solid var(--border);border-radius:8px;cursor:pointer;display:flex;align-items:center;justify-content:center;color:var(--text-secondary);transition:all .15s}.project-card-action-btn:hover{background:var(--surface-2);border-color:var(--text-tertiary)}.project-card-action-btn:hover svg{color:var(--text)}.project-card-action-btn svg{width:14px;height:14px}.new-project-card{border:2px dashed var(--border);background:transparent;flex-direction:column;justify-content:center;padding:32px 20px}.new-project-card:hover{border-color:var(--accent);border-style:solid;background:var(--surface);transform:translateY(-2px);box-shadow:0 8px 24px #00000026}.new-project-card-inner{display:flex;flex-direction:column;align-items:center;gap:12px;text-align:center}.new-project-card-icon{width:56px;height:56px;background:var(--surface-2);border:1px solid var(--border);border-radius:12px;display:flex;align-items:center;justify-content:center}.new-project-card-icon svg{width:26px;height:26px;color:var(--text-tertiary)}.new-project-card:hover .new-project-card-icon{background:var(--surface-3);border-color:var(--text-tertiary)}.new-project-card:hover .new-project-card-icon svg{color:var(--text)}.new-project-card-text{text-align:center;display:flex;flex-direction:column;gap:4px}.new-project-card-title{font-size:16px;font-weight:600;color:var(--text);display:block}.new-project-card-subtitle{font-size:13px;color:var(--text-tertiary);display:block}.new-project-modal{max-width:480px}.new-project-modal .modal-body{display:flex;flex-direction:column;gap:20px}.new-project-modal .modal-header{padding-bottom:0;text-align:left}.new-project-modal .modal-title{font-size:22px}.autosave-section{background:var(--surface-2);border:1px solid var(--border);border-radius:12px;padding:16px}.autosave-header{margin-bottom:8px}.autosave-title{font-size:15px;font-weight:600;color:var(--text);margin-bottom:4px}.autosave-subtitle{font-size:13px;color:var(--text-tertiary)}.autosave-controls{display:flex;align-items:center;justify-content:space-between;padding:12px;background:var(--bg);border-radius:8px}.autosave-branch{display:flex;align-items:center;gap:8px}.autosave-branch svg{width:16px;height:16px;color:var(--text-tertiary)}.autosave-branch-name{font-size:14px;font-weight:500;color:var(--text)}.autosave-branch-badge{font-size:11px;font-weight:600;text-transform:uppercase;background:var(--accent);color:#000;padding:2px 6px;border-radius:4px}.autosave-right{display:flex;align-items:center;gap:12px}.autosave-interval{display:flex;align-items:center;gap:6px}.autosave-select{background:var(--surface);border:1px solid var(--border);border-radius:6px;padding:6px 10px;color:var(--text);font-size:13px;cursor:pointer}.toggle{width:44px;height:24px;background:var(--surface-3);border-radius:12px;position:relative;cursor:pointer;transition:background .2s;border:none}.toggle.active{background:var(--accent)}.toggle-knob{width:18px;height:18px;background:#fff;border-radius:50%;position:absolute;top:3px;left:3px;transition:transform .2s}.toggle.active .toggle-knob{transform:translate(20px)}.modal-actions{display:flex;gap:12px;justify-content:flex-end;padding-top:8px}.modal-actions .btn{width:auto;min-width:100px}.btn-secondary{background:transparent;color:var(--text-secondary);border:1px solid var(--border)}.btn-secondary:hover:not(:disabled){background:var(--surface-2);color:var(--text);border-color:var(--text-tertiary)}.btn-danger{background:#ef4444;color:#fff}.btn-danger:hover:not(:disabled){background:#dc2626}.btn-danger-ghost{background:transparent;color:#ef4444;border:1px solid transparent}.btn-danger-ghost:hover:not(:disabled){background:#ef44441a;border-color:#ef44444d}.edit-project-modal{max-width:480px}.edit-project-modal .modal-header{padding-bottom:0;text-align:left}.edit-project-modal .modal-title{font-size:22px}.edit-project-modal .modal-body{display:flex;flex-direction:column;gap:20px}.modal-actions-split{display:flex;justify-content:space-between;align-items:center;padding-top:8px}.delete-confirm-modal{max-width:400px}.delete-confirm-modal .modal-header{text-align:center}.delete-confirm-modal .modal-subtitle{color:var(--text-secondary)}.delete-icon{background:#ef444426}.delete-icon svg{color:#ef4444}.thread-sidebar-content{flex:1;display:flex;flex-direction:column;overflow:hidden;padding:8px 8px 0}.sidebar-project-selector{position:relative;margin-bottom:8px}.sidebar-project-btn{display:flex;align-items:center;justify-content:space-between;width:100%;padding:8px 10px;background:none;border:1px solid var(--border-subtle);border-radius:8px;color:var(--text);font-size:13px;font-weight:600;cursor:pointer;transition:background .15s,border-color .15s}.sidebar-project-btn:hover{background:var(--bg-hover);border-color:var(--border)}.sidebar-project-name{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.sidebar-project-dropdown{position:absolute;top:calc(100% + 4px);left:0;right:0;background:var(--surface);border:1px solid var(--border);border-radius:8px;padding:4px;z-index:100;max-height:240px;overflow-y:auto}.sidebar-project-item{display:flex;align-items:center;width:100%;padding:6px 10px;background:none;border:none;border-radius:6px;color:var(--text-secondary);font-size:13px;cursor:pointer;text-align:left;transition:background .15s,color .15s}.sidebar-project-item-name{flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.sidebar-project-delete{display:none;align-items:center;background:none;border:none;color:var(--text-tertiary);cursor:pointer;padding:2px;border-radius:4px;flex-shrink:0;transition:color .1s}.sidebar-project-item:hover .sidebar-project-delete{display:flex}.sidebar-project-delete:hover{color:#ef4444}.sidebar-project-item:hover{background:var(--bg-hover);color:var(--text)}.sidebar-project-item.active{color:var(--text);background:var(--surface-2)}.sidebar-project-item.new-project{display:flex;align-items:center;gap:6px;color:var(--text-tertiary);border-bottom:1px solid var(--border);border-radius:6px 6px 0 0;margin-bottom:2px}.sidebar-project-item.new-project:hover{color:var(--text)}.thread-new-btn{display:flex;align-items:center;gap:8px;width:100%;padding:8px 10px;background:none;border:1px solid var(--border-subtle);border-radius:8px;color:var(--text-secondary);font-size:13px;cursor:pointer;transition:background .15s,color .15s,border-color .15s;margin-bottom:4px}.thread-new-btn:hover{background:var(--bg-hover);color:var(--text);border-color:var(--border)}.sidebar-actions{display:flex;flex-direction:column;gap:6px;padding:4px 0 8px;width:100%}.sidebar-action-btn{display:flex;align-items:center;gap:8px;padding:8px 10px;background:var(--surface-1);border:1px solid var(--border-subtle);border-radius:8px;color:var(--text-secondary);font-size:13px;font-family:inherit;cursor:pointer;transition:background .15s,color .15s,border-color .15s;width:100%;box-sizing:border-box}.sidebar-action-btn svg{flex-shrink:0}.sidebar-action-btn:hover{background:var(--surface-2);color:var(--text)}.thread-list-header-label{font-size:11px;font-weight:600;color:var(--text-tertiary);text-transform:uppercase;letter-spacing:.5px}.thread-list-header{display:flex;align-items:center;justify-content:space-between;font-size:11px;font-weight:600;color:var(--text-tertiary);text-transform:uppercase;letter-spacing:.5px;padding:12px 2px 4px;position:relative;z-index:10}.thread-list-header-actions{display:flex;align-items:center;gap:2px}.thread-view-toggle{display:flex;align-items:center;gap:4px;background:none;border:none;color:var(--text-tertiary);font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.5px;cursor:pointer;padding:2px;border-radius:4px;transition:color .15s,background .15s}.thread-view-toggle:hover{color:var(--text-secondary);background:var(--bg-hover)}.thread-view-dropdown{position:fixed;background:var(--surface-2);border:1px solid var(--border-subtle);border-radius:8px;padding:4px;z-index:9999;min-width:120px;box-shadow:0 4px 12px #0000004d}.thread-view-dropdown button{display:block;width:100%;text-align:left;background:none;border:none;color:var(--text-secondary);font-size:12px;padding:6px 10px;border-radius:6px;cursor:pointer;transition:background .15s}.thread-view-dropdown button:hover{background:var(--bg-hover)}.thread-view-dropdown button.active{color:var(--text-primary);background:var(--bg-hover)}.sidebar-file-item{gap:6px}.sidebar-file-item svg{flex-shrink:0}.sidebar-folder-chevron{display:flex;align-items:center;color:var(--text-tertiary)}.sidebar-files-hint{font-size:11px;color:var(--text-tertiary);padding:4px 12px}.thread-list-header-add{background:none;border:none;color:var(--text-tertiary);cursor:pointer;padding:2px;border-radius:4px;display:flex;align-items:center;transition:color .15s,background .15s}.thread-list-header-add:hover{color:var(--text-secondary);background:var(--bg-hover)}.project-expand-toggle{margin-left:auto;display:flex;align-items:center;color:var(--text-tertiary);flex-shrink:0}.thread-list{flex:1;overflow-y:auto;position:relative;z-index:1;padding-bottom:8px}.thread-project-group{margin-bottom:4px}.thread-project-header{display:flex;align-items:center;gap:6px;width:100%;padding:6px 2px 6px 6px;background:none;border:none;border-radius:6px;color:var(--text-secondary);font-size:13px;font-weight:500;cursor:pointer;transition:background .15s}.thread-project-header:hover{background:var(--bg-hover)}.thread-project-header.current{color:var(--accent)}.thread-project-header svg{flex-shrink:0}.thread-project-name{flex:1;text-align:left;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;cursor:pointer}.project-expand-toggle{background:none;border:none;color:inherit;padding:2px;border-radius:4px;cursor:pointer;display:flex;align-items:center;flex-shrink:0}.project-expand-toggle:hover{background:var(--surface-3)}.thread-project-threads{padding-left:0}.thread-item{display:flex;align-items:center;gap:8px;width:100%;padding:8px 2px 8px 4px;background:none;border:none;border-radius:6px;color:var(--text-secondary);font-size:13px;cursor:pointer;transition:background .15s,color .15s;text-align:left}.thread-item:hover{background:var(--bg-hover)}.thread-item.active{background:var(--accent-dim);color:var(--accent)}.thread-title{flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.thread-file-indicator{display:flex;align-items:center;flex-shrink:0;color:var(--text-tertiary)}.thread-file-indicator.single{cursor:pointer}.thread-file-indicator.single:hover{color:var(--text-secondary)}.thread-file-indicator.multi{position:relative}.thread-file-count{display:flex;align-items:center;gap:2px;background:none;border:none;color:var(--text-tertiary);font-size:11px;cursor:pointer;padding:0}.thread-file-count:hover{color:var(--text-secondary)}.thread-file-popover{position:absolute;top:100%;left:0;z-index:100;background:var(--surface-2);border:1px solid var(--border);border-radius:8px;padding:4px;min-width:180px;box-shadow:0 4px 12px #0000004d;margin-top:4px}.thread-file-popover-header{font-size:11px;color:var(--text-tertiary);padding:4px 8px;font-weight:500}.thread-file-popover-item,.thread-file-popover-attach{display:flex;align-items:center;gap:8px;width:100%;padding:6px 8px;background:none;border:none;border-radius:4px;color:var(--text-secondary);font-size:13px;cursor:pointer;text-align:left}.thread-file-popover-item:hover{background:var(--bg-hover);color:var(--text-primary)}.thread-file-popover-attach{color:var(--text-tertiary);border-top:1px solid var(--border);margin-top:2px;padding-top:8px}.thread-file-popover-attach:hover{background:var(--bg-hover);color:var(--text-secondary)}.thread-item.renaming{padding:4px 6px}.thread-rename-input,.project-rename-input{width:100%;padding:4px 6px;background:var(--surface);border:1px solid var(--accent);border-radius:4px;color:var(--text-primary);font-size:13px;outline:none}.project-rename-input{flex:1}.thread-project-header.renaming{display:flex;align-items:center;gap:8px;padding:6px 12px}.thread-context-menu{position:fixed;background:var(--surface-2);border:1px solid var(--border);border-radius:8px;padding:4px;min-width:140px;box-shadow:0 4px 12px #0000004d;z-index:1000}.thread-context-menu button{display:flex;align-items:center;gap:8px;width:100%;padding:8px 12px;background:none;border:none;border-radius:4px;color:var(--text-primary);font-size:13px;cursor:pointer;text-align:left}.thread-context-menu button:hover{background:var(--bg-hover)}.thread-context-menu button.danger{color:var(--error)}.thread-context-menu button.danger:hover{background:#ef44441a}.thread-empty{padding:8px 10px;font-size:12px;color:var(--text-tertiary);font-style:italic}.thread-empty-new{display:flex;align-items:center;gap:6px;width:100%;padding:6px 10px;background:none;border:none;font-size:12px;color:var(--text-tertiary);cursor:pointer;border-radius:6px;transition:background .15s,color .15s}.thread-empty-new:hover{background:var(--bg-hover);color:var(--text-secondary)}.thread-loading{padding:8px}.thread-skeleton{padding:8px 10px}.project-topbar{min-height:56px;background:var(--surface);border-bottom:none;display:flex;align-items:flex-end;padding:0 16px}.project-tabs{display:flex;align-items:flex-end;gap:2px;height:100%;padding-left:12px;overflow-x:auto;overflow-y:hidden;scrollbar-width:none;min-width:0;flex:1}.project-tabs::-webkit-scrollbar{display:none}.project-tab{position:relative;display:flex;align-items:center;gap:10px;padding:12px 16px;background:transparent;border:none;border-radius:10px 10px 0 0;color:var(--text-secondary);font-size:14px;font-weight:500;cursor:pointer;transition:background .15s,color .15s;white-space:nowrap;width:200px;min-width:200px;flex-shrink:0;height:48px;overflow:hidden;box-sizing:border-box}.project-tab.tab-new{animation:tabSlideIn .25s ease-out}.project-tab.tab-closing{animation:tabSlideOut .2s ease-in forwards}@keyframes tabSlideIn{0%{opacity:0;transform:translate(-12px)}to{opacity:1;transform:translate(0)}}@keyframes tabSlideOut{0%{opacity:1;transform:translate(0)}to{opacity:0;transform:translate(-12px)}}.project-tab:hover{background:var(--surface-2);color:var(--text)}.project-tab.active{background:var(--bg);color:var(--text);z-index:1;overflow:visible}.project-tab.active:before,.project-tab.active:after{content:"";position:absolute;bottom:0;width:12px;height:12px;background:transparent}.project-tab.active:before{left:-12px;border-bottom-right-radius:12px;box-shadow:6px 0 0 0 var(--bg)}.project-tab.active:after{right:-12px;border-bottom-left-radius:12px;box-shadow:-6px 0 0 0 var(--bg)}.project-tab.home{width:auto;padding:10px 14px;flex-shrink:0}.project-tab svg{flex-shrink:0}.project-tab-title{flex:1;overflow:hidden;text-overflow:ellipsis;text-align:left}.tab-badge-dot{width:7px;height:7px;border-radius:50%;background:#ef4444;flex-shrink:0;animation:badgePulse 2s ease-in-out infinite}@keyframes badgePulse{0%,to{opacity:1}50%{opacity:.5}}.project-tab.dragging{opacity:.9;cursor:grabbing;box-shadow:0 4px 12px #0000004d;border-radius:8px 8px 0 0}.project-tab-placeholder{height:48px;background:var(--surface-2);border-radius:8px 8px 0 0;opacity:.4;flex-shrink:0;transition:width .15s ease}body.tab-dragging .project-tabs .project-tab:not(.dragging){transition:margin .15s ease,transform .15s ease}.project-tab{-webkit-user-select:none;user-select:none}.project-tab.tab-mousedown{cursor:grab}body.tab-dragging{cursor:grabbing!important;-webkit-user-select:none;user-select:none}body.tab-dragging *{cursor:grabbing!important}.project-tab-add{width:36px;height:36px;display:flex;align-items:center;justify-content:center;background:transparent;border:none;border-radius:8px;color:var(--text-tertiary);cursor:pointer;transition:all .15s;flex-shrink:0;margin-left:8px;margin-bottom:8px}.project-tab-add:hover{background:var(--surface-2);color:var(--text-secondary)}.project-header{display:flex;align-items:center;justify-content:space-between}.project-header-left{display:flex;flex-direction:column;gap:4px}.project-breadcrumb{display:flex;align-items:center;gap:8px;font-size:28px;font-weight:600}.project-breadcrumb-link{color:var(--text-secondary);text-decoration:none;transition:color .15s;background:none;border:none;padding:0;font:inherit;cursor:pointer}.project-breadcrumb-link:hover{color:var(--text)}.project-breadcrumb-sep{color:var(--text-tertiary)}.project-breadcrumb-current{color:var(--text)}.breadcrumb-hint-anchor{position:relative;display:inline-flex;align-items:center}.folder-nav-hint{position:absolute;top:calc(100% + 10px);left:50%;transform:translate(-50%);background:#fff;color:#18181b;font-size:13px;font-weight:500;padding:8px 28px 8px 12px;border-radius:8px;white-space:nowrap;box-shadow:0 4px 16px #0003;z-index:100;animation:folder-hint-in .25s ease-out}.folder-nav-hint-arrow{position:absolute;top:-5px;left:50%;transform:translate(-50%) rotate(45deg);width:10px;height:10px;background:#fff}.folder-nav-hint-close{position:absolute;top:4px;right:6px;background:none;border:none;color:#71717a;font-size:16px;cursor:pointer;padding:0 2px;line-height:1}.folder-nav-hint-close:hover{color:#18181b}.folder-nav-success{background:var(--green);color:#fff;padding:8px 12px;animation:folder-hint-in .25s ease-out,folder-hint-out .4s ease-in 1.5s forwards}.folder-nav-success .folder-nav-hint-arrow{background:var(--green)}@keyframes folder-hint-in{0%{opacity:0;transform:translate(-50%) translateY(4px)}to{opacity:1;transform:translate(-50%) translateY(0)}}@keyframes folder-hint-out{0%{opacity:1;transform:translate(-50%) translateY(0)}to{opacity:0;transform:translate(-50%) translateY(4px)}}.project-branch-selector{display:inline-flex;align-items:center;gap:6px;padding:0;background:transparent;border:none;color:var(--text-secondary);font-size:14px;cursor:pointer;transition:all .15s}.project-branch-selector:hover{color:var(--text)}.project-branch-selector-wrapper{position:relative}.branch-dropdown{position:absolute;top:100%;left:0;margin-top:8px;min-width:200px;background:var(--surface);border:1px solid var(--border);border-radius:10px;box-shadow:0 8px 24px #0000004d;z-index:100;padding:6px}.branch-dropdown-item{display:flex;align-items:center;gap:8px;width:100%;padding:10px 12px;background:none;border:none;border-radius:6px;color:var(--text-secondary);font-size:13px;cursor:pointer;transition:all .15s;text-align:left}.branch-dropdown-item:hover{background:var(--surface-2);color:var(--text)}.branch-dropdown-item.active{background:var(--accent);color:#fff}.branch-dropdown-item .branch-badge{margin-left:auto;font-size:10px;padding:2px 6px;background:var(--surface-2);border-radius:4px;color:var(--text-tertiary)}.branch-dropdown-item.active .branch-badge{background:#fff3;color:#fff}.branch-dropdown-divider{height:1px;background:var(--border);margin:6px 0}.branch-create-form{display:flex;gap:6px;padding:6px}.branch-create-input{flex:1;padding:8px 10px;background:var(--surface-2);border:1px solid var(--border);border-radius:6px;color:var(--text);font-size:13px}.branch-create-input::placeholder{color:var(--text-tertiary)}.branch-create-input:focus{outline:none;border-color:var(--accent)}.branch-create-btn{width:32px;height:32px;display:flex;align-items:center;justify-content:center;background:var(--accent);border:none;border-radius:6px;color:#fff;cursor:pointer;transition:all .15s}.branch-create-btn:hover:not(:disabled){background:var(--accent-hover)}.branch-create-btn:disabled{opacity:.5;cursor:not-allowed}.project-header-actions{display:flex;align-items:center;gap:12px}.project-action-btn{width:40px;height:40px;display:flex;align-items:center;justify-content:center;background:var(--surface-2);border:1px solid var(--border);border-radius:10px;color:var(--text-secondary);cursor:pointer;transition:all .15s}.project-action-btn:hover{background:var(--surface-3);color:var(--text);border-color:var(--text-tertiary)}.sidebar-workspace-actions{display:flex;align-items:center;justify-content:center;gap:8px;padding:12px;border-bottom:1px solid var(--border-subtle)}.sidebar-file-tree{flex:1;padding:12px;overflow-y:auto}.sidebar-empty-state{color:var(--text-tertiary);font-size:13px;text-align:center;padding:20px}.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;padding:60px 24px}.empty-state-icon{width:120px;height:120px;display:flex;align-items:center;justify-content:center;background:var(--surface-2);border:2px dashed var(--border);border-radius:24px;color:var(--text-tertiary);margin-bottom:24px}.empty-state-title{font-size:24px;font-weight:600;color:var(--text);margin:0 0 8px}.empty-state-desc{font-size:15px;color:var(--text-tertiary);margin:0;max-width:360px}.empty-state-compact{display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;padding:24px 16px;height:100%}.empty-state-compact-icon{width:80px;height:80px;display:flex;align-items:center;justify-content:center;background:var(--surface-2);border:2px dashed var(--border);border-radius:16px;color:var(--text-tertiary);margin-bottom:16px}.empty-state-compact-title{font-size:14px;font-weight:600;color:var(--text);margin:0 0 6px}.empty-state-compact-desc{font-size:12px;color:var(--text-tertiary);margin:0;line-height:1.4}.app-sidebar.collapsed .sidebar-workspace-actions{flex-direction:column}.app-sidebar.collapsed .sidebar-file-tree{display:none}.chat-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:60vh;text-align:center}.chat-empty-icon{width:80px;height:80px;display:flex;align-items:center;justify-content:center;color:var(--accent);margin-bottom:16px}.chat-empty-icon svg{width:48px;height:48px}.chat-empty-icon.spinning{animation:chat-pulse 3s ease-in-out infinite}@keyframes chat-pulse{0%,to{opacity:.8}50%{opacity:1}}.chat-empty-title{font-size:24px;font-weight:500;color:var(--text-secondary);margin:0}.chat-input-container{width:100%;background:var(--surface);border:1px solid var(--border);border-radius:16px;padding:12px 16px;cursor:text}.chat-paste-chips{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:8px}.chat-paste-chip{display:inline-flex;align-items:center;gap:6px;padding:5px 8px;background:var(--surface-2);border:1px solid var(--border);border-radius:8px;font-size:12px;color:var(--text-secondary);cursor:pointer;transition:background .12s;max-width:280px}.chat-paste-chip:hover{background:var(--bg-hover)}.chat-paste-chip svg{flex-shrink:0;color:var(--text-tertiary)}.chat-paste-chip-label{overflow:hidden;text-overflow:ellipsis;white-space:nowrap;flex:1}.chat-paste-chip-lines{color:var(--text-tertiary);font-size:11px;white-space:nowrap}.chat-paste-chip-remove{background:none;border:none;color:var(--text-tertiary);font-size:16px;cursor:pointer;padding:0 2px;line-height:1;flex-shrink:0}.chat-paste-chip-remove:hover{color:var(--text)}.chat-paste-overlay{position:fixed;inset:0;z-index:1000;display:flex;align-items:center;justify-content:center;background:#0009;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);animation:paste-overlay-in .15s ease-out}.chat-paste-overlay-panel{width:min(900px,90vw);height:80vh;display:flex;flex-direction:column;background:var(--surface);border:1px solid var(--border);border-radius:12px;overflow:hidden;box-shadow:0 16px 48px #0000004d}.chat-paste-overlay-header{display:flex;align-items:center;justify-content:space-between;padding:12px 16px;border-bottom:1px solid var(--border)}.chat-paste-overlay-title{display:flex;align-items:center;gap:8px;font-size:13px;font-weight:500;color:var(--text)}.chat-paste-overlay-title svg{color:var(--text-tertiary);flex-shrink:0}.chat-paste-overlay-meta{color:var(--text-tertiary);font-weight:400;font-size:12px}.chat-paste-overlay-close{background:none;border:none;color:var(--text-tertiary);font-size:20px;cursor:pointer;padding:0 4px;line-height:1}.chat-paste-overlay-close:hover{color:var(--text)}.chat-paste-overlay-content{flex:1;overflow:auto;padding:20px 24px;margin:0;font-size:14px;font-family:inherit;color:var(--text);line-height:1.7;white-space:pre-wrap;word-wrap:break-word;tab-size:2}@keyframes paste-overlay-in{0%{opacity:0}to{opacity:1}}.chat-locked-search{width:100%;background:var(--surface);border:1px solid var(--border);border-radius:16px;padding:16px}.chat-locked-header{color:var(--text-secondary);font-size:13px;margin-bottom:12px}.chat-search-input-row{display:flex;gap:8px}.chat-search-input{flex:1;background:var(--background);border:1px solid var(--border);border-radius:8px;padding:10px 12px;color:var(--text);font-size:14px;outline:none}.chat-search-input:focus{border-color:var(--accent)}.chat-search-btn{background:var(--accent);color:#fff;border:none;border-radius:8px;padding:10px 16px;font-size:14px;cursor:pointer}.chat-search-btn:disabled{opacity:.6;cursor:not-allowed}.chat-search-error{color:var(--text-secondary);font-size:13px;margin-top:8px}.chat-search-results{display:flex;flex-direction:column;gap:4px;margin-top:12px;max-height:200px;overflow-y:auto}.chat-search-result{display:flex;flex-direction:column;align-items:flex-start;gap:2px;padding:8px 12px;background:var(--background);border:1px solid var(--border);border-radius:8px;cursor:pointer;text-align:left;width:100%}.chat-search-result:hover{border-color:var(--accent)}.chat-search-result-role{font-size:11px;font-weight:500;color:var(--text-tertiary);text-transform:capitalize}.chat-search-result-snippet{font-size:13px;color:var(--text)}.chat-message-highlight{animation:message-highlight 2s ease-out}@keyframes message-highlight{0%{background:rgba(var(--accent-rgb),.2)}to{background:transparent}}.chat-history-panel{position:absolute;bottom:100%;left:0;right:0;margin-bottom:8px;background:var(--surface);border:1px solid var(--border);border-radius:12px;padding:12px;box-shadow:0 4px 12px #00000026;z-index:100}.chat-history-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px;font-size:13px;color:var(--text-secondary)}.chat-history-close{background:none;border:none;color:var(--text-tertiary);font-size:18px;cursor:pointer;padding:0 4px}.chat-history-close:hover{color:var(--text)}.chat-history-search{display:flex;gap:8px}.chat-history-search input{flex:1;background:var(--background);border:1px solid var(--border);border-radius:6px;padding:8px 10px;color:var(--text);font-size:13px;outline:none}.chat-history-search input:focus{border-color:var(--accent)}.chat-history-search button{background:var(--accent);color:#fff;border:none;border-radius:6px;padding:8px 12px;font-size:13px;cursor:pointer}.chat-history-search button:disabled{opacity:.5;cursor:not-allowed}.chat-history-results{display:flex;flex-direction:column;gap:4px;margin-top:8px;max-height:180px;overflow-y:auto}.chat-history-result{display:flex;flex-direction:column;align-items:flex-start;gap:2px;padding:6px 10px;background:var(--background);border:1px solid var(--border);border-radius:6px;cursor:pointer;text-align:left;width:100%}.chat-history-result:hover{border-color:var(--accent)}.chat-history-result-title{font-size:11px;font-weight:500;color:var(--accent)}.chat-history-result-role{font-size:10px;font-weight:500;color:var(--text-tertiary);text-transform:capitalize}.chat-history-result-snippet{font-size:12px;color:var(--text)}.chat-history-empty{color:var(--text-tertiary);font-size:12px;margin-top:8px;text-align:center}.chat-input{width:100%;background:transparent;border:none;color:var(--text);font-size:16px;resize:none;outline:none;min-height:44px;font-family:inherit;padding:6px 0 0 4px}.chat-input::placeholder{color:var(--text-tertiary)}.chat-input-toolbar{display:flex;align-items:center;justify-content:space-between;margin-top:8px;padding-top:8px}.chat-toolbar-left,.chat-toolbar-right{display:flex;align-items:center;gap:4px}.chat-model-selector{display:flex;align-items:center;gap:4px;padding:4px 10px;border:none;border-radius:8px;background:transparent;color:var(--text-tertiary);font-size:15px;font-weight:400;cursor:pointer;transition:all .15s;white-space:nowrap}.chat-model-selector:hover{color:var(--text-secondary)}.chat-model-selector svg{opacity:.6}.chat-toolbar-btn{width:36px;height:36px;display:flex;align-items:center;justify-content:center;background:transparent;border:none;border-radius:10px;color:var(--text-tertiary);cursor:pointer;transition:all .15s}.chat-toolbar-btn:hover{background:var(--surface-2);color:var(--text-secondary)}.chat-toolbar-btn.recording{color:#ef4444;animation:pulse-recording 1.5s ease-in-out infinite}@keyframes pulse-recording{0%,to{opacity:1}50%{opacity:.5}}.chat-send-btn{width:36px;height:36px;display:flex;align-items:center;justify-content:center;background:var(--accent);border:none;border-radius:10px;color:var(--accent-text);cursor:pointer;transition:all .15s}.chat-send-btn:hover:not(:disabled){background:var(--accent-hover);transform:translateY(-1px)}.chat-send-btn:disabled{opacity:.5;cursor:not-allowed}.chat-send-btn.streaming{background:var(--accent);opacity:1;cursor:pointer}.chat-send-btn.streaming:hover{background:var(--accent-hover)}.chat-quick-actions{display:flex;justify-content:center;gap:8px;margin-top:12px}.chat-quick-action-btn{display:flex;align-items:center;gap:6px;padding:8px 14px;background:var(--surface-2);border:1px solid var(--border);border-radius:20px;color:var(--text-secondary);font-size:13px;cursor:pointer;transition:all .15s}.chat-quick-action-btn:hover{background:var(--surface-3);color:var(--text);border-color:var(--border-hover)}.chat-quick-action-btn.special{background:linear-gradient(135deg,var(--accent) 0%,#9333ea 100%);border-color:transparent;color:#fff}.chat-quick-action-btn.special:hover{background:linear-gradient(135deg,var(--accent-hover) 0%,var(--accent-hover) 100%);color:#fff}.chat-discovery-pill{display:flex;align-items:center;justify-content:center;gap:6px;margin-top:8px;padding:8px 16px;background:transparent;border:1px dashed var(--border);border-radius:20px;color:var(--text-tertiary);font-size:13px;cursor:pointer;transition:all .15s}.chat-discovery-pill:hover{background:var(--surface-2);color:var(--text-secondary);border-color:var(--accent);border-style:solid}.chat-questions{display:flex;flex-direction:column;gap:12px}.chat-clarification{background:var(--surface);border:1px solid var(--border-subtle);border-radius:12px;padding:16px}.chat-questions .chat-clarification{margin:0}.chat-clarify-question{font-size:15px;font-weight:500;color:var(--text);margin-bottom:4px}.chat-clarify-counter{font-size:12px;color:var(--text-tertiary);margin-bottom:14px;line-height:16.8px;height:16.8px}.chat-clarify-options{display:flex;flex-direction:column;gap:8px}.chat-clarify-option{display:flex;align-items:center;justify-content:space-between;background:var(--surface-2);border:1px solid var(--border-subtle);border-radius:10px;padding:12px 14px;margin:0;cursor:pointer;transition:all .15s;text-align:left;width:100%;box-sizing:border-box;font-family:inherit;font-size:inherit;line-height:inherit}.chat-clarify-option:hover{background:var(--surface-3);border-color:var(--border)}.chat-clarify-option-content{flex:1;min-width:0}.chat-clarify-option-label{font-size:14px;font-weight:500;color:var(--text)}.chat-clarify-option-desc{font-size:12px;color:var(--text-tertiary);margin-top:2px}.chat-clarify-option-key{width:24px;height:24px;display:flex;align-items:center;justify-content:center;background:var(--surface-3);border-radius:6px;font-size:12px;font-weight:500;color:var(--text-secondary);flex-shrink:0;margin-left:12px}.chat-clarify-option.chat-clarify-custom{border-style:dashed;cursor:pointer;min-height:58px}.chat-clarify-option.chat-clarify-custom .chat-clarify-option-label{color:var(--text-secondary);font-size:14px;font-weight:500}.chat-clarify-option.chat-clarify-custom.editing{border-style:solid;cursor:text}.chat-clarify-option.chat-clarify-custom.editing.focused{border-color:var(--accent)}.chat-clarify-option.chat-clarify-custom.editing:not(.focused){border-color:var(--border)}.chat-clarify-inline-input{flex:1;background:transparent;border:none;font-size:14px;color:var(--text);outline:none;min-width:0;padding:0;height:20px}.chat-clarify-inline-input::placeholder{color:var(--text-tertiary)}.chat-clarify-send-btn{width:28px;height:28px;display:flex;align-items:center;justify-content:center;background:var(--accent);border:none;border-radius:6px;color:#fff;cursor:pointer;flex-shrink:0;transition:opacity .15s}.chat-clarify-send-btn:hover:not(:disabled){opacity:.9}.chat-clarify-send-btn:disabled{opacity:.5;cursor:not-allowed}.chat-clarification.answered{opacity:.85}.chat-clarification.answered .chat-clarify-options{gap:0}.chat-clarify-option.selected{background:var(--surface-2);border-color:var(--accent)}.chat-clarification.answered .chat-clarify-option.selected{cursor:default;pointer-events:none}.chat-clarify-check{color:var(--accent);flex-shrink:0}.chat-clarify-counter.clickable{cursor:pointer;display:inline-flex;align-items:center;gap:4px;background:none;border:none;padding:0;margin:0 0 14px;font-size:12px;line-height:16.8px;height:16.8px;color:var(--text-tertiary);transition:color .15s}.chat-clarify-counter.clickable:hover{color:var(--text-secondary)}.chat-clarify-counter.clickable svg{transition:transform .2s}.chat-clarification.expanded .chat-clarify-counter.clickable svg{transform:rotate(180deg)}.chat-clarification.expanded .chat-clarify-options{gap:8px}.chat-clarification.expanded .chat-clarify-option{pointer-events:auto;cursor:pointer}.chat-clarification.expanded .chat-clarify-option:not(.selected){opacity:.7}.chat-clarification.expanded .chat-clarify-option:not(.selected):hover{opacity:1}.chat-clarification.expanded .chat-clarify-option.selected{pointer-events:auto;cursor:pointer}.chat-clarification.expanded .chat-clarify-option.selected:hover{opacity:.9}.chat-clarify-checkbox{width:18px;height:18px;border:2px solid var(--border);border-radius:4px;display:flex;align-items:center;justify-content:center;flex-shrink:0;margin-right:12px;transition:all .15s}.chat-clarify-checkbox.checked{background:var(--accent);border-color:var(--accent)}.chat-clarify-checkbox svg{color:#fff}.chat-clarify-submit{margin-top:12px;padding:10px 20px;background:var(--accent);border:none;border-radius:8px;color:#fff;font-size:14px;font-weight:500;cursor:pointer;transition:opacity .15s}.chat-clarify-submit:hover{opacity:.9}.chat-clarify-open-ended{cursor:pointer}.chat-clarify-open-ended.expanded{flex-direction:column;align-items:stretch;padding:12px}.chat-open-ended-wrapper{display:flex;flex-direction:column;gap:8px;width:100%}.chat-open-ended-textarea{width:100%;min-height:80px;background:transparent;border:none;font-size:14px;color:var(--text);outline:none;resize:none;font-family:inherit;line-height:1.5}.chat-open-ended-textarea::placeholder{color:var(--text-tertiary);font-style:italic}.chat-clarify-open-ended .chat-clarify-send-btn{align-self:flex-end}.chat-clarification.typing .chat-clarify-option:not(.focused):not(.chat-clarify-open-ended.expanded){opacity:.4;pointer-events:none}.chat-clarification.typing .chat-clarify-question,.chat-clarification.typing .chat-clarify-counter{opacity:.5}.chat-activity-indicator{display:flex;align-items:center;gap:8px;padding:12px 16px;color:var(--text-secondary);font-size:13px;margin:8px 0}.chat-activity-indicator svg{color:var(--text-tertiary)}.chat-thinking-icon{animation:spin 1.5s linear infinite;color:var(--accent)}.chat-branch-nav{display:flex;align-items:center;gap:4px;margin-left:8px;padding-left:8px;border-left:1px solid var(--border)}.chat-branch-btn{display:flex;align-items:center;justify-content:center;padding:2px;background:none;border:none;color:var(--text-secondary);cursor:pointer;border-radius:4px}.chat-branch-btn:hover:not(:disabled){background:var(--bg-hover);color:var(--text-primary)}.chat-branch-btn:disabled{opacity:.3;cursor:default}.chat-branch-count{font-size:12px;color:var(--text-secondary);min-width:32px;text-align:center}.chat-file-types{display:flex;flex-wrap:wrap;justify-content:center;gap:8px}.chat-file-type-btn{display:flex;align-items:center;gap:6px;padding:8px 14px;background:var(--surface);border:1px solid var(--border);border-radius:20px;color:var(--text-secondary);font-size:13px;cursor:pointer;transition:all .15s}.chat-file-type-btn:hover{background:var(--surface-2);border-color:var(--text-tertiary);color:var(--text)}.context-debug-modal{position:fixed;top:50%;left:50%;transform:translate(-50%,-50%);width:90%;max-width:900px;height:80vh;background:var(--surface);border:1px solid var(--border);border-radius:12px;display:flex;flex-direction:column;z-index:1001}.context-debug-header{display:flex;justify-content:space-between;align-items:center;padding:16px 20px;border-bottom:1px solid var(--border)}.context-debug-header h3{margin:0;font-size:16px;font-weight:600;color:var(--text)}.context-debug-header button{background:none;border:none;font-size:24px;color:var(--text-secondary);cursor:pointer;padding:0;line-height:1}.context-debug-header button:hover{color:var(--text)}.context-debug-content{flex:1;padding:16px 20px;margin:0;background:var(--surface-2);border:none;border-radius:0 0 12px 12px;color:var(--text);font-family:var(--font-mono);font-size:12px;line-height:1.5;resize:none;overflow:auto}.app-main-split{display:flex;flex:1;min-height:0}.app-main-split .page-content{flex:1;min-width:0}.app-main.with-editor-atlas .app-main-split .page-content{flex:1}.editor-chat-panel{width:400px;min-width:340px;flex-shrink:0;border-left:1px solid var(--border);display:flex;flex-direction:column;background:var(--surface);animation:slideInFromRight .2s ease-out}@keyframes slideInFromRight{0%{opacity:0;transform:translate(12px)}to{opacity:1;transform:translate(0)}}.editor-chat-panel .chat-chat{height:100%}.files-grid-container{flex:1;overflow-y:auto;min-height:0}.files-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:16px}.files-new-card{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:12px;aspect-ratio:1;padding:16px;background:transparent;border:2px dashed var(--border);border-radius:12px;cursor:pointer;transition:all .2s}.files-new-card:hover{border-color:var(--accent);border-style:solid;background:var(--surface)}.files-new-icon{width:48px;height:48px;display:flex;align-items:center;justify-content:center;background:var(--surface-2);border:1px solid var(--border);border-radius:12px;color:var(--text-tertiary);transition:all .15s}.files-new-card:hover .files-new-icon{background:var(--surface-3);border-color:var(--text-tertiary);color:var(--text)}.files-new-label{font-size:14px;color:var(--text-secondary)}.loading-container{display:flex;align-items:center;justify-content:center;min-height:100vh;width:100%}.share-modal{max-width:520px}.share-modal-header{display:flex;align-items:center;justify-content:space-between;padding:24px 24px 20px;border-bottom:1px solid var(--border-subtle)}.share-modal-title{display:flex;align-items:center;gap:10px;font-size:18px;font-weight:600;color:var(--text)}.share-modal-title svg{color:var(--accent)}.share-modal-body{padding:24px}.share-project-info{display:flex;align-items:center;gap:12px;padding:14px 16px;background:var(--surface-2);border-radius:10px;margin-bottom:24px}.share-project-icon{width:40px;height:40px;background:var(--accent);border-radius:10px;display:flex;align-items:center;justify-content:center;color:#fff}.share-project-name{font-size:15px;font-weight:500;color:var(--text)}.share-section{margin-bottom:20px}.share-label{display:block;font-size:14px;color:var(--text-secondary);margin-bottom:10px}.share-invite-row{display:flex;gap:8px}.share-email-input{flex:1;background:var(--surface-2);border:1px solid var(--border);border-radius:10px;padding:12px 14px;color:var(--text);font-size:14px}.share-email-input:focus{outline:none;border-color:var(--accent)}.share-email-input::placeholder{color:var(--text-tertiary)}.share-permission-select{position:relative;display:flex;align-items:center}.share-permission-select select{appearance:none;background:var(--surface-2);border:1px solid var(--border);border-radius:10px;padding:12px 36px 12px 14px;color:var(--text);font-size:14px;cursor:pointer}.share-permission-select select:focus{outline:none;border-color:var(--accent)}.share-permission-select svg{position:absolute;right:12px;pointer-events:none;color:var(--text-tertiary)}.share-invite-btn{padding:12px 20px;white-space:nowrap}.share-public-row{display:flex;align-items:center;gap:12px;padding:14px 16px;background:var(--surface-2);border-radius:10px}.share-public-text{flex:1;font-size:14px;color:var(--text)}.settings-modal{max-width:720px;padding:0;overflow:hidden}.settings-layout{display:flex;min-height:480px}.settings-actions{display:flex;justify-content:flex-end;gap:10px;margin-top:24px;padding-top:20px;border-top:1px solid var(--border-subtle)}.danger-item{display:flex;align-items:center;justify-content:space-between;gap:20px}.danger-info strong{display:block;font-size:14px;font-weight:600;color:var(--text);margin-bottom:4px}.danger-info p{font-size:13px;color:var(--text-tertiary);margin:0}.ps-modal{width:960px;max-width:960px;height:640px;padding:0;overflow:hidden;border-radius:12px}.ps-layout{display:flex;height:640px}.ps-sidebar{width:220px;flex-shrink:0;background:var(--surface-2);border-right:1px solid var(--border-subtle);padding:20px 0;overflow-y:auto}.ps-sidebar-header{display:flex;align-items:center;gap:10px;padding:0 16px 16px;font-size:15px;font-weight:600;color:var(--text);border-bottom:1px solid var(--border-subtle);margin-bottom:12px}.ps-sidebar-header svg{color:var(--accent);flex-shrink:0}.ps-sidebar-header span{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.ps-nav{display:flex;flex-direction:column;gap:1px;padding:0 8px}.ps-nav-label{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.02em;color:var(--text-tertiary);padding:6px 10px}.ps-nav-item{display:flex;align-items:center;gap:10px;width:100%;padding:7px 10px;background:transparent;border:none;border-radius:6px;color:var(--text-secondary);font-size:13px;cursor:pointer;text-align:left;transition:background .1s,color .1s}.ps-nav-item svg{flex-shrink:0}.ps-nav-item:hover{background:var(--surface-3);color:var(--text)}.ps-nav-item.active{background:var(--accent-dim);color:var(--text)}.ps-nav-item.danger{color:#ef4444}.ps-nav-item.danger:hover{background:#ef44441a}.ps-nav-item.danger.active{background:#ef444426}.ps-nav-sep{height:1px;background:var(--border-subtle);margin:8px 10px}.ps-content{flex:1;overflow-y:auto;min-width:0;position:relative}.ps-content-inner{padding:28px 36px}.ps-title{font-size:20px;font-weight:600;color:var(--text);margin:0 0 24px}.ps-title-danger{color:#ef4444}.ps-section{margin-bottom:28px}.ps-section-label{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.03em;color:var(--text-tertiary);margin:0 0 10px}.ps-toggle-list{background:var(--surface-2);border:1px solid var(--border-subtle);border-radius:10px;overflow:hidden}.ps-toggle-item{display:flex;align-items:center;justify-content:space-between;gap:16px;padding:14px 16px}.ps-toggle-item+.ps-toggle-item{border-top:1px solid var(--border-subtle)}.ps-toggle-item strong{display:block;font-size:13px;font-weight:500;color:var(--text);margin-bottom:2px}.ps-toggle-item p{font-size:12px;color:var(--text-tertiary);margin:0}.ps-select{width:auto;min-width:160px;font-size:13px;padding:6px 32px 6px 10px;flex-shrink:0}.ps-textarea{resize:vertical;min-height:72px;font-size:13px}.ps-textarea-lg{min-height:120px;font-family:SF Mono,Fira Code,monospace;font-size:12px}.ps-hint{font-size:12px;color:var(--text-tertiary);margin:8px 0 0}.ps-hint-mb{margin-bottom:16px}.ps-branch-info{display:flex;align-items:center;gap:10px}.ps-card{background:var(--surface-2);border:1px solid var(--border-subtle);border-radius:10px;overflow:hidden}.ps-card-row{display:flex;align-items:center;justify-content:space-between;gap:16px;padding:14px 16px}.ps-card-row+.ps-card-row{border-top:1px solid var(--border-subtle)}.ps-card-row strong{display:block;font-size:13px;font-weight:500;color:var(--text);margin-bottom:2px}.ps-card-row p{font-size:12px;color:var(--text-tertiary);margin:0}.ps-badge{font-size:11px;font-weight:600;padding:2px 8px;border-radius:4px;background:var(--accent-dim);color:var(--accent);text-transform:uppercase;letter-spacing:.02em}.ps-danger-card{background:#ef44440d;border:1px solid rgba(239,68,68,.25);border-radius:10px;overflow:hidden}.ps-danger-card .ps-card-row+.ps-card-row{border-top:1px solid rgba(239,68,68,.15)}.ps-info-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px}.ps-info-item{background:var(--surface-2);border:1px solid var(--border-subtle);border-radius:8px;padding:12px 14px}.ps-info-label{display:block;font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.03em;color:var(--text-tertiary);margin-bottom:4px}.ps-info-value{font-size:13px;color:var(--text)}.ps-info-mono{font-family:SF Mono,Fira Code,monospace;font-size:12px}.ps-save-bar{position:sticky;bottom:0;display:flex;align-items:center;justify-content:space-between;padding:12px 32px;margin:24px -32px -28px;background:var(--surface-2);border-top:1px solid var(--border-subtle);font-size:13px;color:var(--text-secondary)}.ps-save-bar-actions{display:flex;gap:8px}.form-textarea{resize:vertical;min-height:80px}.form-select{appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' viewBox='0 0 24 24' fill='none' stroke='%23888' stroke-width='2'%3E%3Cpath d='M6 9l6 6 6-6'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 12px center;padding-right:40px}.form-hint{font-size:12px;color:var(--text-tertiary);margin-top:6px}.branches-list{margin-top:20px}.branch-item{display:flex;align-items:center;gap:10px;padding:12px 14px;background:var(--surface-2);border:1px solid var(--border);border-radius:8px;margin-top:8px}.branch-item svg{color:var(--text-tertiary)}.branch-name{flex:1;font-size:14px;font-weight:500;color:var(--text)}.branch-badge{font-size:11px;font-weight:500;color:var(--accent);background:var(--accent-dim);padding:3px 8px;border-radius:4px;text-transform:uppercase}.user-settings-modal{max-width:760px}.user-settings-modal .settings-sidebar{padding-top:24px}.settings-header-title{font-size:20px;font-weight:600;color:var(--text);margin:0 0 24px}.settings-section-label{font-size:12px;font-weight:600;color:var(--text-tertiary);letter-spacing:.5px;margin:0 0 16px}.user-avatar-section{display:flex;align-items:center;gap:16px;margin-bottom:32px}.user-avatar-large{width:72px;height:72px;border-radius:16px;overflow:hidden;background:var(--surface-2)}.user-avatar-large img{width:100%;height:100%;object-fit:cover}.user-avatar-placeholder{width:100%;height:100%;background:linear-gradient(135deg,#4a4a4a,#2a2a2a)}.settings-field{display:flex;align-items:center;justify-content:space-between;padding:16px 0;border-bottom:1px solid var(--border-subtle)}.settings-field:last-child{border-bottom:none}.settings-field-info strong{display:block;font-size:15px;font-weight:500;color:var(--text);margin-bottom:2px}.settings-field-info p{font-size:13px;color:var(--text-tertiary);margin:0}.settings-field-input{width:220px;text-align:right}.settings-field-value{font-size:14px;color:var(--text-secondary)}.settings-field-copyable{display:flex;align-items:center;gap:8px}.settings-theme-picker{display:flex;gap:6px}.settings-theme-option{display:flex;align-items:center;gap:6px;padding:6px 14px;background:transparent;border:1px solid var(--border);border-radius:8px;color:var(--text-secondary);font-size:13px;cursor:pointer;transition:all .15s}.settings-theme-option:hover{border-color:var(--text-tertiary)}.settings-theme-option.active{background:var(--surface-2);border-color:var(--accent);color:var(--text)}.btn-icon{width:32px;height:32px;display:flex;align-items:center;justify-content:center;background:transparent;border:1px solid var(--border);border-radius:8px;color:var(--text-tertiary);cursor:pointer;transition:all .15s}.btn-icon:hover{background:var(--surface-2);color:var(--text);border-color:var(--text-tertiary)}.settings-empty-text{color:var(--text-tertiary);font-size:14px}.user-settings-fullscreen{position:fixed;inset:0;z-index:1000;display:flex;background:#0000004d;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);padding:36px}.user-settings-fullscreen>*{border-radius:0}.user-settings-fullscreen>:first-child{border-radius:12px 0 0 12px}.user-settings-fullscreen>:last-child{border-radius:0 12px 12px 0}.user-settings-sidebar-wrap{width:260px;flex-shrink:0;display:flex;justify-content:flex-end;background:var(--surface-2);overflow:hidden}.user-settings-sidebar{width:100%;padding:20px 16px;overflow-y:auto}.user-settings-nav{display:flex;flex-direction:column;gap:1px}.user-settings-nav-label{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.02em;color:var(--text-tertiary);padding:6px 10px}.user-settings-nav-item{display:flex;align-items:center;gap:10px;width:100%;padding:7px 10px;background:transparent;border:none;border-radius:4px;color:var(--text-secondary);font-size:14px;cursor:pointer;text-align:left;transition:background .1s,color .1s}.user-settings-nav-item svg{flex-shrink:0}.user-settings-nav-item:hover{background:var(--surface-3);color:var(--text)}.user-settings-nav-item.active{background:var(--accent-dim);color:var(--text)}.user-settings-nav-item.danger{color:#ef4444}.user-settings-nav-item.danger:hover{background:#ef44441a}.user-settings-nav-separator{height:1px;background:var(--border-subtle);margin:8px 10px}.user-settings-main-wrap{flex:1;display:flex;min-width:0;background:var(--settings-bg);position:relative;overflow:hidden}.user-settings-main{flex:1;padding:40px;overflow-y:auto;display:flex;justify-content:center}.user-settings-content{max-width:660px;width:100%}.user-settings-close-wrap{position:absolute;top:16px;right:16px;display:flex;flex-direction:column;align-items:center;gap:6px}.user-settings-close-btn{width:36px;height:36px;border-radius:50%;border:2px solid var(--border);background:transparent;color:var(--text-secondary);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .15s}.user-settings-close-btn:hover{border-color:var(--text);color:var(--text)}.user-settings-close-label{font-size:12px;font-weight:600;color:var(--text-tertiary)}.user-settings-title{font-size:20px;font-weight:600;color:var(--text);margin:0 0 20px}.user-settings-section{margin-bottom:32px}.user-settings-section-label{font-size:12px;font-weight:700;text-transform:uppercase;letter-spacing:.02em;color:var(--text-tertiary);margin:0 0 12px}.user-settings-card{background:var(--surface);border-radius:8px;overflow:hidden;margin-bottom:32px;border:1px solid var(--border-subtle)}.user-settings-card-banner{height:100px;background:linear-gradient(135deg,var(--accent-dim),var(--surface-2))}.user-settings-card-body{display:flex;align-items:center;gap:16px;padding:0 16px;margin-top:-32px}.user-settings-card-avatar{width:80px;height:80px;border-radius:50%;border:6px solid var(--surface);overflow:hidden;flex-shrink:0}.user-settings-card-avatar img{width:100%;height:100%;object-fit:cover}.user-settings-avatar-placeholder{width:100%;height:100%;background:var(--surface-3);border-radius:50%}.user-settings-card-name{font-size:20px;font-weight:600;color:var(--text);margin-top:36px}.user-settings-card-fields{padding:16px}.user-settings-card-field{display:flex;align-items:center;justify-content:space-between;padding:12px 0;border-top:1px solid var(--border-subtle)}.user-settings-card-field:first-child{border-top:none}.user-settings-card-field-label{font-size:12px;font-weight:700;text-transform:uppercase;color:var(--text-tertiary);min-width:120px}.user-settings-card-field-value{flex:1;font-size:14px;color:var(--text)}.user-settings-card-field-copyable{display:flex;align-items:center;gap:8px}.user-settings-card-field-edit{flex-shrink:0}.user-settings-field-row{display:flex;align-items:center;justify-content:space-between;gap:20px;padding:16px;background:var(--surface);border-radius:10px;margin-bottom:12px;border:1px solid var(--border-subtle)}.user-settings-field-row strong{display:block;font-size:14px;font-weight:500;color:var(--text);margin-bottom:2px}.user-settings-field-row p{font-size:13px;color:var(--text-tertiary);margin:0}.user-settings-input{width:220px;flex-shrink:0}.user-settings-field-value{font-size:14px;color:var(--text-secondary);text-transform:capitalize}.user-settings-actions{display:flex;justify-content:flex-end;gap:8px;margin-top:8px}.user-settings-empty{color:var(--text-tertiary);font-size:14px;padding:40px 0;text-align:center}.user-settings-danger-section{border:1px solid rgba(239,68,68,.3);border-radius:12px;padding:20px;background:#ef44440d;margin-top:32px}.user-settings-charge-card{background:var(--surface);border:1px solid var(--border-subtle);border-radius:10px;overflow:hidden}.user-settings-charge-plan{display:flex;align-items:center;justify-content:space-between;padding:20px}.user-settings-charge-plan strong{display:block;font-size:14px;color:var(--text);margin-bottom:4px}.user-settings-charge-plan p{font-size:20px;font-weight:600;color:var(--accent);margin:0}.user-settings-usage-row{margin-bottom:16px}.user-settings-usage-label{display:flex;justify-content:space-between;margin-bottom:6px;font-size:13px;color:var(--text-secondary)}.user-settings-usage-count{color:var(--text-tertiary);font-variant-numeric:tabular-nums}.user-settings-usage-bar{height:8px;background:var(--surface-2);border-radius:4px;overflow:hidden}.user-settings-usage-fill{height:100%;background:var(--accent);border-radius:4px;transition:width .3s ease}.user-settings-gifts-hero{display:flex;flex-direction:column;align-items:center;text-align:center;padding:60px 20px;background:var(--surface);border:1px solid var(--border-subtle);border-radius:12px}.user-settings-gifts-icon{font-size:48px;margin-bottom:16px}.user-settings-gifts-hero h3{font-size:18px;font-weight:600;color:var(--text);margin:0 0 8px}.user-settings-gifts-hero p{font-size:14px;color:var(--text-secondary);margin:0 0 24px;max-width:360px}.user-settings-billing-empty{display:flex;align-items:center;justify-content:space-between;padding:20px;background:var(--surface);border:1px solid var(--border-subtle);border-radius:10px}.user-settings-billing-empty p{font-size:14px;color:var(--text-tertiary);margin:0}.btn-icon-sm{background:none;border:none;padding:4px;cursor:pointer;color:var(--text-tertiary);display:flex;align-items:center;border-radius:4px}.btn-icon-sm:hover{color:var(--text);background:var(--surface-2)}.us-profile-card{background:var(--surface);border:1px solid var(--border-subtle);border-radius:8px;overflow:hidden;margin-bottom:32px}.us-profile-card-banner{height:100px;background:linear-gradient(135deg,var(--accent),var(--accent),var(--accent))}.us-profile-card-info{display:flex;align-items:flex-end;gap:16px;padding:0 20px;margin-top:-36px}.us-profile-card-avatar{width:80px;height:80px;border-radius:50%;border:5px solid var(--surface);overflow:hidden;flex-shrink:0}.us-profile-card-avatar img{width:100%;height:100%;object-fit:cover}.us-profile-card-avatar-placeholder{width:100%;height:100%;background:var(--surface-3)}.us-profile-card-name{font-size:20px;font-weight:600;color:var(--text);padding-bottom:8px}.us-profile-card-rows{padding:8px 20px 12px}.us-profile-card-row{display:flex;align-items:center;justify-content:space-between;padding:12px 0;border-top:1px solid var(--border-subtle)}.us-profile-card-row:first-child{border-top:none}.us-profile-card-row-label{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.02em;color:var(--text-tertiary);margin-bottom:2px}.us-profile-card-row-value{font-size:14px;color:var(--text)}.us-profile-inline-input{width:180px;height:32px;font-size:13px;padding:0 10px}.us-security-box{background:var(--surface);border:1px solid var(--border-subtle);border-radius:8px;overflow:hidden}.us-security-box-danger{border-color:#ef44444d;background:#ef44440a}.us-security-row{display:flex;align-items:center;justify-content:space-between;gap:16px;padding:16px 20px;border-top:1px solid var(--border-subtle)}.us-security-box-danger .us-security-row{border-color:#ef444426}.us-security-row:first-child{border-top:none}.us-security-row strong{display:block;font-size:14px;font-weight:500;color:var(--text);margin-bottom:2px}.us-security-row p{font-size:13px;color:var(--text-tertiary);margin:0}.us-theme-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:12px}.us-theme-card{background:var(--surface);border:2px solid var(--border-subtle);border-radius:8px;padding:0;cursor:pointer;overflow:hidden;transition:all .15s}.us-theme-card:hover{border-color:var(--border)}.us-theme-card.active{border-color:var(--accent)}.us-theme-preview{display:flex;height:72px;border-bottom:1px solid var(--border-subtle)}.us-theme-preview[data-theme=dark]{background:#111}.us-theme-preview[data-theme=light]{background:#f5f5f5}.us-theme-preview[data-theme=system]{background:linear-gradient(135deg,#111 50%,#f5f5f5 50%)}.us-theme-preview-sidebar{width:28%;border-right:1px solid rgba(128,128,128,.2)}.us-theme-preview[data-theme=dark] .us-theme-preview-sidebar{background:#1a1a1d}.us-theme-preview[data-theme=light] .us-theme-preview-sidebar{background:#e8e8e8}.us-theme-preview[data-theme=system] .us-theme-preview-sidebar{background:#80808033}.us-theme-preview-content{flex:1;padding:14px 12px;display:flex;flex-direction:column;gap:8px}.us-theme-preview-line{height:6px;border-radius:3px;background:#80808040}.us-theme-preview-line.short{width:60%}.us-theme-card-label{display:flex;align-items:center;justify-content:center;gap:6px;padding:10px;font-size:13px;color:var(--text-secondary)}.us-theme-card.active .us-theme-card-label{color:var(--accent)}.us-language-row{display:flex;align-items:center;justify-content:space-between;gap:20px;padding:16px 20px;background:var(--surface);border:1px solid var(--border-subtle);border-radius:8px}.us-language-row strong{display:block;font-size:14px;font-weight:500;color:var(--text);margin-bottom:2px}.us-language-row p{font-size:13px;color:var(--text-tertiary);margin:0}.us-select{width:180px;height:36px;font-size:13px;padding:0 10px;flex-shrink:0}.us-toggle-list{background:var(--surface);border:1px solid var(--border-subtle);border-radius:8px;overflow:hidden}.us-toggle-item{display:flex;align-items:center;justify-content:space-between;gap:16px;padding:16px 20px;border-top:1px solid var(--border-subtle)}.us-toggle-item:first-child{border-top:none}.us-toggle-item strong{display:block;font-size:14px;font-weight:500;color:var(--text);margin-bottom:2px}.us-toggle-item p{font-size:13px;color:var(--text-tertiary);margin:0}.us-balance-desc{font-size:14px;color:var(--text-secondary);margin:-8px 0 0;line-height:1.5}.us-balance-row{display:flex;gap:20px;align-items:stretch}.us-balance-card{flex:0 0 200px;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:32px 24px;background:linear-gradient(145deg,#1a1a1a,#0d0d0d);border-radius:16px;border:1px solid rgba(255,255,255,.06)}.us-balance-amount{font-size:40px;font-weight:700;color:#fff;line-height:1;font-variant-numeric:tabular-nums;letter-spacing:-.02em}.us-balance-label{font-size:13px;color:#ffffff80;margin-top:8px}.us-balance-detail{font-size:11px;color:#ffffff4d;margin-top:6px}.us-balance-actions{flex:1;display:flex;flex-direction:column;gap:12px;justify-content:center}.us-balance-charged{display:flex;flex-direction:column;gap:6px}.us-balance-charged-label{font-size:12px;color:var(--text-tertiary)}.us-charged-row{display:flex;align-items:center;gap:10px}.us-plan-badge{display:inline-flex;align-items:center;gap:8px;padding:8px 14px;background:var(--surface);border:1px solid var(--border-subtle);border-radius:8px;font-size:13px;font-weight:500;color:var(--text);width:fit-content}.us-plan-badge svg{color:var(--accent)}.us-buy-credits-btn{width:fit-content;padding:8px 20px;font-size:13px}.us-autoreload-bar{display:flex;align-items:center;gap:10px;padding:8px 12px;background:var(--surface);border:1px solid var(--border-subtle);border-radius:10px;white-space:nowrap}.us-autoreload-icon{display:flex;align-items:center;color:var(--text-tertiary);flex-shrink:0}.us-autoreload-text{font-size:12px;color:var(--text-secondary)}.us-autoreload-text strong{color:var(--text);font-weight:600}.us-autoreload-active{border-color:#22c55e40;background:#22c55e0a}.us-autoreload-active .us-autoreload-icon{color:#22c55e}.us-autoreload-edit{flex-shrink:0;font-size:11px;padding:3px 8px;min-width:0;width:auto}.us-autoreload-config{display:flex;gap:12px}.us-autoreload-field{flex:1;display:flex;flex-direction:column;gap:4px}.us-autoreload-field label{font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.03em;color:var(--text-tertiary)}.us-autoreload-field select{background:var(--surface);border:1px solid var(--border-subtle);border-radius:6px;padding:6px 10px;font-size:12px;color:var(--text);cursor:pointer;outline:none}.us-autoreload-field select:focus{border-color:var(--accent)}.us-stats-row{display:grid;grid-template-columns:repeat(3,1fr);gap:12px}.us-stat-card{display:flex;flex-direction:column;align-items:center;gap:4px;padding:20px 16px;background:var(--surface);border:1px solid var(--border-subtle);border-radius:10px}.us-stat-value{font-size:22px;font-weight:700;color:var(--text);font-variant-numeric:tabular-nums}.us-stat-label{font-size:12px;color:var(--text-tertiary)}.us-muted-text{font-size:13px;color:var(--text-tertiary);margin:0}.us-gifts-hero{display:flex;flex-direction:column;align-items:center;text-align:center;padding:60px 32px;background:var(--surface);border:1px solid var(--border-subtle);border-radius:12px}.us-gifts-icon-wrap{width:80px;height:80px;display:flex;align-items:center;justify-content:center;background:var(--accent-dim);border-radius:50%;margin-bottom:20px;color:var(--accent)}.us-gifts-hero h3{font-size:20px;font-weight:600;color:var(--text);margin:0 0 8px}.us-gifts-hero p{font-size:14px;color:var(--text-secondary);margin:0 0 24px;max-width:340px}.us-gifts-actions{display:flex;gap:10px;margin-bottom:16px}.us-coming-soon-pill,.us-gifts-badge{font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:var(--text-tertiary);background:var(--surface-2);padding:4px 12px;border-radius:99px}.us-billing-card{background:var(--surface);border:1px solid var(--border-subtle);border-radius:8px;overflow:hidden}.us-billing-card-empty{display:flex;flex-direction:column;align-items:center;gap:12px;padding:40px 20px;color:var(--text-tertiary)}.us-billing-card-empty p{font-size:14px;margin:0}.us-billing-table-header{display:grid;grid-template-columns:1fr 2fr 1fr 1fr;padding:12px 20px;font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.02em;color:var(--text-tertiary);border-bottom:1px solid var(--border-subtle)}.us-model-grid{grid-template-columns:1fr 1fr 1fr}.us-model-row{display:grid;padding:12px 20px;font-size:13px;color:var(--text-secondary);border-bottom:1px solid var(--border-subtle);font-variant-numeric:tabular-nums}.us-model-row:last-child{border-bottom:none}.us-purchased-badge{font-size:12px;font-weight:500;color:var(--accent);background:var(--accent-dim);padding:2px 10px;border-radius:99px}.us-recharge-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:12px;margin-bottom:12px}.us-recharge-card{display:flex;flex-direction:column;align-items:center;text-align:center;padding:24px 16px 20px;background:var(--surface);border:1px solid var(--border-subtle);border-radius:8px;transition:border-color .15s}.us-recharge-card:hover{border-color:var(--accent)}.us-recharge-card-name{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.05em;color:var(--text-tertiary);margin-bottom:12px}.us-recharge-card-credits{font-size:28px;font-weight:700;color:var(--text);line-height:1;font-variant-numeric:tabular-nums}.us-recharge-card-label{font-size:12px;color:var(--text-tertiary);margin-bottom:8px}.us-recharge-card-price{font-size:20px;font-weight:600;color:var(--text);margin-bottom:2px}.us-recharge-card-rate{font-size:11px;color:var(--text-tertiary);margin-bottom:16px}.us-recharge-btn{width:100%}.user-settings-profile-header{display:flex;align-items:center;gap:12px;padding:16px 12px;background:var(--surface-3);border-radius:8px;margin-bottom:12px}.user-settings-profile-avatar{width:48px;height:48px;border-radius:50%;overflow:hidden;flex-shrink:0}.user-settings-profile-avatar img{width:100%;height:100%;object-fit:cover}.user-settings-profile-avatar-placeholder{width:100%;height:100%;background:var(--surface);border-radius:50%}.user-settings-profile-name{font-size:16px;font-weight:600;color:var(--text);line-height:1.2}.user-settings-profile-edit{background:none;border:none;padding:0;font-size:13px;color:var(--text-secondary);cursor:pointer}.user-settings-profile-edit:hover{color:var(--text)}.user-settings-search{display:flex;align-items:center;gap:10px;padding:10px 12px;background:var(--surface);border:1px solid var(--border-subtle);border-radius:6px;margin-bottom:16px}.user-settings-search svg{color:var(--text-tertiary);flex-shrink:0}.user-settings-search input{flex:1;background:none;border:none;color:var(--text);font-size:14px;outline:none}.user-settings-search input::placeholder{color:var(--text-tertiary)}.api-keys-description{color:var(--text-tertiary);font-size:13px;margin-bottom:12px}.api-keys-description code{background:var(--bg-tertiary);padding:1px 5px;border-radius:4px;font-size:12px}.btn-sm{padding:6px 12px;font-size:13px;gap:4px;display:inline-flex;align-items:center}.api-key-create-form{display:flex;gap:8px;margin-bottom:16px}.api-key-create-form .form-input{flex:1}.api-key-revealed{background:var(--accent-dim);border:1px solid color-mix(in srgb,var(--accent) 25%,transparent);border-radius:8px;padding:12px;margin-bottom:12px}.api-key-revealed-header{display:flex;align-items:center;gap:8px;color:var(--accent);margin-bottom:8px;font-size:13px}.api-key-revealed-value{display:flex;align-items:center;gap:8px;background:var(--bg-primary);border:1px solid var(--border-primary);border-radius:6px;padding:8px 12px;margin-bottom:8px;overflow-x:auto}.api-key-revealed-value code{font-size:12px;word-break:break-all;flex:1}.api-keys-list{display:flex;flex-direction:column;gap:1px;background:var(--border-primary);border:1px solid var(--border-primary);border-radius:8px;overflow:hidden}.api-key-item{display:flex;align-items:center;justify-content:space-between;padding:12px;background:var(--bg-secondary)}.api-key-item-info{flex:1;min-width:0}.api-key-item-name{font-size:14px;font-weight:500;color:var(--text-primary);margin-bottom:2px}.api-key-item-meta{display:flex;align-items:center;gap:12px;font-size:12px;color:var(--text-tertiary)}.api-key-item-prefix{background:var(--bg-tertiary);padding:1px 5px;border-radius:4px;font-size:11px}.api-key-item-actions{display:flex;align-items:center;gap:4px;margin-left:12px}.create-new-modal{max-width:580px;padding:24px}.create-new-title{font-size:15px;font-weight:600;margin-bottom:12px;color:var(--text-secondary)}.create-new-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}.create-new-card{background:var(--surface);border:2px solid var(--border);border-radius:16px;padding:28px 20px;text-align:center;cursor:pointer;transition:all .2s}.create-new-card:hover{border-color:var(--accent);background:var(--surface-2);transform:translateY(-2px)}.create-new-card-icon{width:56px;height:56px;border-radius:14px;background:var(--surface-2);display:flex;align-items:center;justify-content:center;margin:0 auto 16px;transition:all .2s;color:var(--text-secondary)}.create-new-card:hover .create-new-card-icon{background:var(--accent);color:#fff}.create-new-card h3{font-size:16px;font-weight:600;margin:0 0 6px;color:var(--text)}.create-new-card p{font-size:13px;color:var(--text-tertiary);margin:0}.new-folder-modal{max-width:400px;padding:24px}.new-folder-title{font-size:18px;font-weight:600;margin-bottom:20px}.advanced-toggle{display:flex;align-items:center;gap:6px;background:none;border:none;color:var(--text-secondary);font-size:13px;cursor:pointer;padding:8px 0;margin:8px 0;transition:color .15s}.advanced-toggle:hover{color:var(--text)}.advanced-toggle svg{transition:transform .2s}.advanced-toggle.open svg{transform:rotate(180deg)}.advanced-section{margin-bottom:16px;padding:16px;background:var(--surface-2);border-radius:10px}.space-types-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:12px}.space-types-header .form-label{margin:0}.space-types-toggle{font-size:12px;color:var(--accent);cursor:pointer;background:none;border:none;padding:0}.space-types-toggle:hover{text-decoration:underline}.space-types{display:grid;grid-template-columns:repeat(2,1fr);gap:8px}.space-type-option{display:flex;align-items:center;gap:10px;padding:10px 12px;background:var(--surface);border:2px solid var(--border);border-radius:8px;cursor:pointer;transition:all .15s;position:relative}.space-type-option:hover{border-color:var(--accent);background:var(--surface-2)}.space-type-option.checked{border-color:var(--accent);background:var(--accent-dim)}.space-type-check{width:18px;height:18px;border-radius:4px;border:2px solid var(--border);display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:all .15s}.space-type-option.checked .space-type-check{background:var(--accent);border-color:var(--accent)}.space-type-check svg{color:#fff;opacity:0}.space-type-option.checked .space-type-check svg{opacity:1}.space-type-name{font-size:13px;font-weight:500}.new-file-modal{max-width:520px}.new-file-modal .modal-header{text-align:left;padding-bottom:16px}.new-file-modal .modal-title{font-size:20px}.file-type-grid{display:flex;gap:10px}.file-type-item{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:6px;padding:16px 8px;background:var(--surface-2);border:1px solid var(--border);border-radius:12px;cursor:pointer;transition:all .15s}.file-type-item:hover:not(.disabled){background:var(--surface-3);border-color:var(--text-tertiary)}.file-type-item.selected{background:var(--accent-dim);border-color:var(--accent)}.file-type-item.selected .file-type-item-icon{color:var(--accent)}.file-type-item.disabled{opacity:.4;cursor:not-allowed}.file-type-item-icon{color:var(--text-secondary)}.file-type-item-icon svg{width:28px;height:28px}.file-type-item-name{font-size:14px;font-weight:500;color:var(--text-secondary)}.new-folder-modal{max-width:400px}.file-card{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:12px;aspect-ratio:1;padding:16px;background:var(--surface);border:1px solid var(--border);border-radius:12px;cursor:pointer;transition:all .2s}.file-card:hover{background:var(--surface-2);border-color:var(--accent)}.file-card-icon{width:56px;height:56px;display:flex;align-items:center;justify-content:center;background:var(--surface-2);border-radius:8px;color:var(--text-secondary)}.file-card-name{font-size:13px;font-weight:500;color:var(--text);text-align:center;max-width:100%;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.sidebar-tree{display:flex;flex-direction:column;gap:2px}.sidebar-tree-item{display:flex;align-items:center;gap:8px;padding:8px 10px;background:transparent;border:none;border-radius:6px;color:var(--text-secondary);font-size:13px;cursor:pointer;transition:all .15s;text-align:left;width:100%;-webkit-user-select:none;user-select:none}.sidebar-tree-item:hover{background:var(--surface-2);color:var(--text)}.sidebar-tree-item.active{background:var(--accent-dim);color:var(--accent)}.sidebar-tree-name{flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.sidebar-tree-chevron{display:flex;align-items:center;justify-content:center;color:var(--text-muted);width:12px;flex-shrink:0;cursor:pointer;transition:transform .15s}.sidebar-tree-chevron.expanded{transform:rotate(90deg)}.sidebar-tree-chevron:hover{color:var(--text)}.sidebar-tree-item.drop-target{background:var(--accent-subtle);outline:2px dashed var(--accent);outline-offset:-2px}.sidebar-tree-item.dragging-source,.sidebar-tree-item.dragging-item{opacity:.5}.sidebar-tree-item{cursor:grab}.sidebar-tree-item:active{cursor:grabbing}.sidebar-root-drop{padding:8px 10px;margin:4px 0;border:2px dashed var(--accent);border-radius:6px;background:var(--accent-subtle);color:var(--text-muted);font-size:12px;text-align:center}.sidebar-tree-children{display:flex;flex-direction:column}.sidebar-tree-skeleton{display:flex;align-items:center;gap:8px;padding:8px 10px;pointer-events:none}.sidebar-tree-skeleton-icon{width:16px;height:16px}.sidebar-tree-skeleton-name{flex:1;height:14px}.bl-fullscreen{position:fixed;inset:0;z-index:1000;display:flex;background:#0000004d;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);padding:36px}.bl-fullscreen>*{border-radius:0}.bl-fullscreen>:first-child{border-radius:12px 0 0 12px}.bl-fullscreen>:last-child{border-radius:0 12px 12px 0}.bl-sidebar-wrap{width:220px;flex-shrink:0;display:flex;justify-content:flex-end;background:var(--surface-2);overflow:hidden}.bl-sidebar{width:100%;padding:20px 16px;overflow-y:auto;display:flex;flex-direction:column}.bl-sidebar-header{display:flex;align-items:center;gap:8px;color:var(--text);font-size:14px;font-weight:600;padding:0 10px 16px}.bl-nav{display:flex;flex-direction:column;gap:1px}.bl-nav-item{display:flex;align-items:center;gap:10px;width:100%;padding:7px 10px;background:transparent;border:none;border-radius:4px;color:var(--text-secondary);font-size:14px;cursor:pointer;text-align:left;transition:background .1s,color .1s}.bl-nav-item svg{flex-shrink:0}.bl-nav-item:hover{background:var(--surface-3);color:var(--text)}.bl-nav-item.active{background:var(--accent-dim);color:var(--text)}.bl-nav-badge{margin-left:auto;font-size:11px;font-weight:600;background:var(--surface-3);color:var(--text-secondary);padding:1px 7px;border-radius:10px}.bl-sidebar-footer{margin-top:auto;padding-top:16px;border-top:1px solid var(--border-subtle);display:flex;flex-direction:column;gap:6px}.bl-stat-row{display:flex;align-items:center;justify-content:space-between;padding:2px 10px}.bl-stat-label{font-size:12px;color:var(--text-tertiary)}.bl-stat-value{font-size:12px;font-weight:600;color:var(--text-secondary)}.bl-main-wrap{flex:1;display:flex;min-width:0;background:var(--settings-bg);position:relative;overflow:hidden}.bl-main{flex:1;padding:40px;overflow-y:auto;display:flex;justify-content:center}.bl-content{max-width:660px;width:100%}.bl-title{font-size:20px;font-weight:600;color:var(--text);margin:0 0 20px}.bl-close-wrap{position:absolute;top:16px;right:16px;display:flex;flex-direction:column;align-items:center;gap:6px}.bl-close-btn{width:36px;height:36px;border-radius:50%;border:2px solid var(--border);background:transparent;color:var(--text-secondary);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .15s}.bl-close-btn:hover{border-color:var(--text);color:var(--text)}.bl-close-label{font-size:12px;font-weight:600;color:var(--text-tertiary)}.bl-loading-state{display:flex;flex-direction:column;align-items:center;gap:12px;padding:80px 0;color:var(--text-tertiary);font-size:13px}.bl-loading-spinner{width:24px;height:24px;border:2px solid var(--border-subtle);border-top-color:var(--text-secondary);border-radius:50%;animation:bl-spin .6s linear infinite}@keyframes bl-spin{to{transform:rotate(360deg)}}.bl-add-section{margin-bottom:24px}.bl-add-row{display:flex;gap:8px;align-items:center}.bl-add-input{flex:1;background:var(--surface-2);border:1px solid var(--border);border-radius:8px;color:var(--text);font-size:13px;padding:9px 14px;outline:none;transition:border-color .15s}.bl-add-input::placeholder{color:var(--text-tertiary)}.bl-add-input:focus{border-color:var(--accent)}.bl-priority-select{background:var(--surface-2);border:1px solid var(--border);border-radius:8px;color:var(--text-secondary);font-size:13px;padding:8px 10px;cursor:pointer;outline:none}.bl-add-btn{background:var(--accent);border:none;border-radius:8px;color:#fff;cursor:pointer;padding:8px 14px;display:flex;align-items:center;gap:6px;font-size:13px;font-weight:500;transition:opacity .15s}.bl-add-btn:hover{opacity:.9}.bl-add-btn:disabled{opacity:.35;cursor:default}.bl-empty-state{display:flex;flex-direction:column;align-items:center;gap:8px;padding:60px 0;color:var(--text-tertiary)}.bl-empty-state svg{opacity:.4;margin-bottom:4px}.bl-empty-state p{font-size:15px;font-weight:500;color:var(--text-secondary);margin:0}.bl-empty-state span{font-size:13px}.bl-section{margin-bottom:28px}.bl-section-header{display:flex;align-items:center;gap:8px;margin-bottom:8px}.bl-section-label{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.02em;color:var(--text-tertiary);margin:0}.bl-section-count{font-size:11px;font-weight:600;color:var(--text-tertiary);background:var(--surface-3);padding:1px 7px;border-radius:10px}.bl-item-list{display:flex;flex-direction:column;gap:2px}.bl-item{display:flex;align-items:flex-start;gap:10px;padding:10px 12px;border-radius:8px;transition:background .1s}.bl-item:hover{background:var(--surface-2)}.bl-item.resolved{opacity:.5}.bl-check{background:none;border:none;padding:2px 0 0;cursor:pointer;flex-shrink:0;display:flex;align-items:center}.bl-check-box{width:18px;height:18px;border:2px solid var(--border);border-radius:4px;transition:border-color .15s}.bl-check:hover .bl-check-box{border-color:var(--accent)}.bl-check.done{color:var(--accent)}.bl-item-body{flex:1;min-width:0;display:flex;flex-direction:column;gap:3px}.bl-item-title{font-size:14px;color:var(--text);line-height:1.3}.bl-item.resolved .bl-item-title{text-decoration:line-through;color:var(--text-secondary)}.bl-item-desc{font-size:13px;color:var(--text-tertiary);line-height:1.3}.bl-item-meta{display:flex;align-items:center;gap:10px;margin-top:2px}.bl-priority-tag{font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.02em}.bl-item-file{font-size:11px;color:var(--text-tertiary);background:var(--surface-3);padding:1px 6px;border-radius:4px}.bl-item-date{font-size:11px;color:var(--text-tertiary)}.bl-item-delete{background:none;border:none;color:var(--text-tertiary);cursor:pointer;padding:4px;border-radius:4px;opacity:0;display:flex;align-items:center;transition:opacity .1s,color .1s;flex-shrink:0}.bl-item:hover .bl-item-delete{opacity:1}.bl-item-delete:hover{color:#ef4444}.bl-activity-list{display:flex;flex-direction:column;gap:0;position:relative;padding-left:12px}.bl-activity-list:before{content:"";position:absolute;left:4px;top:8px;bottom:8px;width:1px;background:var(--border-subtle)}.bl-activity-item{display:flex;align-items:center;gap:12px;padding:8px 10px;border-radius:8px;transition:background .1s;position:relative}.bl-activity-item:hover{background:var(--surface-2)}.bl-activity-dot{width:7px;height:7px;border-radius:50%;background:var(--text-tertiary);flex-shrink:0;position:relative;z-index:1}.bl-activity-body{flex:1;min-width:0;display:flex;gap:8px;align-items:center}.bl-activity-action{font-size:13px;color:var(--text-secondary)}.bl-activity-file{font-size:13px;color:var(--text-tertiary);background:var(--surface-3);padding:1px 8px;border-radius:4px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.bl-activity-time{font-size:12px;color:var(--text-tertiary);flex-shrink:0}.chat-toggle{position:relative;display:inline-block;width:44px;height:24px;flex-shrink:0}.chat-toggle input{opacity:0;width:0;height:0}.chat-toggle-slider{position:absolute;cursor:pointer;inset:0;background:var(--surface-3);border-radius:12px;transition:.2s}.chat-toggle-slider:before{content:"";position:absolute;width:18px;height:18px;left:3px;bottom:3px;background:#fff;border-radius:50%;transition:.2s}.chat-toggle input:checked+.chat-toggle-slider{background:var(--accent)}.chat-toggle input:checked+.chat-toggle-slider:before{transform:translate(20px)}.chat-chat{display:flex;flex-direction:column;flex:1;min-height:0;max-width:800px;margin:0 auto;width:100%;position:relative}.page-content-chat>.chat-back-btn{position:absolute;top:8px;left:8px;z-index:10;width:36px;height:36px;border-radius:10px;background:var(--surface-1);border:1px solid var(--border);color:var(--text-secondary);display:flex;align-items:center;justify-content:center;cursor:pointer;transition:background .15s,color .15s,border-color .15s}.page-content-chat>.chat-back-btn:hover{background:var(--surface-2);color:var(--text);border-color:var(--border-strong)}.chat-conversation-header{position:relative;display:flex;justify-content:center;padding:4px 0;flex-shrink:0}.chat-conversation-title-btn{display:flex;align-items:center;gap:6px;padding:6px 12px;background:transparent;border:none;border-radius:8px;color:var(--text);font-size:16px;font-weight:500;cursor:pointer;transition:all .15s}.chat-conversation-title-btn:hover{background:var(--surface-2)}.chat-conversation-title-text{max-width:300px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.chat-conversation-dropdown{position:absolute;top:100%;left:50%;transform:translate(-50%);min-width:280px;max-width:360px;background:var(--surface);border:1px solid var(--border);border-radius:12px;padding:8px;box-shadow:0 8px 24px #0000004d;z-index:100}.chat-conversation-new-btn{display:flex;align-items:center;gap:10px;width:100%;padding:10px 12px;background:transparent;border:none;border-radius:8px;color:var(--text);font-size:14px;cursor:pointer;transition:all .15s}.chat-conversation-new-btn:hover{background:var(--surface-2)}.chat-conversation-divider{height:1px;background:var(--border);margin:8px 0}.chat-conversation-list{max-height:320px;overflow-y:auto;display:flex;flex-direction:column;gap:2px}.chat-conversation-item{display:flex;align-items:flex-start;gap:10px;width:100%;padding:10px 12px;background:transparent;border:none;border-radius:8px;color:var(--text-secondary);font-size:14px;cursor:pointer;transition:all .15s;text-align:left}.chat-conversation-item:hover{background:var(--surface-2);color:var(--text)}.chat-conversation-item.active{background:var(--accent-dim);color:var(--accent)}.chat-conversation-item svg{flex-shrink:0;margin-top:2px}.chat-conversation-item-info{flex:1;min-width:0;display:flex;flex-direction:column;gap:2px}.chat-conversation-item-title{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.chat-conversation-item-date{font-size:12px;color:var(--text-tertiary)}.chat-conversation-item.active .chat-conversation-item-date{color:var(--accent);opacity:.7}.chat-messages{flex:1;display:flex;flex-direction:column;gap:16px;padding:0 24px 0 0;overflow-y:auto;margin-right:-24px}.chat-message-wrapper{display:flex;flex-direction:column;align-items:flex-start}.chat-message-wrapper:first-child{padding-top:24px}.chat-message-wrapper-user{align-items:flex-end}.chat-message{max-width:100%;width:100%}.chat-message-user{max-width:85%;width:auto}.chat-message-user .chat-message-content{background:var(--accent);color:var(--accent-text);padding:12px 16px;border-radius:16px 16px 4px;font-size:15px;line-height:1.5;white-space:pre-wrap}.chat-hover-actions{display:flex;gap:2px;height:28px;margin-top:4px;opacity:0;transition:opacity .15s}.chat-hover-actions-right{justify-content:flex-end}.chat-message-wrapper:hover .chat-hover-actions{opacity:1}.chat-user-edit{display:flex;flex-direction:column;gap:8px;width:100%;min-width:300px}.chat-user-edit-input{background:var(--surface-2);border:1px solid var(--border);border-radius:12px;padding:12px 16px;font-size:14px;line-height:1.5;color:var(--text);resize:none;font-family:inherit}.chat-user-edit-input:focus{outline:none;border-color:var(--accent)}.chat-user-edit-actions{display:flex;gap:8px;justify-content:flex-end}.chat-user-edit-cancel{background:transparent;border:1px solid var(--border);border-radius:8px;padding:6px 14px;font-size:13px;color:var(--text-secondary);cursor:pointer;transition:all .15s}.chat-user-edit-cancel:hover{background:var(--surface-2)}.chat-user-edit-save{background:var(--accent);border:none;border-radius:8px;padding:6px 14px;font-size:13px;color:#fff;cursor:pointer;transition:all .15s}.chat-user-edit-save:hover{filter:brightness(1.1)}.chat-message-assistant{align-self:flex-start;display:flex;flex-direction:column;gap:12px}.chat-message-header{display:flex;align-items:center;gap:6px;font-size:14px;font-weight:500;color:var(--text)}.chat-message-header svg{color:var(--accent)}.chat-message-assistant .chat-message-content{font-size:15px;color:var(--text-secondary);line-height:1.6}.chat-model-label{display:flex;align-items:center;gap:5px;font-size:11px;font-weight:500;color:var(--text-tertiary);padding:4px 0;letter-spacing:.03em}.chat-model-label-dot{width:5px;height:5px;border-radius:50%;background:var(--accent);opacity:.6}.chat-message-images{display:flex;flex-wrap:wrap;justify-content:center;gap:12px}.img-card{border-radius:12px;overflow:hidden;background:var(--surface-2);border:1px solid var(--border-subtle);max-width:420px}.img-card-preview{cursor:pointer;overflow:hidden;position:relative}.img-card-preview img{width:100%;display:block;transition:transform .2s ease}.img-card-preview:hover img{transform:scale(1.02)}.img-card-bar{display:flex;align-items:center;gap:8px;padding:10px 12px;border-top:1px solid var(--border-subtle)}.img-card-info{flex:1;min-width:0;display:flex;align-items:center;gap:8px}.img-card-prompt{font-size:12px;color:var(--text-tertiary);overflow:hidden;text-overflow:ellipsis;white-space:nowrap;flex:1;min-width:0}.img-card-style{font-size:10px;font-weight:600;text-transform:uppercase;letter-spacing:.03em;color:var(--text-tertiary);background:var(--surface-3);padding:2px 6px;border-radius:4px;flex-shrink:0}.img-card-actions{display:flex;gap:4px;flex-shrink:0}.img-card-btn{background:none;border:1px solid var(--border);border-radius:6px;color:var(--text-tertiary);cursor:pointer;padding:5px 7px;display:flex;align-items:center;transition:all .15s}.img-card-btn:hover{color:var(--text);border-color:var(--text-secondary);background:var(--surface-3)}.img-card-btn.active{color:var(--accent);border-color:var(--accent);background:var(--accent-dim)}.img-card-iterate{padding:10px 12px;border-top:1px solid var(--border-subtle);display:flex;flex-direction:column;gap:8px}.img-card-iterate-styles{display:flex;gap:4px;flex-wrap:wrap}.img-card-style-btn{background:var(--surface-3);border:1px solid transparent;border-radius:14px;color:var(--text-secondary);font-size:11px;font-weight:500;padding:3px 10px;cursor:pointer;transition:all .15s}.img-card-style-btn:hover{color:var(--text);background:var(--surface-2);border-color:var(--border)}.img-card-style-btn.active{color:var(--accent);background:var(--accent-dim);border-color:var(--accent)}.img-card-iterate-row{display:flex;gap:6px}.img-card-iterate-input{flex:1;background:var(--surface-3);border:1px solid var(--border);border-radius:8px;color:var(--text);font-size:12px;padding:7px 10px;outline:none;transition:border-color .15s}.img-card-iterate-input::placeholder{color:var(--text-tertiary)}.img-card-iterate-input:focus{border-color:var(--accent)}.img-card-iterate-btn{background:var(--accent);border:none;border-radius:8px;color:#fff;font-size:12px;font-weight:500;padding:7px 14px;cursor:pointer;transition:opacity .15s;flex-shrink:0}.img-card-iterate-btn:hover{opacity:.9}.image-lightbox-overlay{position:fixed;inset:0;background:#000000d9;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);display:flex;align-items:center;justify-content:center;z-index:1000;animation:fadeIn .2s ease}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.image-lightbox{position:relative;max-width:90vw;max-height:90vh;animation:scaleIn .2s ease}@keyframes scaleIn{0%{transform:scale(.95);opacity:0}to{transform:scale(1);opacity:1}}.image-lightbox img{max-width:90vw;max-height:80vh;border-radius:12px;display:block}.image-lightbox-actions{display:flex;gap:8px;justify-content:center;margin-top:16px}.image-lightbox-actions button{width:44px;height:44px;display:flex;align-items:center;justify-content:center;background:#ffffff1a;border:none;border-radius:50%;color:#fff;cursor:pointer;transition:background .15s ease}.image-lightbox-actions button:hover{background:#fff3}.image-lightbox-close{position:absolute;top:-48px;right:0;width:40px;height:40px;display:flex;align-items:center;justify-content:center;background:transparent;border:none;color:#fff;cursor:pointer;opacity:.7;transition:opacity .15s ease}.image-lightbox-close:hover{opacity:1}.chat-message-action{width:28px;height:28px;display:flex;align-items:center;justify-content:center;background:transparent;border:none;border-radius:6px;color:var(--text-tertiary);cursor:pointer;transition:all .15s}.chat-message-action:hover{background:var(--surface-3);color:var(--text-secondary)}.chat-message-action.copied{color:var(--accent)}.image-lightbox-actions button.copied{background:#10b98133;color:#10b981}.chat-input-area{position:relative;padding-top:0;padding-bottom:16px;flex-shrink:0}.chat-input-wrapper{display:flex;flex-direction:column}.chat-abort-confirm{display:flex;align-items:center;gap:8px;padding:8px 12px;margin-bottom:8px;background:var(--surface-2);border:1px solid var(--border);border-radius:10px;font-size:13px;color:var(--text-secondary);animation:chat-abort-in .15s ease-out}@keyframes chat-abort-in{0%{opacity:0;transform:translateY(4px)}to{opacity:1;transform:translateY(0)}}.chat-abort-confirm span{flex:1}.chat-abort-confirm button{padding:4px 12px;border:none;border-radius:6px;font-size:12px;font-weight:500;cursor:pointer;transition:background .12s;background:var(--error, #ef4444);color:#fff}.chat-abort-confirm button:hover{opacity:.9}.chat-abort-confirm .chat-abort-dismiss{background:transparent;color:var(--text-tertiary);border:1px solid var(--border)}.chat-abort-confirm .chat-abort-dismiss:hover{background:var(--bg-hover);color:var(--text-secondary)}.browser-status-bar{display:flex;align-items:center;gap:12px;margin-bottom:8px;background:var(--surface);border:1px solid var(--border);border-radius:12px;cursor:pointer;transition:background .15s;position:relative;padding:8px 12px 8px 116px}.browser-status-bar:hover{background:var(--surface-2)}.browser-status-preview{position:absolute;left:12px;top:50%;transform:translateY(-80%);width:96px;height:60px;border-radius:8px;overflow:hidden;background:#0d0d0f;border:1px solid var(--border);cursor:pointer;transition:box-shadow .15s,transform .15s,border-color .15s;z-index:2;display:flex;align-items:center;justify-content:center}.browser-status-preview:hover{box-shadow:0 4px 16px #0006;transform:translateY(-80%) scale(1.03);border-color:var(--accent)}.browser-status-preview svg{width:28px;height:28px;color:var(--text-tertiary)}.browser-status-preview img{width:100%;height:100%;object-fit:cover}.browser-code-preview{width:100%;height:100%;margin:0;padding:4px 6px;font-family:SF Mono,Monaco,monospace;font-size:6px;line-height:1.3;color:var(--text-secondary);overflow:hidden;white-space:pre;text-overflow:ellipsis}.browser-status-bar.coding{border-color:var(--accent);background:var(--accent-dim)}.browser-status-bar.coding .browser-status-dot{background:var(--accent)}.browser-status-info{display:flex;align-items:center;gap:8px;flex:1}.browser-status-dot{width:6px;height:6px;border-radius:50%;background:var(--text-tertiary)}.browser-status-dot.active{background:var(--accent);animation:pulse 1.5s infinite}.browser-status-text{font-size:13px;color:var(--text-secondary)}.browser-status-toggle{transition:transform .2s}.browser-status-toggle svg{width:16px;height:16px;color:var(--text-tertiary)}.browser-status-toggle.expanded{transform:rotate(180deg)}.browser-timeline-modal{width:94vw;height:92vh;max-width:1400px;background:#0d0d0f;border:1px solid var(--border);border-radius:16px;display:flex;flex-direction:column;overflow:hidden;animation:modalIn .2s ease-out}.btm-viewport{flex:1;position:relative;display:flex;align-items:center;justify-content:center;overflow:hidden;min-height:0}.btm-viewport-img{max-width:100%;max-height:100%;object-fit:contain;border-radius:4px}.btm-viewport-code{width:90%;max-height:90%;overflow:auto;background:#1a1a1e;border:1px solid var(--border);border-radius:12px}.btm-viewport-code-filename{padding:10px 16px;font-size:13px;font-weight:600;color:var(--text-secondary);border-bottom:1px solid var(--border);font-family:SF Mono,Monaco,monospace}.btm-viewport-code-content{margin:0;padding:16px;font-family:SF Mono,Monaco,monospace;font-size:13px;line-height:1.6;color:var(--text-primary);white-space:pre-wrap;word-break:break-word}.btm-viewport-empty{display:flex;flex-direction:column;align-items:center;gap:12px;color:var(--text-tertiary);font-size:14px}.btm-close{position:absolute;top:12px;right:12px;background:#0009;border:1px solid rgba(255,255,255,.1);color:var(--text-secondary);cursor:pointer;padding:6px;border-radius:8px;transition:background .12s,color .12s;z-index:2}.btm-close:hover{background:#000c;color:var(--text-primary)}.btm-status-badge{position:absolute;bottom:12px;left:12px;display:flex;align-items:center;gap:8px;background:#000000b3;border:1px solid rgba(255,255,255,.08);border-radius:8px;padding:6px 12px;font-size:13px;color:var(--text-secondary);z-index:2;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.btm-controls{display:flex;align-items:center;gap:12px;padding:12px 16px;border-top:1px solid var(--border);background:var(--surface);flex-shrink:0}.btm-controls-left{display:flex;align-items:center;gap:4px;flex-shrink:0}.btm-nav-btn{background:none;border:1px solid var(--border);color:var(--text-secondary);cursor:pointer;padding:6px;border-radius:6px;display:flex;align-items:center;justify-content:center;transition:background .12s,color .12s,border-color .12s}.btm-nav-btn:hover:not(:disabled){background:var(--bg-hover);color:var(--text-primary);border-color:var(--text-tertiary)}.btm-nav-btn:disabled{opacity:.3;cursor:default}.btm-scrubber-wrap{flex:1;position:relative;height:20px;cursor:pointer;display:flex;align-items:center}.btm-scrubber-track{width:100%;height:4px;background:var(--border);border-radius:2px;position:relative}.btm-scrubber-fill{height:100%;background:var(--accent);border-radius:2px;transition:width .15s ease-out}.btm-scrubber-thumb{position:absolute;top:50%;width:12px;height:12px;background:var(--accent);border:2px solid var(--surface);border-radius:50%;transform:translate(-50%,-50%);transition:left .15s ease-out;z-index:2}.btm-scrubber-wrap:hover .btm-scrubber-thumb{width:14px;height:14px}.btm-scrubber-ticks{position:absolute;inset:0;pointer-events:none}.btm-scrubber-tick{position:absolute;top:50%;width:3px;height:3px;border-radius:50%;background:var(--text-tertiary);transform:translate(-50%,-50%);opacity:.4}.btm-scrubber-tick.browser{background:var(--accent)}.btm-scrubber-tick.code{background:#f59e0b}.btm-scrubber-tick.activity{background:#10b981}.btm-scrubber-tick.selected{opacity:1;width:5px;height:5px}.btm-controls-right{display:flex;align-items:center;gap:10px;flex-shrink:0}.btm-step-counter{font-size:12px;font-family:SF Mono,Monaco,monospace;color:var(--text-tertiary);min-width:40px;text-align:center}.btm-live-btn{display:flex;align-items:center;gap:5px;background:none;border:1px solid var(--border);color:var(--text-tertiary);font-size:12px;padding:4px 10px;border-radius:12px;cursor:pointer;transition:background .12s,color .12s,border-color .12s}.btm-live-btn:hover{background:var(--bg-hover);color:var(--text-secondary)}.btm-live-btn.active{color:#10b981;border-color:#10b9814d}.btm-live-dot{width:6px;height:6px;border-radius:50%;background:var(--text-tertiary)}.btm-live-btn.active .btm-live-dot{background:#10b981;animation:pulse 1.5s infinite}.btm-tasks-badge{position:absolute;top:12px;left:12px;display:flex;align-items:center;gap:6px;background:#000000b3;border:1px solid rgba(255,255,255,.1);color:var(--text-secondary);font-size:12px;padding:5px 10px;border-radius:8px;cursor:pointer;z-index:3;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);transition:background .12s,border-color .12s}.btm-tasks-badge:hover{background:#000000d9;border-color:#ffffff26}.btm-tasks-badge.expanded svg{transform:rotate(180deg)}.btm-tasks-panel{position:absolute;top:44px;left:12px;background:#000000d9;border:1px solid rgba(255,255,255,.1);border-radius:10px;padding:6px;z-index:3;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);min-width:180px;max-width:320px;animation:btm-panel-in .12s ease-out}@keyframes btm-panel-in{0%{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:translateY(0)}}.btm-task-row{display:flex;align-items:center;gap:8px;padding:5px 8px;border-radius:6px}.btm-task-dot{width:5px;height:5px;border-radius:50%;flex-shrink:0}.btm-task-row.browser .btm-task-dot{background:var(--accent)}.btm-task-row.code .btm-task-dot{background:#f59e0b}.btm-task-row.activity .btm-task-dot{background:#10b981}.btm-task-label{font-size:12px;color:var(--text-secondary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.btm-viewport.split{flex-direction:row}.btm-split-screenshot{flex:1;display:flex;align-items:center;justify-content:center;min-width:0;overflow:hidden;padding:12px}.btm-split-screenshot img{max-width:100%;max-height:100%;object-fit:contain;border-radius:4px}.btm-split-divider{display:flex;align-items:center;justify-content:center;width:32px;flex-shrink:0;color:var(--text-tertiary)}.btm-split-text{flex:1;display:flex;flex-direction:column;min-width:0;overflow:hidden;border-left:1px solid var(--border)}.btm-split-text-header{display:flex;align-items:center;gap:8px;padding:10px 16px;border-bottom:1px solid var(--border);font-size:12px;font-weight:600;color:var(--text-secondary);flex-shrink:0}.btm-split-text-url{font-weight:400;color:var(--text-tertiary)}.btm-split-text-content{flex:1;margin:0;padding:16px;font-family:SF Mono,Monaco,monospace;font-size:12px;line-height:1.6;color:var(--text-primary);white-space:pre-wrap;word-break:break-word;overflow-y:auto}.chat-plus-menu-anchor{position:relative}.chat-plus-menu{position:absolute;bottom:calc(100% + 8px);left:0;background:var(--surface-2);border:1px solid var(--border);border-radius:12px;padding:6px;min-width:220px;z-index:100;box-shadow:0 8px 24px #0006;animation:chat-plus-menu-in .15s ease-out}@keyframes chat-plus-menu-in{0%{opacity:0;transform:translateY(4px)}to{opacity:1;transform:translateY(0)}}.chat-plus-menu-item{display:flex;align-items:center;gap:12px;width:100%;padding:10px 12px;background:none;border:none;font-size:14px;color:var(--text-primary);text-align:left;cursor:pointer;border-radius:8px;transition:background .12s}.chat-plus-menu-item:hover{background:var(--bg-hover)}.chat-plus-menu-item svg{color:var(--text-secondary);flex-shrink:0}.chat-plus-menu-item span{flex:1}.chat-plus-menu-chevron{margin-left:auto;color:var(--text-tertiary)!important}.chat-plus-menu-active-label{color:var(--accent)}.chat-plus-menu-check{color:var(--accent)!important;margin-left:auto}.chat-plus-menu-divider{height:1px;background:var(--border);margin:4px 8px}.chat-plus-menu-file-header{display:flex;align-items:center;gap:4px;padding:4px;border-bottom:1px solid var(--border);margin-bottom:4px}.chat-plus-menu-back{width:28px;height:28px;display:flex;align-items:center;justify-content:center;background:none;border:none;border-radius:6px;color:var(--text-secondary);cursor:pointer;flex-shrink:0;transition:background .12s}.chat-plus-menu-back:hover{background:var(--bg-hover)}.chat-plus-menu-file-search{flex:1;background:none;border:none;outline:none;color:var(--text-primary);font-size:14px;padding:6px 8px}.chat-plus-menu-file-search::placeholder{color:var(--text-tertiary)}.chat-plus-menu-file-list{max-height:240px;overflow-y:auto}.chat-plus-menu-file-item svg{color:var(--text-tertiary)}.chat-plus-menu-empty{padding:16px 12px;text-align:center;color:var(--text-tertiary);font-size:13px}.chat-toolbar-btn.active{background:var(--surface-2);color:var(--text-primary)}.chat-input-question{padding:12px 16px;display:flex;flex-direction:column;gap:10px}.chat-input-question-text{font-size:14px;font-weight:500;color:var(--text)}.chat-input-question-options{display:flex;flex-direction:column;gap:4px}.chat-input-question-option{display:flex;align-items:center;gap:10px;padding:10px 12px;background:var(--surface-1);border:1px solid var(--border);border-radius:10px;cursor:pointer;transition:background .15s,border-color .15s;text-align:left;color:var(--text);font-size:13px}.chat-input-question-option:hover{background:var(--surface-2);border-color:var(--text-tertiary)}.chat-input-question-option-label{flex:1;font-weight:500}.chat-input-question-option-desc{flex:1;font-size:12px;color:var(--text-secondary)}.chat-input-question-option-key{width:20px;height:20px;display:flex;align-items:center;justify-content:center;border-radius:4px;background:var(--surface-2);color:var(--text-tertiary);font-size:11px;font-weight:600;flex-shrink:0}.chat-input-question-custom{display:flex;align-items:center;gap:8px;padding:10px 12px;background:var(--surface-1);border:1px solid var(--border);border-radius:10px;transition:border-color .15s}.chat-input-question-custom:focus-within{border-color:var(--text-tertiary)}.chat-input-question-custom-input{flex:1;background:transparent;border:none;outline:none;color:var(--text);font-size:13px;font-family:inherit;resize:none;padding:0;line-height:1.4}.chat-input-question-custom-send{width:26px;height:26px;display:flex;align-items:center;justify-content:center;border-radius:6px;background:var(--accent);color:#fff;border:none;cursor:pointer;flex-shrink:0}.chat-input-question-custom-send:hover:not(.disabled){opacity:.9}.chat-input-question-custom-send.disabled{opacity:.3;cursor:default}.chat-loading-thread{flex:1;display:flex;align-items:center;justify-content:center;opacity:.6}.chat-empty-state{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;padding:40px 20px;margin-top:-100px}.chat-empty-state .chat-empty-icon{width:72px;height:72px;display:flex;align-items:center;justify-content:center;color:var(--text);margin-bottom:12px}.chat-empty-state .chat-empty-title{font-size:32px;font-weight:700;color:color-mix(in srgb,var(--text) 75%,transparent);margin:0;display:inline-flex;align-items:baseline;flex-wrap:wrap;gap:8px}.chat-empty-title-dropdown{position:relative;display:inline-flex}.chat-empty-title-project{display:inline-flex;align-items:center;gap:4px;background:none;border:none;font:inherit;color:var(--accent);cursor:pointer;padding:0;border-radius:4px;transition:opacity .15s}.chat-empty-title-project:hover{opacity:.8}.chat-empty-title-project svg{opacity:.6}.chat-empty-title-menu{position:absolute;top:100%;left:0;margin-top:8px;background:var(--surface-2);border:1px solid var(--border);border-radius:8px;padding:4px;min-width:180px;z-index:100;box-shadow:0 4px 12px #0000004d}.chat-empty-title-menu:has(.chat-empty-title-menu-item:only-child){padding:0;background:transparent;border:none;box-shadow:none}.chat-empty-title-menu-item:only-child{background:var(--surface-2);border:1px solid var(--border);border-radius:8px;box-shadow:0 4px 12px #0000004d}.chat-empty-title-menu-item{display:block;width:100%;padding:8px 12px;background:none;border:none;font-size:14px;color:var(--text-primary);text-align:left;cursor:pointer;border-radius:4px;transition:background .15s}.chat-empty-title-menu-item:hover{background:var(--bg-hover)}.chat-empty-title-menu-new{display:flex;align-items:center;gap:8px;color:var(--text-secondary)}.chat-empty-state .chat-empty-input{width:100%;max-width:780px;margin-top:16px}.chat-resume-group{display:inline-flex;align-items:center;gap:6px;margin-top:20px}.chat-resume-clock{display:flex;align-items:center;justify-content:center;width:34px;height:34px;border-radius:50%;border:1px solid var(--border);background:var(--surface);color:var(--text-secondary);cursor:pointer;transition:background .15s,border-color .15s,transform .1s;flex-shrink:0}.chat-resume-clock:hover{background:var(--hover);border-color:color-mix(in srgb,var(--accent) 40%,transparent)}.chat-resume-clock:active{transform:scale(.95)}.chat-resume-clock:disabled{opacity:.5;cursor:default}.chat-resume-pill{display:inline-flex;align-items:center;gap:6px;padding:10px 18px;border-radius:999px;border:1px solid var(--border);background:var(--surface);cursor:pointer;transition:background .15s,border-color .15s,transform .1s;max-width:780px;font-size:13px;line-height:1;color:var(--text-secondary)}.chat-resume-pill:hover{background:var(--hover);border-color:color-mix(in srgb,var(--accent) 40%,transparent)}.chat-resume-pill:active{transform:scale(.98)}.chat-resume-pill:disabled{opacity:.5;cursor:default}.chat-resume-quip{color:var(--text);font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:500px}.chat-resume-arrow{color:var(--text-secondary);font-size:14px;transition:transform .15s}.chat-resume-pill:hover .chat-resume-arrow{transform:translate(2px)}.spinner.small{width:14px;height:14px;border-width:2px}.chat-tool-activity{display:flex;flex-wrap:wrap;gap:4px;margin-top:8px;padding-top:8px;border-top:1px solid var(--border-subtle, rgba(255, 255, 255, .06))}.chat-tool-activity-item{display:inline-flex;align-items:center}.tool-badge{display:inline-flex;align-items:center;gap:4px;padding:2px 8px;border-radius:4px;font-size:11px;font-weight:500;background:var(--bg-tertiary, rgba(255, 255, 255, .04));color:var(--text-secondary, rgba(255, 255, 255, .5));white-space:nowrap}.tool-badge-done{background:#22c55e14;color:#22c55eb3}.tool-badge-agent{background:#a855f714;color:#a855f7b3}.thinking-pill-wrapper{margin-top:8px;font-size:12px}.ico-loader.expandable{cursor:pointer}.thinking-pill-chevron{display:flex;align-items:center;color:var(--text-tertiary);transition:transform .2s;margin-left:2px}.thinking-pill-chevron.open{transform:rotate(180deg)}.thinking-pill-expanded{margin-top:8px;display:flex;flex-direction:column;gap:8px}.thinking-pill-text{font-size:13px;color:var(--text-tertiary);line-height:1.5;padding:0 4px;white-space:pre-wrap}.tool-activity-list{padding:4px 0 0 4px;display:flex;flex-direction:column;gap:2px}.tool-node{border-left:1px solid var(--border-subtle, rgba(255, 255, 255, .06));margin-left:8px}.tool-node-header{display:flex;align-items:center;gap:5px;padding:3px 8px;border-radius:4px;color:var(--text-secondary);font-size:12px}.tool-node-header.expandable{cursor:pointer}.tool-node-header.expandable:hover{background:var(--hover, rgba(255, 255, 255, .04))}.tool-node-header.running .tool-node-name{color:var(--accent)}.tool-node-header.agent .tool-node-name{color:#a855f7cc;font-weight:500}.tool-node-header.done .tool-node-name{color:var(--text-tertiary)}.tool-node-chevron{display:flex;align-items:center;flex-shrink:0;color:var(--text-tertiary)}.tool-node-name{font-family:var(--font-mono);font-size:11px}.tool-node-detail{font-family:var(--font-mono);font-size:10px;color:var(--text-secondary);opacity:.7;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.tool-node-progress{font-family:var(--font-mono);font-size:10px;color:var(--accent);opacity:.8;flex-shrink:0}.tool-node-status{width:6px;height:6px;border-radius:50%;background:var(--accent);animation:tool-pulse 1.2s ease-in-out infinite;flex-shrink:0}@keyframes tool-pulse{0%,to{opacity:.4}50%{opacity:1}}.tool-node-body{padding:2px 0 4px 20px;display:flex;flex-direction:column;gap:4px}.tool-node-children{display:flex;flex-direction:column;gap:2px}.tool-detail{border-radius:6px;overflow:hidden}.tool-detail-label{display:flex;align-items:center;justify-content:space-between;font-size:10px;font-weight:600;text-transform:uppercase;letter-spacing:.5px;color:var(--text-tertiary);padding:4px 8px;background:var(--surface-2, rgba(255, 255, 255, .03));cursor:default}.tool-detail-toggle{font-size:10px;font-weight:400;text-transform:none;letter-spacing:0;color:var(--accent);cursor:pointer}.tool-detail-content{margin:0;padding:6px 8px;font-family:var(--font-mono);font-size:11px;line-height:1.5;color:var(--text-secondary);background:var(--surface, rgba(0, 0, 0, .2));white-space:pre-wrap;word-break:break-word;max-height:200px;overflow-y:auto}.diff-view{border-radius:6px;overflow:hidden}.diff-header{font-family:var(--font-mono);font-size:11px;font-weight:600;color:var(--text-secondary);padding:4px 8px;background:var(--surface-2, rgba(255, 255, 255, .03))}.diff-header-tag{font-weight:400;color:var(--accent);margin-left:6px;font-size:10px}.diff-content{max-height:300px;overflow-y:auto;background:var(--surface, rgba(0, 0, 0, .2))}.diff-line{display:flex;font-family:var(--font-mono);font-size:11px;line-height:1.6;padding:0 8px;white-space:pre-wrap;word-break:break-all}.diff-line.diff-added{background:#3b82f61f;color:#ffffffe6}.diff-line.diff-removed{background:#ef44441f;color:#ffffffe6}.diff-line.diff-truncated{color:var(--text-tertiary);font-style:italic;padding:4px 8px}.diff-gutter{flex-shrink:0;width:16px;text-align:center;-webkit-user-select:none;user-select:none;opacity:.5}.diff-line.diff-added .diff-gutter{color:#3b82f6cc}.diff-line.diff-removed .diff-gutter{color:#ef4444cc}.tool-view-toggle{display:flex;gap:2px;padding:2px;background:var(--surface-2, rgba(255, 255, 255, .03));border-radius:6px;width:fit-content}.tool-view-toggle button{background:none;border:none;color:var(--text-tertiary);font-size:10px;font-weight:500;padding:2px 8px;border-radius:4px;cursor:pointer;transition:all .15s}.tool-view-toggle button.active{background:var(--surface, rgba(255, 255, 255, .08));color:var(--text-primary)}.tool-view-toggle button:hover:not(.active){color:var(--text-secondary)}.todo-list-view{display:flex;flex-direction:column;gap:2px;padding:4px 0}.todo-list-title{font-family:var(--font-mono);font-size:11px;font-weight:600;color:var(--text-primary);margin-bottom:4px}.todo-list-item{display:flex;align-items:baseline;gap:6px;padding:3px 6px;border-radius:3px;font-family:var(--font-mono);font-size:11px;line-height:1.5;background:var(--bg-secondary)}.todo-list-id{color:var(--text-tertiary);flex-shrink:0;min-width:18px}.todo-list-action{font-size:10px;font-weight:600;text-transform:uppercase;letter-spacing:.5px;padding:1px 4px;border-radius:2px;flex-shrink:0}.todo-list-action-write{color:#4ade80;background:#4ade801a}.todo-list-action-edit{color:#60a5fa;background:#60a5fa1a}.todo-list-action-delete{color:#f87171;background:#f871711a}.todo-list-action-check,.todo-list-action-other{color:#a78bfa;background:#a78bfa1a}.todo-list-file{color:var(--text-secondary);opacity:.7;flex-shrink:0}.todo-list-desc{color:var(--text-primary);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.backlog-result-view{padding:4px 0}.backlog-result-header{display:flex;align-items:center;gap:8px;margin-bottom:4px;font-family:var(--font-mono);font-size:11px}.backlog-result-label{color:var(--text-secondary)}.backlog-result-count{color:var(--accent);font-weight:600}.chat-build-progress{padding:8px 12px;margin:4px 0}.chat-deploy-result{display:flex;align-items:center;gap:8px;padding:8px 12px;margin:4px 0;border-radius:6px;font-size:13px}.chat-deploy-result.success{background:#22c55e1a;color:#22c55e}.chat-deploy-result.error{background:#ef44441a;color:#ef4444}.chat-deploy-result a{color:inherit;text-decoration:underline}.chat-deploy-result button,.chat-error button{margin-left:auto;background:none;border:none;color:inherit;cursor:pointer;opacity:.7;font-size:12px}.chat-error{display:flex;align-items:center;gap:8px;padding:8px 12px;margin:4px 0;border-radius:6px;font-size:13px;background:#ef44441a;color:#ef4444}.chat-loader-idle-edge,.chat-loader-spark{fill:none;stroke:currentColor;stroke-width:3.5;stroke-linecap:round;stroke-linejoin:round}.chat-loader-idle-edge{opacity:.15}.chat-loader-spark{opacity:0}.chat-loader-tri-face{fill:currentColor;opacity:0}.chat-loader-tri-edge{fill:none;stroke:currentColor;stroke-width:3.5;stroke-linecap:round;stroke-linejoin:round;opacity:.15}.chat-loader-x-edge{fill:none;stroke:currentColor;stroke-width:1.8;stroke-linecap:round;stroke-linejoin:round;opacity:0}.chat-loader-wireframe{fill:none;stroke:currentColor;stroke-width:2;stroke-linecap:round;stroke-linejoin:round;opacity:.08}.chat-loader-blueprint{fill:none;stroke:currentColor;stroke-width:3.5;stroke-linecap:round;stroke-linejoin:round;opacity:0}.chat-loader-alt-r1,.chat-loader-alt-r2,.chat-loader-alt-r3{fill:none;stroke:currentColor;stroke-width:3.5;stroke-linecap:round;stroke-linejoin:round;opacity:.15}.chat-loader-xc-edge{fill:none;stroke:currentColor;stroke-width:1.8;stroke-linecap:round;stroke-linejoin:round;opacity:1}.ico-loader{display:inline-flex;align-items:center;align-self:flex-start;gap:14px;padding:10px 22px 10px 14px;background:#ffffff0f;border:1px solid rgba(255,255,255,.08);border-radius:9999px;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px)}.ico-loader__icon{width:28px;height:28px;flex-shrink:0}.ico-loader__text{font-size:15px;font-weight:600;letter-spacing:.3px;background:linear-gradient(110deg,#ffffff59 30%,#fffc,#ffffff59 70%);background-size:200% 100%;-webkit-background-clip:text;background-clip:text;color:transparent;animation:ico-text-shimmer 2s linear infinite;white-space:nowrap;max-width:220px;overflow:hidden;text-overflow:ellipsis}.ico-loader__timer{font-size:12px;font-weight:500;opacity:.5;margin-left:6px;font-variant-numeric:tabular-nums;background:none;-webkit-background-clip:unset;background-clip:unset;color:#ffffff80;animation:none}@keyframes ico-text-shimmer{0%{background-position:200% center}to{background-position:-200% center}}.anim-showcase{max-width:900px;margin:0 auto;padding:60px 32px;color:var(--text-primary)}.anim-showcase-back{display:inline-flex;align-items:center;gap:6px;color:var(--text-secondary);text-decoration:none;font-size:14px;margin-bottom:24px}.anim-showcase-back:hover{color:var(--text-primary)}.anim-showcase-title{font-size:28px;font-weight:700;margin-bottom:40px}.anim-showcase-subtitle{font-size:20px;font-weight:600;margin:40px 0 20px}.anim-showcase-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:20px}.anim-showcase-card{background:#ffffff0a;border:1px solid rgba(255,255,255,.08);border-radius:14px;padding:24px}.anim-showcase-card h2{font-size:16px;font-weight:600;margin-bottom:4px}.anim-showcase-card p{font-size:13px;color:var(--text-secondary);margin-bottom:20px}.anim-showcase-preview{display:flex;align-items:center;justify-content:center;height:120px;color:var(--text-primary)}.anim-showcase-preview svg{width:64px;height:64px}.credit-limit-card{display:flex;align-items:center;gap:16px;padding:16px 20px;background:#ffffff0a;border:1px solid rgba(255,255,255,.08);border-radius:12px;margin:4px 0}.credit-limit-card-icon{flex-shrink:0;width:32px;height:32px;color:var(--text-secondary)}.credit-limit-card-body{display:flex;flex-direction:column;gap:2px;flex:1;min-width:0}.credit-limit-card-title{font-size:14px;font-weight:600;color:var(--text-primary)}.credit-limit-card-desc{font-size:13px;color:var(--text-secondary)}.credit-limit-card-btn{flex-shrink:0;padding:8px 20px;background:linear-gradient(135deg,#c8c8d233,#ffffff1a);border:1px solid rgba(255,255,255,.15);border-radius:8px;color:var(--text-primary);font-size:13px;font-weight:600;cursor:pointer;transition:all .15s}.credit-limit-card-btn:hover{background:linear-gradient(135deg,#c8c8d24d,#ffffff2e);border-color:#ffffff38}.chat-artifacts{display:flex;flex-wrap:wrap;gap:10px;margin-top:12px;width:100%}.chat-artifact-card{display:flex;align-items:center;gap:12px;padding:12px 16px;background:var(--surface);border:1px solid var(--border);border-radius:12px;cursor:pointer;transition:all .15s;text-align:left;min-width:180px}.chat-artifact-card:hover{background:var(--surface-2);border-color:var(--accent);transform:translateY(-1px)}.chat-artifact-icon{width:40px;height:40px;background:var(--accent-dim);border-radius:10px;display:flex;align-items:center;justify-content:center;color:var(--accent);flex-shrink:0}.chat-artifact-info{display:flex;flex-direction:column;gap:2px;overflow:hidden}.chat-artifact-title{font-size:14px;font-weight:500;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.chat-artifact-type{font-size:12px;color:var(--text-tertiary)}.chat-message-artifacts{display:flex;flex-direction:column;gap:8px;width:100%}.artifact-card{display:flex;flex-direction:column;background:var(--surface-2);border:1px solid var(--accent);border-radius:8px;transition:all .15s;width:100%;overflow:hidden}.artifact-card.working{border-color:var(--accent)}.artifact-card.deployment{border-color:#10b981}.artifact-card.deployment .artifact-card-icon{background:#10b981;color:#fff}.artifact-card-header{display:flex;align-items:center;gap:12px;padding:12px 16px;cursor:pointer}.artifact-card-icon{width:44px;height:44px;background:var(--accent);border-radius:8px;display:flex;align-items:center;justify-content:center;color:#fff;flex-shrink:0}.artifact-card-info{flex:1;min-width:0;display:flex;flex-direction:column;gap:2px}.artifact-card-name{font-size:14px;font-weight:500;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.artifact-card-type{display:flex;align-items:center;gap:8px;font-size:12px;color:var(--text-secondary)}.artifact-stat-add{color:var(--green);font-family:var(--font-mono)}.artifact-stat-remove{color:var(--red);font-family:var(--font-mono)}.artifact-card-actions{display:flex;align-items:center;gap:8px;flex-shrink:0}.artifact-open-btn{display:flex;align-items:center;justify-content:center;gap:4px;padding:8px 16px;background:var(--accent);border:none;border-radius:6px;color:#fff;font-size:14px;font-weight:500;cursor:pointer;transition:background .15s}.artifact-open-btn:hover{background:var(--accent-hover)}.artifact-card-folder{position:relative;flex-shrink:0}.artifact-folder-btn{display:flex;align-items:center;gap:6px;padding:8px 12px;background:transparent;border:1px solid var(--border);border-radius:6px;color:var(--text-secondary);font-size:13px;cursor:pointer;transition:all .15s}.artifact-folder-btn:hover{background:var(--surface-3);border-color:var(--text-tertiary);color:var(--text)}.artifact-folder-picker{position:absolute;top:100%;right:0;margin-top:4px;min-width:200px;background:var(--surface);border:1px solid var(--border);border-radius:8px;padding:6px;z-index:100;box-shadow:0 4px 12px #0000004d}.artifact-folder-item{display:flex;align-items:center;gap:8px;width:100%;padding:8px 10px;background:transparent;border:none;border-radius:6px;color:var(--text-secondary);font-size:13px;cursor:pointer;transition:all .15s;text-align:left}.artifact-folder-item:hover{background:var(--surface-2);color:var(--text)}.artifact-folder-item.active{background:var(--accent-dim);color:var(--accent)}.artifact-steps{padding:12px 16px;display:flex;flex-direction:column;gap:6px;border-top:1px solid var(--border-subtle);margin-top:4px}.artifact-step{display:flex;align-items:center;gap:8px;font-size:12px;color:var(--text-secondary)}.artifact-step.completed{color:var(--text-tertiary)}.artifact-step.completed .artifact-step-icon{color:var(--green)}.artifact-step.in_progress .artifact-step-icon{color:var(--accent)}.artifact-step-icon{width:14px;height:14px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.artifact-step-spinner{width:10px;height:10px;border:2px solid var(--accent);border-top-color:transparent;border-radius:50%;animation:spin .8s linear infinite}.artifact-step-pending{width:6px;height:6px;background:var(--text-tertiary);border-radius:50%}.artifact-step-text{flex:1}@keyframes spin{to{transform:rotate(360deg)}}.artifact-status{display:flex;align-items:center;gap:6px;padding:6px 12px;font-size:12px;color:var(--text-secondary);background:var(--surface-3);border-radius:6px}.artifact-status.editing{color:var(--accent)}.artifact-status-spinner{width:12px;height:12px;border:2px solid var(--accent);border-top-color:transparent;border-radius:50%;animation:spin 1s linear infinite}.artifact-card.software.working{animation:working-pulse 2s ease-in-out infinite}@keyframes working-pulse{0%,to{border-color:var(--accent)}50%{border-color:var(--accent-hover);box-shadow:0 0 12px color-mix(in srgb,var(--accent) 20%,transparent)}}.artifact-expand-btn{display:flex;align-items:center;justify-content:center;width:28px;height:28px;background:transparent;border:none;border-radius:6px;color:var(--text-tertiary);cursor:pointer;transition:all .15s}.artifact-expand-btn:hover{background:var(--surface-3);color:var(--text)}.artifact-card.expanded .artifact-expand-btn{transform:rotate(180deg)}.artifact-card-content{border-top:1px solid var(--border-subtle)}.artifact-file-changes{display:flex;flex-direction:column;padding:8px 16px 12px}.artifact-file-change{display:flex;align-items:center;gap:8px;padding:6px 8px;margin:0 -8px;font-size:13px;color:var(--text-secondary);border:none;border-bottom:1px solid var(--border-subtle);border-radius:4px;background:transparent;cursor:pointer;transition:background .15s;text-align:left;width:calc(100% + 16px)}.artifact-file-change:hover{background:var(--surface-3)}.artifact-file-change:last-child{border-bottom:none}.artifact-file-change>svg{color:var(--green);flex-shrink:0}.artifact-file-action{color:var(--text-tertiary)}.artifact-file-name{flex:1;color:var(--text);font-family:var(--font-mono);font-size:12px}.artifact-file-stats{display:flex;gap:6px;font-size:12px;font-family:var(--font-mono)}.artifact-dep-change{cursor:default}.artifact-dep-change:hover{background:transparent}.artifact-dep-change .artifact-file-action{color:var(--accent)}.chat-read-operations{display:flex;flex-direction:column;gap:8px}.read-operation-card{background:var(--surface-2);border:1px solid var(--border-subtle);border-radius:8px;overflow:hidden}.read-operation-header{display:flex;align-items:center;gap:8px;padding:8px 12px;cursor:pointer;transition:background .15s}.read-operation-header:hover{background:var(--surface-3)}.read-operation-header svg{color:var(--text-tertiary);flex-shrink:0}.read-operation-label{color:var(--text-tertiary);font-size:12px}.read-operation-target{flex:1;color:var(--text);font-family:var(--font-mono);font-size:12px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.read-operation-lines{color:var(--text-tertiary);font-size:11px;font-family:var(--font-mono)}.read-operation-expand{color:var(--text-tertiary);transition:transform .2s}.read-operation-expand.expanded{transform:rotate(180deg)}.read-operation-content{border-top:1px solid var(--border-subtle);max-height:400px;overflow:auto}.read-operation-content pre{margin:0;padding:12px;font-size:12px;font-family:var(--font-mono);color:var(--text-secondary);white-space:pre-wrap;word-break:break-word;line-height:1.5}.thinking-card{background:var(--surface-2);border:1px solid var(--border-subtle);border-radius:8px;overflow:hidden;margin-bottom:8px}.thinking-card-header{display:flex;align-items:center;gap:8px;padding:8px 12px;cursor:pointer;transition:background .15s}.thinking-card-header:hover{background:var(--surface-3)}.thinking-card-header svg{color:var(--accent);flex-shrink:0}.thinking-card-label{color:var(--text-secondary);font-size:12px;flex:1}.thinking-card-expand{color:var(--text-tertiary);transition:transform .2s}.thinking-card-expand.expanded{transform:rotate(180deg)}.thinking-card-content{border-top:1px solid var(--border-subtle);max-height:400px;overflow:auto}.thinking-card-text{margin:0;padding:12px;font-size:13px;color:var(--text-secondary);white-space:pre-wrap;word-break:break-word;line-height:1.6}.chat-traces{display:flex;flex-direction:column;gap:8px;margin-bottom:12px}.trace-card{background:var(--surface-2);border:1px solid var(--border-subtle);border-radius:8px;overflow:hidden}.trace-card-header{display:flex;align-items:center;gap:8px;padding:10px 12px;cursor:pointer;-webkit-user-select:none;user-select:none}.trace-card-header:hover{background:var(--surface-3)}.trace-card-header svg{color:var(--text-secondary);flex-shrink:0}.trace-card-label{font-size:12px;font-weight:500;color:var(--text-secondary);flex:1}.trace-card-expand{transition:transform .2s ease;color:var(--text-tertiary)}.trace-card-expand.expanded{transform:rotate(180deg)}.trace-card-content{padding:12px;border-top:1px solid var(--border-subtle);display:flex;flex-direction:column;gap:10px}.trace-item{display:flex;flex-direction:column;gap:4px}.trace-item-label{font-size:11px;font-weight:600;color:var(--text-tertiary);text-transform:uppercase;letter-spacing:.5px}.trace-item span:last-child{font-size:13px;color:var(--text-primary);line-height:1.5}.chat-derivations{display:flex;flex-direction:column;gap:8px;margin-bottom:12px}.derivation-card{background:var(--surface-2);border:1px solid var(--border-subtle);border-radius:8px;overflow:hidden}.derivation-card-header{display:flex;align-items:center;gap:8px;padding:8px 12px;cursor:pointer;transition:background .15s}.derivation-card-header:hover{background:var(--surface-3)}.derivation-card-header svg{color:var(--accent);flex-shrink:0}.derivation-card-label{color:var(--text-secondary);font-size:12px;font-weight:500;flex:1}.derivation-card-expand{color:var(--text-tertiary);transition:transform .2s}.derivation-card-expand.expanded{transform:rotate(180deg)}.derivation-card-content{border-top:1px solid var(--border-subtle);padding:12px;font-size:13px;color:var(--text-primary);line-height:1.6}.derivation-trace{background:linear-gradient(135deg,#22c55e14,#22c55e0a);border:1px solid rgba(34,197,94,.2);border-radius:6px;padding:12px;margin-bottom:12px}.derivation-trace-content{margin-top:8px;display:flex;flex-direction:column;gap:8px}.derivation-trace-item{display:flex;flex-direction:column;gap:2px}.derivation-trace-label{font-size:11px;font-weight:500;color:#22c55e}.derivation-trace-item span:last-child{color:var(--text-primary);font-size:13px;line-height:1.5}.derivation-system{margin-bottom:12px;color:var(--text-secondary)}.derivation-section{margin-bottom:12px}.derivation-section strong{color:var(--text-secondary);font-size:11px;text-transform:uppercase;letter-spacing:.5px;display:block;margin-bottom:6px}.derivation-constraints{margin:0;padding-left:20px}.derivation-constraints li{margin-bottom:8px}.derivation-fact{color:var(--text-primary)}.derivation-why{font-size:12px;color:var(--text-tertiary);font-style:italic;margin-top:2px}.derivation-variables{display:flex;flex-wrap:wrap;gap:8px}.derivation-var{display:flex;align-items:center;gap:6px;padding:4px 8px;background:var(--surface-3);border-radius:4px;font-size:12px}.derivation-var-symbol{font-family:KaTeX_Math,serif;color:var(--accent)}.derivation-var-meaning{color:var(--text-secondary)}.derivation-var-role{font-size:10px;padding:2px 4px;border-radius:3px;text-transform:uppercase}.derivation-var-role.varies{background:#3b82f626;color:#3b82f6}.derivation-var-role.fixed{background:#9ca3af26;color:var(--text-tertiary)}.derivation-steps{margin:0;padding-left:20px}.derivation-steps li{margin-bottom:12px}.derivation-step-rel{color:var(--text-secondary);margin-bottom:4px}.derivation-step-form{margin:8px 0;padding:8px 12px;background:var(--surface-3);border-radius:4px}.derivation-step-from{font-size:11px;color:var(--text-tertiary)}.derivation-final{padding-top:12px;border-top:1px solid var(--border-subtle)}.derivation-final strong{color:var(--text-secondary);font-size:11px;text-transform:uppercase;letter-spacing:.5px;display:block;margin-bottom:8px}.derivation-final-eq{padding:12px 16px;background:linear-gradient(135deg,#3b82f614,#3b82f60a);border:1px solid rgba(59,130,246,.2);border-radius:6px}.derivation-validity{background:linear-gradient(135deg,#f59e0b14,#f59e0b0a);border:1px solid rgba(245,158,11,.2);border-radius:6px;padding:12px}.derivation-validity-list{display:flex;flex-direction:column;gap:10px;margin-top:8px}.derivation-validity-item{padding:8px 12px;background:var(--surface-2);border-radius:4px}.derivation-validity-assumption{color:var(--text-primary);font-weight:500;margin-bottom:4px}.derivation-validity-regime{font-size:12px;color:#f59e0b;margin-bottom:2px}.derivation-validity-verified{font-size:12px;color:#22c55e}.derivation-boundary{border-left:2px solid var(--accent);padding-left:10px}.derivation-boundary-content{display:flex;flex-direction:column;gap:6px;margin-top:6px}.derivation-boundary-item{display:flex;gap:6px;font-size:13px;line-height:1.4}.derivation-boundary-label{color:#94a3b8;flex-shrink:0;font-weight:500}.derivation-boundary-verdict{font-weight:600}.derivation-boundary-verdict.yes{color:#f59e0b}.derivation-boundary-verdict.no{color:#22c55e}.derivation-boundary-type{font-weight:500}.derivation-boundary-type.closed_conservation{color:#22c55e}.derivation-boundary-type.algebraic_flux{color:#3b82f6}.derivation-boundary-type.differential{color:#f59e0b}.derivation-boundary-type.discovery{color:#ef4444}.derivation-boundary-ode{font-family:Berkeley Mono,monospace;color:#e2e8f0;background:#6366f11a;padding:2px 6px;border-radius:3px}.chat-case-results{display:flex;flex-direction:column;gap:8px;margin-bottom:12px}.case-result-card{padding:12px 16px;background:linear-gradient(135deg,var(--accent-dim) 0%,var(--accent-dim) 100%);border:1px solid color-mix(in srgb,var(--accent) 20%,transparent);border-radius:8px}.case-result-name{font-size:12px;font-weight:500;color:var(--accent);margin-bottom:8px}.case-result-bindings{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:8px}.case-result-binding{font-size:12px;padding:4px 8px;background:var(--surface-2);border-radius:4px;color:var(--text-secondary);font-family:KaTeX_Math,serif}.case-result-equation{padding:8px 12px;background:var(--surface-2);border-radius:4px}.chat-derive-attempts{display:flex;flex-direction:column;gap:8px;margin-bottom:12px}.derive-attempt-card{background:var(--surface-2);border:1px solid rgba(239,68,68,.2);border-radius:8px;overflow:hidden}.derive-attempt-header{display:flex;align-items:center;gap:8px;padding:8px 12px;cursor:pointer;transition:background .15s}.derive-attempt-header:hover{background:var(--surface-3)}.derive-attempt-header svg{color:#ef4444;flex-shrink:0}.derive-attempt-label{color:var(--text-tertiary);font-size:12px;flex:1}.derive-attempt-error{padding:6px 12px 8px;font-size:11px;color:#ef4444;font-family:SF Mono,Monaco,monospace}.derive-attempt-expand{color:var(--text-tertiary);transition:transform .2s}.derive-attempt-expand.expanded{transform:rotate(180deg)}.derive-attempt-content{border-top:1px solid var(--border-subtle);max-height:300px;overflow:auto}.derive-attempt-json{margin:0;padding:12px;font-size:11px;color:var(--text-secondary);white-space:pre-wrap;word-break:break-word;line-height:1.5;font-family:SF Mono,Monaco,monospace}.plan-card{background:var(--surface-2);border:1px solid rgba(59,130,246,.2);border-radius:8px;overflow:hidden}.plan-card-header{display:flex;align-items:center;gap:8px;padding:8px 12px;cursor:pointer;-webkit-user-select:none;user-select:none}.plan-card-header:hover{background:var(--surface-3)}.plan-card-header svg{color:#3b82f6;flex-shrink:0}.plan-card-label{color:var(--text-secondary);font-size:12px;font-weight:500}.plan-card-meta{color:var(--text-tertiary);font-size:11px;margin-left:auto}.plan-card-expand{color:var(--text-tertiary);transition:transform .2s}.plan-card-expand.expanded{transform:rotate(180deg)}.plan-card-summary{padding:0 12px 8px;display:flex;flex-direction:column;gap:4px}.plan-step-brief{display:flex;align-items:center;gap:8px;font-size:11px}.plan-step-id{color:#3b82f6;font-family:SF Mono,Monaco,monospace;font-size:10px;font-weight:500}.plan-step-op{color:var(--text-secondary);flex:1}.plan-step-method{color:var(--text-tertiary);font-size:10px}.plan-card-content{border-top:1px solid var(--border-subtle)}.plan-section{padding:8px 12px}.plan-section+.plan-section{border-top:1px solid var(--border-subtle)}.plan-section-title{font-size:11px;font-weight:600;color:var(--text-tertiary);text-transform:uppercase;letter-spacing:.5px;margin-bottom:6px}.plan-step-detail{margin-bottom:8px}.plan-step-header{display:flex;align-items:center;gap:8px;margin-bottom:4px}.plan-precision-badge{font-size:9px;padding:1px 6px;border-radius:4px;font-family:SF Mono,Monaco,monospace}.plan-precision-badge.exact{background:#22c55e26;color:#22c55e}.plan-precision-badge.symbolic{background:#a855f726;color:#a855f7}.plan-precision-badge.floating_point{background:#eab30826;color:#eab308}.plan-step-body{font-size:11px;color:var(--text-secondary);padding-left:16px}.plan-step-body div{margin-bottom:2px}.plan-error-mode{margin-bottom:6px;display:flex;flex-wrap:wrap;gap:6px;align-items:flex-start}.plan-error-type{font-size:9px;padding:1px 6px;border-radius:4px;font-family:SF Mono,Monaco,monospace;background:#ef44441a;color:#ef4444}.plan-error-step{font-size:10px;color:var(--text-tertiary)}.plan-error-body{width:100%;font-size:11px;color:var(--text-secondary);padding-left:16px}.plan-error-body div{margin-bottom:2px}.plan-constraint{margin-bottom:6px;display:flex;flex-wrap:wrap;gap:6px;align-items:flex-start}.plan-constraint-layer{font-size:9px;padding:1px 6px;border-radius:4px;font-family:SF Mono,Monaco,monospace;background:#3b82f626;color:#3b82f6;font-weight:600}.plan-constraint-law{font-size:11px;color:var(--text-secondary);font-weight:500}.plan-constraint-body{width:100%;font-size:11px;color:var(--text-secondary);padding-left:16px}.plan-constraint-body div{margin-bottom:2px}.verification-card{background:var(--surface-2);border-radius:8px;overflow:hidden}.verification-card.pass{border:1px solid rgba(34,197,94,.2)}.verification-card.fail{border:1px solid rgba(239,68,68,.2)}.verification-card-header{display:flex;align-items:center;gap:8px;padding:8px 12px;cursor:pointer;-webkit-user-select:none;user-select:none}.verification-card-header:hover{background:var(--surface-3)}.verification-card.pass .verification-card-header svg{color:#22c55e}.verification-card.fail .verification-card-header svg{color:#ef4444}.verification-card-label{color:var(--text-secondary);font-size:12px;font-weight:500}.verification-card-meta{color:var(--text-tertiary);font-size:11px;margin-left:auto}.verification-card-expand{color:var(--text-tertiary);transition:transform .2s}.verification-card-expand.expanded{transform:rotate(180deg)}.verification-card-summary{padding:0 12px 8px;display:flex;flex-wrap:wrap;gap:8px}.verification-result-brief{display:flex;gap:4px;font-size:11px}.verification-result-name{color:var(--text-tertiary)}.verification-result-value{color:var(--text-secondary);font-family:SF Mono,Monaco,monospace}.verification-card-content{border-top:1px solid var(--border-subtle)}.verification-section{padding:8px 12px}.verification-section+.verification-section{border-top:1px solid var(--border-subtle)}.verification-section-title{font-size:11px;font-weight:600;color:var(--text-tertiary);text-transform:uppercase;letter-spacing:.5px;margin-bottom:6px;display:flex;align-items:center;gap:8px}.verification-layer-badge{font-size:10px;font-weight:400}.verification-layer-badge.pass{color:#22c55e}.verification-layer-badge.fail{color:#ef4444}.verification-result-detail{display:flex;justify-content:space-between;font-size:11px;margin-bottom:4px}.verification-result-name{color:var(--text-secondary);font-family:SF Mono,Monaco,monospace}.verification-result-source{color:var(--text-tertiary);font-size:10px}.verification-check{display:flex;gap:8px;margin-bottom:6px;align-items:flex-start}.verification-verdict{font-size:12px;flex-shrink:0;width:16px;text-align:center}.verification-verdict.pass{color:#22c55e}.verification-verdict.fail{color:#ef4444}.verification-check-body{font-size:11px;color:var(--text-secondary)}.verification-check-body div{margin-bottom:1px}.verification-check-type{font-weight:500;color:var(--text-primary)}.verification-check-detail{color:var(--text-tertiary);font-style:italic;margin-top:2px}.orbit-review-card{background:var(--surface-2);border-radius:8px;overflow:hidden}.orbit-review-card.orbit-fail{border:1px solid rgba(239,68,68,.2)}.orbit-review-card.orbit-pass{border:1px solid rgba(234,179,8,.15)}.orbit-review-header{display:flex;align-items:center;gap:8px;padding:8px 12px;cursor:pointer;-webkit-user-select:none;user-select:none}.orbit-review-header:hover{background:var(--surface-3)}.orbit-review-header svg{color:var(--accent);flex-shrink:0}.orbit-review-label{color:var(--text-secondary);font-size:12px;font-weight:500}.orbit-verdict{font-size:11px;font-weight:500;margin-left:auto}.orbit-verdict-fail{color:#ef4444}.orbit-verdict-pass{color:#eab308}.orbit-review-expand{color:var(--text-tertiary);transition:transform .2s}.orbit-review-expand.expanded{transform:rotate(180deg)}.orbit-review-violations{padding:0 12px 8px;display:flex;flex-direction:column;gap:6px}.orbit-violation{padding:6px 8px;border-radius:6px;font-size:12px}.orbit-violation-critical{background:#ef44440f}.orbit-violation-warning{background:#eab3080f}.orbit-violation-header{display:flex;align-items:center;gap:6px;margin-bottom:3px}.orbit-severity-badge{font-size:10px;font-weight:600;text-transform:uppercase;letter-spacing:.5px;padding:1px 5px;border-radius:3px}.orbit-badge-critical{background:#ef444426;color:#ef4444}.orbit-badge-warning{background:#eab30826;color:#ca8a04}.orbit-violation-location{font-size:11px;color:var(--text-tertiary);font-family:SF Mono,Monaco,monospace}.orbit-violation-issue{color:var(--text-secondary);line-height:1.4}.orbit-violation-fix{margin-top:4px;padding:4px 8px;background:#22c55e0f;border-radius:4px;color:var(--text-secondary);font-size:11px;line-height:1.4}.orbit-violation-fix:before{content:"Fix: ";font-weight:600;color:#22c55e}.chat-failed-tools{display:flex;flex-direction:column;gap:8px;margin-bottom:12px}.failed-tool-card{background:var(--surface-2);border:1px solid rgba(239,68,68,.2);border-radius:8px;overflow:hidden}.failed-tool-header{display:flex;align-items:center;gap:8px;padding:8px 12px;cursor:pointer;transition:background .15s}.failed-tool-header:hover{background:var(--surface-3)}.failed-tool-header svg{color:#ef4444;flex-shrink:0}.failed-tool-label{color:var(--text-tertiary);font-size:12px;flex:1}.failed-tool-error{padding:6px 12px 8px;font-size:11px;color:#ef4444;font-family:SF Mono,Monaco,monospace}.failed-tool-expand{color:var(--text-tertiary);transition:transform .2s}.failed-tool-expand.expanded{transform:rotate(180deg)}.failed-tool-content{border-top:1px solid var(--border-subtle);max-height:300px;overflow:auto}.failed-tool-json{margin:0;padding:12px;font-size:11px;color:var(--text-secondary);white-space:pre-wrap;word-break:break-word;line-height:1.5;font-family:SF Mono,Monaco,monospace}.chat-deployments{display:flex;flex-direction:column;gap:8px}.deployment-card{display:flex;align-items:center;gap:12px;padding:12px 16px;background:linear-gradient(135deg,#22c55e14,#22c55e0a);border:1px solid rgba(34,197,94,.2);border-radius:10px}.deployment-card-icon{display:flex;align-items:center;justify-content:center;width:36px;height:36px;background:#22c55e26;border-radius:8px;color:#22c55e;flex-shrink:0}.deployment-card-content{flex:1;min-width:0}.deployment-card-title{font-size:14px;font-weight:500;color:var(--text);margin-bottom:2px}.deployment-card-url{font-size:12px;color:var(--text-tertiary);font-family:var(--font-mono);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.deployment-card-visit{display:flex;align-items:center;gap:6px;padding:8px 14px;background:#22c55e;border:none;border-radius:6px;color:#fff;font-size:13px;font-weight:500;cursor:pointer;transition:all .15s;flex-shrink:0}.deployment-card-visit:hover{background:#16a34a;transform:translateY(-1px)}.deployment-card-visit svg{opacity:.9}.artifact-launch-btn{display:flex;align-items:center;gap:6px;padding:6px 12px;background:var(--accent);border:none;border-radius:6px;color:#fff;font-size:13px;font-weight:500;cursor:pointer;transition:all .15s}.artifact-launch-btn:hover:not(:disabled){background:var(--accent-hover);transform:translateY(-1px)}.artifact-launch-btn:disabled{opacity:.7;cursor:not-allowed}.artifact-launch-btn.launching{background:var(--surface-2);color:var(--text-secondary);border:1px solid var(--border)}.artifact-launch-spinner{width:12px;height:12px;border:2px solid currentColor;border-top-color:transparent;border-radius:50%;animation:spin .8s linear infinite}.artifact-visit-btn{display:flex;align-items:center;gap:4px;padding:6px 12px;background:#10b981;border:none;border-radius:6px;color:#fff;font-size:13px;font-weight:500;cursor:pointer;transition:all .15s}.artifact-visit-btn:hover{background:#059669;transform:translateY(-1px)}.artifact-build-section{padding:12px 16px;border-top:1px solid var(--border)}.artifact-build-section.building{background:#3b82f60d;border-top-color:var(--accent, #3b82f6)}.artifact-build-section.error{background:#ef44440d;border-top-color:var(--error, #ef4444)}.artifact-build-section.fixing{background:#f59e0b0d;border-top-color:var(--warning, #f59e0b)}.artifact-build-section.fixing .artifact-build-header{color:var(--warning, #f59e0b)}.artifact-build-section.fixing .artifact-build-spinner{border-color:var(--warning, #f59e0b);border-top-color:transparent}.artifact-build-header{display:flex;align-items:center;gap:8px;font-size:12px;font-weight:600}.artifact-build-section.building .artifact-build-header{color:var(--accent, #3b82f6)}.artifact-build-section.error .artifact-build-header{color:var(--error, #ef4444)}.artifact-build-spinner{width:12px;height:12px;border:2px solid var(--accent, #3b82f6);border-top-color:transparent;border-radius:50%;animation:spin .8s linear infinite}.artifact-build-error-icon{width:16px;height:16px;display:flex;align-items:center;justify-content:center;background:var(--error, #ef4444);color:#fff;border-radius:50%;font-size:10px;font-weight:700}.artifact-build-error{margin-top:10px}.artifact-build-error-content{font-size:11px;font-family:var(--font-mono);color:var(--text-secondary);background:var(--surface);padding:8px 10px;border-radius:6px;max-height:200px;overflow-y:auto;white-space:pre-wrap;word-break:break-word;margin:0}.artifact-build-error-hint{font-size:11px;color:var(--text-tertiary);margin-top:8px}.artifact-build-actions{display:flex;gap:8px;margin-top:10px}.artifact-build-fix-btn,.artifact-build-retry-btn{padding:6px 12px;font-size:12px;font-weight:500;border-radius:6px;border:none;cursor:pointer;transition:all .15s ease}.artifact-build-fix-btn{background:var(--accent, #3b82f6);color:#fff}.artifact-build-fix-btn:hover{background:var(--accent-hover, #2563eb)}.artifact-build-retry-btn{background:var(--surface-hover);color:var(--text-secondary)}.artifact-build-retry-btn:hover{background:var(--border)}.artifact-status-row{pointer-events:none}.artifact-status-spinner{width:12px;height:12px;border:2px solid var(--accent, #3b82f6);border-top-color:transparent;border-radius:50%;animation:spin .8s linear infinite;flex-shrink:0}.artifact-status-error{border-color:var(--error, #ef4444)!important;background:#ef44440d!important}.artifact-status-error .artifact-file-action{color:var(--error, #ef4444)}.artifact-status-error-icon{width:14px;height:14px;display:flex;align-items:center;justify-content:center;background:var(--error, #ef4444);color:#fff;border-radius:50%;font-size:9px;font-weight:700;flex-shrink:0}.artifact-error-details{font-size:11px;font-family:var(--font-mono);color:var(--text-secondary);background:var(--surface);padding:8px 10px;border-radius:6px;max-height:150px;overflow-y:auto;white-space:pre-wrap;word-break:break-word;margin:4px 0 0}.artifact-error-actions{display:flex;gap:6px;margin-top:8px}.artifact-error-btn{padding:5px 10px;font-size:11px;font-weight:500;border-radius:5px;border:none;cursor:pointer;background:var(--surface-hover);color:var(--text-secondary);transition:all .15s ease}.artifact-error-btn:hover{background:var(--border)}.artifact-error-btn.primary{background:var(--accent, #3b82f6);color:#fff}.artifact-error-btn.primary:hover{background:var(--accent-hover, #2563eb)}.chat-file-changes{display:flex;flex-direction:column;gap:2px;margin-top:8px}.file-change-item{display:flex;align-items:center;gap:8px;padding:6px 10px;background:var(--surface-2);border-radius:6px;font-size:13px;color:var(--text-secondary)}.file-change-icon{width:16px;height:16px;display:flex;align-items:center;justify-content:center;color:var(--success, #22c55e);flex-shrink:0}.file-change-action{color:var(--text-tertiary)}.file-change-name{color:var(--text);font-family:var(--font-mono, monospace);font-size:12px}.file-change-stats{margin-left:auto;display:flex;gap:6px;font-size:12px;font-family:var(--font-mono, monospace)}.file-change-add{color:var(--success, #22c55e)}.file-change-remove{color:var(--error, #ef4444)}.code-execution-card{border:1px solid rgba(255,255,255,.08);border-radius:8px;overflow:hidden;margin:6px 0}.code-execution-card.success{border-color:#22c55e33}.code-execution-card.error{border-color:#ef444433}.code-execution-header{display:flex;align-items:center;justify-content:space-between;padding:8px 12px;cursor:pointer;background:#ffffff08}.code-execution-header:hover{background:#ffffff0f}.code-execution-status{display:flex;align-items:center;gap:8px;font-size:13px;color:#fffc}.code-execution-dot{width:6px;height:6px;border-radius:50%}.code-execution-dot.success{background:#22c55e}.code-execution-dot.error{background:#ef4444}.code-execution-meta{display:flex;align-items:center;gap:8px}.code-execution-duration{font-size:11px;color:#fff6}.code-execution-body{border-top:1px solid rgba(255,255,255,.06)}.code-execution-section{padding:8px 12px}.code-execution-section+.code-execution-section{border-top:1px solid rgba(255,255,255,.04)}.code-execution-section-label{font-size:10px;text-transform:uppercase;letter-spacing:.5px;color:#fff6;margin-bottom:4px}.code-execution-code,.code-execution-output,.code-execution-stderr{margin:0;padding:8px;border-radius:4px;font-size:12px;line-height:1.5;overflow-x:auto;white-space:pre-wrap;word-break:break-word;max-height:300px;overflow-y:auto}.code-execution-code{background:#0000004d;color:#fffc}.code-execution-output{background:#22c55e0f;color:#22c55ee6}.code-execution-stderr{background:#ef44440f;color:#ef4444e6}.note-write-card{flex-direction:row;align-items:center;gap:12px;padding:12px 16px;cursor:pointer;border:none;text-align:left;font:inherit}.note-write-card:hover{background:var(--surface-3)}.browse-card .artifact-card-icon{color:var(--blue, #3b82f6)}.browse-steps{display:flex;flex-direction:column;padding:8px 16px 12px}.browse-step-item{display:flex;align-items:center;gap:6px;padding:5px 8px;margin:0 -8px;font-size:13px;color:var(--text-secondary);border-bottom:1px solid var(--border-subtle)}.browse-step-item:last-child{border-bottom:none}.browse-step-action{color:var(--text-tertiary);flex-shrink:0}.browse-step-url{color:var(--text);font-family:var(--font-mono);font-size:12px}.browse-step-title{color:var(--text-tertiary);font-size:12px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.browse-open-timeline{display:block;width:100%;padding:8px 16px;background:none;border:none;border-top:1px solid var(--border-subtle);color:var(--blue, #3b82f6);font-size:13px;cursor:pointer;text-align:center;transition:background .15s}.browse-open-timeline:hover{background:var(--surface-3)}.artifact-visualizer{width:50%;min-width:360px;flex-shrink:0;border-left:1px solid var(--border);display:flex;flex-direction:column;background:var(--surface);animation:visualizerSlideIn .2s ease-out}@keyframes visualizerSlideIn{0%{opacity:0;transform:translate(12px)}to{opacity:1;transform:translate(0)}}.artifact-visualizer-header{display:flex;align-items:center;justify-content:space-between;padding:12px 16px;border-bottom:1px solid var(--border);gap:12px;flex-shrink:0}.artifact-visualizer-title{display:flex;align-items:center;gap:10px;min-width:0}.artifact-visualizer-icon{flex-shrink:0;color:var(--text-secondary);display:flex;align-items:center}.artifact-visualizer-info{display:flex;flex-direction:column;min-width:0}.artifact-visualizer-name{font-size:14px;font-weight:500;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.artifact-visualizer-type{font-size:12px;color:var(--text-tertiary);display:flex;align-items:center;gap:6px}.artifact-visualizer-actions{display:flex;align-items:center;gap:4px;flex-shrink:0}.artifact-visualizer-action-btn,.artifact-visualizer-close-btn{background:none;border:none;color:var(--text-secondary);cursor:pointer;padding:6px;border-radius:6px;display:flex;align-items:center;transition:background .15s,color .15s}.artifact-visualizer-action-btn:hover,.artifact-visualizer-close-btn:hover{background:var(--surface-3);color:var(--text)}.artifact-visualizer-body{flex:1;min-height:0;overflow:auto}.artifact-visualizer-iframe{width:100%;height:100%;border:none;background:#fff}.artifact-visualizer-loading{display:flex;align-items:center;justify-content:center;gap:8px;padding:48px 16px;color:var(--text-secondary);font-size:13px}.artifact-visualizer-file-changes{display:flex;flex-direction:column;padding:8px;gap:2px}.artifact-visualizer-launch-btn{display:flex;align-items:center;gap:6px;margin:12px 8px;padding:8px 16px;background:var(--accent);color:#fff;border:none;border-radius:8px;font-size:13px;font-weight:500;cursor:pointer;transition:background .15s;width:fit-content}.artifact-visualizer-launch-btn:hover{background:var(--accent-hover)}.artifact-visualizer-open-prompt{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:16px;padding:64px 24px;height:100%}.artifact-visualizer-open-icon{color:var(--text-tertiary);opacity:.5}.artifact-visualizer-open-btn{padding:10px 24px;background:var(--surface-3);color:var(--text);border:1px solid var(--border);border-radius:8px;font-size:14px;cursor:pointer;transition:background .15s}.artifact-visualizer-open-btn:hover{background:var(--surface-2)}.page-content.with-visualizer{flex:1;min-width:0}.chat-md{display:flex;flex-direction:column;gap:0}.chat-md-h1{font-size:20px;font-weight:600;color:var(--text);margin:16px 0 8px;line-height:1.3}.chat-md-h1:first-child{margin-top:0}.chat-md-h2{font-size:17px;font-weight:600;color:var(--text);margin:14px 0 6px;line-height:1.3}.chat-md-h2:first-child{margin-top:0}.chat-md-h3{font-size:15px;font-weight:600;color:var(--text);margin:12px 0 4px;line-height:1.3}.chat-md-h3:first-child{margin-top:0}.chat-md-p{margin:0;line-height:1.6}.chat-md-li{margin-left:20px;line-height:1.6;list-style:disc}.chat-md-li.chat-md-ol{list-style:decimal}.chat-md-hr{border:none;border-top:1px solid var(--border);margin:16px 0}.chat-md strong{font-weight:600;color:var(--text)}.chat-md em{font-style:italic}.chat-md-code-inline{font-family:var(--font-mono);font-size:12px;background:var(--surface-2);padding:2px 6px;border-radius:4px;color:var(--accent)}.chat-md-code-block{background:var(--surface-2);border-radius:8px;padding:12px 14px;margin:8px 0;overflow-x:auto}.chat-md-code-lang{font-size:11px;color:var(--text-secondary);margin-bottom:6px;font-family:var(--font-mono);text-transform:uppercase;letter-spacing:.5px}.chat-md-code-block code{font-family:var(--font-mono);font-size:12px;color:var(--text);line-height:1.5;white-space:pre}.chat-md-link{color:var(--accent);text-decoration:none}.chat-md-link:hover{text-decoration:underline}.chat-md>*:last-child{margin-bottom:0}.chat-latex-block{display:block;text-align:center;margin:12px 0;padding:12px;background:transparent;border:1px solid var(--border);border-radius:6px;overflow-x:auto;position:relative}.chat-latex-block:hover .chat-latex-copy{opacity:1}.chat-latex-copy{position:absolute;top:6px;right:6px;opacity:0;background:var(--surface);border:1px solid var(--border);border-radius:4px;padding:4px 8px;font-size:11px;color:var(--text-secondary);cursor:pointer;transition:opacity .15s,background .15s}.chat-latex-copy:hover{background:var(--hover)}.chat-latex-inline{display:inline;padding:0 2px}.chat-latex-block .katex-display{margin:0!important;padding:0!important}.chat-latex-block .katex-html{overflow:visible}.chat-md .katex{font-size:1.1em}.chat-modal{position:fixed;inset:0;background:#000c;display:none;align-items:center;justify-content:center;z-index:1000;padding:20px}.chat-modal.active{display:flex}.chat-modal-content{background:var(--surface);border:1px solid var(--border);border-radius:16px;width:100%;max-width:420px;animation:modalIn .2s ease-out}.chat-settings-wide .chat-modal-content,.chat-modal-content.chat-settings-wide{max-width:560px}.chat-modal-header{display:flex;align-items:center;justify-content:space-between;padding:16px 20px;border-bottom:1px solid var(--border)}.chat-modal-header h3{margin:0;font-size:16px;font-weight:600}.chat-modal-close{background:none;border:none;font-size:24px;color:var(--text-secondary);cursor:pointer;padding:4px;display:flex;align-items:center;justify-content:center}.chat-modal-close:hover{color:var(--text)}.chat-modal-body{padding:20px}.chat-settings-tabs{display:flex;gap:4px;padding:4px;background:var(--surface-2);border-radius:10px;margin-bottom:20px}.chat-settings-tab{flex:1;padding:10px 16px;border:none;background:transparent;color:var(--text-secondary);font-size:13px;font-weight:500;border-radius:8px;cursor:pointer;transition:all .15s}.chat-settings-tab:hover{color:var(--text)}.chat-settings-tab.active{background:var(--surface);color:var(--text);box-shadow:0 1px 3px #0000001a}.chat-settings-panel{display:none}.chat-settings-panel.active{display:block}.chat-models-list{display:flex;flex-direction:column;gap:12px}.chat-model-row{display:flex;align-items:center;gap:16px;padding:12px 16px;background:var(--surface-2);border-radius:10px}.chat-model-row.disabled{opacity:.5;pointer-events:none}.chat-model-row .coming-soon{font-size:10px;font-weight:600;color:var(--accent);background:var(--accent-dim);padding:2px 6px;border-radius:4px;margin-left:4px;text-transform:uppercase;letter-spacing:.5px}.chat-model-label{display:flex;align-items:center;gap:10px;min-width:80px;font-size:13px;font-weight:500;color:var(--text)}.chat-model-label svg{width:18px;height:18px;color:var(--text-tertiary);flex-shrink:0}.chat-model-selects{display:flex;gap:10px;flex:1}.chat-select{flex:1;padding:8px 32px 8px 12px;background:var(--surface);border:1px solid var(--border);border-radius:8px;color:var(--text);font-size:13px;cursor:pointer;transition:all .15s;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%23888' stroke-width='2'%3E%3Cpath d='M6 9l6 6 6-6'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 10px center}.chat-select:hover{border-color:var(--text-tertiary)}.chat-select:focus{outline:none;border-color:var(--accent)}.chat-select option{background:var(--surface);color:var(--text)}.chat-key-btn{display:flex;align-items:center;justify-content:center;width:34px;height:34px;background:var(--surface);border:1px solid var(--border);border-radius:8px;color:var(--text-tertiary);cursor:pointer;transition:all .15s;flex-shrink:0}.chat-key-btn:hover{border-color:var(--text-tertiary);color:var(--text-secondary)}.chat-key-btn.has-key{color:var(--accent);border-color:var(--accent);background:var(--accent-dim)}.chat-key-btn svg{width:16px;height:16px}.chat-setting-row{display:flex;align-items:center;justify-content:space-between;padding:12px 0;border-bottom:1px solid var(--border-subtle)}.chat-setting-row:last-child{border-bottom:none}.chat-setting-info{display:flex;flex-direction:column;gap:2px}.chat-setting-label{font-size:14px;font-weight:500;color:var(--text)}.chat-setting-desc{font-size:12px;color:var(--text-tertiary)}.chat-setting-disabled{opacity:.5;pointer-events:none}.chat-coming-soon{font-size:11px;font-weight:500;color:var(--text-tertiary);background:var(--surface-2);padding:1px 6px;border-radius:4px;margin-left:6px}.chat-threshold-control{display:flex;align-items:center;gap:12px}.chat-threshold-slider{width:120px;height:4px;appearance:none;background:var(--surface-3);border-radius:2px;cursor:pointer}.chat-threshold-slider::-webkit-slider-thumb{appearance:none;width:16px;height:16px;background:var(--accent);border-radius:50%;cursor:pointer}.chat-threshold-slider::-moz-range-thumb{width:16px;height:16px;background:var(--accent);border-radius:50%;border:none;cursor:pointer}.chat-threshold-value{font-size:14px;font-weight:500;color:var(--text);min-width:28px;text-align:right}.chat-usage-section{padding:8px 0}.chat-usage-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px}.chat-usage-header h4{margin:0;font-size:14px;font-weight:600;color:var(--text)}.chat-usage-reset{background:none;border:none;color:var(--accent);font-size:12px;cursor:pointer;padding:4px 8px;border-radius:4px;transition:background .15s}.chat-usage-reset:hover{background:var(--surface-3)}.chat-usage-actions{display:flex;gap:8px}.chat-usage-stats{display:grid;grid-template-columns:repeat(2,1fr);gap:12px}.chat-usage-stat{background:var(--surface-2);border-radius:8px;padding:12px;display:flex;flex-direction:column;gap:4px}.chat-usage-label{font-size:11px;color:var(--text-tertiary);text-transform:uppercase;letter-spacing:.5px}.chat-usage-value{font-size:20px;font-weight:600;color:var(--text)}.chat-usage-note{margin-top:16px;font-size:12px;color:var(--text-tertiary);line-height:1.5}.chat-debug-logs{margin-top:20px;border-top:1px solid var(--border-color);padding-top:16px}.chat-debug-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px;gap:12px}.chat-debug-header h4{margin:0;font-size:14px;font-weight:500;flex:1}.chat-debug-actions{display:flex;gap:8px}.chat-debug-log-list{max-height:400px;overflow-y:auto;display:flex;flex-direction:column;gap:8px}.chat-debug-log-item{background:var(--bg-tertiary);border-radius:6px;padding:8px 12px;font-size:12px}.chat-debug-log-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:6px}.chat-debug-event-type{font-weight:600;padding:2px 6px;border-radius:4px;background:var(--bg-secondary)}.chat-debug-event-type.stream{color:#3b82f6}.chat-debug-event-type.build{color:#22c55e}.chat-debug-event-type.deploy{color:var(--accent)}.chat-debug-event-type.tool{color:#f59e0b}.chat-debug-event-type.api{color:#06b6d4}.chat-debug-log-item.error{border-left:3px solid #ef4444}.chat-debug-log-item.warn{border-left:3px solid #f59e0b}.chat-debug-message{flex:1;color:var(--text);font-size:12px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.chat-debug-time{color:var(--text-tertiary);font-size:11px;flex-shrink:0}.chat-debug-log-data{margin:0;padding:8px;background:var(--bg-primary);border-radius:4px;font-size:11px;line-height:1.4;overflow-x:auto;white-space:pre-wrap;word-break:break-word;color:var(--text-secondary)}.chat-chat.chat-chat-panel{display:flex;flex-direction:column;height:100%}.chat-panel-header{display:flex;align-items:center;justify-content:space-between;padding:10px 12px;border-bottom:1px solid var(--border);background:var(--surface);flex-shrink:0;z-index:5;position:relative}.chat-panel-header-actions{display:flex;align-items:center;gap:2px}.chat-panel-header-left{display:flex;align-items:center;gap:6px;color:var(--text-secondary);font-size:13px}.chat-panel-header-left svg{color:var(--accent)}.chat-panel-title{font-weight:500;color:var(--text)}.chat-panel-context{color:var(--text-tertiary)}.chat-panel-context:before{content:"·";margin-right:6px}.chat-panel-close{display:flex;align-items:center;justify-content:center;width:24px;height:24px;border:none;background:transparent;border-radius:4px;color:var(--text-tertiary);cursor:pointer;transition:background .15s,color .15s}.chat-panel-close:hover{background:var(--surface-2);color:var(--text)}.chat-chat-panel .chat-messages{flex:1;min-height:0;padding:16px 12px;margin-right:0}.chat-chat-panel .chat-message{padding:0;margin-bottom:16px}.chat-chat-panel .chat-input-area{padding:12px;border-top:1px solid var(--border)}.chat-chat-panel .chat-input-wrapper{padding:8px 12px}.chat-chat-panel .chat-empty-state{flex:1;min-height:0;padding:24px 16px}.chat-chat-panel .chat-empty-icon{width:48px;height:48px}.chat-chat-panel .chat-empty-title{font-size:16px}.chat-chat-panel .chat-empty-input{max-width:100%}.chat-chat-panel .chat-quick-actions{display:none}.chat-attached-files{display:flex;align-items:center;gap:4px;margin-right:4px}.chat-attached-chip{display:flex;align-items:center;gap:4px;padding:2px 8px;border:1px solid var(--border);background:var(--surface);border-radius:12px;color:var(--text-secondary);font-size:11px;cursor:pointer;white-space:nowrap;max-width:120px;transition:background .15s,color .15s}.chat-attached-chip span{overflow:hidden;text-overflow:ellipsis}.chat-attached-chip:hover{background:var(--surface-2);color:var(--text)}.note-editor{display:flex;flex-direction:column;flex:1;min-height:0;max-height:100%;position:relative;overflow:hidden}.note-editor-stats{position:absolute;bottom:16px;right:16px;display:flex;gap:16px;font-size:13px;color:var(--text-tertiary);z-index:10;pointer-events:none}.note-editor-actions{position:absolute;top:8px;right:0;display:flex;align-items:center;gap:4px;z-index:10}.note-editor-title{font-size:14px;font-weight:500;color:var(--text)}.note-editor-stats{display:flex;gap:16px;margin-left:auto;font-size:13px;color:var(--text-tertiary)}.note-editor-actions{display:flex;align-items:center;gap:4px}.note-editor-btn{width:32px;height:32px;display:flex;align-items:center;justify-content:center;background:transparent;border:none;border-radius:6px;color:var(--text-tertiary);cursor:pointer;transition:all .15s}.note-editor-btn:hover:not(:disabled){background:var(--surface-2);color:var(--text-secondary)}.note-editor-btn:disabled{opacity:.4;cursor:not-allowed}.note-editor-sep{width:1px;height:20px;background:var(--border);margin:0 4px}.note-editor-body{flex:1;display:flex;flex-direction:column;padding:8px 0 8px 40px;overflow-y:auto;overflow-x:hidden;max-width:760px;margin:0 auto;width:100%;min-height:0}.note-editor-page-title{font-size:14px;font-weight:500;color:var(--text);margin-bottom:12px;letter-spacing:0;outline:none}.note-editor-content{flex:1;font-size:16px;line-height:1.75;color:var(--text);outline:none;min-height:200px}.note-editor-content:empty:before{content:attr(data-placeholder);color:var(--text-tertiary);pointer-events:none}.note-editor-content:focus{outline:none}.note-editor-textarea{flex:1;width:100%;min-height:200px;padding:0;background:transparent;border:none;outline:none;font-family:inherit;font-size:16px;line-height:1.75;color:var(--text);resize:none}.note-editor-textarea::placeholder{color:var(--text-tertiary)}.project-tab-close{width:18px;height:18px;display:flex;align-items:center;justify-content:center;background:transparent;border:none;border-radius:4px;color:var(--text-tertiary);cursor:pointer;opacity:0;transition:all .15s;flex-shrink:0;margin-left:auto}.project-tab:hover .project-tab-close{opacity:1}.project-tab-close:hover{background:var(--surface-3);color:var(--text)}.project-tab.active .project-tab-close:hover{background:#ffffff1a}.project-tab-close svg{width:12px;height:12px}.note-line{display:flex;align-items:flex-start;min-height:1.75em;line-height:1.75}.note-line-content{flex:1;outline:none}.note-line-h1 .note-line-content{font-size:2em;font-weight:700}.note-line-h2 .note-line-content{font-size:1.5em;font-weight:600}.note-line-h3 .note-line-content{font-size:1.25em;font-weight:600}.note-line-h4 .note-line-content{font-size:1.1em;font-weight:600}.note-line-quote{padding-left:16px;border-left:3px solid var(--accent);color:var(--text-secondary);font-style:italic}.note-line-code,.note-line-code-fence{font-family:SF Mono,Monaco,monospace;font-size:14px;background:var(--surface-2);padding:2px 8px;border-radius:4px;color:var(--text-secondary)}.note-prefix{color:var(--accent);margin-right:4px;font-weight:500;-webkit-user-select:none;user-select:none}.note-bullet{width:6px;height:6px;background:var(--text-tertiary);border-radius:50%;margin-right:12px;margin-top:.6em;flex-shrink:0}.note-number{color:var(--text-tertiary);margin-right:8px;min-width:20px;text-align:right;flex-shrink:0}.note-number:before{content:attr(data-num) "."}.note-checkbox{width:16px;height:16px;border:2px solid var(--text-tertiary);border-radius:4px;margin-right:10px;margin-top:.35em;flex-shrink:0;cursor:pointer;transition:all .15s}.note-checkbox:hover{border-color:var(--accent)}.note-checkbox.checked{background:var(--accent);border-color:var(--accent);position:relative}.note-checkbox.checked:after{content:"";position:absolute;left:4px;top:1px;width:4px;height:8px;border:solid white;border-width:0 2px 2px 0;transform:rotate(45deg)}.note-line-checked .note-line-content{color:var(--text-tertiary);text-decoration:line-through}.note-divider{flex:1;border:none;border-top:1px solid var(--border);margin:8px 0}.note-line-content strong{font-weight:600}.note-line-content em{font-style:italic}.note-line-content code{background:var(--surface-2);padding:2px 6px;border-radius:4px;font-family:SF Mono,Monaco,monospace;font-size:.9em;color:var(--pink)}.note-line-content del{text-decoration:line-through;color:var(--text-tertiary)}.note-line-content mark{background:#f59e0b4d;color:var(--text);padding:1px 2px;border-radius:2px}.note-line-content .md-marker{color:var(--text-tertiary);font-size:.9em}.note-line-content .md-link{color:var(--accent);text-decoration:none}.note-line-content .md-link:hover{text-decoration:underline}.note-slash-menu{position:absolute;background:var(--surface);border:1px solid var(--border);border-radius:8px;padding:6px;min-width:200px;box-shadow:0 8px 24px #0006;z-index:100}.note-slash-item{display:flex;align-items:center;gap:12px;width:100%;padding:8px 12px;background:transparent;border:none;border-radius:6px;color:var(--text);font-size:14px;cursor:pointer;text-align:left;transition:background .1s}.note-slash-item:hover,.note-slash-item.active{background:var(--surface-2)}.note-slash-icon{width:28px;height:28px;display:flex;align-items:center;justify-content:center;background:var(--surface-3);border-radius:6px;font-size:12px;font-weight:600;color:var(--text-secondary)}.note-slash-name{flex:1}.tiptap-editor{flex:1;outline:none;font-size:16px;line-height:1.75;color:var(--text);min-height:200px}.tiptap-editor p.is-editor-empty:first-child:before{content:attr(data-placeholder);color:var(--text-tertiary);pointer-events:none;float:left;height:0}.tiptap-editor>*+*{margin-top:.75em}.tiptap-editor .md-heading{position:relative}.tiptap-editor .md-h1{font-size:2em;font-weight:700;line-height:1.2}.tiptap-editor .md-h2{font-size:1.5em;font-weight:600;line-height:1.3}.tiptap-editor .md-h3{font-size:1.25em;font-weight:600;line-height:1.4}.tiptap-editor .md-hash-hidden{display:none}.tiptap-editor .md-hash-visible{color:var(--text-tertiary)}.tiptap-editor .md-heading:first-child{margin-top:0}.tiptap-editor ul,.tiptap-editor ol{padding-left:1.5em}.tiptap-editor li{margin:.25em 0}.tiptap-editor li p{margin:0}.tiptap-editor blockquote{padding-left:1em;border-left:3px solid var(--accent);color:var(--text-secondary);font-style:italic;margin:1em 0}.tiptap-editor hr{border:none;border-top:1px solid var(--border);margin:1.5em 0}.tiptap-editor code{background:var(--surface-2);padding:.15em .4em;border-radius:4px;font-family:SF Mono,Monaco,Cascadia Code,monospace;font-size:.9em;color:var(--pink)}.tiptap-editor pre{background:var(--surface-2);padding:1em;border-radius:8px;font-family:SF Mono,Monaco,Cascadia Code,monospace;font-size:14px;overflow-x:auto;margin:1em 0}.tiptap-editor pre code{background:none;padding:0;color:var(--text);font-size:inherit}.tiptap-editor mark{background:#f59e0b4d;color:var(--text);padding:.1em .2em;border-radius:2px}.tiptap-editor a,.tiptap-editor .md-link{color:var(--accent);text-decoration:none;border-bottom:1px solid transparent;transition:border-color .15s}.tiptap-editor a:hover,.tiptap-editor .md-link:hover{border-bottom-color:var(--accent)}.tiptap-editor .md-blockquote{padding-left:1.5em;border-left:3px solid var(--accent);color:var(--text-secondary);font-style:italic;position:relative}.tiptap-editor .md-blockquote:before{content:">";position:absolute;left:.5em;color:var(--text-tertiary);font-style:normal;opacity:0}.tiptap-editor .md-blockquote-focused:before{opacity:1}.tiptap-editor .md-quote-marker-hidden{display:none}.tiptap-editor .md-quote-marker-visible{color:var(--text-tertiary)}.tiptap-editor .md-list-item,.tiptap-editor .md-list-item-focused{position:relative}.tiptap-editor img{max-width:100%;border-radius:8px}.tiptap-editor ul[data-type=taskList]{list-style:none;padding-left:0}.tiptap-editor ul[data-type=taskList] li{display:flex;align-items:flex-start;gap:8px}.tiptap-editor ul[data-type=taskList] li>label{flex-shrink:0;margin-top:.25em}.tiptap-editor ul[data-type=taskList] li>label input[type=checkbox]{appearance:none;width:16px;height:16px;border:2px solid var(--text-tertiary);border-radius:4px;cursor:pointer;transition:all .15s}.tiptap-editor ul[data-type=taskList] li>label input[type=checkbox]:hover{border-color:var(--accent)}.tiptap-editor ul[data-type=taskList] li>label input[type=checkbox]:checked{background:var(--accent);border-color:var(--accent);background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='white' stroke-width='3' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='20 6 9 17 4 12'%3E%3C/polyline%3E%3C/svg%3E");background-size:10px;background-position:center;background-repeat:no-repeat}.tiptap-editor ul[data-type=taskList] li>div{flex:1}.tiptap-editor ul[data-type=taskList] li[data-checked=true]>div p{color:var(--text-tertiary);text-decoration:line-through}.tiptap-editor table{border-collapse:collapse;margin:1em 0;width:auto;min-width:50%;table-layout:auto}.tiptap-editor table td,.tiptap-editor table th{border:1px solid var(--border);padding:8px 12px;vertical-align:top;box-sizing:border-box;position:relative;min-width:80px}.tiptap-editor table th{background:transparent;font-weight:400;text-align:left}.tiptap-editor table td p,.tiptap-editor table th p{margin:0}.tiptap-editor table .selectedCell:after{content:"";position:absolute;inset:0;background:#3b82f626;pointer-events:none}.tiptap-editor table .column-resize-handle{position:absolute;right:-2px;top:0;bottom:0;width:4px;background:var(--accent);cursor:col-resize;z-index:10}.tiptap-editor .tableWrapper{overflow-x:auto;margin:1em 0}.table-context-menu{position:fixed;background:var(--surface);border:1px solid var(--border);border-radius:8px;padding:6px;min-width:200px;box-shadow:0 8px 24px #0006;z-index:1000}.table-context-menu button{display:block;width:100%;padding:8px 12px;background:transparent;border:none;border-radius:6px;color:var(--text);font-size:14px;text-align:left;cursor:pointer;transition:background .1s}.table-context-menu button:hover{background:var(--surface-2)}.table-context-menu button.danger{color:#ef4444}.table-context-menu button.danger:hover{background:#ef44441a}.table-context-divider{height:1px;background:var(--border);margin:6px 0}.table-add-button{position:fixed;min-width:24px;height:24px;display:flex;align-items:center;justify-content:center;background:var(--accent);border:none;border-radius:12px;color:#fff;cursor:grab;z-index:100;opacity:.9;transition:opacity .15s,transform .15s,width .15s,border-radius .15s;box-shadow:0 2px 8px #0000004d;-webkit-user-select:none;user-select:none}.table-add-button:hover{opacity:1;transform:translate(-50%,-50%) scale(1.05)}.table-add-button.dragging{cursor:grabbing;border-radius:8px;padding:4px 8px;min-width:auto;height:auto}.table-add-drag-handle{display:flex;flex-direction:column;align-items:center;gap:4px}.drag-dots{display:grid;grid-template-columns:repeat(3,1fr);gap:3px}.drag-dots span{width:4px;height:4px;background:#fffc;border-radius:50%}.drag-count{font-size:11px;font-weight:600;color:#fff}.table-drag-highlight{position:fixed;background:var(--accent);opacity:.15;border:2px solid var(--accent);border-radius:4px;pointer-events:none;z-index:99}.tiptap-editor img{max-width:100%;height:auto;border-radius:8px;margin:1em 0;display:block}.tiptap-editor img.ProseMirror-selectednode{outline:2px solid var(--accent);outline-offset:2px}.tiptap-editor iframe{width:100%;border:none;border-radius:8px;margin:1em 0;background:var(--surface-2)}.bubble-menu{display:flex;background:var(--surface);border:1px solid var(--border);border-radius:8px;padding:4px;gap:2px;box-shadow:0 4px 16px #0000004d}.bubble-menu button{width:32px;height:32px;display:flex;align-items:center;justify-content:center;background:transparent;border:none;border-radius:6px;color:var(--text-secondary);font-size:14px;font-weight:600;cursor:pointer;transition:all .1s}.bubble-menu button:hover{background:var(--surface-2);color:var(--text)}.bubble-menu button.is-active{background:var(--accent);color:#fff}.bubble-menu-link{gap:4px}.bubble-link-input{width:200px;height:32px;padding:0 10px;background:var(--surface-2);border:1px solid var(--border);border-radius:6px;color:var(--text);font-size:13px;outline:none}.bubble-link-input:focus{border-color:var(--accent)}.bubble-link-input::placeholder{color:var(--text-tertiary)}.slash-menu{position:fixed;background:var(--surface);border:1px solid var(--border);border-radius:8px;padding:6px;min-width:200px;max-height:320px;overflow-y:auto;box-shadow:0 8px 24px #0006;z-index:1000}.slash-menu-item{display:flex;align-items:center;gap:12px;width:100%;padding:8px 12px;background:transparent;border:none;border-radius:6px;color:var(--text);font-size:14px;cursor:pointer;text-align:left;transition:background .1s}.slash-menu-item:hover,.slash-menu-item.selected{background:var(--surface-2)}.slash-menu-icon{width:28px;height:28px;display:flex;align-items:center;justify-content:center;background:var(--surface-3);border-radius:6px;font-size:12px;font-weight:600;color:var(--text-secondary)}.slash-menu-name{flex:1}.slash-menu-section{position:relative}.slash-menu-chevron{display:flex;align-items:center;justify-content:center;color:var(--text-tertiary);margin-left:8px}.slash-menu-item.selected .slash-menu-chevron{color:var(--text-secondary)}.slash-menu-back{display:flex;align-items:center;gap:8px;width:100%;padding:8px 12px;background:var(--surface-2);border:none;border-bottom:1px solid var(--border);color:var(--text-secondary);font-size:13px;font-weight:500;cursor:pointer;text-align:left;margin-bottom:4px}.slash-menu-back:hover{background:var(--surface-3);color:var(--text)}.slash-menu-back-arrow{font-size:14px}.slash-menu-hint{display:flex;align-items:center;gap:12px;padding:8px 12px;border-top:1px solid var(--border);margin-top:4px;font-size:11px;color:var(--text-tertiary)}.slash-menu-hint span{display:inline-flex;align-items:center;gap:4px;padding:2px 6px;background:var(--surface-3);border-radius:4px;font-family:inherit}.slash-menu-input{min-width:280px}.slash-menu-input-header{border-bottom:1px solid var(--border);margin-bottom:8px}.slash-menu-input-header .slash-menu-back{border-bottom:none;margin-bottom:0}.slash-menu-input-body{display:flex;gap:8px;padding:0 8px 8px}.slash-input{flex:1;height:36px;padding:0 12px;background:var(--surface-2);border:1px solid var(--border);border-radius:6px;color:var(--text);font-size:13px;outline:none}.slash-input:focus{border-color:var(--accent)}.slash-input::placeholder{color:var(--text-tertiary)}.slash-input-submit{height:36px;padding:0 16px;background:var(--accent);border:none;border-radius:6px;color:#fff;font-size:13px;font-weight:500;cursor:pointer;transition:opacity .15s}.slash-input-submit:hover{opacity:.9}.file-card{position:relative}.file-card-menu{position:absolute;top:8px;right:8px;width:24px;height:24px;display:flex;align-items:center;justify-content:center;background:var(--surface-2);border:1px solid var(--border);border-radius:6px;color:var(--text-tertiary);cursor:pointer;opacity:0;transition:all .15s}.file-card:hover .file-card-menu{opacity:1}.file-card-menu:hover{background:var(--surface-3);color:var(--text)}.file-context-menu{position:fixed;background:var(--surface);border:1px solid var(--border);border-radius:10px;padding:6px;min-width:180px;box-shadow:0 8px 32px #0006;z-index:1000}.file-context-item{display:flex;align-items:center;gap:10px;width:100%;padding:8px 12px;background:transparent;border:none;border-radius:6px;color:var(--text);font-size:13px;cursor:pointer;text-align:left;transition:background .1s}.file-context-item:hover{background:var(--surface-2)}.file-context-item.danger{color:#ef4444}.file-context-item.danger:hover{background:#ef44441a}.file-context-divider{height:1px;background:var(--border);margin:6px 0}.sidebar-tree-item{position:relative}.sidebar-tree-menu{position:absolute;right:4px;top:50%;transform:translateY(-50%);width:20px;height:20px;display:flex;align-items:center;justify-content:center;background:transparent;border:none;border-radius:4px;color:var(--text-tertiary);cursor:pointer;opacity:0;transition:all .15s}.sidebar-tree-item:hover .sidebar-tree-menu{opacity:1}.sidebar-tree-menu:hover{background:var(--surface-3);color:var(--text)}.text-editor{position:relative;flex:1;display:flex;flex-direction:column;min-height:0;max-height:100%;overflow:hidden}.text-editor-toolbar{display:flex;align-items:center;gap:8px;padding:6px 12px;border-bottom:1px solid var(--border);background:var(--bg-secondary);flex-shrink:0}.text-editor-filename{font-size:13px;font-weight:500;color:var(--text-primary)}.text-editor-lang{font-size:11px;color:var(--text-tertiary);background:var(--bg-tertiary);padding:2px 6px;border-radius:4px}.text-editor-spacer{flex:1}.text-editor-btn{background:none;border:none;color:var(--text-secondary);cursor:pointer;padding:4px;border-radius:4px;display:flex;align-items:center}.text-editor-btn:hover{background:var(--bg-tertiary);color:var(--text-primary)}.text-editor-body{flex:1;min-height:0;overflow:hidden}.text-editor-body .monaco-editor,.text-editor-body .monaco-editor .overflow-guard,.text-editor-body .monaco-editor-background,.text-editor-body .margin{background:transparent!important}.text-editor-status{display:flex;gap:12px;padding:4px 12px;font-size:12px;color:var(--text-tertiary);border-top:1px solid var(--border);background:var(--bg-secondary);flex-shrink:0}.vh-content-area{display:flex;flex-direction:column;height:100%;position:relative}.vh-loading{display:flex;align-items:center;justify-content:center;height:200px;color:var(--text-tertiary)}.vh-content{flex:1;overflow-y:auto;padding:16px 24px 100px}.vh-ambient{display:flex;align-items:center;gap:16px;margin-bottom:20px}.vh-ambient-item{font-size:13px;color:var(--text-tertiary)}.vh-saves-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px}.vh-saves-stats{display:flex;gap:12px}.vh-saves-stat{font-size:12px;color:var(--text-tertiary)}.vh-saves-stat.total{color:var(--text-secondary);font-weight:500}.vh-saves-stat.manual{color:var(--accent)}.vh-saves-stat-sep{color:var(--text-tertiary);opacity:.5}.vh-last-saved{font-size:13px;color:var(--text-tertiary)}.vh-saves{display:flex;flex-direction:column;gap:12px}.vh-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:80px 20px;text-align:center}.vh-empty-icon{width:64px;height:64px;display:flex;align-items:center;justify-content:center;background:var(--surface-2);border-radius:16px;margin-bottom:16px}.vh-empty-icon svg{color:var(--text-tertiary)}.vh-empty p{font-size:15px;font-weight:500;color:var(--text-secondary);margin:0 0 4px}.vh-empty span{font-size:13px;color:var(--text-tertiary);margin-bottom:20px}.vh-empty-btn{display:flex;align-items:center;gap:6px;padding:10px 18px;background:var(--accent);border:none;border-radius:10px;font-size:13px;font-weight:500;color:#fff;cursor:pointer;transition:all .15s}.vh-empty-btn:hover{background:var(--accent-hover);transform:translateY(-1px)}.vh-date-group{margin-bottom:16px}.vh-date-header{display:flex;align-items:center;gap:8px;width:100%;padding:10px 12px;background:var(--surface);border:1px solid var(--border);border-radius:10px;cursor:pointer;transition:all .15s}.vh-date-header:hover{background:var(--surface-2);border-color:var(--text-tertiary)}.vh-date-chevron{color:var(--text-tertiary);transition:transform .2s;flex-shrink:0}.vh-date-group.collapsed .vh-date-chevron{transform:rotate(-90deg)}.vh-date-label{font-size:13px;font-weight:600;color:var(--text-secondary)}.vh-date-stats{font-size:12px;color:var(--text-tertiary);margin-left:auto}.vh-date-count{font-size:11px;color:var(--text-tertiary);background:var(--surface-2);padding:2px 8px;border-radius:10px;flex-shrink:0}.vh-date-items{display:flex;flex-direction:column;gap:8px;margin-top:12px;padding-left:8px}.vh-date-group.collapsed .vh-date-items{display:none}.vh-save-card{display:flex;align-items:flex-start;gap:12px;padding:12px;background:var(--surface);border:1px solid var(--border);border-radius:12px;transition:all .15s;cursor:pointer;opacity:.7}.vh-save-card:hover{border-color:var(--text-tertiary);background:var(--surface-2);opacity:1}.vh-save-card.manual{border-left:3px solid var(--accent);background:var(--surface-2);opacity:1}.vh-save-dot{width:8px;height:8px;background:var(--border);border-radius:50%;margin-top:5px;flex-shrink:0}.vh-save-card.manual .vh-save-dot{background:var(--accent)}.vh-save-content{flex:1;min-width:0}.vh-save-header{display:flex;align-items:center;justify-content:space-between;gap:8px}.vh-save-name{font-size:13px;font-weight:500;color:var(--text)}.vh-save-time{font-size:12px;color:var(--text-tertiary)}.vh-save-actions{display:flex;gap:6px;align-items:center;flex-shrink:0;opacity:0;transition:opacity .15s}.vh-save-card:hover .vh-save-actions{opacity:1}.vh-save-action-btn{display:flex;align-items:center;justify-content:center;width:32px;height:32px;padding:0;background:var(--surface-2);border:1px solid var(--border);border-radius:8px;color:var(--text-secondary);cursor:pointer;transition:all .15s}.vh-save-action-btn:hover{background:var(--accent);border-color:var(--accent);color:#fff}.vh-floating-save{position:fixed;bottom:32px;right:32px;width:56px;height:56px;background:var(--accent);border:none;border-radius:16px;box-shadow:0 4px 20px color-mix(in srgb,var(--accent) 40%,transparent);cursor:pointer;transition:all .2s;display:flex;align-items:center;justify-content:center;z-index:50}.vh-floating-save:hover{transform:translateY(-2px) scale(1.05);box-shadow:0 8px 30px color-mix(in srgb,var(--accent) 50%,transparent)}.vh-floating-save svg{color:#fff}.vh-timeline-container{position:relative;margin-bottom:20px}.vh-timeline-controls{position:absolute;bottom:12px;right:12px;z-index:100;display:flex;gap:6px}.vh-icon-btn{width:32px;height:32px;display:flex;align-items:center;justify-content:center;background:var(--surface);border:1px solid var(--border);border-radius:8px;color:var(--text-tertiary);cursor:pointer;transition:all .15s}.vh-icon-btn:hover{background:var(--surface-2);color:var(--text)}.vh-icon-btn.active{background:var(--accent);border-color:var(--accent);color:#fff}.vh-timeline-scroll{overflow-x:auto;overflow-y:hidden;border:1px solid var(--border);border-radius:12px;background:var(--surface)}.vh-timeline-scroll::-webkit-scrollbar{height:8px}.vh-timeline-scroll::-webkit-scrollbar-track{background:var(--surface-2)}.vh-timeline-scroll::-webkit-scrollbar-thumb{background:var(--surface-3);border-radius:4px}.vh-timeline-scroll::-webkit-scrollbar-thumb:hover{background:var(--text-tertiary)}.vh-timeline-canvas{position:relative;min-height:300px}.vh-timeline-svg{position:absolute;top:0;left:0}.vh-branch-tip.clickable,.vh-svg-label.clickable,.vh-svg-main-line,.vh-svg-branch-path{pointer-events:all;cursor:pointer}.vh-grid-line{stroke:var(--border);stroke-width:1;opacity:.4}.vh-grid-label{font-size:10px;fill:var(--text-tertiary);font-weight:500}.vh-svg-main-line{stroke:var(--accent);stroke-width:4;stroke-linecap:round;filter:drop-shadow(0 0 6px color-mix(in srgb,var(--accent) 40%,transparent))}.vh-svg-branch-path{stroke-linecap:round;stroke-linejoin:round;opacity:.7;transition:opacity .2s}.vh-fork-point{filter:drop-shadow(0 0 4px var(--accent))}.vh-branch-tip{transition:r .15s,filter .15s}.vh-branch-tip.current{filter:drop-shadow(0 0 6px var(--accent));fill:var(--accent)}.vh-svg-label{font-size:11px;font-weight:500;fill:var(--text-tertiary)}.vh-svg-label.main-label{fill:var(--accent);font-weight:600}.vh-svg-label.merged{opacity:.6;font-style:italic}.vh-node{position:absolute;width:12px;height:12px;border-radius:50%;background:var(--surface);border:3px solid var(--text-tertiary);transform:translate(-50%,-50%);cursor:pointer;transition:all .15s;box-shadow:0 2px 6px #0003;z-index:30}.vh-node:hover{transform:translate(-50%,-50%) scale(1.4);border-color:var(--accent);box-shadow:0 0 12px color-mix(in srgb,var(--accent) 50%,transparent);z-index:31}.vh-node.manual{background:var(--accent);border-color:var(--accent)}.vh-node.main{width:14px;height:14px}.vh-node.main.manual{box-shadow:0 0 10px color-mix(in srgb,var(--accent) 60%,transparent)}.vh-diff-modal{max-width:500px;width:100%}.vh-diff-modal .modal-header{display:flex;justify-content:space-between;align-items:flex-start}.vh-diff-time{font-size:13px;color:var(--text-tertiary);margin:4px 0 0}.vh-diff-loading,.vh-diff-empty{padding:32px;text-align:center;color:var(--text-tertiary)}.vh-diff-summary{font-size:13px;color:var(--text-secondary);margin:0 0 16px}.vh-diff-list{display:flex;flex-direction:column;gap:8px}.vh-diff-item{display:flex;align-items:center;gap:10px;padding:10px 12px;background:var(--surface);border-radius:8px;border:1px solid var(--border)}.vh-diff-item svg{flex-shrink:0}.vh-diff-added svg{color:#22c55e}.vh-diff-removed svg{color:var(--error)}.vh-diff-modified svg{color:#f59e0b}.vh-diff-name{flex:1;font-size:13px;font-weight:500;color:var(--text)}.vh-diff-type{font-size:11px;color:var(--text-tertiary);text-transform:capitalize}.modal-footer{display:flex;justify-content:flex-end;gap:12px;padding:16px 24px;border-top:1px solid var(--border)}.modal-footer .btn{display:flex;align-items:center;gap:6px}.modal-close{background:none;border:none;padding:4px;cursor:pointer;color:var(--text-tertiary);border-radius:6px;transition:all .15s}.modal-close:hover{background:var(--surface-2);color:var(--text)}.vh-branch-edit-modal{max-width:360px}.vh-branch-stats{display:flex;align-items:center;gap:8px;padding:12px 16px;background:var(--surface-2);border-radius:8px;margin-bottom:16px}.vh-branch-stat{font-size:13px;color:var(--text-secondary)}.vh-branch-stat.manual{color:var(--accent)}.vh-branch-stat.auto{color:var(--text-tertiary)}.vh-branch-stat-sep{color:var(--text-tertiary);opacity:.5}.vh-branch-actions{display:flex;flex-direction:column;gap:4px}.vh-branch-action{display:flex;align-items:center;gap:12px;padding:12px 16px;background:transparent;border:none;border-radius:8px;color:var(--text);font-size:14px;cursor:pointer;transition:background .15s;text-align:left;width:100%}.vh-branch-action:hover{background:var(--surface-2)}.vh-branch-action svg{color:var(--text-tertiary);flex-shrink:0}.vh-branch-action:hover svg{color:var(--text-secondary)}.vh-branch-action.danger{color:#ef4444}.vh-branch-action.danger svg{color:#ef4444}.vh-branch-action.danger:hover{background:#ef44441a}.vh-fork-info{font-size:13px;color:var(--text-secondary);margin-bottom:16px}.vh-svg-label.clickable{cursor:pointer}.vh-svg-label.clickable:hover{fill:var(--accent)}.vh-branch-tip.clickable:hover{transform:scale(1.2);transform-origin:center}.vh-view-switcher{display:flex;gap:0;border-bottom:1px solid var(--border-subtle);margin-bottom:16px}.vh-view-tab{flex:1;padding:10px 16px;font-size:13px;font-weight:600;color:var(--text-tertiary);background:none;border:none;border-bottom:2px solid transparent;cursor:pointer;transition:color .15s,border-color .15s}.vh-view-tab:hover{color:var(--text-secondary)}.vh-view-tab.active{color:var(--text);border-bottom-color:var(--accent)}.vh-branches-section{margin-bottom:24px}.vh-section-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:12px}.vh-section-header h3{font-size:14px;font-weight:600;color:var(--text);margin:0}.vh-new-branch-btn{display:flex;align-items:center;gap:6px;padding:6px 12px;background:var(--surface-2);border:1px solid var(--border);border-radius:6px;color:var(--text-secondary);font-size:13px;cursor:pointer;transition:all .15s}.vh-new-branch-btn:hover{background:var(--surface-3);color:var(--text);border-color:var(--accent)}.vh-branches-list{display:flex;flex-direction:column;gap:4px}.vh-branch-item{display:flex;align-items:center;gap:10px;padding:10px 14px;background:var(--surface);border:1px solid var(--border);border-radius:8px;color:var(--text);font-size:14px;cursor:pointer;transition:all .15s;text-align:left;width:100%}.vh-branch-item:hover{background:var(--surface-2);border-color:var(--accent)}.vh-branch-item.current{border-color:var(--accent);background:rgba(var(--accent-rgb),.05)}.vh-branch-item svg{color:var(--text-tertiary);flex-shrink:0}.vh-branch-item.current svg{color:var(--accent)}.vh-branch-name{flex:1;font-weight:500}.vh-branch-badge{font-size:11px;padding:2px 6px;background:var(--accent);color:#fff;border-radius:4px;font-weight:500}.vh-branch-saves{font-size:12px;color:var(--text-tertiary)}.vh-transfer-info{display:flex;align-items:center;gap:16px;padding:16px;background:var(--surface-2);border-radius:8px;margin-bottom:16px}.vh-transfer-from,.vh-transfer-to{flex:1}.vh-transfer-label{display:block;font-size:11px;color:var(--text-tertiary);text-transform:uppercase;margin-bottom:4px}.vh-transfer-name{font-weight:500;color:var(--text)}.vh-transfer-arrow{font-size:20px;color:var(--text-tertiary)}.vh-transfer-to select{width:100%}.vh-transfer-desc{font-size:13px;color:var(--text-secondary);margin:0}.vh-filter-bar{display:flex;gap:4px;margin-bottom:12px}.vh-filter-btn{padding:5px 12px;font-size:12px;font-weight:500;color:var(--text-tertiary);background:var(--surface);border:1px solid var(--border);border-radius:6px;cursor:pointer;transition:all .15s}.vh-filter-btn:hover{color:var(--text-secondary);background:var(--surface-2)}.vh-filter-btn.active{color:var(--text);background:var(--surface-2);border-color:var(--accent)}.vh-save-meta{display:flex;align-items:center;gap:6px;flex-shrink:0}.vh-save-badge{font-size:10px;font-weight:600;padding:1px 6px;border-radius:4px;text-transform:uppercase;letter-spacing:.3px}.vh-save-badge.chat{background:var(--accent-dim);color:var(--accent)}.vh-save-badge.edit{background:#22c55e26;color:#22c55e}.vh-save-summary{font-size:12px;color:var(--text-tertiary);margin:4px 0 0;line-height:1.4;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.vh-diff-summary-text{font-size:12px;color:var(--text-secondary);margin:4px 0 0;line-height:1.4}.admin-portal{min-height:100vh;background:var(--bg);color:var(--text)}.admin-denied{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:100vh;gap:12px}.admin-denied h1{font-size:24px;font-weight:600}.admin-denied p{color:var(--text-tertiary);margin-bottom:12px}.admin-header{display:flex;align-items:center;justify-content:space-between;padding:12px 24px;border-bottom:1px solid var(--border-primary);background:var(--bg-secondary)}.admin-header-left{display:flex;align-items:center;gap:12px}.admin-back-link{color:var(--text-tertiary);display:flex;align-items:center;text-decoration:none}.admin-back-link:hover{color:var(--text)}.admin-title{font-size:16px;font-weight:600;margin:0}.admin-nav{display:flex;gap:4px}.admin-nav-btn{padding:6px 16px;border:none;border-radius:6px;background:transparent;color:var(--text-secondary);font-size:13px;font-weight:500;cursor:pointer;transition:all .15s}.admin-nav-btn:hover,.admin-nav-btn.active{background:var(--surface-2);color:var(--text)}.admin-content{max-width:1200px;margin:0 auto;padding:24px}.admin-stats-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;margin-bottom:32px}.admin-stat-card{background:var(--bg-secondary);border:1px solid var(--border-primary);border-radius:12px;padding:20px}.admin-stat-value{font-size:32px;font-weight:700;margin-bottom:4px}.admin-stat-label{font-size:13px;color:var(--text-tertiary)}.admin-section{margin-bottom:24px}.admin-section-title{font-size:14px;font-weight:600;color:var(--text-secondary);margin:0 0 12px}.admin-toolbar{display:flex;gap:8px;margin-bottom:16px}.admin-search{flex:1;display:flex;align-items:center;gap:8px;background:var(--bg-secondary);border:1px solid var(--border-primary);border-radius:8px;padding:0 12px}.admin-search input{flex:1;background:transparent;border:none;color:var(--text);font-size:13px;padding:8px 0;outline:none}.admin-search svg{color:var(--text-tertiary);flex-shrink:0}.admin-filter{background:var(--bg-secondary);border:1px solid var(--border-primary);border-radius:8px;color:var(--text);font-size:13px;padding:8px 12px;cursor:pointer}.admin-table{background:var(--bg-secondary);border:1px solid var(--border-primary);border-radius:10px;overflow:hidden}.admin-table-header{display:flex;align-items:center;padding:8px 16px;border-bottom:1px solid var(--border-primary);background:var(--bg-tertiary)}.admin-th{flex:1;font-size:11px;font-weight:600;color:var(--text-tertiary);text-transform:uppercase;letter-spacing:.5px}.admin-table-row{display:flex;align-items:center;padding:10px 16px;border-bottom:1px solid var(--border-primary);background:transparent;border-left:none;border-right:none;border-top:none;width:100%;text-align:left;color:inherit;font:inherit;cursor:default}.admin-table-row:last-child{border-bottom:none}.admin-table-row.clickable{cursor:pointer}.admin-table-row.clickable:hover{background:var(--surface-2)}.admin-cell-user{display:flex;flex-direction:column;gap:2px;background:transparent;border:none;color:inherit;font:inherit;text-align:left;padding:0;cursor:pointer}.admin-cell-user:hover .admin-cell-primary{color:var(--accent)}.admin-cell-primary{font-size:13px;font-weight:500;color:var(--text);transition:color .15s}.admin-cell-secondary,.admin-cell-meta{font-size:12px;color:var(--text-tertiary);flex:1}.admin-cell-actions{display:flex;gap:4px;width:60px;justify-content:flex-end}.admin-flag-select{background:var(--bg-tertiary);border:1px solid var(--border-primary);border-radius:4px;color:var(--text);font-size:11px;padding:2px 4px;cursor:pointer}.btn-xs{padding:2px 8px;font-size:11px}.admin-loading{text-align:center;padding:40px;color:var(--text-tertiary)}.admin-empty{text-align:center;padding:20px;color:var(--text-tertiary);font-size:13px}.admin-back-btn{display:inline-flex;align-items:center;gap:6px;background:transparent;border:none;color:var(--text-tertiary);font-size:13px;cursor:pointer;padding:0;margin-bottom:16px}.admin-back-btn:hover{color:var(--text)}.admin-user-header{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:24px;padding-bottom:16px;border-bottom:1px solid var(--border-primary)}.admin-user-info h2{font-size:20px;font-weight:600;margin:0 0 4px}.admin-user-email{color:var(--text-tertiary);font-size:14px;margin:0 0 8px}.admin-user-meta{display:flex;gap:16px;font-size:13px;color:var(--text-tertiary)}.admin-danger-section{margin-top:32px;padding-top:16px;border-top:1px solid rgba(239,68,68,.2)}.admin-danger-section .admin-section-title{color:#ef4444}.admin-danger-confirm{display:flex;align-items:center;justify-content:space-between}.admin-danger-confirm p{font-size:13px;color:var(--text-secondary);margin:0}.admin-danger-actions{display:flex;gap:8px}.admin-convo-header{display:flex;align-items:center;justify-content:space-between}.admin-messages{display:flex;flex-direction:column;gap:12px;max-height:600px;overflow-y:auto;padding:4px 0}.admin-message{padding:12px 16px;border-radius:10px;max-width:85%}.admin-message.user{background:var(--bg-secondary);border:1px solid var(--border-primary);align-self:flex-end}.admin-message.assistant{background:var(--accent-dim);border:1px solid var(--accent-dim);align-self:flex-start}.admin-message.system{background:#eab30814;border:1px solid rgba(234,179,8,.15);align-self:center;font-size:12px}.admin-message-header{display:flex;align-items:center;gap:8px;margin-bottom:6px}.admin-message-role{font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.5px;color:var(--text-tertiary)}.admin-message-time{font-size:11px;color:var(--text-tertiary);opacity:.6}.admin-message-content{font-size:13px;line-height:1.6;color:var(--text);white-space:pre-wrap;word-break:break-word}.clib-layout{display:flex;height:100vh;background:var(--bg);overflow:hidden}.clib-sidebar{width:280px;flex-shrink:0;border-right:1px solid var(--border);display:flex;flex-direction:column;background:var(--surface);overflow:hidden}.clib-sidebar-header{display:flex;align-items:center;gap:8px;padding:16px 16px 12px;border-bottom:1px solid var(--border)}.clib-back{color:var(--text-secondary);display:flex;align-items:center;text-decoration:none;padding:4px;border-radius:6px;transition:background .15s}.clib-back:hover{background:var(--surface-3);color:var(--text)}.clib-title{font-size:16px;font-weight:600;color:var(--text);margin:0}.clib-search-wrap{padding:8px 12px}.clib-search{width:100%;padding:8px 12px;background:var(--surface-2);border:1px solid var(--border);border-radius:8px;color:var(--text);font-size:13px;outline:none;transition:border-color .15s}.clib-search::placeholder{color:var(--text-tertiary)}.clib-search:focus{border-color:var(--accent)}.clib-nav{flex:1;overflow-y:auto;padding:4px 8px 16px}.clib-nav-group{margin-bottom:8px}.clib-nav-group-title{font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.06em;color:var(--text-tertiary);padding:12px 8px 4px}.clib-nav-item{width:100%;display:flex;align-items:center;justify-content:space-between;padding:7px 10px;border:none;background:none;border-radius:6px;cursor:pointer;transition:background .12s;text-align:left}.clib-nav-item:hover{background:var(--surface-2)}.clib-nav-item.active{background:var(--accent-dim)}.clib-nav-name{font-size:13px;color:var(--text);font-weight:450}.clib-nav-item.active .clib-nav-name{color:var(--accent);font-weight:500}.clib-nav-signal{font-size:11px;color:var(--text-tertiary);font-style:italic}.clib-empty{padding:24px 12px;text-align:center;color:var(--text-tertiary);font-size:13px}.clib-main{flex:1;display:flex;flex-direction:column;overflow-y:auto;padding:32px 40px;min-width:0}.clib-main-header{display:flex;align-items:baseline;gap:12px;margin-bottom:8px}.clib-component-name{font-size:28px;font-weight:700;color:var(--text);margin:0}.clib-component-category{font-size:13px;color:var(--text-tertiary);background:var(--surface-2);padding:3px 10px;border-radius:20px}.clib-component-desc{font-size:15px;color:var(--text-secondary);margin:0 0 12px;line-height:1.5}.clib-component-meta{display:flex;gap:8px;margin-bottom:24px}.clib-signal-badge{font-size:12px;color:var(--accent);background:var(--accent-dim);padding:4px 10px;border-radius:6px;font-weight:500}.clib-source-badge{font-size:12px;color:var(--text-tertiary);background:var(--surface-2);padding:4px 10px;border-radius:6px;font-family:JetBrains Mono,monospace}.clib-preview{position:relative;border:1px solid var(--border);border-radius:12px;background:var(--bg);min-height:300px;overflow:hidden;display:flex;align-items:center;justify-content:center}.clib-empty-main{display:flex;align-items:center;justify-content:center;height:100%;color:var(--text-tertiary);font-size:15px}.sm-view{display:flex;flex-direction:column;height:100%}.sm-toolbar{display:flex;align-items:center;justify-content:space-between;padding:0 12px;height:36px;border-bottom:1px solid var(--border-subtle);flex-shrink:0}.sm-toolbar-left{display:flex;align-items:center;gap:8px}.sm-toolbar-right{display:flex;align-items:center;gap:4px}.sm-toolbar-count{font-size:12px;color:var(--text-tertiary)}.sm-toolbar-btn{display:flex;align-items:center;justify-content:center;padding:4px 8px;border-radius:6px;border:none;background:transparent;color:var(--text-tertiary);cursor:pointer;transition:all .15s}.sm-toolbar-btn:hover,.sm-toolbar-btn.active{color:var(--text);background:var(--accent-dim)}.sm-content{display:flex;flex:1;min-height:0}.sm-graph-area{flex:1;position:relative;min-width:0}.sm-graph-container{width:100%;height:100%;background:var(--bg)}.sm-loading{display:flex;align-items:center;justify-content:center;height:100%;color:var(--text-tertiary);font-size:13px}.sm-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100%;text-align:center;padding:40px}.sm-empty-title{font-size:16px;font-weight:500;color:var(--text-secondary);margin-bottom:8px}.sm-empty-desc{font-size:13px;color:var(--text-tertiary);max-width:340px;margin-bottom:16px;line-height:1.5}.sm-empty-btn{font-size:13px;padding:8px 16px;border-radius:6px;border:1px solid var(--border);background:transparent;color:var(--text);cursor:pointer;transition:all .15s}.sm-empty-btn:hover{background:var(--accent-dim)}.sm-sidebar{width:360px;border-left:1px solid var(--border-subtle);display:flex;flex-direction:column;flex-shrink:0;background:var(--bg)}.sm-sidebar-tabs{display:flex;flex-wrap:wrap;gap:4px;padding:8px 12px;border-bottom:1px solid var(--border-subtle);flex-shrink:0}.sm-sidebar-tab{font-size:10px;padding:4px 8px;border-radius:6px;border:none;background:transparent;color:var(--text-tertiary);cursor:pointer;transition:all .15s}.sm-sidebar-tab:hover{color:var(--text);background:var(--accent-dim)}.sm-sidebar-tab.active{color:var(--text);background:var(--accent-dim);font-weight:500}.sm-sidebar-content{flex:1;overflow-y:auto;padding:16px}.sm-entity-header{display:flex;align-items:baseline;justify-content:space-between;margin-bottom:12px}.sm-entity-title{font-size:13px;font-weight:600;color:var(--text)}.sm-entity-count{color:var(--text-tertiary);font-weight:400}.sm-entity-add-btn{font-size:12px;color:var(--text-tertiary);background:none;border:none;cursor:pointer;transition:color .15s}.sm-entity-add-btn:hover{color:var(--text)}.sm-entity-form{margin-bottom:16px;padding:12px;background:var(--accent-dim);border:1px solid var(--border-subtle);border-radius:8px;display:flex;flex-direction:column;gap:8px}.sm-entity-form-label{display:block;font-size:11px;color:var(--text-tertiary);margin-bottom:2px}.sm-entity-form-input{width:100%;font-size:13px;padding:6px 8px;background:var(--surface);border:1px solid var(--border);border-radius:6px;color:var(--text);outline:none;font-family:inherit;transition:border-color .15s}.sm-entity-form-input:focus{border-color:var(--text-tertiary)}.sm-entity-form-textarea{font-family:SF Mono,Fira Code,monospace;font-size:12px;resize:vertical}.sm-entity-form-submit{font-size:12px;padding:6px 12px;background:var(--accent);color:var(--accent-text);border:none;border-radius:6px;cursor:pointer;font-weight:500;transition:opacity .15s;align-self:flex-start}.sm-entity-form-submit:hover{opacity:.9}.sm-entity-list{display:flex;flex-direction:column;gap:1px}.sm-entity-item{display:flex;align-items:flex-start;justify-content:space-between;padding:8px;margin:0 -8px;border-radius:6px;transition:background .1s}.sm-entity-item:hover{background:var(--accent-dim)}.sm-entity-item-content{flex:1;min-width:0}.sm-entity-item-delete{font-size:11px;color:#ef4444;background:none;border:none;cursor:pointer;opacity:0;margin-left:8px;transition:opacity .1s}.sm-entity-item:hover .sm-entity-item-delete{opacity:1}.sm-entity-empty{font-size:13px;color:var(--text-tertiary);padding:16px 0}.sm-item-name{font-size:13px;font-weight:500;color:var(--text)}.sm-item-meta{font-size:12px;color:var(--text-tertiary)}.sm-item-detail{font-size:11px;color:var(--text-tertiary);font-family:SF Mono,Fira Code,monospace;margin-top:2px}.sm-node-content{text-align:left;line-height:1.3}.sm-node-name{font-weight:600;font-size:11px;color:#fff}.sm-node-sub{font-size:9px;color:#ffffff80;margin-bottom:2px}.sm-node-field{font-size:9px;color:#ffffffb3;font-family:SF Mono,Fira Code,monospace}.sm-node-field-type{color:#fff6}.sm-node-field-more{font-size:9px;color:#ffffff4d}.sm-graph-container .react-flow__node{font-family:Inter,-apple-system,BlinkMacSystemFont,sans-serif}.sm-graph-container .react-flow__controls{border-radius:8px;overflow:hidden;border:1px solid var(--border-subtle);box-shadow:0 4px 12px #0006}.sm-graph-container .react-flow__controls button{background:var(--surface);border:none;border-bottom:1px solid var(--border-subtle);color:var(--text-tertiary);width:28px;height:28px;display:flex;align-items:center;justify-content:center;transition:background .15s,color .15s}.sm-graph-container .react-flow__controls button:hover{background:var(--surface-2);color:var(--text)}.sm-graph-container .react-flow__controls button:last-child{border-bottom:none}.sm-graph-container .react-flow__controls button svg{fill:currentColor}.sm-graph-container .react-flow__controls button svg path{fill:currentColor}.sm-graph-container .react-flow__minimap{background:var(--bg)!important;border:1px solid var(--border-subtle);border-radius:6px}
