:root{--bg: #12141a;--bg-accent: #14161d;--bg-elevated: #1a1d25;--bg-hover: #262a35;--bg-muted: #262a35;--card: #181b22;--card-foreground: #f4f4f5;--card-highlight: rgba(255, 255, 255, .05);--popover: #181b22;--popover-foreground: #f4f4f5;--panel: #12141a;--panel-strong: #1a1d25;--panel-hover: #262a35;--chrome: rgba(18, 20, 26, .95);--chrome-strong: rgba(18, 20, 26, .98);--text: #e4e4e7;--text-strong: #fafafa;--chat-text: #e4e4e7;--muted: #71717a;--muted-strong: #52525b;--muted-foreground: #71717a;--border: #27272a;--border-strong: #3f3f46;--border-hover: #52525b;--input: #27272a;--ring: #ff5c5c;--accent: #ff5c5c;--accent-hover: #ff7070;--accent-muted: #ff5c5c;--accent-subtle: rgba(255, 92, 92, .15);--accent-foreground: #fafafa;--accent-glow: rgba(255, 92, 92, .25);--primary: #ff5c5c;--primary-foreground: #ffffff;--secondary: #1e2028;--secondary-foreground: #f4f4f5;--accent-2: #14b8a6;--accent-2-muted: rgba(20, 184, 166, .7);--accent-2-subtle: rgba(20, 184, 166, .15);--ok: #22c55e;--ok-muted: rgba(34, 197, 94, .75);--ok-subtle: rgba(34, 197, 94, .12);--destructive: #ef4444;--destructive-foreground: #fafafa;--warn: #f59e0b;--warn-muted: rgba(245, 158, 11, .75);--warn-subtle: rgba(245, 158, 11, .12);--danger: #ef4444;--danger-muted: rgba(239, 68, 68, .75);--danger-subtle: rgba(239, 68, 68, .12);--info: #3b82f6;--focus: rgba(255, 92, 92, .25);--focus-ring: 0 0 0 2px var(--bg), 0 0 0 4px var(--ring);--focus-glow: 0 0 0 2px var(--bg), 0 0 0 4px var(--ring), 0 0 20px var(--accent-glow);--grid-line: rgba(255, 255, 255, .04);--theme-switch-x: 50%;--theme-switch-y: 50%;--mono: "JetBrains Mono", ui-monospace, SFMono-Regular, "SF Mono", Menlo, Monaco, Consolas, monospace;--font-body: "Space Grotesk", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif;--font-display: "Space Grotesk", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif;--shadow-sm: 0 1px 2px rgba(0, 0, 0, .2);--shadow-md: 0 4px 12px rgba(0, 0, 0, .25), 0 0 0 1px rgba(255, 255, 255, .03);--shadow-lg: 0 12px 28px rgba(0, 0, 0, .35), 0 0 0 1px rgba(255, 255, 255, .03);--shadow-xl: 0 24px 48px rgba(0, 0, 0, .4), 0 0 0 1px rgba(255, 255, 255, .03);--shadow-glow: 0 0 30px var(--accent-glow);--radius-sm: 6px;--radius-md: 8px;--radius-lg: 12px;--radius-xl: 16px;--radius-full: 9999px;--radius: 8px;--ease-out: cubic-bezier(.16, 1, .3, 1);--ease-in-out: cubic-bezier(.4, 0, .2, 1);--ease-spring: cubic-bezier(.34, 1.56, .64, 1);--duration-fast: .12s;--duration-normal: .2s;--duration-slow: .35s;color-scheme:dark}:root[data-theme=light]{--bg: #fafafa;--bg-accent: #f5f5f5;--bg-elevated: #ffffff;--bg-hover: #f0f0f0;--bg-muted: #f0f0f0;--bg-content: #f5f5f5;--card: #ffffff;--card-foreground: #18181b;--card-highlight: rgba(0, 0, 0, .03);--popover: #ffffff;--popover-foreground: #18181b;--panel: #fafafa;--panel-strong: #f5f5f5;--panel-hover: #ebebeb;--chrome: rgba(250, 250, 250, .95);--chrome-strong: rgba(250, 250, 250, .98);--text: #3f3f46;--text-strong: #18181b;--chat-text: #3f3f46;--muted: #71717a;--muted-strong: #52525b;--muted-foreground: #71717a;--border: #e4e4e7;--border-strong: #d4d4d8;--border-hover: #a1a1aa;--input: #e4e4e7;--accent: #dc2626;--accent-hover: #ef4444;--accent-muted: #dc2626;--accent-subtle: rgba(220, 38, 38, .12);--accent-foreground: #ffffff;--accent-glow: rgba(220, 38, 38, .15);--primary: #dc2626;--primary-foreground: #ffffff;--secondary: #f4f4f5;--secondary-foreground: #3f3f46;--accent-2: #0d9488;--accent-2-muted: rgba(13, 148, 136, .75);--accent-2-subtle: rgba(13, 148, 136, .12);--ok: #16a34a;--ok-muted: rgba(22, 163, 74, .75);--ok-subtle: rgba(22, 163, 74, .1);--destructive: #dc2626;--destructive-foreground: #fafafa;--warn: #d97706;--warn-muted: rgba(217, 119, 6, .75);--warn-subtle: rgba(217, 119, 6, .1);--danger: #dc2626;--danger-muted: rgba(220, 38, 38, .75);--danger-subtle: rgba(220, 38, 38, .1);--info: #2563eb;--focus: rgba(220, 38, 38, .2);--focus-glow: 0 0 0 2px var(--bg), 0 0 0 4px var(--ring), 0 0 16px var(--accent-glow);--grid-line: rgba(0, 0, 0, .05);--shadow-sm: 0 1px 2px rgba(0, 0, 0, .06);--shadow-md: 0 4px 12px rgba(0, 0, 0, .08), 0 0 0 1px rgba(0, 0, 0, .04);--shadow-lg: 0 12px 28px rgba(0, 0, 0, .12), 0 0 0 1px rgba(0, 0, 0, .04);--shadow-xl: 0 24px 48px rgba(0, 0, 0, .15), 0 0 0 1px rgba(0, 0, 0, .04);--shadow-glow: 0 0 24px var(--accent-glow);color-scheme:light}*{box-sizing:border-box}html,body{height:100%}body{margin:0;font:400 14px/1.55 var(--font-body);letter-spacing:-.02em;background:var(--bg);color:var(--text);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}@keyframes theme-circle-transition{0%{clip-path:circle(0% at var(--theme-switch-x, 50%) var(--theme-switch-y, 50%))}to{clip-path:circle(150% at var(--theme-switch-x, 50%) var(--theme-switch-y, 50%))}}html.theme-transition{view-transition-name:theme}html.theme-transition::view-transition-old(theme){mix-blend-mode:normal;animation:none;z-index:1}html.theme-transition::view-transition-new(theme){mix-blend-mode:normal;z-index:2;animation:theme-circle-transition .4s var(--ease-out) forwards}@media(prefers-reduced-motion:reduce){html.theme-transition::view-transition-old(theme),html.theme-transition::view-transition-new(theme){animation:none!important}}openclaw-app{display:block;position:relative;z-index:1;min-height:100vh}a{color:var(--accent);text-decoration:none}a:hover{text-decoration:underline}button,input,textarea,select{font:inherit;color:inherit}::selection{background:var(--accent-subtle);color:var(--text-strong)}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--border);border-radius:var(--radius-full)}::-webkit-scrollbar-thumb:hover{background:var(--border-strong)}@keyframes rise{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}@keyframes fade-in{0%{opacity:0}to{opacity:1}}@keyframes scale-in{0%{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}@keyframes dashboard-enter{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}@keyframes shimmer{0%{background-position:-200% 0}to{background-position:200% 0}}@keyframes pulse-subtle{0%,to{opacity:1}50%{opacity:.7}}@keyframes glow-pulse{0%,to{box-shadow:0 0 #ff5c5c00}50%{box-shadow:0 0 20px var(--accent-glow)}}.stagger-1{animation-delay:0ms}.stagger-2{animation-delay:50ms}.stagger-3{animation-delay:.1s}.stagger-4{animation-delay:.15s}.stagger-5{animation-delay:.2s}.stagger-6{animation-delay:.25s}:focus-visible{outline:none;box-shadow:var(--focus-ring)}.shell{--shell-pad: 16px;--shell-gap: 16px;--shell-nav-width: 220px;--shell-topbar-height: 56px;--shell-focus-duration: .2s;--shell-focus-ease: var(--ease-out);height:100vh;display:grid;grid-template-columns:var(--shell-nav-width) minmax(0,1fr);grid-template-rows:var(--shell-topbar-height) 1fr;grid-template-areas:"topbar topbar" "nav content";gap:0;animation:dashboard-enter .4s var(--ease-out);transition:grid-template-columns var(--shell-focus-duration) var(--shell-focus-ease);overflow:hidden}@supports (height: 100dvh){.shell{height:100dvh}}.shell--chat{min-height:100vh;height:100vh;overflow:hidden}@supports (height: 100dvh){.shell--chat{height:100dvh}}.shell--nav-collapsed,.shell--chat-focus{grid-template-columns:0px minmax(0,1fr)}.shell--onboarding{grid-template-rows:0 1fr}.shell--onboarding .topbar{display:none}.shell--onboarding .content,.shell--chat-focus .content{padding-top:0}.shell--chat-focus .content>*+*{margin-top:0}.topbar{grid-area:topbar;position:sticky;top:0;z-index:40;display:flex;justify-content:space-between;align-items:center;gap:16px;padding:0 20px;height:var(--shell-topbar-height);border-bottom:1px solid var(--border);background:var(--bg)}.topbar-left{display:flex;align-items:center;gap:12px}.topbar .nav-collapse-toggle{width:36px;height:36px;margin-bottom:0}.topbar .nav-collapse-toggle__icon{width:20px;height:20px}.topbar .nav-collapse-toggle__icon svg{width:20px;height:20px}.brand{display:flex;align-items:center;gap:10px}.brand-logo{width:28px;height:28px;flex-shrink:0}.brand-logo img{width:100%;height:100%;object-fit:contain}.brand-text{display:flex;flex-direction:column;gap:1px}.brand-title{font-size:16px;font-weight:700;letter-spacing:-.03em;line-height:1.1;color:var(--text-strong)}.brand-sub{font-size:10px;font-weight:500;color:var(--muted);letter-spacing:.05em;text-transform:uppercase;line-height:1}.topbar-status{display:flex;align-items:center;gap:8px}.topbar-status .pill{padding:6px 10px;gap:6px;font-size:12px;font-weight:500;height:32px;box-sizing:border-box}.topbar-status .pill .mono{display:flex;align-items:center;line-height:1;margin-top:0}.topbar-status .statusDot{width:6px;height:6px}.topbar-status .theme-toggle{--theme-item: 24px;--theme-gap: 2px;--theme-pad: 3px}.topbar-status .theme-icon{width:12px;height:12px}.nav{grid-area:nav;overflow-y:auto;overflow-x:hidden;padding:16px 12px;background:var(--bg);scrollbar-width:none;transition:width var(--shell-focus-duration) var(--shell-focus-ease),padding var(--shell-focus-duration) var(--shell-focus-ease),opacity var(--shell-focus-duration) var(--shell-focus-ease);min-height:0}.nav::-webkit-scrollbar{display:none}.shell--chat-focus .nav{width:0;padding:0;border-width:0;overflow:hidden;pointer-events:none;opacity:0}.nav--collapsed{width:0;min-width:0;padding:0;overflow:hidden;border:none;opacity:0;pointer-events:none}.nav-collapse-toggle{width:32px;height:32px;display:flex;align-items:center;justify-content:center;background:transparent;border:1px solid transparent;border-radius:var(--radius-md);cursor:pointer;transition:background var(--duration-fast) ease,border-color var(--duration-fast) ease;margin-bottom:16px}.nav-collapse-toggle:hover{background:var(--bg-hover);border-color:var(--border)}.nav-collapse-toggle__icon{display:flex;align-items:center;justify-content:center;width:18px;height:18px;color:var(--muted);transition:color var(--duration-fast) ease}.nav-collapse-toggle__icon svg{width:18px;height:18px;stroke:currentColor;fill:none;stroke-width:1.5px;stroke-linecap:round;stroke-linejoin:round}.nav-collapse-toggle:hover .nav-collapse-toggle__icon{color:var(--text)}.nav-group{margin-bottom:20px;display:grid;gap:2px}.nav-group:last-child{margin-bottom:0}.nav-group__items{display:grid;gap:1px}.nav-label{display:flex;align-items:center;justify-content:space-between;gap:8px;width:100%;padding:6px 10px;font-size:11px;font-weight:500;color:var(--muted);margin-bottom:4px;background:transparent;border:none;cursor:pointer;text-align:left;border-radius:var(--radius-sm);transition:color var(--duration-fast) ease,background var(--duration-fast) ease}.nav-label:hover{color:var(--text);background:var(--bg-hover)}.nav-label--static{cursor:default}.nav-label--static:hover{color:var(--muted);background:transparent}.nav-label__text{flex:1}.nav-label__chevron{font-size:10px;opacity:.5;transition:transform var(--duration-fast) ease}.nav-item{position:relative;display:flex;align-items:center;justify-content:flex-start;gap:10px;padding:8px 10px;border-radius:var(--radius-md);border:1px solid transparent;background:transparent;color:var(--muted);cursor:pointer;text-decoration:none;transition:border-color var(--duration-fast) ease,background var(--duration-fast) ease,color var(--duration-fast) ease}.nav-item__icon{width:16px;height:16px;display:flex;align-items:center;justify-content:center;flex-shrink:0;opacity:.7;transition:opacity var(--duration-fast) ease}.nav-item__icon svg{width:16px;height:16px;stroke:currentColor;fill:none;stroke-width:1.5px;stroke-linecap:round;stroke-linejoin:round}.nav-item__text{font-size:13px;font-weight:500;white-space:nowrap}.nav-item:hover{color:var(--text);background:var(--bg-hover);text-decoration:none}.nav-item:hover .nav-item__icon{opacity:1}.nav-item.active{color:var(--text-strong);background:var(--accent-subtle)}.nav-item.active .nav-item__icon{opacity:1;color:var(--accent)}.content{grid-area:content;padding:12px 16px 32px;display:block;min-height:0;overflow-y:auto;overflow-x:hidden}.content>*+*{margin-top:24px}:root[data-theme=light] .content{background:var(--bg-content)}.content--chat{display:flex;flex-direction:column;gap:24px;overflow:hidden;padding-bottom:0}.content--chat>*+*{margin-top:0}.content-header{display:flex;align-items:flex-end;justify-content:space-between;gap:16px;padding:4px 8px;overflow:hidden;transform-origin:top center;transition:opacity var(--shell-focus-duration) var(--shell-focus-ease),transform var(--shell-focus-duration) var(--shell-focus-ease),max-height var(--shell-focus-duration) var(--shell-focus-ease),padding var(--shell-focus-duration) var(--shell-focus-ease);max-height:80px}.shell--chat-focus .content-header{opacity:0;transform:translateY(-8px);max-height:0px;padding:0;pointer-events:none}.page-title{font-size:26px;font-weight:700;letter-spacing:-.035em;line-height:1.15;color:var(--text-strong)}.page-sub{color:var(--muted);font-size:14px;font-weight:400;margin-top:6px;letter-spacing:-.01em}.page-meta{display:flex;gap:8px}.content--chat .content-header{flex-direction:row;align-items:center;justify-content:space-between;gap:16px}.content--chat .content-header>div:first-child{text-align:left}.content--chat .page-meta{justify-content:flex-start}.content--chat .chat-controls{flex-shrink:0}.grid{display:grid;gap:20px}.grid-cols-2{grid-template-columns:repeat(2,minmax(0,1fr))}.grid-cols-3{grid-template-columns:repeat(3,minmax(0,1fr))}.stat-grid{display:grid;gap:14px;grid-template-columns:repeat(auto-fit,minmax(150px,1fr))}.note-grid{display:grid;gap:16px;grid-template-columns:repeat(auto-fit,minmax(220px,1fr))}.row{display:flex;gap:12px;align-items:center}.stack{display:grid;gap:12px;grid-template-columns:minmax(0,1fr)}.filters{display:flex;flex-wrap:wrap;gap:8px;align-items:center}@media(max-width:1100px){.shell{--shell-pad: 12px;--shell-gap: 12px;grid-template-columns:1fr;grid-template-rows:auto auto 1fr;grid-template-areas:"topbar" "nav" "content"}.nav{position:static;max-height:none;display:flex;gap:6px;overflow-x:auto;border-right:none;border-bottom:1px solid var(--border);padding:10px 14px;background:var(--bg)}.nav-group{grid-auto-flow:column;grid-template-columns:repeat(auto-fit,minmax(100px,1fr));margin-bottom:0}.grid-cols-2,.grid-cols-3{grid-template-columns:1fr}.topbar{position:static;padding:12px 14px;gap:10px}.topbar-status{flex-wrap:wrap}.table-head,.table-row,.list-item{grid-template-columns:1fr}}@media(max-width:600px){.shell{--shell-pad: 8px;--shell-gap: 8px}.topbar{padding:10px 12px;gap:8px;flex-direction:row;flex-wrap:wrap;justify-content:space-between;align-items:center}.brand{flex:1;min-width:0}.brand-title{font-size:14px}.brand-sub{display:none}.topbar-status{gap:6px;width:auto;flex-wrap:nowrap}.topbar-status .pill{padding:4px 8px;font-size:11px;gap:4px}.topbar-status .pill .mono{display:none}.topbar-status .pill span:nth-child(2){display:none}.content-header{display:none}.content{padding:4px 4px 16px;gap:12px}.card{padding:12px;border-radius:var(--radius-md)}.card-title{font-size:13px}.stat-grid{gap:8px;grid-template-columns:repeat(2,1fr)}.stat{padding:10px;border-radius:var(--radius-md)}.stat-label{font-size:11px}.stat-value{font-size:18px}.note-grid{grid-template-columns:1fr;gap:8px}.form-grid{grid-template-columns:1fr;gap:10px}.field input,.field textarea,.field select{padding:8px 10px;border-radius:var(--radius-md);font-size:14px}.btn{padding:8px 12px;font-size:12px}.pill{padding:4px 10px;font-size:12px}.chat-header{flex-direction:column;align-items:stretch;gap:8px}.chat-header__left{flex-direction:column;align-items:stretch}.chat-header__right{justify-content:space-between}.chat-session{min-width:unset;width:100%}.chat-thread{margin-top:8px;padding:12px 8px}.chat-msg{max-width:90%}.chat-bubble{padding:8px 12px;border-radius:var(--radius-md)}.chat-compose{gap:8px}.chat-compose__field textarea{min-height:60px;padding:8px 10px;border-radius:var(--radius-md);font-size:14px}.log-stream{border-radius:var(--radius-md);max-height:380px}.log-row{grid-template-columns:1fr;gap:4px;padding:8px}.log-time{font-size:10px}.log-level{font-size:9px}.log-subsystem{font-size:11px}.log-message{font-size:12px}.list-item{padding:10px;border-radius:var(--radius-md)}.list-title{font-size:13px}.list-sub{font-size:11px}.code-block{padding:8px;border-radius:var(--radius-md);font-size:11px}.theme-toggle{--theme-item: 24px;--theme-gap: 2px;--theme-pad: 3px}.theme-icon{width:12px;height:12px}}@media(max-width:400px){.shell{--shell-pad: 4px}.topbar{padding:8px 10px}.brand-title{font-size:13px}.nav{padding:6px 8px}.nav-item{padding:6px 8px;font-size:11px}.content{padding:4px 4px 12px;gap:10px}.card{padding:10px}.stat{padding:8px}.stat-value{font-size:16px}.chat-bubble{padding:8px 10px}.chat-compose__field textarea{min-height:52px;padding:8px 10px;font-size:13px}.btn{padding:6px 10px;font-size:11px}.topbar-status .pill{padding:3px 6px;font-size:10px}.theme-toggle{--theme-item: 22px;--theme-gap: 2px;--theme-pad: 2px}.theme-icon{width:11px;height:11px}}.chat{position:relative;display:flex;flex-direction:column;flex:1 1 0;height:100%;min-height:0;overflow:hidden;background:transparent!important;border:none!important;box-shadow:none!important}.chat-header{display:flex;justify-content:space-between;align-items:center;gap:12px;flex-wrap:nowrap;flex-shrink:0;padding-bottom:12px;margin-bottom:12px;background:transparent}.chat-header__left{display:flex;align-items:center;gap:12px;flex-wrap:wrap;min-width:0}.chat-session{min-width:180px}.chat-thread{flex:1 1 0;overflow-y:auto;overflow-x:hidden;overflow-anchor:auto;padding:12px 4px;margin:0 -4px;min-height:0;border-radius:12px;background:transparent}.chat-focus-exit{position:absolute;top:12px;right:12px;z-index:100;width:32px;height:32px;border-radius:50%;border:1px solid var(--border);background:var(--panel);color:var(--muted);font-size:20px;line-height:1;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .15s ease-out,color .15s ease-out,border-color .15s ease-out;box-shadow:0 4px 12px #0003}.chat-focus-exit:hover{background:var(--panel-strong);color:var(--text);border-color:var(--accent)}.chat-focus-exit svg{width:16px;height:16px;stroke:currentColor;fill:none;stroke-width:2px;stroke-linecap:round;stroke-linejoin:round}.chat-new-messages{align-self:center;display:inline-flex;align-items:center;gap:6px;padding:6px 14px;margin:8px auto;font-size:13px;font-family:var(--font-body);color:var(--text);background:var(--panel-strong);border:1px solid var(--border);border-radius:999px;cursor:pointer;white-space:nowrap;z-index:10;transition:background .15s ease-out,border-color .15s ease-out}.chat-new-messages:hover{background:var(--panel);border-color:var(--accent)}.chat-new-messages svg{width:16px;height:16px;stroke:currentColor;fill:none;stroke-width:1.5px;stroke-linecap:round;stroke-linejoin:round;flex-shrink:0}.chat-compose{position:sticky;bottom:0;flex-shrink:0;display:flex;flex-direction:column;gap:12px;margin-top:auto;padding:12px 4px 4px;background:linear-gradient(to bottom,transparent,var(--bg) 20%);z-index:10}.chat-attachments{display:inline-flex;flex-wrap:wrap;gap:8px;padding:8px;background:var(--panel);border-radius:8px;border:1px solid var(--border);width:fit-content;max-width:100%;align-self:flex-start}.chat-attachment{position:relative;width:80px;height:80px;border-radius:6px;overflow:hidden;border:1px solid var(--border);background:var(--bg)}.chat-attachment__img{width:100%;height:100%;object-fit:contain}.chat-attachment__remove{position:absolute;top:4px;right:4px;width:20px;height:20px;border-radius:50%;border:none;background:#000000b3;color:#fff;font-size:12px;line-height:1;cursor:pointer;display:flex;align-items:center;justify-content:center;opacity:0;transition:opacity .15s ease-out}.chat-attachment:hover .chat-attachment__remove{opacity:1}.chat-attachment__remove:hover{background:#dc2626e6}.chat-attachment__remove svg{width:12px;height:12px;stroke:currentColor;fill:none;stroke-width:2px}:root[data-theme=light] .chat-attachments{background:#f8fafc;border-color:#1018281a}:root[data-theme=light] .chat-attachment{border-color:#10182826;background:#fff}:root[data-theme=light] .chat-attachment__remove{background:#0009}.chat-message-images{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:8px}.chat-message-image{max-width:300px;max-height:200px;border-radius:8px;object-fit:contain;cursor:pointer;transition:transform .15s ease-out}.chat-message-image:hover{transform:scale(1.02)}.chat-group.user .chat-message-images{justify-content:flex-end}.chat-compose__row{display:flex;align-items:stretch;gap:12px;flex:1}:root[data-theme=light] .chat-compose{background:linear-gradient(to bottom,transparent,var(--bg-content) 20%)}.chat-compose__field{flex:1 1 auto;min-width:0;display:flex;align-items:stretch}.chat-compose__field>span{display:none}.chat-compose .chat-compose__field textarea{width:100%;height:40px;min-height:40px;max-height:150px;padding:9px 12px;border-radius:8px;overflow-y:auto;resize:none;white-space:pre-wrap;font-family:var(--font-body);font-size:14px;line-height:1.45}.chat-compose__field textarea:disabled{opacity:.7;cursor:not-allowed}.chat-compose__actions{flex-shrink:0;display:flex;align-items:stretch;gap:8px}.chat-compose .chat-compose__actions .btn{padding:0 16px;font-size:13px;height:40px;min-height:40px;max-height:40px;line-height:1;white-space:nowrap;box-sizing:border-box}.chat-controls{display:flex;align-items:center;justify-content:flex-start;gap:12px;flex-wrap:wrap}.chat-controls__session{min-width:140px;max-width:300px}.chat-controls__thinking{display:flex;align-items:center;gap:6px;font-size:13px}.btn--icon{padding:8px!important;min-width:36px;height:36px;display:inline-flex;align-items:center;justify-content:center;border:1px solid var(--border);background:#ffffff0f}.chat-controls__separator{color:#fff6;font-size:18px;margin:0 8px;font-weight:300}:root[data-theme=light] .chat-controls__separator{color:#1018284d}.btn--icon:hover{background:#ffffff1f;border-color:#fff3}:root[data-theme=light] .btn--icon{background:#fff;border-color:var(--border);box-shadow:0 1px 2px #1018280d;color:var(--muted)}:root[data-theme=light] .btn--icon:hover{background:#fff;border-color:var(--border-strong);color:var(--text)}.btn--icon svg{display:block;width:18px;height:18px;stroke:currentColor;fill:none;stroke-width:1.5px;stroke-linecap:round;stroke-linejoin:round}.chat-controls__session select{padding:6px 10px;font-size:13px;max-width:300px;overflow:hidden;text-overflow:ellipsis}.chat-controls__thinking{display:flex;align-items:center;gap:4px;font-size:12px;padding:4px 10px;background:#ffffff0a;border-radius:6px;border:1px solid var(--border)}:root[data-theme=light] .chat-controls__thinking{background:#ffffffe6;border-color:#10182826}@media(max-width:640px){.chat-session{min-width:140px}.chat-compose{grid-template-columns:1fr}.chat-controls{flex-wrap:wrap;gap:8px}.chat-controls__session{min-width:120px}}.chat-thinking{margin-bottom:10px;padding:10px 12px;border-radius:10px;border:1px dashed rgba(255,255,255,.18);background:#ffffff0a;color:var(--muted);font-size:12px;line-height:1.4}:root[data-theme=light] .chat-thinking{border-color:#10182840;background:#1018280a}.chat-text{font-size:14px;line-height:1.5;word-wrap:break-word;overflow-wrap:break-word}.chat-text :where(p+p,p+ul,p+ol,p+pre,p+blockquote){margin-top:.75em}.chat-text :where(ul,ol){padding-left:1.5em}.chat-text :where(a){color:var(--accent);text-decoration:underline;text-underline-offset:2px}.chat-text :where(a:hover){opacity:.8}.chat-text :where(:not(pre)>code){background:#00000026;padding:.15em .4em;border-radius:4px}.chat-text :where(pre){background:#00000026;border-radius:6px;padding:10px 12px;overflow-x:auto}.chat-text :where(pre code){background:none;padding:0}.chat-text :where(blockquote){border-left:3px solid var(--border-strong);margin-left:0;color:var(--muted);background:#ffffff05;padding:8px 12px;border-radius:0 var(--radius-sm) var(--radius-sm) 0}.chat-text :where(blockquote blockquote){margin-top:8px;border-left-color:var(--border-hover);background:#ffffff08}.chat-text :where(blockquote blockquote blockquote){border-left-color:var(--muted-strong);background:#ffffff0a}:root[data-theme=light] .chat-text :where(blockquote){background:#00000008}:root[data-theme=light] .chat-text :where(blockquote blockquote){background:#0000000d}:root[data-theme=light] .chat-text :where(blockquote blockquote blockquote){background:#0000000a}:root[data-theme=light] .chat-text :where(:not(pre)>code){background:#00000014;border:1px solid rgba(0,0,0,.1)}:root[data-theme=light] .chat-text :where(pre){background:#0000000d;border:1px solid rgba(0,0,0,.1)}.chat-text :where(hr){border:none;border-top:1px solid var(--border);margin:1em 0}.chat-text[dir=rtl]{text-align:right}.chat-text[dir=rtl] :where(ul,ol){padding-left:0;padding-right:1.5em}.chat-text[dir=rtl] :where(blockquote){border-left:none;border-right:3px solid var(--border);padding-left:0;padding-right:1em}.chat-group{display:flex;gap:12px;align-items:flex-start;margin-bottom:16px;margin-left:4px;margin-right:16px}.chat-group.user{flex-direction:row-reverse;justify-content:flex-start}.chat-group-messages{display:flex;flex-direction:column;gap:2px;max-width:min(900px,calc(100% - 60px))}.chat-group.user .chat-group-messages{align-items:flex-end}.chat-group.user .chat-group-footer{justify-content:flex-end}.chat-group-footer{display:flex;gap:8px;align-items:baseline;margin-top:6px}.chat-sender-name{font-weight:500;font-size:12px;color:var(--muted)}.chat-group-timestamp{font-size:11px;color:var(--muted);opacity:.7}.chat-divider{display:flex;align-items:center;gap:10px;margin:18px 8px;color:var(--muted);font-size:11px;letter-spacing:.08em;text-transform:uppercase;-webkit-user-select:none;user-select:none}.chat-divider__line{flex:1 1 0;height:1px;background:var(--border);opacity:.9}.chat-divider__label{padding:2px 10px;border:1px solid var(--border);border-radius:999px;background:#ffffff05}.chat-avatar{width:40px;height:40px;border-radius:8px;background:var(--panel-strong);display:grid;place-items:center;font-weight:600;font-size:14px;flex-shrink:0;align-self:flex-end;margin-bottom:4px}.chat-avatar.user{background:var(--accent-subtle);color:var(--accent)}.chat-avatar.assistant,.chat-avatar.other,.chat-avatar.tool{background:var(--secondary);color:var(--muted)}img.chat-avatar{display:block;object-fit:cover;object-position:center}.chat-bubble{position:relative;display:inline-block;border:1px solid transparent;background:var(--card);border-radius:var(--radius-lg);padding:10px 14px;box-shadow:none;transition:background .15s ease-out,border-color .15s ease-out;max-width:100%;word-wrap:break-word}.chat-bubble.has-copy{padding-right:36px}.chat-copy-btn{position:absolute;top:6px;right:8px;border:1px solid var(--border);background:var(--bg);color:var(--muted);border-radius:var(--radius-md);padding:4px 6px;font-size:14px;line-height:1;cursor:pointer;opacity:0;pointer-events:none;transition:opacity .12s ease-out,background .12s ease-out}.chat-copy-btn__icon{display:inline-flex;width:14px;height:14px;position:relative}.chat-copy-btn__icon svg{width:14px;height:14px;stroke:currentColor;fill:none;stroke-width:1.5px;stroke-linecap:round;stroke-linejoin:round}.chat-copy-btn__icon-copy,.chat-copy-btn__icon-check{position:absolute;top:0;left:0;transition:opacity .15s ease}.chat-copy-btn__icon-check,.chat-copy-btn[data-copied="1"] .chat-copy-btn__icon-copy{opacity:0}.chat-copy-btn[data-copied="1"] .chat-copy-btn__icon-check{opacity:1}.chat-bubble:hover .chat-copy-btn{opacity:1;pointer-events:auto}.chat-copy-btn:hover{background:var(--bg-hover)}.chat-copy-btn[data-copying="1"]{opacity:0;pointer-events:none}.chat-copy-btn[data-error="1"]{opacity:1;pointer-events:auto;border-color:var(--danger-subtle);background:var(--danger-subtle);color:var(--danger)}.chat-copy-btn[data-copied="1"]{opacity:1;pointer-events:auto;border-color:var(--ok-subtle);background:var(--ok-subtle);color:var(--ok)}.chat-copy-btn:focus-visible{opacity:1;pointer-events:auto;outline:2px solid var(--accent);outline-offset:2px}@media(hover:none){.chat-copy-btn{opacity:1;pointer-events:auto}}:root[data-theme=light] .chat-bubble{border-color:var(--border);box-shadow:inset 0 1px 0 var(--card-highlight)}.chat-bubble:hover{background:var(--bg-hover)}.chat-group.user .chat-bubble{background:var(--accent-subtle);border-color:transparent}:root[data-theme=light] .chat-group.user .chat-bubble{border-color:#ea580c33;background:#fb923c1f}.chat-group.user .chat-bubble:hover{background:#ff4d4d26}.chat-bubble.streaming{animation:pulsing-border 1.5s ease-out infinite}@keyframes pulsing-border{0%,to{border-color:var(--border)}50%{border-color:var(--accent)}}.chat-bubble.fade-in{animation:fade-in .2s ease-out}@keyframes fade-in{0%{opacity:0;transform:translateY(4px)}to{opacity:1;transform:translateY(0)}}.chat-tool-card{border:1px solid var(--border);border-radius:8px;padding:12px;margin-top:8px;background:var(--card);box-shadow:inset 0 1px 0 var(--card-highlight);transition:border-color .15s ease-out,background .15s ease-out;max-height:120px;overflow:hidden}.chat-tool-card:hover{border-color:var(--border-strong);background:var(--bg-hover)}.chat-tool-card:first-child{margin-top:0}.chat-tool-card--clickable{cursor:pointer}.chat-tool-card--clickable:focus{outline:2px solid var(--accent);outline-offset:2px}.chat-tool-card__header{display:flex;justify-content:space-between;align-items:center;gap:8px}.chat-tool-card__title{display:inline-flex;align-items:center;gap:6px;font-weight:600;font-size:13px;line-height:1.2}.chat-tool-card__icon{display:inline-flex;align-items:center;justify-content:center;width:16px;height:16px;flex-shrink:0}.chat-tool-card__icon svg{width:14px;height:14px;stroke:currentColor;fill:none;stroke-width:1.5px;stroke-linecap:round;stroke-linejoin:round}.chat-tool-card__action{display:inline-flex;align-items:center;gap:4px;font-size:12px;color:var(--accent);opacity:.8;transition:opacity .15s ease-out}.chat-tool-card__action svg{width:12px;height:12px;stroke:currentColor;fill:none;stroke-width:1.5px;stroke-linecap:round;stroke-linejoin:round}.chat-tool-card--clickable:hover .chat-tool-card__action{opacity:1}.chat-tool-card__status{display:inline-flex;align-items:center;color:var(--ok)}.chat-tool-card__status svg{width:14px;height:14px;stroke:currentColor;fill:none;stroke-width:2px;stroke-linecap:round;stroke-linejoin:round}.chat-tool-card__status-text{font-size:11px;margin-top:4px}.chat-tool-card__detail{font-size:12px;color:var(--muted);margin-top:4px}.chat-tool-card__preview{font-size:11px;color:var(--muted);margin-top:8px;padding:8px 10px;background:var(--secondary);border-radius:var(--radius-md);white-space:pre-wrap;overflow:hidden;max-height:44px;line-height:1.4;border:1px solid var(--border)}.chat-tool-card--clickable:hover .chat-tool-card__preview{background:var(--bg-hover);border-color:var(--border-strong)}.chat-tool-card__inline{font-size:11px;color:var(--text);margin-top:6px;padding:6px 8px;background:var(--secondary);border-radius:var(--radius-sm);white-space:pre-wrap;word-break:break-word}.chat-reading-indicator{background:transparent;border:1px solid var(--border);padding:12px;display:inline-flex}.chat-reading-indicator__dots{display:flex;gap:6px;align-items:center}.chat-reading-indicator__dots span{width:6px;height:6px;border-radius:50%;background:var(--muted);animation:reading-pulse 1.4s ease-in-out infinite}.chat-reading-indicator__dots span:nth-child(1){animation-delay:0s}.chat-reading-indicator__dots span:nth-child(2){animation-delay:.2s}.chat-reading-indicator__dots span:nth-child(3){animation-delay:.4s}@keyframes reading-pulse{0%,60%,to{opacity:.3;transform:scale(.8)}30%{opacity:1;transform:scale(1)}}.chat-split-container{display:flex;gap:0;flex:1;min-height:0;height:100%}.chat-main{min-width:400px;display:flex;flex-direction:column;overflow:hidden;transition:flex .25s ease-out}.chat-sidebar{flex:1;min-width:300px;border-left:1px solid var(--border);display:flex;flex-direction:column;overflow:hidden;animation:slide-in .2s ease-out}@keyframes slide-in{0%{opacity:0;transform:translate(20px)}to{opacity:1;transform:translate(0)}}.sidebar-panel{display:flex;flex-direction:column;height:100%;background:var(--panel)}.sidebar-header{display:flex;justify-content:space-between;align-items:center;padding:12px 16px;border-bottom:1px solid var(--border);flex-shrink:0;position:sticky;top:0;z-index:10;background:var(--panel)}.sidebar-header .btn{padding:4px 8px;font-size:14px;min-width:auto;line-height:1}.sidebar-title{font-weight:600;font-size:14px}.sidebar-content{flex:1;overflow:auto;padding:16px}.sidebar-markdown{font-size:14px;line-height:1.5}.sidebar-markdown pre{background:#0000001f;border-radius:4px;padding:12px;overflow-x:auto}.sidebar-markdown code{font-family:var(--mono);font-size:13px}@media(max-width:768px){.chat-split-container--open{position:fixed;inset:0;z-index:1000}.chat-split-container--open .chat-main{display:none}.chat-split-container--open .chat-sidebar{width:100%;min-width:0;border-left:none}}.update-banner{position:sticky;top:0;z-index:10;margin:0 calc(-1 * var(--shell-pad)) 0;border-radius:0;border-left:none;border-right:none;text-align:center;font-weight:500;padding:10px 16px}.update-banner__btn{margin-left:8px;border-color:var(--danger);color:var(--danger);font-size:12px;padding:4px 12px}.update-banner__btn:hover:not(:disabled){background:#ef444426}.card{border:1px solid var(--border);background:var(--card);border-radius:var(--radius-lg);padding:20px;animation:rise .35s var(--ease-out) backwards;transition:border-color var(--duration-normal) var(--ease-out),box-shadow var(--duration-normal) var(--ease-out),transform var(--duration-normal) var(--ease-out);box-shadow:var(--shadow-sm),inset 0 1px 0 var(--card-highlight)}.card:hover{border-color:var(--border-strong);box-shadow:var(--shadow-md),inset 0 1px 0 var(--card-highlight)}.card-title{font-size:15px;font-weight:600;letter-spacing:-.02em;color:var(--text-strong)}.card-sub{color:var(--muted);font-size:13px;margin-top:6px;line-height:1.5}.stat{background:var(--card);border-radius:var(--radius-md);padding:14px 16px;border:1px solid var(--border);transition:border-color var(--duration-normal) var(--ease-out),box-shadow var(--duration-normal) var(--ease-out);box-shadow:inset 0 1px 0 var(--card-highlight)}.stat:hover{border-color:var(--border-strong);box-shadow:var(--shadow-sm),inset 0 1px 0 var(--card-highlight)}.stat-label{color:var(--muted);font-size:11px;font-weight:500;text-transform:uppercase;letter-spacing:.04em}.stat-value{font-size:24px;font-weight:700;margin-top:6px;letter-spacing:-.03em;line-height:1.1}.stat-value.ok{color:var(--ok)}.stat-value.warn{color:var(--warn)}.stat-card{display:grid;gap:6px}.note-title{font-weight:600;letter-spacing:-.01em}.status-list{display:grid;gap:8px}.status-list div{display:flex;justify-content:space-between;gap:12px;padding:8px 0;border-bottom:1px solid var(--border)}.status-list div:last-child{border-bottom:none}.account-count{margin-top:10px;font-size:12px;font-weight:500;color:var(--muted)}.account-card-list{margin-top:16px;display:grid;gap:12px}.account-card{border:1px solid var(--border);border-radius:var(--radius-md);padding:12px;background:var(--bg-elevated);transition:border-color var(--duration-fast) ease}.account-card:hover{border-color:var(--border-strong)}.account-card-header{display:flex;justify-content:space-between;align-items:baseline;gap:12px}.account-card-title{font-weight:500}.account-card-id{font-family:var(--mono);font-size:12px;color:var(--muted)}.account-card-status{margin-top:10px;font-size:13px}.account-card-status div{padding:4px 0}.account-card-error{margin-top:8px;color:var(--danger);font-size:12px}.label{color:var(--muted);font-size:12px;font-weight:500}.pill{display:inline-flex;align-items:center;gap:6px;border:1px solid var(--border);padding:6px 12px;border-radius:var(--radius-full);background:var(--secondary);font-size:13px;font-weight:500;transition:border-color var(--duration-fast) ease}.pill:hover{border-color:var(--border-strong)}.pill.danger{border-color:var(--danger-subtle);background:var(--danger-subtle);color:var(--danger)}.theme-toggle{--theme-item: 28px;--theme-gap: 2px;--theme-pad: 4px;position:relative}.theme-toggle__track{position:relative;display:grid;grid-template-columns:repeat(3,var(--theme-item));gap:var(--theme-gap);padding:var(--theme-pad);border-radius:var(--radius-full);border:1px solid var(--border);background:var(--secondary)}.theme-toggle__indicator{position:absolute;top:50%;left:var(--theme-pad);width:var(--theme-item);height:var(--theme-item);border-radius:var(--radius-full);transform:translateY(-50%) translate(calc(var(--theme-index, 0) * (var(--theme-item) + var(--theme-gap))));background:var(--accent);transition:transform var(--duration-normal) var(--ease-out);z-index:0}.theme-toggle__button{height:var(--theme-item);width:var(--theme-item);display:grid;place-items:center;border:0;border-radius:var(--radius-full);background:transparent;color:var(--muted);cursor:pointer;position:relative;z-index:1;transition:color var(--duration-fast) ease}.theme-toggle__button:hover{color:var(--text)}.theme-toggle__button.active{color:var(--accent-foreground)}.theme-toggle__button.active .theme-icon{stroke:var(--accent-foreground)}.theme-icon{width:14px;height:14px;stroke:currentColor;fill:none;stroke-width:1.5px;stroke-linecap:round;stroke-linejoin:round}.statusDot{width:8px;height:8px;border-radius:var(--radius-full);background:var(--danger);box-shadow:0 0 8px #ef444480;animation:pulse-subtle 2s ease-in-out infinite}.statusDot.ok{background:var(--ok);box-shadow:0 0 8px #22c55e80;animation:none}.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;border:1px solid var(--border);background:var(--bg-elevated);padding:9px 16px;border-radius:var(--radius-md);font-size:13px;font-weight:500;letter-spacing:-.01em;cursor:pointer;transition:border-color var(--duration-fast) var(--ease-out),background var(--duration-fast) var(--ease-out),box-shadow var(--duration-fast) var(--ease-out),transform var(--duration-fast) var(--ease-out)}.btn:hover{background:var(--bg-hover);border-color:var(--border-strong);transform:translateY(-1px);box-shadow:var(--shadow-sm)}.btn:active{background:var(--secondary);transform:translateY(0);box-shadow:none}.btn svg{width:16px;height:16px;stroke:currentColor;fill:none;stroke-width:1.5px;stroke-linecap:round;stroke-linejoin:round;flex-shrink:0}.btn.primary,.btn.btn-primary{border-color:var(--accent);background:var(--accent);color:var(--primary-foreground);box-shadow:0 1px 2px #0003}.btn.primary:hover,.btn.btn-primary:hover{background:var(--accent-hover);border-color:var(--accent-hover);box-shadow:var(--shadow-md),0 0 20px var(--accent-glow)}.btn-kbd{display:inline-flex;align-items:center;justify-content:center;margin-left:6px;padding:2px 5px;font-family:var(--mono);font-size:11px;font-weight:500;line-height:1;border-radius:4px;background:#ffffff26;color:inherit;opacity:.8}.btn.primary .btn-kbd{background:#fff3}:root[data-theme=light] .btn-kbd{background:#00000014}:root[data-theme=light] .btn.primary .btn-kbd{background:#ffffff40}.btn.active{border-color:var(--accent);background:var(--accent-subtle);color:var(--accent)}.btn.danger{border-color:transparent;background:var(--danger-subtle);color:var(--danger)}.btn.danger:hover{background:#ef444426}.btn--sm,.btn.btn-sm{padding:6px 10px;font-size:12px}.btn:disabled{opacity:.5;cursor:not-allowed}.field{display:grid;gap:6px}.field.full{grid-column:1 / -1}.field span{color:var(--muted);font-size:13px;font-weight:500}.field input,.field textarea,.field select{border:1px solid var(--input);background:var(--card);border-radius:var(--radius-md);padding:8px 12px;outline:none;box-shadow:inset 0 1px 0 var(--card-highlight);transition:border-color var(--duration-fast) ease,box-shadow var(--duration-fast) ease}.field input:focus,.field textarea:focus,.field select:focus{border-color:var(--ring);box-shadow:var(--focus-ring)}.field select{appearance:none;padding-right:36px;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='%23a1a1aa' stroke-width='2'%3E%3Cpolyline points='6 9 12 15 18 9'%3E%3C/polyline%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 10px center;cursor:pointer}.field textarea{font-family:var(--mono);min-height:160px;resize:vertical;white-space:pre;line-height:1.5}.field.checkbox{grid-template-columns:auto 1fr;align-items:center}.config-form .field.checkbox{grid-template-columns:18px minmax(0,1fr);column-gap:10px}.config-form .field.checkbox input[type=checkbox]{margin:0;width:16px;height:16px;accent-color:var(--accent)}.form-grid{display:grid;gap:12px;grid-template-columns:repeat(auto-fit,minmax(200px,1fr))}:root[data-theme=light] .field input,:root[data-theme=light] .field textarea,:root[data-theme=light] .field select{background:var(--card);border-color:var(--input)}:root[data-theme=light] .btn{background:var(--bg);border-color:var(--input)}:root[data-theme=light] .btn:hover{background:var(--bg-hover)}:root[data-theme=light] .btn.primary{background:var(--accent);border-color:var(--accent)}.muted{color:var(--muted)}.mono{font-family:var(--mono)}.callout{padding:14px 16px;border-radius:var(--radius-md);background:var(--secondary);border:1px solid var(--border);font-size:13px;line-height:1.5;position:relative}.callout.danger{border-color:#ef444440;background:linear-gradient(135deg,#ef444414,#ef44440a);color:var(--danger)}.callout.info{border-color:#3b82f640;background:linear-gradient(135deg,#3b82f614,#3b82f60a);color:var(--info)}.callout.success{border-color:#22c55e40;background:linear-gradient(135deg,#22c55e14,#22c55e0a);color:var(--ok)}.compaction-indicator{align-self:center;display:inline-flex;align-items:center;gap:6px;font-size:13px;line-height:1.2;padding:6px 14px;margin-bottom:8px;border-radius:999px;border:1px solid var(--border);background:var(--panel-strong);color:var(--text);white-space:nowrap;-webkit-user-select:none;user-select:none;animation:fade-in .2s var(--ease-out)}.compaction-indicator svg{width:16px;height:16px;stroke:currentColor;fill:none;stroke-width:1.5px;stroke-linecap:round;stroke-linejoin:round;flex-shrink:0}.compaction-indicator--active{color:var(--info);border-color:#3b82f659}.compaction-indicator--active svg{animation:compaction-spin 1s linear infinite}.compaction-indicator--complete{color:var(--ok);border-color:#22c55e59}.compaction-indicator--fallback{color:#d97706;border-color:#d9770659}.compaction-indicator--fallback-cleared{color:var(--ok);border-color:#22c55e59}@keyframes compaction-spin{to{transform:rotate(360deg)}}.code-block{font-family:var(--mono);font-size:13px;line-height:1.5;background:var(--secondary);padding:12px;border-radius:var(--radius-md);border:1px solid var(--border);max-height:360px;overflow:auto;max-width:100%}:root[data-theme=light] .code-block,:root[data-theme=light] .list-item,:root[data-theme=light] .table-row,:root[data-theme=light] .chip{background:var(--bg)}.list{display:grid;gap:8px;container-type:inline-size}.list-item{display:grid;grid-template-columns:minmax(0,1fr) minmax(200px,260px);gap:16px;align-items:start;border:1px solid var(--border);border-radius:var(--radius-md);padding:12px;background:var(--card);transition:border-color var(--duration-fast) ease}.list-item-clickable{cursor:pointer}.list-item-clickable:hover{border-color:var(--border-strong)}.list-item-selected{border-color:var(--accent);box-shadow:var(--focus-ring)}.list-main{display:grid;gap:4px;min-width:0}.list-title{font-weight:500}.list-sub{color:var(--muted);font-size:12px}.list-meta{text-align:right;color:var(--muted);font-size:12px;display:grid;gap:4px;min-width:200px}.list-meta .btn{padding:6px 10px}.list-meta .field input,.list-meta .field textarea,.list-meta .field select{width:100%}.cron-job-payload,.cron-job-agent,.cron-job-state{overflow-wrap:anywhere;word-break:break-word}.cron-job .list-title{font-weight:600;font-size:15px;letter-spacing:-.015em}.cron-job{grid-template-columns:minmax(0,1fr) minmax(240px,300px);grid-template-areas:"main meta" "footer footer";row-gap:10px}.cron-job .list-main{grid-area:main}.cron-job .list-meta{grid-area:meta;min-width:240px;gap:8px}.cron-job-footer{grid-area:footer;display:flex;justify-content:space-between;align-items:center;gap:12px;border-top:1px solid var(--border);padding-top:10px}.cron-job-chips{flex:1 1 auto}.cron-job-detail{display:grid;gap:3px;margin-top:2px}.cron-job-detail-label{color:var(--muted);font-size:11px;font-weight:600;letter-spacing:.03em;text-transform:uppercase}.cron-job-detail-value{font-size:13px;line-height:1.35}.cron-job-state{display:grid;gap:4px}.cron-job-state-row{display:flex;justify-content:space-between;align-items:baseline;gap:10px}.cron-job-state-key{color:var(--muted);font-size:10px;font-weight:600;letter-spacing:.05em;text-transform:uppercase}.cron-job-state-value{color:var(--text);font-size:12px;white-space:nowrap}.cron-job-status-pill{font-size:11px;font-weight:600;border:1px solid var(--border);border-radius:var(--radius-full);padding:2px 8px;text-transform:lowercase}.cron-job-status-ok{color:var(--ok);border-color:#22c55e59;background:var(--ok-subtle)}.cron-job-status-error{color:var(--danger);border-color:#ef444459;background:var(--danger-subtle)}.cron-job-status-skipped{color:var(--warn);border-color:#f59e0b59;background:var(--warn-subtle)}.cron-job-status-na{color:var(--muted)}.cron-job-actions{flex-wrap:wrap;justify-content:flex-end;margin-top:0}.cron-job-actions .btn{flex:0 0 auto}@container (max-width: 560px){.list-item{grid-template-columns:1fr}.list-meta{min-width:0;text-align:left}.cron-job-actions{justify-content:flex-start}.cron-job{grid-template-columns:1fr;grid-template-areas:"main" "meta" "footer"}.cron-job-footer{flex-direction:column;align-items:stretch}}.chip-row{display:flex;flex-wrap:wrap;gap:8px}.chip{font-size:12px;font-weight:500;border:1px solid var(--border);border-radius:var(--radius-full);padding:5px 12px;color:var(--muted);background:var(--secondary);transition:border-color var(--duration-fast) var(--ease-out),background var(--duration-fast) var(--ease-out),transform var(--duration-fast) var(--ease-out)}.chip:hover{border-color:var(--border-strong);transform:translateY(-1px)}.chip input{margin-right:6px}.chip-ok{color:var(--ok);border-color:#22c55e4d;background:var(--ok-subtle)}.chip-warn{color:var(--warn);border-color:#f59e0b4d;background:var(--warn-subtle)}.chip-danger{color:var(--danger);border-color:#ef44444d;background:var(--danger-subtle)}.table{display:grid;gap:6px}.table-head,.table-row{display:grid;grid-template-columns:1.4fr 1fr .8fr .7fr .8fr .8fr .8fr .8fr .6fr;gap:12px;align-items:center}.table-head{font-size:12px;font-weight:500;color:var(--muted);padding:0 12px}.table-row{border:1px solid var(--border);padding:10px 12px;border-radius:var(--radius-md);background:var(--card);transition:border-color var(--duration-fast) ease}.table-row:hover{border-color:var(--border-strong)}.session-link{text-decoration:none;color:var(--accent);font-weight:500}.session-link:hover{text-decoration:underline}.session-key-cell{display:grid;gap:4px;min-width:0}.session-key-cell .session-link,.session-key-display-name{overflow-wrap:anywhere;word-break:break-word}.session-key-display-name{font-size:11px}.log-stream{border:1px solid var(--border);border-radius:var(--radius-md);background:var(--card);max-height:500px;overflow:auto;container-type:inline-size}.log-row{display:grid;grid-template-columns:90px 70px minmax(140px,200px) minmax(0,1fr);gap:12px;align-items:start;padding:8px 12px;border-bottom:1px solid var(--border);font-size:12px;transition:background var(--duration-fast) ease}.log-row:hover{background:var(--bg-hover)}.log-row:last-child{border-bottom:none}.log-time{color:var(--muted);font-family:var(--mono)}.log-level{font-size:11px;font-weight:500;border:1px solid var(--border);border-radius:var(--radius-sm);padding:2px 6px;width:fit-content}.log-level.trace,.log-level.debug{color:var(--muted)}.log-level.info{color:var(--info);border-color:#3b82f64d}.log-level.warn{color:var(--warn);border-color:var(--warn-subtle)}.log-level.error,.log-level.fatal{color:var(--danger);border-color:var(--danger-subtle)}.log-chip.trace,.log-chip.debug{color:var(--muted)}.log-chip.info{color:var(--info);border-color:#3b82f64d}.log-chip.warn{color:var(--warn);border-color:var(--warn-subtle)}.log-chip.error,.log-chip.fatal{color:var(--danger);border-color:var(--danger-subtle)}.log-subsystem{color:var(--muted);font-family:var(--mono)}.log-message{white-space:pre-wrap;word-break:break-word;font-family:var(--mono)}@container (max-width: 620px){.log-row{grid-template-columns:70px 60px minmax(0,1fr)}.log-subsystem{display:none}}.chat{display:flex;flex-direction:column;min-height:0}.shell--chat .chat{flex:1}.chat-header{display:flex;justify-content:space-between;align-items:flex-end;gap:16px;flex-wrap:wrap}.chat-header__left{display:flex;align-items:flex-end;gap:12px;flex-wrap:wrap;min-width:0}.chat-header__right{display:flex;align-items:center;gap:8px}.chat-session{min-width:240px}.chat-thread{margin-top:16px;display:flex;flex-direction:column;gap:12px;flex:1;min-height:0;overflow-y:auto;overflow-x:hidden;padding:16px 12px;min-width:0;border-radius:0;border:none;background:transparent}.chat-queue{margin-top:12px;padding:12px;border-radius:var(--radius-lg);border:1px solid var(--border);background:var(--card);display:grid;gap:8px}.chat-queue__title{font-family:var(--mono);font-size:12px;font-weight:500;color:var(--muted)}.chat-queue__list{display:grid;gap:8px}.chat-queue__item{display:grid;grid-template-columns:minmax(0,1fr) auto;align-items:start;gap:12px;padding:10px 12px;border-radius:var(--radius-md);border:1px dashed var(--border-strong);background:var(--secondary)}.chat-queue__text{color:var(--chat-text);font-size:13px;line-height:1.45;white-space:pre-wrap;overflow:hidden;display:-webkit-box;line-clamp:3;-webkit-line-clamp:3;-webkit-box-orient:vertical}.chat-queue__remove{align-self:start;padding:4px 10px;font-size:12px;line-height:1}.chat-new-messages{align-self:center;margin:8px auto 0;border-radius:999px;padding:6px 12px;font-size:12px;line-height:1}.chat-line{display:flex}.chat-line.user{justify-content:flex-end}.chat-line.assistant,.chat-line.other{justify-content:flex-start}.chat-msg{display:grid;gap:6px;max-width:min(700px,82%)}.chat-line.user .chat-msg{justify-items:end}.chat-bubble{border:1px solid transparent;background:var(--card);border-radius:var(--radius-lg);padding:10px 14px;min-width:0}:root[data-theme=light] .chat-bubble{border-color:var(--border);background:var(--bg)}.chat-line.user .chat-bubble{border-color:transparent;background:var(--accent-subtle)}:root[data-theme=light] .chat-line.user .chat-bubble{border-color:#ea580c33;background:#fb923c1f}.chat-line.assistant .chat-bubble{border-color:transparent;background:var(--secondary)}:root[data-theme=light] .chat-line.assistant .chat-bubble{border-color:var(--border);background:var(--bg-muted)}@keyframes chatStreamPulse{0%,to{border-color:var(--border)}50%{border-color:var(--accent)}}.chat-bubble.streaming{animation:chatStreamPulse 1.5s ease-in-out infinite}@media(prefers-reduced-motion:reduce){.chat-bubble.streaming{animation:none;border-color:var(--accent)}}.chat-activity-status{display:flex;flex-direction:column;gap:4px}.chat-activity-status__label{font-size:13px;color:var(--muted);padding-left:4px;animation:chatActivityFadeIn .3s ease-out}@keyframes chatActivityFadeIn{0%{opacity:0;transform:translateY(4px)}to{opacity:1;transform:translateY(0)}}.chat-bubble.chat-reading-indicator{width:fit-content;padding:10px 16px}.chat-bubble.chat-reading-indicator--with-label{padding:6px 12px}.chat-reading-indicator__dots{display:inline-flex;align-items:center;gap:4px;height:12px}.chat-reading-indicator--with-label .chat-reading-indicator__dots{height:8px}.chat-reading-indicator__dots>span{display:inline-block;width:6px;height:6px;border-radius:var(--radius-full);background:var(--muted);opacity:.6;transform:translateY(0);animation:chatReadingDot 1.2s ease-in-out infinite;will-change:transform,opacity}.chat-reading-indicator--with-label .chat-reading-indicator__dots>span{width:4px;height:4px}.chat-reading-indicator__dots>span:nth-child(2){animation-delay:.15s}.chat-reading-indicator__dots>span:nth-child(3){animation-delay:.3s}@keyframes chatReadingDot{0%,80%,to{opacity:.4;transform:translateY(0)}40%{opacity:1;transform:translateY(-3px)}}@media(prefers-reduced-motion:reduce){.chat-reading-indicator__dots>span{animation:none;opacity:.6}.chat-activity-status__label{animation:none}}.chat-text{overflow-wrap:anywhere;word-break:break-word;color:var(--chat-text);line-height:1.5}.chat-text :where(p,ul,ol,pre,blockquote,table){margin:0}.chat-text :where(p+p,p+ul,p+ol,p+pre,p+blockquote,p+table){margin-top:.75em}.chat-text :where(ul,ol){padding-left:1.2em}.chat-text :where(li+li){margin-top:.25em}.chat-text :where(a){color:var(--accent)}.chat-text :where(a:hover){text-decoration:underline}.chat-text :where(blockquote){border-left:2px solid var(--border-strong);padding-left:12px;color:var(--muted)}.chat-text :where(hr){border:0;border-top:1px solid var(--border);margin:1em 0}.chat-text :where(code){font-family:var(--mono);font-size:.9em}.chat-text :where(:not(pre)>code){padding:.15em .35em;border-radius:var(--radius-sm);border:1px solid var(--border);background:var(--secondary)}:root[data-theme=light] .chat-text :where(:not(pre)>code){background:var(--bg-muted)}.chat-text :where(pre){margin-top:.75em;padding:10px 12px;border-radius:var(--radius-md);border:1px solid var(--border);background:var(--secondary);overflow:auto}:root[data-theme=light] .chat-text :where(pre){background:var(--bg-muted)}.chat-text :where(pre code){font-size:12px;white-space:pre}.chat-text :where(table){margin-top:.75em;border-collapse:collapse;width:100%;font-size:13px}.chat-text :where(th,td){border:1px solid var(--border);padding:6px 10px;vertical-align:top}.chat-text :where(th){font-family:var(--mono);font-weight:500;color:var(--muted);background:var(--secondary)}.chat-tool-card{margin-top:8px;padding:10px 12px;border-radius:var(--radius-md);border:1px solid var(--border);background:var(--secondary);display:grid;gap:4px}:root[data-theme=light] .chat-tool-card{background:var(--bg-muted)}.chat-tool-card__title{font-family:var(--mono);font-size:12px;font-weight:500;color:var(--text)}.chat-tool-card__detail{font-family:var(--mono);font-size:11px;color:var(--muted)}.chat-tool-card__details{margin-top:6px}.chat-tool-card__summary{font-family:var(--mono);font-size:11px;color:var(--muted);cursor:pointer;list-style:none;display:inline-flex;align-items:center;gap:6px}.chat-tool-card__summary::-webkit-details-marker{display:none}.chat-tool-card__summary-meta{color:var(--muted);opacity:.7}.chat-tool-card__details[open] .chat-tool-card__summary{color:var(--text)}.chat-tool-card__output{margin-top:8px;font-family:var(--mono);font-size:11px;line-height:1.5;white-space:pre-wrap;color:var(--chat-text);padding:8px 10px;border-radius:var(--radius-md);border:1px solid var(--border);background:var(--card)}:root[data-theme=light] .chat-tool-card__output{background:var(--bg)}.chat-stamp{font-size:11px;color:var(--muted)}.chat-line.user .chat-stamp{text-align:right}.chat-compose{margin-top:12px;display:flex;flex-direction:column;gap:10px}.shell--chat .chat-compose{position:sticky;bottom:0;z-index:5;margin-top:0;padding-top:12px;background:linear-gradient(180deg,transparent 0%,var(--bg) 40%)}.shell--chat-focus .chat-compose{bottom:calc(var(--shell-pad) + 8px);padding-bottom:calc(12px + env(safe-area-inset-bottom,0px));border-bottom-left-radius:var(--radius-lg);border-bottom-right-radius:var(--radius-lg)}.chat-compose__field{gap:4px}.chat-compose__field textarea{min-height:72px;padding:10px 14px;border-radius:var(--radius-lg);resize:vertical;white-space:pre-wrap;font-family:var(--font-body);line-height:1.5;border:1px solid var(--input);background:var(--card);box-shadow:inset 0 1px 0 var(--card-highlight);transition:border-color var(--duration-fast) ease,box-shadow var(--duration-fast) ease}.chat-compose__field textarea:focus{border-color:var(--ring);box-shadow:var(--focus-ring)}.chat-compose__field textarea:disabled{opacity:.5;cursor:not-allowed}.chat-compose__actions{justify-content:flex-end;align-self:end}@media(max-width:900px){.chat-session{min-width:180px}.chat-compose{grid-template-columns:1fr}}.qr-wrap{margin-top:16px;border-radius:var(--radius-md);background:var(--card);border:1px dashed var(--border-strong);padding:16px;display:inline-flex}.qr-wrap img{width:160px;height:160px;border-radius:var(--radius-sm);image-rendering:pixelated}.exec-approval-overlay{position:fixed;inset:0;background:#000c;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;padding:24px;z-index:200}.exec-approval-card{width:min(540px,100%);background:var(--card);border:1px solid var(--border);border-radius:var(--radius-lg);padding:20px;animation:scale-in .2s var(--ease-out)}.exec-approval-header{display:flex;align-items:center;justify-content:space-between;gap:16px}.exec-approval-title{font-size:14px;font-weight:600}.exec-approval-sub{color:var(--muted);font-size:13px;margin-top:4px}.exec-approval-queue{font-size:11px;font-weight:500;color:var(--muted);border:1px solid var(--border);border-radius:var(--radius-full);padding:4px 10px}.exec-approval-command{margin-top:12px;padding:10px 12px;background:var(--secondary);border:1px solid var(--border);border-radius:var(--radius-md);word-break:break-word;white-space:pre-wrap;font-family:var(--mono);font-size:13px}.exec-approval-meta{margin-top:12px;display:grid;gap:6px;font-size:13px;color:var(--muted)}.exec-approval-meta-row{display:flex;justify-content:space-between;gap:12px}.exec-approval-meta-row span:last-child{color:var(--text);font-family:var(--mono)}.exec-approval-error{margin-top:10px;font-size:13px;color:var(--danger)}.exec-approval-actions{margin-top:16px;display:flex;flex-wrap:wrap;gap:8px}.agents-layout{display:grid;grid-template-columns:minmax(220px,280px) minmax(0,1fr);gap:16px}.agents-sidebar{display:grid;gap:12px;align-self:start}.agents-main{display:grid;gap:16px}.agent-list{display:grid;gap:8px}.agent-row{display:grid;grid-template-columns:auto minmax(0,1fr) auto;align-items:center;gap:12px;width:100%;text-align:left;border:1px solid var(--border);border-radius:var(--radius-md);background:var(--card);padding:10px 12px;cursor:pointer;transition:border-color var(--duration-fast) ease}.agent-row:hover{border-color:var(--border-strong)}.agent-row.active{border-color:var(--accent);box-shadow:var(--focus-ring)}.agent-avatar{width:32px;height:32px;border-radius:50%;background:var(--secondary);display:grid;place-items:center;font-weight:600}.agent-avatar--lg{width:48px;height:48px;font-size:20px}.agent-info{display:grid;gap:2px;min-width:0}.agent-title{font-weight:600}.agent-sub{color:var(--muted);font-size:12px}.agent-pill{border:1px solid var(--border);border-radius:var(--radius-full);padding:4px 10px;font-size:11px;color:var(--muted);background:var(--secondary);text-transform:uppercase;letter-spacing:.04em}.agent-pill.warn{color:var(--warn);border-color:var(--warn)}.agent-header{display:grid;grid-template-columns:minmax(0,1fr) auto;gap:16px;align-items:center}.agent-header-main{display:flex;gap:16px;align-items:center}.agent-header-meta{display:grid;justify-items:end;gap:6px;color:var(--muted)}.agent-tabs{display:flex;gap:8px;flex-wrap:wrap}.agent-tab{border:1px solid var(--border);border-radius:var(--radius-full);padding:6px 14px;font-size:12px;font-weight:600;background:var(--secondary);cursor:pointer;transition:border-color var(--duration-fast) ease,background var(--duration-fast) ease}.agent-tab.active{background:var(--accent);border-color:var(--accent);color:#fff}.agents-overview-grid{display:grid;gap:14px;grid-template-columns:repeat(auto-fit,minmax(200px,1fr))}.agent-kv{display:grid;gap:6px;min-width:0}.agent-kv>div{min-width:0;overflow-wrap:anywhere;word-break:break-word}.agent-kv-sub{font-size:12px}.agent-model-select{display:grid;gap:12px}.agent-model-meta{display:grid;gap:6px;min-width:200px}.agent-files-grid{display:grid;grid-template-columns:minmax(220px,280px) minmax(0,1fr);gap:16px}.agent-files-list{display:grid;gap:8px}.agent-file-row{display:flex;justify-content:space-between;align-items:center;gap:12px;width:100%;text-align:left;border:1px solid var(--border);border-radius:var(--radius-md);background:var(--card);padding:10px 12px;cursor:pointer;transition:border-color var(--duration-fast) ease}.agent-file-row:hover{border-color:var(--border-strong)}.agent-file-row.active{border-color:var(--accent);box-shadow:var(--focus-ring)}.agent-file-name{font-weight:600}.agent-file-meta{color:var(--muted);font-size:12px;margin-top:4px}.agent-files-editor{border:1px solid var(--border);border-radius:var(--radius-lg);padding:16px;background:var(--card)}.agent-file-header{display:flex;justify-content:space-between;align-items:center;gap:12px;flex-wrap:wrap}.agent-file-title{font-weight:600}.agent-file-sub{color:var(--muted);font-size:12px;margin-top:4px}.agent-file-actions{display:flex;gap:8px}.agent-tools-meta{display:grid;gap:12px;grid-template-columns:repeat(auto-fit,minmax(180px,1fr))}.agent-tools-buttons{display:flex;gap:8px;flex-wrap:wrap;margin-top:8px}.agent-tools-grid{display:grid;gap:16px}.agent-tools-section{border:1px solid var(--border);border-radius:var(--radius-md);padding:10px;background:var(--bg-elevated)}.agent-tools-header{font-weight:600;margin-bottom:10px}.agent-tools-list{display:grid;gap:8px 12px;grid-template-columns:repeat(auto-fit,minmax(220px,1fr))}.agent-tool-row{display:flex;justify-content:space-between;align-items:center;gap:12px;padding:6px 8px;border:1px solid var(--border);border-radius:var(--radius-md);background:var(--card)}.agent-tool-title{font-weight:600;font-size:13px}.agent-tool-sub{color:var(--muted);font-size:11px;margin-top:2px}.agent-skills-groups{display:grid;gap:16px}.agent-skills-group{display:grid;gap:10px}.agent-skills-group summary{list-style:none}.agent-skills-header{display:flex;align-items:center;font-weight:600;font-size:13px;text-transform:uppercase;letter-spacing:.04em;color:var(--muted);cursor:pointer;gap:8px}.agent-skills-header>span:last-child{margin-left:auto}.agent-skills-group summary::-webkit-details-marker{display:none}.agent-skills-group summary::marker{content:""}.agent-skills-header:after{content:"▸";font-size:12px;color:var(--muted);transition:transform var(--duration-fast) ease;margin-left:8px}.agent-skills-group[open] .agent-skills-header:after{transform:rotate(90deg)}.agent-skill-row{align-items:flex-start;gap:18px}.agent-skill-row .list-meta{display:flex;align-items:flex-start;justify-content:flex-end;min-width:auto}.skills-grid{grid-template-columns:1fr}@container (min-width: 900px){.skills-grid{grid-template-columns:repeat(2,minmax(0,1fr))}}@media(max-width:980px){.agents-layout,.agent-header{grid-template-columns:1fr}.agent-header-meta{justify-items:start}.agent-files-grid,.agent-tools-list{grid-template-columns:1fr}}.config-layout{display:grid;grid-template-columns:260px minmax(0,1fr);gap:0;height:calc(100vh - 160px);margin:-16px;border-radius:var(--radius-xl);border:1px solid var(--border);background:var(--panel)}.config-sidebar{display:flex;flex-direction:column;background:var(--bg-accent);border-right:1px solid var(--border);min-height:0;overflow:hidden}:root[data-theme=light] .config-sidebar{background:var(--bg-hover)}.config-sidebar__header{display:flex;align-items:center;justify-content:space-between;padding:18px;border-bottom:1px solid var(--border)}.config-sidebar__title{font-weight:600;font-size:14px;letter-spacing:-.01em}.config-sidebar__footer{margin-top:auto;padding:14px;border-top:1px solid var(--border)}.config-search{position:relative;padding:14px;border-bottom:1px solid var(--border)}.config-search__icon{position:absolute;left:28px;top:50%;transform:translateY(-50%);width:16px;height:16px;color:var(--muted);pointer-events:none}.config-search__input{width:100%;padding:11px 36px 11px 42px;border:1px solid var(--border);border-radius:var(--radius-md);background:var(--bg-elevated);font-size:13px;outline:none;transition:border-color var(--duration-fast) ease,box-shadow var(--duration-fast) ease,background var(--duration-fast) ease}.config-search__input::placeholder{color:var(--muted)}.config-search__input:focus{border-color:var(--accent);box-shadow:var(--focus-ring);background:var(--bg-hover)}:root[data-theme=light] .config-search__input{background:#fff}:root[data-theme=light] .config-search__input:focus{background:#fff}.config-search__clear{position:absolute;right:22px;top:50%;transform:translateY(-50%);width:22px;height:22px;border:none;border-radius:var(--radius-full);background:var(--bg-hover);color:var(--muted);font-size:14px;line-height:1;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background var(--duration-fast) ease,color var(--duration-fast) ease}.config-search__clear:hover{background:var(--border-strong);color:var(--text)}.config-nav{flex:1;overflow-y:auto;padding:10px}.config-nav__item{display:flex;align-items:center;gap:12px;width:100%;padding:11px 14px;border:none;border-radius:var(--radius-md);background:transparent;color:var(--muted);font-size:13px;font-weight:500;text-align:left;cursor:pointer;transition:background var(--duration-fast) ease,color var(--duration-fast) ease}.config-nav__item:hover{background:var(--bg-hover);color:var(--text)}:root[data-theme=light] .config-nav__item:hover{background:#0000000a}.config-nav__item.active{background:var(--accent-subtle);color:var(--accent)}.config-nav__icon{width:20px;height:20px;display:flex;align-items:center;justify-content:center;font-size:15px;opacity:.7}.config-nav__item:hover .config-nav__icon,.config-nav__item.active .config-nav__icon{opacity:1}.config-nav__icon svg{width:18px;height:18px;stroke:currentColor;fill:none}.config-nav__label{flex:1;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.config-mode-toggle{display:flex;padding:4px;background:var(--bg-elevated);border-radius:var(--radius-md);border:1px solid var(--border)}:root[data-theme=light] .config-mode-toggle{background:#fff}.config-mode-toggle__btn{flex:1;padding:9px 14px;border:none;border-radius:var(--radius-sm);background:transparent;color:var(--muted);font-size:12px;font-weight:600;cursor:pointer;transition:background var(--duration-fast) ease,color var(--duration-fast) ease,box-shadow var(--duration-fast) ease}.config-mode-toggle__btn:hover{color:var(--text)}.config-mode-toggle__btn.active{background:var(--accent);color:#fff;box-shadow:var(--shadow-sm)}.config-main{display:flex;flex-direction:column;min-height:0;min-width:0;background:var(--panel);overflow:hidden}.config-actions{display:flex;align-items:center;justify-content:space-between;gap:14px;padding:14px 22px;background:var(--bg-accent);border-bottom:1px solid var(--border)}:root[data-theme=light] .config-actions{background:var(--bg-hover)}.config-actions__left,.config-actions__right{display:flex;align-items:center;gap:10px}.config-changes-badge{padding:6px 14px;border-radius:var(--radius-full);background:var(--accent-subtle);border:1px solid rgba(255,77,77,.3);color:var(--accent);font-size:12px;font-weight:600}.config-status{font-size:13px;color:var(--muted)}.config-diff{margin:18px 22px 0;border:1px solid rgba(255,77,77,.25);border-radius:var(--radius-lg);background:var(--accent-subtle);overflow:hidden}.config-diff__summary{display:flex;align-items:center;justify-content:space-between;padding:14px 18px;cursor:pointer;font-size:13px;font-weight:600;color:var(--accent);list-style:none}.config-diff__summary::-webkit-details-marker{display:none}.config-diff__chevron{width:16px;height:16px;transition:transform var(--duration-normal) var(--ease-out)}.config-diff__chevron svg{width:100%;height:100%}.config-diff[open] .config-diff__chevron{transform:rotate(180deg)}.config-diff__content{padding:0 18px 18px;display:grid;gap:10px}.config-diff__item{display:flex;align-items:baseline;gap:14px;padding:10px 14px;border-radius:var(--radius-md);background:var(--bg-elevated);font-size:12px;font-family:var(--mono)}:root[data-theme=light] .config-diff__item{background:#fff}.config-diff__path{font-weight:600;color:var(--text);flex-shrink:0}.config-diff__values{display:flex;align-items:baseline;gap:10px;min-width:0;flex-wrap:wrap}.config-diff__from{color:var(--danger);opacity:.85}.config-diff__arrow{color:var(--muted)}.config-diff__to{color:var(--ok)}.config-section-hero{display:flex;align-items:center;gap:16px;padding:16px 22px;border-bottom:1px solid var(--border);background:var(--bg-accent)}:root[data-theme=light] .config-section-hero{background:var(--bg-hover)}.config-section-hero__icon{width:30px;height:30px;color:var(--accent);display:flex;align-items:center;justify-content:center}.config-section-hero__icon svg{width:100%;height:100%;stroke:currentColor;fill:none}.config-section-hero__text{display:grid;gap:3px;min-width:0}.config-section-hero__title{font-size:16px;font-weight:600;letter-spacing:-.01em;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.config-section-hero__desc{font-size:13px;color:var(--muted)}.config-subnav{display:flex;gap:8px;padding:12px 22px 14px;border-bottom:1px solid var(--border);background:var(--bg-accent);overflow-x:auto}:root[data-theme=light] .config-subnav{background:var(--bg-hover)}.config-subnav__item{border:1px solid transparent;border-radius:var(--radius-full);padding:7px 14px;font-size:12px;font-weight:600;color:var(--muted);background:var(--bg-elevated);cursor:pointer;transition:background var(--duration-fast) ease,color var(--duration-fast) ease,border-color var(--duration-fast) ease;white-space:nowrap}:root[data-theme=light] .config-subnav__item{background:#fff}.config-subnav__item:hover{color:var(--text);border-color:var(--border)}.config-subnav__item.active{color:var(--accent);border-color:#ff4d4d66;background:var(--accent-subtle)}.config-content{flex:1;overflow-y:auto;padding:22px}.config-raw-field textarea{min-height:500px;font-family:var(--mono);font-size:13px;line-height:1.55}.config-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:18px;padding:80px 24px;color:var(--muted)}.config-loading__spinner{width:40px;height:40px;border:3px solid var(--border);border-top-color:var(--accent);border-radius:var(--radius-full);animation:spin .75s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.config-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:18px;padding:80px 24px;text-align:center}.config-empty__icon{font-size:56px;opacity:.35}.config-empty__text{color:var(--muted);font-size:15px}.config-form--modern{display:grid;gap:26px}.config-section-card{border:1px solid var(--border);border-radius:var(--radius-lg);background:var(--bg-elevated);overflow:hidden;transition:border-color var(--duration-fast) ease}.config-section-card:hover{border-color:var(--border-strong)}:root[data-theme=light] .config-section-card{background:#fff}.config-section-card__header{display:flex;align-items:flex-start;gap:16px;padding:20px 22px;background:var(--bg-accent);border-bottom:1px solid var(--border)}:root[data-theme=light] .config-section-card__header{background:var(--bg-hover)}.config-section-card__icon{width:34px;height:34px;color:var(--accent);flex-shrink:0}.config-section-card__icon svg{width:100%;height:100%}.config-section-card__titles{flex:1;min-width:0}.config-section-card__title{margin:0;font-size:17px;font-weight:600;letter-spacing:-.01em;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.config-section-card__desc{margin:5px 0 0;font-size:13px;color:var(--muted);line-height:1.45}.config-section-card__content{padding:22px}.cfg-fields{display:grid;gap:22px}.cfg-field{display:grid;gap:8px}.cfg-field--error{padding:14px;border-radius:var(--radius-md);background:var(--danger-subtle);border:1px solid rgba(239,68,68,.3)}.cfg-field__label{font-size:13px;font-weight:600;color:var(--text)}.cfg-field__help{font-size:12px;color:var(--muted);line-height:1.45}.cfg-field__error{font-size:12px;color:var(--danger)}.cfg-input-wrap{display:flex;gap:10px}.cfg-input{flex:1;padding:11px 14px;border:1px solid var(--border-strong);border-radius:var(--radius-md);background:var(--bg-accent);font-size:14px;outline:none;transition:border-color var(--duration-fast) ease,box-shadow var(--duration-fast) ease,background var(--duration-fast) ease}.cfg-input::placeholder{color:var(--muted);opacity:.7}.cfg-input:focus{border-color:var(--accent);box-shadow:var(--focus-ring);background:var(--bg-hover)}:root[data-theme=light] .cfg-input{background:#fff}:root[data-theme=light] .cfg-input:focus{background:#fff}.cfg-input--sm{padding:9px 12px;font-size:13px}.cfg-input__reset{padding:10px 14px;border:1px solid var(--border);border-radius:var(--radius-md);background:var(--bg-elevated);color:var(--muted);font-size:14px;cursor:pointer;transition:background var(--duration-fast) ease,color var(--duration-fast) ease}.cfg-input__reset:hover:not(:disabled){background:var(--bg-hover);color:var(--text)}.cfg-input__reset:disabled{opacity:.5;cursor:not-allowed}.cfg-textarea{width:100%;padding:12px 14px;border:1px solid var(--border-strong);border-radius:var(--radius-md);background:var(--bg-accent);font-family:var(--mono);font-size:13px;line-height:1.55;resize:vertical;outline:none;transition:border-color var(--duration-fast) ease,box-shadow var(--duration-fast) ease}.cfg-textarea:focus{border-color:var(--accent);box-shadow:var(--focus-ring)}:root[data-theme=light] .cfg-textarea{background:#fff}.cfg-textarea--sm{padding:10px 12px;font-size:12px}.cfg-number{display:inline-flex;border:1px solid var(--border-strong);border-radius:var(--radius-md);overflow:hidden;background:var(--bg-accent)}:root[data-theme=light] .cfg-number{background:#fff}.cfg-number__btn{width:44px;border:none;background:var(--bg-elevated);color:var(--text);font-size:18px;font-weight:300;cursor:pointer;transition:background var(--duration-fast) ease}.cfg-number__btn:hover:not(:disabled){background:var(--bg-hover)}.cfg-number__btn:disabled{opacity:.4;cursor:not-allowed}:root[data-theme=light] .cfg-number__btn{background:var(--bg-hover)}:root[data-theme=light] .cfg-number__btn:hover:not(:disabled){background:var(--border)}.cfg-number__input{width:85px;padding:11px;border:none;border-left:1px solid var(--border);border-right:1px solid var(--border);background:transparent;font-size:14px;text-align:center;outline:none;-moz-appearance:textfield}.cfg-number__input::-webkit-outer-spin-button,.cfg-number__input::-webkit-inner-spin-button{-webkit-appearance:none;margin:0}.cfg-select{padding:11px 40px 11px 14px;border:1px solid var(--border-strong);border-radius:var(--radius-md);background-color:var(--bg-accent);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%3Cpolyline points='6 9 12 15 18 9'%3E%3C/polyline%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 12px center;font-size:14px;cursor:pointer;outline:none;appearance:none;transition:border-color var(--duration-fast) ease,box-shadow var(--duration-fast) ease}.cfg-select:focus{border-color:var(--accent);box-shadow:var(--focus-ring)}:root[data-theme=light] .cfg-select{background-color:#fff}.cfg-segmented{display:inline-flex;padding:4px;border:1px solid var(--border);border-radius:var(--radius-md);background:var(--bg-accent)}:root[data-theme=light] .cfg-segmented{background:var(--bg-hover)}.cfg-segmented__btn{padding:9px 18px;border:none;border-radius:var(--radius-sm);background:transparent;color:var(--muted);font-size:13px;font-weight:500;cursor:pointer;transition:background var(--duration-fast) ease,color var(--duration-fast) ease,box-shadow var(--duration-fast) ease}.cfg-segmented__btn:hover:not(:disabled):not(.active){color:var(--text)}.cfg-segmented__btn.active{background:var(--accent);color:#fff;box-shadow:var(--shadow-sm)}.cfg-segmented__btn:disabled{opacity:.5;cursor:not-allowed}.cfg-toggle-row{display:flex;align-items:center;justify-content:space-between;gap:18px;padding:16px 18px;border:1px solid var(--border);border-radius:var(--radius-lg);background:var(--bg-accent);cursor:pointer;transition:background var(--duration-fast) ease,border-color var(--duration-fast) ease}.cfg-toggle-row:hover:not(.disabled){background:var(--bg-hover);border-color:var(--border-strong)}.cfg-toggle-row.disabled{opacity:.55;cursor:not-allowed}:root[data-theme=light] .cfg-toggle-row{background:#fff}:root[data-theme=light] .cfg-toggle-row:hover:not(.disabled){background:var(--bg-hover)}.cfg-toggle-row__content{flex:1;min-width:0}.cfg-toggle-row__label{display:block;font-size:14px;font-weight:500;color:var(--text)}.cfg-toggle-row__help{display:block;margin-top:3px;font-size:12px;color:var(--muted);line-height:1.45}.cfg-toggle{position:relative;flex-shrink:0}.cfg-toggle input{position:absolute;opacity:0;width:0;height:0}.cfg-toggle__track{display:block;width:50px;height:28px;background:var(--bg-elevated);border:1px solid var(--border-strong);border-radius:var(--radius-full);position:relative;transition:background var(--duration-normal) ease,border-color var(--duration-normal) ease}:root[data-theme=light] .cfg-toggle__track{background:var(--border)}.cfg-toggle__track:after{content:"";position:absolute;top:3px;left:3px;width:20px;height:20px;background:var(--text);border-radius:var(--radius-full);box-shadow:var(--shadow-sm);transition:transform var(--duration-normal) var(--ease-out),background var(--duration-normal) ease}.cfg-toggle input:checked+.cfg-toggle__track{background:var(--ok-subtle);border-color:#22c55e66}.cfg-toggle input:checked+.cfg-toggle__track:after{transform:translate(22px);background:var(--ok)}.cfg-toggle input:focus+.cfg-toggle__track{box-shadow:var(--focus-ring)}.cfg-object{border:1px solid var(--border);border-radius:var(--radius-lg);background:var(--bg-accent);overflow:hidden}:root[data-theme=light] .cfg-object{background:#fff}.cfg-object__header{display:flex;align-items:center;justify-content:space-between;padding:14px 18px;cursor:pointer;list-style:none;transition:background var(--duration-fast) ease}.cfg-object__header:hover{background:var(--bg-hover)}.cfg-object__header::-webkit-details-marker{display:none}.cfg-object__title{font-size:14px;font-weight:600;color:var(--text)}.cfg-object__chevron{width:18px;height:18px;color:var(--muted);transition:transform var(--duration-normal) var(--ease-out)}.cfg-object__chevron svg{width:100%;height:100%}.cfg-object[open] .cfg-object__chevron{transform:rotate(180deg)}.cfg-object__help{padding:0 18px 14px;font-size:12px;color:var(--muted);border-bottom:1px solid var(--border)}.cfg-object__content{padding:18px;display:grid;gap:18px}.cfg-array{border:1px solid var(--border);border-radius:var(--radius-lg);overflow:hidden}.cfg-array__header{display:flex;align-items:center;gap:14px;padding:14px 18px;background:var(--bg-accent);border-bottom:1px solid var(--border)}:root[data-theme=light] .cfg-array__header{background:var(--bg-hover)}.cfg-array__label{flex:1;font-size:14px;font-weight:600;color:var(--text)}.cfg-array__count{font-size:12px;color:var(--muted);padding:4px 10px;background:var(--bg-elevated);border-radius:var(--radius-full)}:root[data-theme=light] .cfg-array__count{background:#fff}.cfg-array__add{display:inline-flex;align-items:center;gap:6px;padding:7px 14px;border:1px solid var(--border);border-radius:var(--radius-md);background:var(--bg-elevated);color:var(--text);font-size:12px;font-weight:500;cursor:pointer;transition:background var(--duration-fast) ease}.cfg-array__add:hover:not(:disabled){background:var(--bg-hover)}.cfg-array__add:disabled{opacity:.5;cursor:not-allowed}.cfg-array__add-icon{width:14px;height:14px}.cfg-array__add-icon svg{width:100%;height:100%}.cfg-array__help{padding:12px 18px;font-size:12px;color:var(--muted);border-bottom:1px solid var(--border)}.cfg-array__empty{padding:36px 18px;text-align:center;color:var(--muted);font-size:13px}.cfg-array__items{display:grid;gap:1px;background:var(--border)}.cfg-array__item{background:var(--panel)}.cfg-array__item-header{display:flex;align-items:center;justify-content:space-between;padding:12px 18px;background:var(--bg-accent);border-bottom:1px solid var(--border)}:root[data-theme=light] .cfg-array__item-header{background:var(--bg-hover)}.cfg-array__item-index{font-size:11px;font-weight:600;color:var(--muted);text-transform:uppercase;letter-spacing:.05em}.cfg-array__item-remove{width:30px;height:30px;display:flex;align-items:center;justify-content:center;border:none;border-radius:var(--radius-md);background:transparent;color:var(--muted);cursor:pointer;transition:background var(--duration-fast) ease,color var(--duration-fast) ease}.cfg-array__item-remove svg{width:16px;height:16px}.cfg-array__item-remove:hover:not(:disabled){background:var(--danger-subtle);color:var(--danger)}.cfg-array__item-remove:disabled{opacity:.4;cursor:not-allowed}.cfg-array__item-content{padding:18px}.cfg-map{border:1px solid var(--border);border-radius:var(--radius-lg);overflow:hidden}.cfg-map__header{display:flex;align-items:center;justify-content:space-between;gap:14px;padding:14px 18px;background:var(--bg-accent);border-bottom:1px solid var(--border)}:root[data-theme=light] .cfg-map__header{background:var(--bg-hover)}.cfg-map__label{font-size:13px;font-weight:600;color:var(--muted)}.cfg-map__add{display:inline-flex;align-items:center;gap:6px;padding:7px 14px;border:1px solid var(--border);border-radius:var(--radius-md);background:var(--bg-elevated);color:var(--text);font-size:12px;font-weight:500;cursor:pointer;transition:background var(--duration-fast) ease}.cfg-map__add:hover:not(:disabled){background:var(--bg-hover)}.cfg-map__add-icon{width:14px;height:14px}.cfg-map__add-icon svg{width:100%;height:100%}.cfg-map__empty{padding:28px 18px;text-align:center;color:var(--muted);font-size:13px}.cfg-map__items{display:grid;gap:10px;padding:14px}.cfg-map__item{display:grid;grid-template-columns:150px 1fr auto;gap:10px;align-items:start}.cfg-map__item-key,.cfg-map__item-value{min-width:0}.cfg-map__item-remove{width:34px;height:34px;display:flex;align-items:center;justify-content:center;border:none;border-radius:var(--radius-md);background:transparent;color:var(--muted);cursor:pointer;transition:background var(--duration-fast) ease,color var(--duration-fast) ease}.cfg-map__item-remove svg{width:16px;height:16px}.cfg-map__item-remove:hover:not(:disabled){background:var(--danger-subtle);color:var(--danger)}.pill--sm{padding:5px 12px;font-size:11px}.pill--ok{border-color:#22c55e59;color:var(--ok)}.pill--danger{border-color:#ef444459;color:var(--danger)}@media(max-width:768px){.config-layout{grid-template-columns:1fr}.config-sidebar{border-right:none;border-bottom:1px solid var(--border)}.config-sidebar__header{padding:14px 16px}.config-nav{display:flex;flex-wrap:nowrap;gap:6px;padding:10px 14px;overflow-x:auto;-webkit-overflow-scrolling:touch}.config-nav__item{flex:0 0 auto;padding:9px 14px;white-space:nowrap}.config-nav__label{display:inline}.config-sidebar__footer{display:none}.config-actions{flex-wrap:wrap;padding:14px 16px}.config-actions__left,.config-actions__right{width:100%;justify-content:center}.config-section-hero{padding:14px 16px}.config-subnav{padding:10px 16px 12px}.config-content{padding:18px}.config-section-card__header{padding:16px 18px}.config-section-card__content{padding:18px}.cfg-toggle-row{padding:14px 16px}.cfg-map__item{grid-template-columns:1fr;gap:10px}.cfg-map__item-remove{justify-self:end}}@media(max-width:480px){.config-nav__icon{width:26px;height:26px;font-size:17px}.config-nav__label{display:none}.config-section-card__icon{width:30px;height:30px}.config-section-card__title{font-size:16px}.cfg-segmented{flex-wrap:wrap}.cfg-segmented__btn{flex:1 0 auto;min-width:70px}}:root,:root[data-theme=light]{--primary-color: #007aff;--primary-light: #e3f2fd;--secondary-color: #5856d6;--success-color: #34c759;--warning-color: #ff9500;--danger-color: #ff3b30;--gray-50: #f9fafb;--gray-100: #f3f4f6;--gray-200: #e5e7eb;--gray-300: #d1d5db;--gray-400: #9ca3af;--gray-500: #6b7280;--gray-600: #4b5563;--gray-700: #374151;--gray-800: #1f2937;--bg: var(--gray-100);--bg-content: var(--gray-100);--bg-accent: #ffffff;--bg-elevated: #ffffff;--bg-hover: #f0f3f8;--bg-muted: var(--gray-100);--card: #ffffff;--card-foreground: var(--gray-800);--card-highlight: rgba(255, 255, 255, .85);--panel: #ffffff;--panel-strong: #ffffff;--panel-hover: #f8fafc;--text: var(--gray-700);--text-strong: var(--gray-800);--chat-text: var(--gray-700);--muted: var(--gray-500);--muted-strong: var(--gray-600);--border: var(--gray-200);--border-strong: var(--gray-300);--border-hover: #c7d2e3;--input: var(--gray-200);--accent: var(--primary-color);--accent-hover: #0066cc;--accent-muted: var(--primary-color);--accent-subtle: rgba(0, 122, 255, .12);--accent-foreground: #ffffff;--accent-glow: rgba(0, 122, 255, .2);--ok: var(--success-color);--warn: var(--warning-color);--danger: var(--danger-color);--bg-2: var(--gray-50);--border-color: var(--gray-200);--muted-color: var(--gray-500);--shadow-sm: 0 1px 2px rgba(0, 0, 0, .05);--shadow-md: 0 4px 6px rgba(0, 0, 0, .07);--shadow-lg: 0 10px 15px rgba(0, 0, 0, .1);--radius-sm: 8px;--radius-md: 10px;--radius-lg: 14px;--radius-xl: 18px;--font-body: -apple-system, BlinkMacSystemFont, "SF Pro Display", "SF Pro Text", "Segoe UI", Roboto, Arial, sans-serif;--font-display: var(--font-body);--mono: "SF Mono", Menlo, Monaco, Consolas, "Liberation Mono", monospace;color-scheme:light}:root[data-theme=dark]{--primary-color: #5aa8ff;--primary-light: rgba(90, 168, 255, .2);--secondary-color: #8b93ff;--success-color: #40d37f;--warning-color: #ffbe64;--danger-color: #ff7b72;--gray-50: #141b28;--gray-100: #111826;--gray-200: #253349;--gray-300: #3a4a63;--gray-400: #95a2ba;--gray-500: #b1bccf;--gray-600: #ccd5e4;--gray-700: #e4ebf7;--gray-800: #f7faff;--bg: #0d141f;--bg-content: #0d141f;--bg-accent: #131c2c;--bg-elevated: #172033;--bg-hover: #1f2a40;--bg-muted: #111826;--card: #172033;--card-foreground: var(--gray-800);--card-highlight: rgba(255, 255, 255, .08);--panel: #111826;--panel-strong: #141f31;--panel-hover: #1f2c43;--text: var(--gray-700);--text-strong: var(--gray-800);--chat-text: var(--gray-700);--muted: var(--gray-400);--muted-strong: var(--gray-500);--border: var(--gray-200);--border-strong: var(--gray-300);--border-hover: #4d6385;--input: #31445f;--accent: var(--primary-color);--accent-hover: #79bcff;--accent-muted: var(--primary-color);--accent-subtle: rgba(90, 168, 255, .18);--accent-foreground: #ffffff;--accent-glow: rgba(90, 168, 255, .3);--ok: var(--success-color);--warn: var(--warning-color);--danger: var(--danger-color);--bg-2: #0f1a2a;--border-color: var(--border);--muted-color: var(--muted);--shadow-sm: 0 2px 4px rgba(4, 9, 18, .42);--shadow-md: 0 8px 20px rgba(4, 9, 18, .45);--shadow-lg: 0 18px 34px rgba(4, 9, 18, .52);color-scheme:dark}body{background:var(--bg);color:var(--text)}.shell{grid-template-columns:252px minmax(0,1fr);grid-template-rows:1fr;grid-template-areas:"nav content";background:var(--bg)}.nav{background:#fff;border-right:1px solid var(--gray-200);padding:0 10px 14px;display:flex;flex-direction:column;min-height:0}.nav-sidehead{position:sticky;top:0;z-index:4;background:#fff;padding:14px 8px 12px;border-bottom:1px solid var(--gray-200);margin:0 -10px 12px;display:flex;flex-direction:column;gap:10px}.nav-sidehead-top{display:flex;align-items:center;justify-content:space-between;gap:8px}.nav-sidebrand{display:flex;align-items:center;gap:10px;padding:0 10px}.nav-sidebrand__logo{width:34px;height:34px;border-radius:10px;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;display:inline-flex;align-items:center;justify-content:center;box-shadow:var(--shadow-sm)}.nav-sidebrand__logo svg{width:18px;height:18px;fill:none;stroke:currentColor;stroke-width:1.8px;stroke-linecap:round;stroke-linejoin:round}.nav-sidebrand__meta{display:flex;flex-direction:column;min-width:0}.nav-sidebrand__title{font-size:29px;font-weight:700;letter-spacing:-.03em;color:var(--gray-800)}.nav-sidebrand__sub{font-size:12px;color:var(--gray-500)}.nav-sidebrand__trial{display:inline-block;margin-top:4px;padding:1px 6px;font-size:10px;font-weight:600;letter-spacing:.02em;color:#fff;background:linear-gradient(135deg,#f59e0b,#ef4444);border-radius:4px;line-height:1.4;white-space:nowrap}.nav-create-btn{width:calc(100% - 20px);margin:14px 10px 2px;border:0;border-radius:12px;padding:12px 14px;display:inline-flex;align-items:center;justify-content:center;gap:8px;color:#fff;background:linear-gradient(135deg,#1677ff,#4f46e5);font-size:15px;font-weight:600;cursor:pointer;box-shadow:0 6px 16px #1677ff40;transition:transform .2s ease}.nav-create-btn:hover{transform:translateY(-1px)}.nav-create-btn__icon{font-size:19px;line-height:1;font-weight:500}.nav-group{margin-bottom:6px}.nav-label{display:flex;align-items:center;justify-content:space-between;gap:8px;width:100%;padding:8px 10px;margin-bottom:4px;color:var(--gray-500);font-size:12px;font-weight:600;text-transform:none;letter-spacing:.02em;border:0;background:transparent;border-radius:8px;cursor:pointer}.nav-label__text{flex:1;text-align:left}.nav-label__chevron{font-size:12px;line-height:1;color:var(--gray-400);transition:transform .2s ease}.nav-group--collapsed .nav-label__chevron{transform:rotate(-90deg)}.nav-group__items{display:grid;gap:4px}.nav-group--collapsed .nav-group__items{display:none}.nav-item{border-radius:10px;padding:10px 12px;color:var(--gray-700);background:transparent;border:1px solid transparent}.nav-item:hover{background:#f3f7ff;border-color:#deebff;color:var(--gray-800)}.nav-item.active{background:#e8f2ff;color:#1d4ed8;border-color:#d0e3ff}.nav-item.active .nav-item__icon{color:#1d4ed8}.nav-item__text{font-size:15px;font-weight:600}.nav-quota{margin-top:auto;border:1px solid var(--gray-200);border-radius:12px;padding:14px 12px 12px;background:#f8fafc}.nav-quota__title{font-size:13px;font-weight:700;color:var(--gray-600)}.nav-quota__bar{margin-top:10px;width:100%;height:8px;background:#e8edf5;border-radius:999px;overflow:hidden}.nav-quota__bar span{display:block;height:100%;border-radius:999px;background:linear-gradient(90deg,#5169f6,#7a5af8)}.nav-quota__meta{margin-top:8px;font-size:12px;color:var(--gray-500)}.content{background:var(--gray-100);padding:0;overflow-y:auto;overflow-x:hidden;display:flex;flex-direction:column}.content>*+*{margin-top:0}.content--chat{gap:0}.content-header{background:#fff;border-bottom:1px solid var(--gray-200);padding:14px 22px;max-height:none;align-items:center}.content-header--workbench{flex-direction:column;align-items:stretch;gap:10px;padding:16px 24px}.workbench-header-main{display:flex;align-items:flex-start;justify-content:space-between;gap:18px}.workbench-project-info{display:flex;align-items:center;gap:14px;min-width:0}.workbench-project-icon{width:44px;height:44px;border-radius:12px;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;display:inline-flex;align-items:center;justify-content:center;flex-shrink:0}.workbench-project-icon svg{width:22px;height:22px;fill:none;stroke:currentColor;stroke-width:1.8px;stroke-linecap:round;stroke-linejoin:round}.workbench-project-meta{min-width:0}.workbench-project-title{margin:0;font-size:37px;font-weight:700;color:var(--gray-800);letter-spacing:-.02em;line-height:1.1}.workbench-project-tags{display:flex;align-items:center;gap:10px;margin-top:6px;flex-wrap:wrap}.workbench-tag{display:inline-flex;align-items:center;border-radius:6px;font-size:11px;font-weight:600;padding:3px 8px}.workbench-tag--tech{background:var(--gray-100);color:var(--gray-600)}.workbench-tag--mock{background:#ede9fe;color:#7c3aed;cursor:pointer;border:1px solid transparent}.workbench-tag--mock:hover{background:#ddd6fe;border-color:#c4b5fd}.workbench-status{display:inline-flex;align-items:center;gap:6px;font-size:12px;color:var(--success-color);font-weight:500}.status-dot{width:8px;height:8px;border-radius:50%;background:var(--gray-300)}.status-dot.ok{background:var(--success-color)}.workbench-user-actions{display:flex;align-items:center;gap:10px;flex-wrap:nowrap}.workbench-header-right{display:flex;align-items:center;justify-content:flex-end;gap:12px;margin-left:auto;min-width:0}.workbench-user-pill{display:inline-flex;align-items:center;gap:10px;padding:6px 10px;background:var(--gray-50);border:1px solid var(--gray-200);border-radius:10px}.workbench-user-avatar{width:30px;height:30px;border-radius:50%;background:linear-gradient(135deg,#1677ff,#4f46e5);color:#fff;display:inline-flex;align-items:center;justify-content:center;font-size:13px;font-weight:700}.workbench-user-name{font-size:13px;font-weight:600;color:var(--gray-800)}.workbench-user-role{font-size:11px;color:var(--gray-500)}.workbench-header-btn{border:1px solid var(--gray-200);background:#fff;color:var(--gray-700);border-radius:8px;padding:8px 14px;font-size:13px;font-weight:500;cursor:pointer;white-space:nowrap;min-width:92px}.workbench-header-btn:hover{background:var(--gray-50)}.workbench-header-control-inline{display:inline-flex;align-items:center;gap:8px;min-width:0}.workbench-header-control-inline .chat-controls{flex-wrap:nowrap;gap:8px}.workbench-header-control-inline .chat-controls__session{min-width:160px;max-width:300px}.workbench-header-control-inline .chat-controls__session select{height:36px;border-radius:10px;border-color:var(--gray-200);background:#f8fafc;font-size:13px}.workbench-layout{flex:1;min-height:0;display:grid;grid-template-columns:minmax(0,1fr) 320px}.workbench-main-column{min-width:0;min-height:0;display:flex;flex-direction:column;padding:18px 24px 24px}.workbench-main-column .chat{flex:1;min-height:0}.workbench-main-column .chat-thread{background:#fff;border:1px solid var(--gray-200);border-radius:14px;padding:14px 12px;margin:0}.chat-compose{background:transparent;padding:14px 0 0}.chat-compose__row{background:#fff;border:1px solid var(--gray-200);border-radius:14px;box-shadow:var(--shadow-sm);padding:8px 10px;gap:10px;align-items:center}.chat-compose__tools{display:inline-flex;align-items:center;gap:4px;flex-shrink:0}.chat-compose__tool-btn{width:32px;height:32px;border-radius:8px;border:0;background:transparent;color:var(--gray-500);display:inline-flex;align-items:center;justify-content:center;cursor:pointer}.chat-compose__tool-btn:hover:not(:disabled){background:var(--gray-100);color:var(--gray-700)}.chat-compose__tool-btn:disabled{opacity:.6;cursor:not-allowed}.chat-compose__tool-btn svg{width:16px;height:16px;fill:none;stroke:currentColor;stroke-width:1.8px;stroke-linecap:round;stroke-linejoin:round}.chat-compose__field textarea{border:0;box-shadow:none;background:transparent;font-size:15px;line-height:1.4;color:var(--gray-700)}.chat-compose__field textarea::placeholder{color:#9aa3b2}.chat-compose__actions{display:inline-flex;align-items:center;flex-shrink:0}.chat-compose__send-btn{width:46px;height:46px;border:0;border-radius:14px;background:#8cbefb;color:#fff;display:inline-flex;align-items:center;justify-content:center;box-shadow:0 6px 14px #4d90fe59;cursor:pointer;transition:background-color .2s ease}.chat-compose__send-btn:hover:not(:disabled){background:#5ea2fb}.chat-compose__send-btn.is-busy{background:#5ea2fb}.chat-compose__send-btn:disabled{opacity:.6;cursor:not-allowed}.chat-compose__send-btn svg{width:18px;height:18px;transform:rotate(-90deg);fill:none;stroke:currentColor;stroke-width:1.8px;stroke-linecap:round;stroke-linejoin:round}.workbench-right-panel{background:#fff;border-left:1px solid var(--gray-200);overflow-y:auto}.workbench-panel-section{padding:16px;border-bottom:1px solid var(--gray-200)}.workbench-panel-header{display:flex;align-items:center;justify-content:space-between;gap:8px;margin-bottom:12px}.workbench-panel-title{font-size:14px;font-weight:700;color:var(--gray-800)}.workbench-panel-link{border:0;background:transparent;color:var(--primary-color);font-size:12px;font-weight:600;cursor:pointer}.workbench-panel-badge{font-size:12px;color:var(--primary-color);font-weight:600}.workbench-action-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:8px}.workbench-action-btn{border:1px solid transparent;border-radius:9px;background:var(--gray-50);color:var(--gray-700);padding:9px 8px;display:inline-flex;align-items:center;gap:7px;font-size:12px;font-weight:600;cursor:pointer;text-align:left}.workbench-action-btn:hover{border-color:var(--gray-200);background:#fff}.workbench-action-icon{width:16px;height:16px;display:inline-flex;color:var(--primary-color)}.workbench-action-icon svg{width:16px;height:16px;fill:none;stroke:currentColor;stroke-width:1.8px;stroke-linecap:round;stroke-linejoin:round}.workbench-integration-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:8px}.workbench-integration-item{border:1px solid transparent;background:var(--gray-50);border-radius:10px;padding:10px;display:inline-flex;align-items:center;gap:10px;cursor:pointer;text-align:left}.workbench-integration-item:hover{border-color:var(--gray-200);background:#fff}.workbench-integration-icon{width:30px;height:30px;border-radius:8px;background:#eaf2ff;color:var(--primary-color);display:inline-flex;align-items:center;justify-content:center;flex-shrink:0}.workbench-integration-icon svg{width:16px;height:16px;fill:none;stroke:currentColor;stroke-width:1.8px;stroke-linecap:round;stroke-linejoin:round}.workbench-integration-meta{min-width:0;display:flex;flex-direction:column}.workbench-integration-name{font-size:12px;font-weight:600;color:var(--gray-700)}.workbench-integration-status{font-size:11px;margin-top:2px}.workbench-integration-status.connected{color:var(--success-color)}.workbench-integration-status.disconnected{color:var(--warning-color)}.workbench-integration-status.unconfigured{color:var(--gray-500)}.workbench-module-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:8px}.workbench-module-item{border:1px solid transparent;border-radius:10px;background:var(--gray-50);padding:12px 6px;cursor:pointer;display:inline-flex;align-items:center;justify-content:center;flex-direction:column;gap:8px;text-align:center}.workbench-module-item:hover{background:#fff;border-color:var(--gray-200)}.workbench-module-icon{width:30px;height:30px;border-radius:8px;background:#eaf2ff;color:#1976d2;display:inline-flex;align-items:center;justify-content:center}.workbench-module-icon svg{width:16px;height:16px;fill:none;stroke:currentColor;stroke-width:1.8px;stroke-linecap:round;stroke-linejoin:round}.workbench-module-name{font-size:11px;font-weight:600;color:var(--gray-600)}.codevox-project-grid{margin-top:14px;display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:10px}.codevox-project-card{border:1px solid var(--gray-200);border-radius:12px;background:#fff;padding:12px;display:grid;gap:8px}.codevox-project-card__head{display:flex;align-items:center;justify-content:space-between;gap:8px}.codevox-project-card__title{margin:0;font-size:14px;color:var(--gray-800)}.codevox-project-card__status{border-radius:999px;background:#e8f7ec;color:#137b3b;font-size:11px;padding:2px 8px;text-transform:uppercase}.codevox-project-card__desc{margin:0;font-size:12px;color:var(--gray-600)}.codevox-project-card__meta{display:flex;flex-wrap:wrap;gap:8px;color:var(--gray-500);font-size:11px}.codevox-project-card__actions{display:flex;justify-content:flex-end}.codevox-project-files{margin-top:14px;border-top:1px solid var(--gray-200);padding-top:12px}.codevox-project-files__list{margin-top:8px;display:grid;gap:8px}.codevox-project-files__item{border:1px solid var(--gray-200);border-radius:10px;padding:8px 10px;background:var(--gray-50)}.project-wizard-overlay{position:fixed;inset:0;z-index:1200;background:#0006;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center}.project-wizard__actions-inline{display:flex;gap:8px}.form-group{margin-bottom:0}.form-label{display:block;margin-bottom:8px;font-size:13px;font-weight:600;color:var(--gray-700)}.required{color:var(--danger-color);margin-left:2px}.form-input{width:100%;border:1px solid var(--gray-200);border-radius:var(--radius-sm);background:var(--gray-50);color:var(--gray-700);font-size:14px;padding:12px 16px;transition:all .2s ease}.form-input:focus{outline:none;border-color:var(--primary-color);background:#fff;box-shadow:0 0 0 3px #007aff1a}.industry-grid{display:grid;grid-template-columns:repeat(5,minmax(0,1fr));gap:8px}.industry-item{display:flex;flex-direction:column;align-items:center;padding:10px 6px;border-radius:10px;cursor:pointer;border:1px solid transparent;transition:all .15s ease;-webkit-user-select:none;user-select:none;gap:6px}.industry-item:hover{background:#fff;border-color:var(--gray-200)}.industry-item.selected{background:#007aff0f;border-color:var(--primary-color)}.project-description-input{min-height:180px;resize:vertical}.btn-ai-inline{margin-top:10px;align-self:flex-start;padding:8px 16px;font-size:13px}.wizard-step-fill{flex:1;display:flex;flex-direction:column;gap:12px;min-height:0;overflow:hidden}.template-selection-list{display:flex;flex-direction:column;gap:8px}.template-selection-card{border:1px solid var(--gray-200);border-radius:12px;background:var(--gray-50);padding:12px 14px;cursor:pointer;transition:all .2s ease}.template-selection-card:hover{border-color:var(--primary-color)}.template-selection-card.selected{border-color:#007aff73;background:#f2f8ff;box-shadow:0 0 0 2px #007aff14}.template-selection-title{font-size:14px;line-height:1.2;font-weight:600;color:#334155}.template-selection-desc{margin-top:4px;font-size:12px;color:#6b7280}.template-selection-source{margin-top:8px;font-size:12px;color:#2f80ff;font-weight:600}.techstack-checkbox-grid{display:grid;grid-template-columns:repeat(6,minmax(0,1fr));gap:8px;align-items:start}.techstack-checkbox-item{display:inline-flex;align-items:center;gap:9px;border:1px solid var(--gray-200);border-radius:10px;padding:9px 12px;background:var(--gray-50);font-size:13px;color:var(--gray-600);min-height:37px}.techstack-checkbox-item input{width:14px;height:14px;margin:0;accent-color:#2f80ff;flex-shrink:0}.reference-upload-simple{display:flex;flex-direction:column;gap:7px}.reference-file-picker{position:relative;width:100%;max-width:100%;border:1px solid var(--gray-200);border-radius:8px;min-height:36px;background:var(--gray-50);display:flex;align-items:center;cursor:pointer;overflow:hidden}.reference-file-trigger{height:36px;min-width:96px;border-right:1px solid var(--gray-200);background:#fff;color:var(--gray-700);font-size:14px;display:inline-flex;align-items:center;justify-content:center;padding:0 14px}.reference-file-status{color:var(--gray-500);font-size:14px;padding-left:10px;white-space:nowrap}.reference-upload-list{display:flex;flex-direction:column;gap:6px;margin-top:2px}.upload-empty{font-size:13px;color:#9ca3af}.upload-simple-file-item{border:1px solid var(--gray-200);border-radius:8px;background:var(--gray-50);padding:8px 10px;font-size:13px;color:var(--gray-600)}.project-init-log{border:1px solid #dfe5ed;border-radius:12px;background:#0f172a;color:#e2e8f0;padding:12px;display:grid;gap:8px;font-family:var(--mono);font-size:12px;max-height:280px;overflow-y:auto}.project-init-log__line{white-space:pre-wrap;word-break:break-word}.project-init-page{display:flex;flex-direction:column;min-height:calc(100vh - 138px);border-radius:16px;border:1px solid var(--gray-200);background:#fff;overflow:hidden}.project-init-page-head{display:flex;flex-wrap:wrap;align-items:center;gap:8px 12px;padding:18px 22px;border-bottom:1px solid var(--gray-200);background:#fff}.project-init-back{order:0;font-size:13px;color:var(--gray-500);background:var(--gray-100);border:1px solid var(--gray-200)}.project-init-page-title{order:1;flex-basis:100%;margin:4px 0 0;font-size:34px;font-weight:700;color:#1f2937}.project-init-page-status{order:0;margin-left:auto;display:inline-flex;align-items:center;border-radius:999px;padding:6px 12px;font-size:13px;font-weight:600}.project-init-page-status.running{background:#ecfdf3;color:#22c55e}.project-init-page-status.ready{background:#ecfdf3;color:#16a34a;border:1px solid #bbf7d0}.project-init-page-status.error{background:#fef2f2;color:#b91c1c;border:1px solid #fecaca}.project-init-page-steps{display:flex;align-items:center;justify-content:center;gap:10px;padding:18px 22px 20px;border-bottom:1px solid var(--gray-200);background:#fff}.project-init-step{display:inline-flex;align-items:center;gap:8px;color:var(--gray-300);font-size:14px;font-weight:600}.project-init-step.done{color:#22c55e}.project-init-step-dot{width:34px;height:34px;border-radius:999px;border:2px solid currentColor;display:inline-flex;align-items:center;justify-content:center;font-size:14px;line-height:1}.project-init-step.done .project-init-step-dot{background:#22c55e;border-color:#22c55e;color:#fff}.project-init-step-dot svg{width:16px;height:16px;fill:none;stroke:currentColor;stroke-width:2.2px;stroke-linecap:round;stroke-linejoin:round}.project-init-step-label{white-space:nowrap}.project-init-step-line{width:54px;height:2px;border-radius:999px;background:var(--gray-200)}.project-init-step-line.done{background:#22c55e}.project-init-terminal{margin:22px;border:1px solid #1f2d5c;border-radius:14px;background:#141939;color:#e8ecff;overflow:hidden}.project-init-terminal-head{display:flex;align-items:center;gap:8px;padding:10px 14px;border-bottom:1px solid rgba(255,255,255,.08);background:#111633}.project-init-terminal-dot{width:10px;height:10px;border-radius:50%}.project-init-terminal-dot.red{background:#ff5f57}.project-init-terminal-dot.yellow{background:#febc2e}.project-init-terminal-dot.green{background:#28c840}.project-init-terminal-title{margin-left:8px;font-size:13px;color:#e2e8ffd1}.project-init-terminal-body{display:grid;gap:6px;padding:14px 16px 18px;min-height:120px;max-height:480px;flex:1;overflow-y:auto;scroll-behavior:smooth;font-family:var(--mono);font-size:13px;line-height:1.6;align-content:start}.project-init-terminal-body::-webkit-scrollbar{width:6px}.project-init-terminal-body::-webkit-scrollbar-track{background:transparent}.project-init-terminal-body::-webkit-scrollbar-thumb{background:#ffffff26;border-radius:3px}.project-init-terminal-body::-webkit-scrollbar-thumb:hover{background:#ffffff40}.project-init-terminal-line{display:flex;align-items:baseline;gap:8px;animation:terminal-line-fadein .15s ease-out}@keyframes terminal-line-fadein{0%{opacity:0;transform:translateY(4px)}to{opacity:1;transform:translateY(0)}}.project-init-terminal-line .line-prefix{color:#6ee7b7;flex-shrink:0;-webkit-user-select:none;user-select:none}.project-init-terminal-line .line-text{color:#c9d1d9}.project-init-terminal-line .line-text.success{color:#6ee7b7}.project-init-terminal-line .line-text.active{color:#7dd3fc}.project-init-terminal-line .line-text.error{color:#fca5a5}.terminal-cursor{display:inline-block;width:8px;height:15px;background:#6ee7b7;border-radius:1px;vertical-align:text-bottom;animation:terminal-cursor-blink 1s step-end infinite}@keyframes terminal-cursor-blink{0%,to{opacity:1}50%{opacity:0}}.terminal-progress-badge{margin-left:auto;font-size:12px;font-weight:600;color:#6ee7b7;background:#6ee7b71f;padding:2px 8px;border-radius:4px}.project-init-page-actions{margin-top:auto;display:flex;align-items:center;justify-content:center;gap:12px;padding:14px 22px 18px;border-top:1px solid var(--gray-200);background:#fff}.mock-chat-entry{margin-top:24px;display:flex;flex-direction:column;align-items:center;text-align:center;padding:40px 24px;border:2px dashed var(--accent, #007aff);border-radius:12px;background:var(--accent-subtle, rgba(0, 122, 255, .06))}.mock-chat-entry-icon{width:48px;height:48px;color:var(--accent, #007aff);margin-bottom:12px}.mock-chat-entry-icon svg{width:100%;height:100%}.mock-chat-entry-title{font-size:18px;font-weight:700;color:var(--text-strong, #1f2937);margin:0 0 8px}.mock-chat-entry-desc{font-size:14px;color:var(--muted, #6b7280);margin:0 0 20px;max-width:420px;line-height:1.5}.mock-chat-entry .btn-lg{padding:12px 32px;font-size:16px;font-weight:600}.mock-canvas-layout{display:flex;flex-direction:column;min-height:clamp(620px,calc(100vh - 200px),860px);overflow:hidden}.mock-canvas-body{display:grid;grid-template-columns:minmax(240px,28%) minmax(0,1fr);flex:1;min-height:0;overflow:hidden}.mock-canvas-left{display:flex;flex-direction:column;border-right:1px solid var(--gray-200, #e5e7eb);overflow:hidden;padding:0}.mock-canvas-steps{padding:16px;flex-shrink:0;flex-wrap:nowrap;gap:4px}.mock-canvas-terminal{flex:1;margin:0!important;border-left:none!important;border-right:none!important;border-bottom:none!important;border-radius:0!important;overflow:hidden;display:flex;flex-direction:column}.mock-canvas-terminal .project-init-terminal-body{flex:1;min-height:0;max-height:none!important}.mock-canvas-right{display:flex;flex-direction:column;overflow:hidden;background:#0d1117}.mock-canvas-tabs{display:flex;gap:0;border-bottom:1px solid #30363d;background:#161b22;flex-shrink:0}.mock-canvas-tab{padding:8px 20px;background:none;border:none;border-bottom:2px solid transparent;cursor:pointer;font-size:13px;font-weight:500;color:#8b949e;transition:color .15s,border-color .15s}.mock-canvas-tab:hover{color:#e6edf3}.mock-canvas-tab.active{color:#e6edf3;border-bottom-color:#388bfd;border-bottom-width:3px;background:#388bfd0f}.mock-canvas-code{flex:1;overflow:auto;background:#0d1117}.mock-code-pre{margin:0;padding:16px;font-size:12px;font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,monospace;color:#c9d1d9;white-space:pre-wrap;word-break:break-all;line-height:1.6}.mock-canvas-preview{flex:1;overflow:hidden;background:#fff;min-height:520px}.mock-canvas-iframe{width:100%;height:100%;border:none;display:block}.mock-canvas-placeholder{display:flex;align-items:center;justify-content:center;height:100%;color:#8b949e;font-size:14px;background:#0d1117}.mock-canvas-placeholder--code{background:#111827;color:#9ca3af}.mock-canvas-footer{padding:12px 24px;border-top:1px solid var(--gray-200, #e5e7eb);display:flex;align-items:center;justify-content:space-between;gap:12px;background:#fff;flex-shrink:0}.mock-canvas-footer-actions{margin-left:auto;display:inline-flex;align-items:center;gap:10px}.mock-canvas-error{display:inline-flex;flex-wrap:wrap;align-items:center;gap:6px 10px;color:#b91c1c;font-size:13px}.mock-canvas-error code{padding:2px 6px;border-radius:6px;background:#fef2f2;border:1px solid #fecaca;color:#7f1d1d;font-family:var(--mono);font-size:12px}@media(max-width:1100px){.mock-canvas-body{grid-template-columns:minmax(0,1fr)}.mock-canvas-left{border-right:none;border-bottom:1px solid var(--gray-200, #e5e7eb);max-height:300px}.mock-canvas-preview{min-height:420px}}.mock-canvas-steps--done{padding:10px 22px;gap:8px;border-bottom:1px solid var(--gray-200)}.mock-canvas-steps--done .project-init-step{font-size:12px}.mock-canvas-steps--done .project-init-step-dot{width:24px;height:24px;font-size:11px}.mock-canvas-steps--done .project-init-step-line{width:32px}.mock-canvas-cta{padding:12px 32px;font-size:15px;font-weight:600;border-radius:var(--radius-lg, 10px);background:var(--primary-color, #007aff);border-color:var(--primary-color, #007aff);color:#fff;box-shadow:0 2px 8px #007aff4d;transition:all .15s ease-out}.mock-canvas-cta:hover{background:#0066d6;border-color:#0066d6;box-shadow:0 4px 16px #007aff66;transform:translateY(-1px)}.mock-canvas-tabs-actions{margin-left:auto;display:flex;align-items:center;padding-right:8px}.mock-canvas-fullscreen-btn{width:32px;height:32px;padding:0;background:transparent;border:none;color:#8b949e;cursor:pointer;border-radius:var(--radius-sm, 4px);transition:all .15s ease-out;display:inline-flex;align-items:center;justify-content:center}.mock-canvas-fullscreen-btn:hover{background:#ffffff1a;color:#e6edf3}.mock-canvas-fullscreen-btn svg{width:16px;height:16px;fill:none;stroke:currentColor;stroke-width:2px;stroke-linecap:round;stroke-linejoin:round}.mock-preview-fullscreen{position:fixed;inset:0;z-index:9999;background:#0009;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);display:flex;align-items:center;justify-content:center;animation:fullscreen-overlay-in .2s ease-out}@keyframes fullscreen-overlay-in{0%{opacity:0}to{opacity:1}}.mock-preview-fullscreen-container{width:calc(100vw - 48px);height:calc(100vh - 48px);border-radius:var(--radius-xl, 16px);overflow:hidden;background:#fff;box-shadow:0 25px 50px #0006;display:flex;flex-direction:column;animation:fullscreen-panel-in .2s ease-out}@keyframes fullscreen-panel-in{0%{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}.mock-preview-fullscreen-header{display:flex;align-items:center;justify-content:space-between;padding:12px 20px;background:#f8f9fa;border-bottom:1px solid var(--gray-200);flex-shrink:0}.mock-preview-fullscreen-title{font-size:14px;font-weight:600;color:var(--gray-700)}.mock-preview-fullscreen-close{width:32px;height:32px;padding:0;border-radius:var(--radius-md, 6px);color:var(--gray-500);background:transparent;border:none;cursor:pointer;display:inline-flex;align-items:center;justify-content:center;transition:all .15s}.mock-preview-fullscreen-close:hover{background:var(--gray-200);color:var(--gray-800)}.mock-preview-fullscreen-close svg{width:18px;height:18px;fill:none;stroke:currentColor;stroke-width:2px;stroke-linecap:round;stroke-linejoin:round}.mock-preview-fullscreen-iframe{flex:1;width:100%;border:none;display:block}.nav-toggle-btn{width:32px;height:32px;padding:0;border-radius:var(--radius-md, 6px);background:transparent;border:1px solid transparent;color:var(--gray-500);cursor:pointer;transition:all .15s ease-out;flex-shrink:0;display:inline-flex;align-items:center;justify-content:center}.nav-toggle-btn:hover{background:var(--gray-100);color:var(--gray-700);border-color:var(--gray-200)}.nav-toggle-btn svg{width:18px;height:18px;fill:none;stroke:currentColor;stroke-width:2px;stroke-linecap:round;stroke-linejoin:round}.shell{transition:grid-template-columns .2s ease-out}.shell.shell--nav-collapsed{grid-template-columns:48px minmax(0,1fr)}.nav.nav--collapsed{width:48px;min-width:48px;overflow:hidden;padding:0;opacity:1;pointer-events:auto}.nav.nav--collapsed .nav-create-btn,.nav.nav--collapsed .nav-group,.nav.nav--collapsed .nav-footer{display:none}.nav.nav--collapsed .nav-sidehead{padding:14px 8px;margin:0;justify-content:center;gap:0}.nav.nav--collapsed .nav-sidehead-top{justify-content:center;width:32px}.nav.nav--collapsed .nav-sidebrand{display:none}.nav-label__chevron svg{width:14px;height:14px;fill:none;stroke:currentColor;stroke-width:2px;stroke-linecap:round;stroke-linejoin:round}.codevox-files-page{border:1px solid var(--gray-200);border-radius:14px;background:#fff;overflow:hidden}.file-toolbar-actions{margin-left:auto;display:flex;align-items:center;flex-wrap:wrap;gap:8px}.file-toolbar-actions .btn.btn-sm{height:32px;padding:0 12px;font-size:13px;border-radius:10px}.file-toolbar-actions .btn.btn-sm svg{width:14px;height:14px;margin-right:4px;fill:none;stroke:currentColor;stroke-width:1.9px;stroke-linecap:round;stroke-linejoin:round}.file-toolbar-actions .btn.btn-sm.danger{color:#ef4444}.codevox-files-content{min-height:640px;border-top:1px solid var(--gray-200)}.codevox-files-tree{width:300px;padding:10px 0}.file-tree-item.folder .tree-icon-folder svg,.tree-icon-file svg{width:14px;height:14px;fill:none;stroke:currentColor;stroke-width:1.9px;stroke-linecap:round;stroke-linejoin:round}.file-tree-item.folder .tree-icon-folder{color:#f4b400}.codevox-files-viewer{min-height:640px}.workbench-chat-empty{margin:auto;max-width:520px;text-align:center;color:var(--gray-500)}.workbench-chat-empty__icon{width:86px;height:86px;margin:0 auto 18px;border-radius:24px;background:linear-gradient(135deg,#1677ff,#4f46e5);color:#fff;display:inline-flex;align-items:center;justify-content:center;box-shadow:0 14px 26px #1677ff3d}.workbench-chat-empty__icon svg{width:40px;height:40px;fill:none;stroke:currentColor;stroke-width:1.9px;stroke-linecap:round;stroke-linejoin:round}.workbench-chat-empty__title{margin:0;color:#334155;font-size:clamp(18px,5vw,42px);font-weight:700;white-space:nowrap}.workbench-chat-empty__sub{margin:14px auto 0;max-width:480px;color:var(--gray-400);font-size:20px;line-height:1.45}.workbench-chat-empty__icon--pulse{animation:workspace-pulse 2s ease-in-out infinite}@keyframes workspace-pulse{0%,to{transform:scale(1);opacity:1}50%{transform:scale(1.05);opacity:.85}}.workbench-chat-preparing__dots{display:flex;justify-content:center;gap:6px;margin-top:18px}.workbench-chat-preparing__dots>span{width:8px;height:8px;border-radius:50%;background:var(--primary-color, #007aff);opacity:.4;animation:preparing-bounce 1.2s infinite ease-in-out}.workbench-chat-preparing__dots>span:nth-child(2){animation-delay:.15s}.workbench-chat-preparing__dots>span:nth-child(3){animation-delay:.3s}@keyframes preparing-bounce{0%,80%,to{opacity:.4;transform:scale(1)}40%{opacity:1;transform:scale(1.2)}}@media(prefers-reduced-motion:reduce){.workbench-chat-empty__icon--pulse{animation:none}.workbench-chat-preparing__dots>span{animation:none;opacity:.6}}@media(max-width:1280px){.workbench-header-right{width:100%;justify-content:flex-start;flex-wrap:wrap}.project-wizard{width:min(940px,calc(100vw - 24px));max-height:calc(100vh - 24px)}.wizard-steps{grid-template-columns:repeat(7,minmax(120px,1fr));overflow-x:auto;padding-bottom:2px}}@media(max-width:960px){.shell{grid-template-columns:180px minmax(0,1fr);grid-template-rows:1fr;grid-template-areas:"nav content"}.nav{position:static;display:flex;flex-direction:column;width:180px;max-height:none;overflow-x:visible;overflow-y:auto;border-right:1px solid var(--gray-200);border-bottom:none;padding:0;background:#fff}.nav-group{grid-auto-flow:row;grid-template-columns:1fr}.nav-label{display:block}.nav-group__items{display:grid}.nav-item{white-space:normal;flex-shrink:unset}.workbench-main-column,.content-header,.content-header--workbench{padding:12px}.workbench-header-main{flex-direction:column;align-items:flex-start}.workbench-header-right{width:100%;justify-content:flex-start;flex-wrap:wrap}.workbench-header-control-inline .chat-controls{flex-wrap:wrap}.workbench-user-actions{width:100%;flex-wrap:wrap}.workbench-layout{grid-template-columns:minmax(0,1fr)}.workbench-right-panel{display:none}.project-wizard .modal-title{font-size:22px}}.shell--chat-focus .workbench-layout{grid-template-columns:minmax(0,1fr)}.shell--chat-focus .workbench-right-panel{display:none}:root,:root[data-theme=light],:root[data-theme=dark]{--font-body: -apple-system, BlinkMacSystemFont, "SF Pro Display", "SF Pro Text", "Helvetica Neue", Arial, sans-serif;--font-display: var(--font-body)}body{font-family:var(--font-body);background:var(--gray-100);color:var(--gray-800)}.shell{grid-template-columns:240px minmax(0,1fr);grid-template-rows:1fr;grid-template-areas:"nav content";background:var(--gray-100)}.nav{width:240px;padding:0;background:#fff;border-right:1px solid var(--gray-200);display:flex;flex-direction:column;overflow-y:auto}@media(max-width:1100px){.shell{grid-template-columns:200px minmax(0,1fr);grid-template-rows:1fr;grid-template-areas:"nav content"}.nav{position:static;display:flex;flex-direction:column;width:200px;max-height:none;overflow-x:visible;overflow-y:auto;border-right:1px solid var(--gray-200);border-bottom:none;padding:0;background:#fff}.nav-group{grid-auto-flow:row;grid-template-columns:1fr}.nav-label{display:block}.nav-group__items{display:grid}.nav-item{white-space:normal;flex-shrink:unset}}.nav-sidehead{padding:20px;margin:0;border-bottom:1px solid var(--gray-200)}.nav-sidebrand{padding:0;gap:12px}.nav-sidebrand__logo{width:36px;height:36px;border-radius:var(--radius-sm);background:linear-gradient(135deg,#667eea,#764ba2)}.nav-sidebrand__title{font-size:18px;font-weight:600;letter-spacing:0}.nav-sidebrand__sub{font-size:12px}.nav-create-btn{width:100%;margin:16px 0 0;border-radius:var(--radius);padding:12px 16px;font-size:14px}.nav-group{margin:0;padding:16px 12px 0}.nav-label{padding:0 12px;margin-bottom:8px;font-size:11px;font-weight:600;color:var(--gray-400);text-transform:uppercase;letter-spacing:.5px}.nav-label:hover{background:var(--gray-100);color:var(--gray-600)}.nav-group__items{gap:0}.nav-item{padding:10px 12px;border:0;border-radius:var(--radius-sm);color:var(--gray-600)}.nav-item__text{font-size:14px;font-weight:500}.nav-item:hover{background:var(--gray-100)}.nav-item.active{background:var(--primary-light);color:var(--primary-color);border:0}.nav-quota{margin:16px;padding:12px;background:var(--gray-50)}.content{background:var(--gray-100)}.content-header,.content-header--workbench{background:#fff;border-bottom:1px solid var(--gray-200);padding:16px 24px}.workbench-project-title{font-size:18px;font-weight:600;letter-spacing:0}.workbench-project-tags{gap:12px}.workbench-tag{border-radius:4px;font-size:11px;padding:2px 8px}.workbench-tag--db{background:#e3f2fd;color:#1976d2}.workbench-user-pill{padding:6px 12px;border-radius:var(--radius);border:0}.workbench-user-avatar{width:32px;height:32px;font-size:14px}.workbench-header-btn{padding:8px 14px;font-size:13px;border-radius:var(--radius-sm)}.workbench-layout{grid-template-columns:minmax(0,1fr) 320px}.workbench-main-column{padding:24px}.workbench-main-column .chat-thread{margin:0;padding:0 4px;border:0;background:transparent}.chat-compose{padding:16px 0 0;background:transparent}.chat-compose__row{padding:8px;border:0;border-radius:var(--radius-lg);box-shadow:var(--shadow-md);background:#fff}.chat-compose__field textarea{min-height:44px;height:44px;max-height:200px;padding:12px 14px}.chat-compose__send-btn{width:44px;height:44px;border-radius:var(--radius);background:var(--primary-color);box-shadow:none}.chat-compose__send-btn:hover:not(:disabled){background:#06c}.workbench-right-panel{width:320px;border-left:1px solid var(--gray-200)}.workbench-panel-section{padding:16px}.workbench-panel-title{font-size:14px;font-weight:600}.workbench-action-grid,.workbench-integration-grid{gap:8px}.workbench-action-btn,.workbench-integration-item,.workbench-module-item{border:1px solid transparent;background:var(--gray-50)}.workbench-action-btn:hover,.workbench-integration-item:hover,.workbench-module-item:hover{background:#fff;border-color:var(--gray-200);box-shadow:var(--shadow-sm)}.workbench-module-grid{grid-template-columns:repeat(3,minmax(0,1fr));gap:12px}.projects-grid.codevox-project-grid{grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:20px;margin-top:16px}.projects-empty svg{width:100%;height:100%}.openclaw-sessions-raw{display:none}.project-card.codevox-project-card{border-radius:var(--radius-lg);padding:24px;border:1px solid var(--gray-200);box-shadow:var(--shadow-sm);background:#fff;transition:transform .15s ease,border-color .15s ease,box-shadow .15s ease}.project-card.codevox-project-card:hover{transform:translateY(-2px);border-color:var(--primary-color);box-shadow:var(--shadow-md)}.project-card-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px}.project-card-icon{width:44px;height:44px;border-radius:var(--radius);background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;display:inline-flex;align-items:center;justify-content:center}.project-card-icon svg{width:20px;height:20px}.project-card-status{display:inline-flex;align-items:center;gap:6px;font-size:12px;font-weight:500}.project-card-dot{width:6px;height:6px;border-radius:50%;background:var(--success-color)}.project-card-name{margin:0 0 8px;font-size:16px;color:var(--gray-800)}.project-card-id{display:flex;align-items:baseline;gap:6px;margin:0 0 10px;font-size:12px;color:var(--gray-500);line-height:1.4}.project-card-id-label{flex-shrink:0;font-weight:600;color:var(--gray-600)}.project-card-id-value{font-family:var(--mono);font-size:12px;color:var(--gray-700);word-break:break-all}.project-card-desc{margin:0 0 16px;font-size:13px;color:var(--gray-500);line-height:1.5}.project-card-tags{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:16px}.project-card-tag{font-size:11px;padding:2px 8px;border-radius:4px;background:var(--gray-100);color:var(--gray-600);font-weight:500}.project-card-footer{display:flex;align-items:center;justify-content:space-between;color:var(--gray-400);font-size:12px;padding-top:12px;border-top:1px solid var(--gray-100)}.project-card-actions{display:flex;gap:6px}.card-action-btn{width:34px;height:34px;border:none;border-radius:8px;display:inline-flex;align-items:center;justify-content:center;cursor:pointer;transition:all .15s ease}.card-action-btn svg{width:16px;height:16px;fill:none;stroke:currentColor;stroke-width:1.8px;stroke-linecap:round;stroke-linejoin:round}.card-action-btn.files{background:#34c75914;color:#34c759}.card-action-btn.files:hover{background:#34c7592e}.card-action-btn.enter{background:#007aff14;color:#007aff}.card-action-btn.enter:hover{background:#007aff2e}.card-action-btn.preview{background:#af52de14;color:#af52de}.card-action-btn.preview:hover{background:#af52de2e}.card-action-btn.delete{background:#ff3b3014;color:#ff3b30}.card-action-btn.delete:hover{background:#ff3b302e}.codevox-project-files{margin-top:20px;border:1px solid var(--gray-200);border-radius:var(--radius-lg);background:#fff;overflow:hidden}.file-toolbar{display:flex;align-items:center;gap:10px;padding:12px 20px;background:#fff;border-bottom:1px solid var(--gray-200)}.file-toolbar-title{font-size:16px;font-weight:600;color:var(--gray-800)}.file-toolbar-path{margin-left:auto;font-size:12px;color:var(--gray-500);font-family:var(--mono)}.file-content{display:flex;min-height:260px}.file-tree-panel{width:280px;border-right:1px solid var(--gray-200);background:#fff;padding:8px 0;overflow-y:auto}.file-tree-item{display:flex;align-items:center;gap:8px;padding:6px 12px;font-size:13px;color:var(--gray-700);cursor:pointer}.file-tree-item.selected{background:#007aff14;color:var(--primary-color)}.file-tree-item.folder:hover,.file-tree-item:not(.folder):hover{background:#0000000a}.file-tree-item .tree-icon-file svg{width:14px;height:14px}.tree-chevron{display:inline-flex;align-items:center;justify-content:center;width:16px;height:16px;flex-shrink:0}.tree-chevron:before{content:"";display:block;border-left:5px solid var(--gray-400);border-top:4px solid transparent;border-bottom:4px solid transparent;transition:transform .15s ease}.tree-chevron.expanded:before{transform:rotate(90deg)}.file-tree-item.folder .tree-icon-folder svg{color:#f4b400}.tree-name{white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.file-viewer-panel{flex:1;display:flex;flex-direction:column;min-width:0}.file-viewer-header{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:12px 16px;border-bottom:1px solid var(--gray-200);background:var(--gray-50);font-weight:500;font-size:14px;color:var(--gray-700)}.file-viewer-filename{font-size:13px;font-weight:600;font-family:var(--mono)}.file-viewer-meta{font-size:12px;color:var(--gray-500)}.file-viewer-content{flex:1;overflow:auto}.file-viewer-content pre{margin:0;padding:16px;font-size:13px;line-height:1.6;color:var(--gray-700);white-space:pre-wrap;word-break:break-word}.file-viewer-empty{flex:1;display:flex;align-items:center;justify-content:center;color:var(--gray-400)}.file-viewer-name{font-family:var(--mono)}.file-viewer-body{padding:16px;flex:1;overflow:auto}.file-viewer-desc{margin:0 0 16px;color:var(--gray-500);font-size:13px}.file-viewer-code{margin:0;padding:16px;background:var(--gray-50);border-radius:var(--radius-md);font-size:13px;line-height:1.6;color:var(--gray-600);overflow-x:auto}.file-viewer-code code{font-family:var(--mono)}.project-wizard{width:min(1024px,calc(100vw - 24px));height:min(820px,calc(100vh - 32px));max-height:calc(100vh - 32px);background:#fff;box-shadow:var(--shadow-lg);position:relative;display:flex;flex-direction:column;overflow:hidden;color:var(--gray-700);border-radius:var(--radius-xl)}.project-wizard .callout{margin:12px 24px 0}.project-wizard .modal-header{display:flex;justify-content:space-between;gap:12px;padding:24px 24px 0;align-items:flex-start}.wizard-title-wrap{flex:0 0 140px;min-width:140px}.project-wizard .modal-title{margin:0;font-size:20px;line-height:1.2;font-weight:600;white-space:nowrap}.project-wizard-subtitle{margin-top:4px;font-size:13px;line-height:1.55;color:var(--gray-500)}.project-wizard .modal-close{width:32px;min-width:32px;height:32px;border-radius:50%;border:none;background:var(--gray-100);color:var(--gray-500);display:inline-flex;align-items:center;justify-content:center;padding:0;cursor:pointer;transition:background .2s ease}.project-wizard .modal-close:hover{background:var(--gray-200)}.project-wizard .modal-close svg{width:16px;height:16px}.wizard-steps{display:flex;align-items:center;justify-content:flex-start;flex:1;min-width:0;gap:0;margin:0 8px 0 auto;overflow-x:auto;overflow-y:hidden;padding:0 8px 2px 0}.wizard-step-item{display:flex;align-items:center;gap:8px;flex:0 0 auto}.wizard-step-line{width:24px;height:2px;margin:0 1px;background:var(--gray-200);transition:background .2s ease}.wizard-step-line.completed{background:var(--primary-color)}.wizard-step-dot{width:28px;height:28px;border-radius:50%;border:2px solid var(--gray-300);color:var(--gray-400);background:#fff;font-size:12px;font-weight:600;display:inline-flex;align-items:center;justify-content:center}.wizard-step-dot svg{width:12px;height:12px}.wizard-step-dot.active,.wizard-step-dot.completed{border-color:var(--primary-color);background:var(--primary-color);color:#fff}.wizard-step-label{font-size:11px;color:var(--gray-400);white-space:nowrap;line-height:1}.wizard-step-label.active{color:var(--primary-color);font-weight:500}.project-wizard .modal-body{min-height:500px;padding:20px 24px;border-top:1px solid var(--gray-100);overflow-y:auto;display:flex;flex-direction:column;gap:12px}.project-wizard .modal-footer{padding:16px 24px 24px;border-top:1px solid var(--gray-100);display:flex;align-items:center;justify-content:space-between;gap:10px}.project-wizard .btn{display:inline-flex;align-items:center;justify-content:center;gap:6px;border-radius:var(--radius-sm);border:1px solid transparent;font-size:14px;font-weight:500;cursor:pointer;transition:all .2s ease;padding:8px 16px}.project-wizard .btn:disabled{opacity:.55;cursor:not-allowed}.project-wizard .btn.btn-lg{min-width:64px;padding:10px 24px;font-size:15px;line-height:1.2}.project-wizard .btn.btn-primary{background:var(--primary-color);color:#fff;border-color:var(--primary-color)}.project-wizard .btn.btn-primary:hover:not(:disabled){background:#06c;border-color:#06c}.project-wizard .btn.btn-secondary{background:var(--gray-100);color:var(--gray-600);border-color:transparent}.project-wizard .btn.btn-secondary:hover:not(:disabled){background:var(--gray-200)}.form-label-row{display:flex;align-items:center;justify-content:space-between;margin-bottom:6px}.form-label-row .form-label{margin-bottom:0}.project-wizard .btn.btn-ai-generate{padding:4px 14px;font-size:12px;font-weight:600;color:#fff;background:linear-gradient(135deg,#007aff,#5856d6);border:none;border-radius:6px;box-shadow:0 2px 8px #007aff40}.project-wizard .btn.btn-ai-generate:hover:not(:disabled){background:linear-gradient(135deg,#06c,#4a45c0);box-shadow:0 4px 12px #007aff59;transform:translateY(-1px)}.project-wizard .btn.btn-ai-generate:active:not(:disabled){transform:translateY(0);box-shadow:0 1px 4px #007aff33}.project-wizard .btn.btn-ai-generate svg{width:14px;height:14px}.project-wizard .btn.btn-ai-generate .btn-spinner{width:14px;height:14px;border:2px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:btn-spin .6s linear infinite}@keyframes btn-spin{to{transform:rotate(360deg)}}.project-description-input{min-height:120px}.wizard-industry-grid{display:grid;grid-template-columns:repeat(5,minmax(0,1fr))}.wizard-industry-grid .industry-item{background:var(--gray-50);border:1px solid transparent;border-radius:10px;padding:10px 6px;display:flex;flex-direction:column;align-items:center;gap:6px;cursor:pointer}.wizard-industry-grid .industry-item span{font-size:11px;color:var(--gray-600);font-weight:500;text-align:center}.wizard-industry-grid .industry-item.selected{background:#007aff0f;border-color:var(--primary-color)}.wizard-industry-grid .industry-icon{width:32px;height:32px;border-radius:8px;background:#f1f5f9;color:#64748b;display:inline-flex;align-items:center;justify-content:center;font-size:13px;font-weight:600}.wizard-industry-grid .industry-icon svg{width:18px;height:18px;fill:none;stroke:currentColor;stroke-width:1.8px;stroke-linecap:round;stroke-linejoin:round}.wizard-industry-grid .industry-item.selected span{color:var(--primary-color)}.wizard-industry-grid .industry-icon.gov{background:#dbeafe;color:#2563eb}.wizard-industry-grid .industry-icon.manufacture{background:#fee2e2;color:#dc2626}.wizard-industry-grid .industry-icon.service{background:#d1fae5;color:#059669}.wizard-industry-grid .industry-icon.finance{background:#fef3c7;color:#d97706}.wizard-industry-grid .industry-icon.logistics{background:#e0e7ff;color:#4f46e5}.wizard-industry-grid .industry-icon.medical{background:#fce7f3;color:#db2777}.wizard-industry-grid .industry-icon.education{background:#cffafe;color:#0891b2}.wizard-industry-grid .industry-icon.catering{background:#ffedd5;color:#ea580c}.wizard-industry-grid .industry-icon.group{background:#f3e8ff;color:#9333ea}.wizard-industry-grid .industry-icon.other{background:#f1f5f9;color:#64748b}.wizard-template-selection-list{display:flex;flex-direction:column;gap:8px}.wizard-template-selection-card{border:1px solid var(--gray-200);border-radius:12px;background:var(--gray-50);padding:12px 14px;cursor:pointer;transition:all .2s ease}.wizard-template-selection-card:hover{border-color:var(--primary-color)}.wizard-template-selection-card.selected{border-color:#007aff73;background:#f2f8ff;box-shadow:0 0 0 2px #007aff14}.wizard-template-selection-title{font-size:14px;line-height:1.2;font-weight:600;color:#334155}.wizard-template-selection-desc{margin-top:4px;font-size:12px;color:#6b7280}.wizard-template-selection-source{margin-top:8px;display:inline-block;font-size:12px;color:#2f80ff;font-weight:600}.wizard-template-preview-stage{margin-top:12px;min-height:320px;border:1px solid var(--gray-200);border-radius:10px;overflow:hidden;background:var(--gray-50)}.wizard-template-preview-frame{width:100%;height:320px;border:0;background:#fff}.wizard-template-preview-empty{height:100%;min-height:320px;display:flex;align-items:center;justify-content:center;color:var(--gray-400);font-size:13px}.wizard-template-preview-open{margin-top:12px;display:flex;justify-content:center}.wizard-template-open-link{color:var(--primary-color);font-size:13px;font-weight:500;text-decoration:none}.wizard-template-open-link:hover{text-decoration:underline}.wizard-generating-overlay{position:absolute;inset:0;z-index:3;display:flex;align-items:center;justify-content:center;background:#ffffffdb;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px)}.wizard-generating-card{display:flex;flex-direction:column;align-items:center;gap:10px;max-width:520px;text-align:center}.wizard-generating-icon{width:72px;height:72px;border-radius:20px;border:1px solid rgba(0,122,255,.18);background:#007aff14;color:var(--primary-color);display:inline-flex;align-items:center;justify-content:center}.wizard-generating-icon svg{width:34px;height:34px}.wizard-generating-title{font-size:24px;font-weight:700;color:var(--gray-800)}.wizard-generating-subtitle{font-size:16px;color:var(--gray-500);line-height:1.5}.wizard-generating-progress{width:320px;display:flex;flex-direction:column;align-items:center;gap:8px;margin-top:6px}.wizard-generating-progress-track{width:100%;height:6px;background:var(--gray-100);border-radius:3px;overflow:hidden}.wizard-generating-progress-bar{height:100%;border-radius:3px;background:linear-gradient(90deg,#007aff,#5856d6);transition:width .4s ease}.wizard-generating-progress-text{font-size:13px;font-weight:600;color:var(--gray-500);font-variant-numeric:tabular-nums}.wizard-generating-cancel{margin-top:6px;min-width:120px}.wizard-streaming-overlay{position:absolute;inset:0;z-index:3;display:flex;flex-direction:column;background:var(--bg, #fff)}.wizard-streaming-container{display:flex;flex-direction:column;height:100%;overflow:hidden}.wizard-streaming-header{display:flex;align-items:center;gap:12px;padding:12px 20px;border-bottom:1px solid var(--gray-100);flex-shrink:0}.wizard-streaming-status{display:flex;align-items:center;gap:8px;flex-shrink:0}.wizard-streaming-dot{width:8px;height:8px;border-radius:50%;background:#34c759;animation:wizard-streaming-pulse 1.5s ease-in-out infinite}@keyframes wizard-streaming-pulse{0%,to{opacity:1}50%{opacity:.4}}.wizard-streaming-label{font-size:13px;font-weight:600;color:var(--gray-700);white-space:nowrap}.wizard-streaming-progress-mini{flex:1;min-width:80px;max-width:200px}.wizard-streaming-progress-track{width:100%;height:4px;background:var(--gray-100);border-radius:2px;overflow:hidden}.wizard-streaming-progress-bar{height:100%;border-radius:2px;background:linear-gradient(90deg,#34c759,#30d158);transition:width .3s ease}.wizard-streaming-cancel{flex-shrink:0}.wizard-streaming-preview{flex:1;overflow-y:auto;padding:20px 24px;font-size:14px;line-height:1.7;color:var(--gray-800);overflow-anchor:auto}.wizard-streaming-markdown{animation:wizard-streaming-fadein .2s ease}@keyframes wizard-streaming-fadein{0%{opacity:.6}to{opacity:1}}.wizard-streaming-placeholder{color:var(--gray-400);font-style:italic}.wizard-streaming-cursor{display:inline-block;width:2px;height:1em;background:var(--primary-color, #007aff);margin-left:2px;vertical-align:text-bottom;animation:wizard-cursor-blink .8s step-end infinite}@keyframes wizard-cursor-blink{0%,to{opacity:1}50%{opacity:0}}.wizard-error-details{margin-top:10px}.wizard-error-details summary{cursor:pointer;font-size:12px;color:var(--gray-700)}.wizard-error-details pre{margin:8px 0 0;white-space:pre-wrap;word-break:break-word;font-size:12px;line-height:1.5;color:var(--gray-600)}.template-scroll-wrapper{position:relative;overflow:hidden;padding:0 40px}.template-scroll-btn{position:absolute;top:50%;transform:translateY(-50%);z-index:2;width:32px;height:32px;border-radius:50%;border:1px solid var(--gray-200);background:#fff;color:var(--gray-500);display:inline-flex;align-items:center;justify-content:center;cursor:pointer;box-shadow:0 2px 6px #00000014;transition:all .2s ease}.template-scroll-btn:hover{background:var(--gray-50);color:var(--gray-700);box-shadow:0 3px 10px #0000001f}.template-scroll-btn svg{width:16px;height:16px}.template-scroll-btn.left{left:0}.template-scroll-btn.right{right:0}.template-scroll{display:flex;gap:16px;overflow-x:auto;padding:4px 0;scroll-snap-type:x mandatory;scrollbar-width:none}.template-scroll::-webkit-scrollbar{display:none}.template-card{min-width:240px;max-width:240px;border:2px solid var(--gray-200);border-radius:12px;background:#fff;overflow:hidden;cursor:pointer;position:relative;scroll-snap-align:start;transition:all .2s ease}.template-card:hover{border-color:var(--gray-300);box-shadow:0 4px 14px #00000014;transform:translateY(-2px)}.template-card.selected{border-color:var(--primary-color);box-shadow:0 0 0 3px #007aff26;transform:none}.template-card-image{height:140px;background:var(--gray-50);display:flex;align-items:center;justify-content:center;overflow:hidden}.template-card-image img{width:100%;height:100%;object-fit:cover}.template-card-placeholder svg{width:28px;height:28px;color:var(--gray-300)}.template-card-body{padding:12px 14px}.template-card-name{font-size:14px;font-weight:600;color:var(--gray-800)}.template-card-desc{margin-top:4px;font-size:12px;color:var(--gray-500);line-height:1.4}.template-card-category{margin-top:8px;display:inline-block;font-size:11px;padding:2px 8px;border-radius:4px;background:#007aff14;color:var(--primary-color);font-weight:500}.template-card-check{position:absolute;top:8px;left:8px;width:24px;height:24px;border-radius:50%;background:var(--primary-color);color:#fff;display:inline-flex;align-items:center;justify-content:center}.template-card-check svg{width:14px;height:14px}.template-skip{display:flex;align-items:center;justify-content:center;width:100%;margin-top:16px;padding:10px 16px;font-size:13px;font-weight:500;color:var(--gray-500);background:var(--gray-50);border:1px dashed var(--gray-200);border-radius:var(--radius-sm);cursor:pointer;transition:all .2s ease}.template-skip:hover{color:var(--gray-700);background:var(--gray-100);border-color:var(--gray-300)}.template-preview-stage{margin-top:12px;min-height:320px;border:1px solid var(--gray-200);border-radius:10px;overflow:hidden;background:var(--gray-50)}.template-preview-frame{width:100%;height:320px;border:0}.template-preview-empty{height:100%;min-height:320px;display:flex;align-items:center;justify-content:center;color:var(--gray-400);font-size:13px}.template-preview-open{margin-top:12px;display:flex;justify-content:center}.template-open-link{color:var(--primary-color);font-size:13px;font-weight:500;text-decoration:none}.techstack-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px}.techstack-item{border:1px solid var(--gray-200);border-radius:10px;padding:12px 14px;background:#fff;cursor:pointer;text-align:left}.techstack-item.selected{border-color:var(--primary-color);border-width:2px;background:#007aff14;box-shadow:0 0 0 3px #007aff1f}.techstack-item.selected .techstack-label{color:var(--primary-color)}.techstack-header{display:flex;align-items:center;gap:6px;margin-bottom:4px}.techstack-label{font-size:14px;font-weight:600;color:var(--gray-800)}.techstack-badge{font-size:10px;font-weight:600;color:#fff;background:linear-gradient(135deg,#007aff,#5856d6);border-radius:4px;padding:1px 6px}.techstack-desc{font-size:12px;color:var(--gray-500);line-height:1.5;margin-bottom:6px}.techstack-tags{font-size:11px;color:var(--gray-400)}.upload-header{margin-bottom:16px}.upload-title{margin:0 0 4px;font-size:16px;font-weight:600}.upload-subtitle{margin:0;font-size:13px;color:var(--gray-500)}.upload-zone{position:relative;border:2px dashed var(--gray-200);border-radius:12px;background:var(--gray-50);text-align:center;padding:32px 20px;cursor:pointer;display:block}.upload-zone.drag-over,.upload-zone:hover{border-color:var(--primary-color);background:#007aff0a}.reference-file-input{position:absolute;inset:0;opacity:0;cursor:pointer}.upload-zone-icon{color:var(--gray-300)}.upload-zone-icon svg{width:32px;height:32px}.upload-zone-text{margin-top:10px;font-size:14px;color:var(--gray-600);font-weight:500}.upload-zone-hint{margin-top:4px;font-size:12px;color:var(--gray-400)}.upload-file-list{margin-top:12px;display:flex;flex-direction:column;gap:6px}.upload-file-item{display:flex;align-items:center;gap:10px;border:1px solid var(--gray-100);border-radius:8px;padding:8px 12px;background:var(--gray-50)}.upload-file-icon{color:var(--gray-400)}.upload-file-icon svg{width:14px;height:14px}.upload-file-info{min-width:0}.upload-file-name{font-size:13px;color:var(--gray-700)}.plan-review-header{display:flex;align-items:center;gap:12px;margin:14px 0 16px;padding-bottom:16px;border-bottom:1px solid var(--gray-100)}.plan-review-icon{width:40px;height:40px;border-radius:10px;background:#007aff1a;color:var(--primary-color);display:inline-flex;align-items:center;justify-content:center}.plan-review-icon svg{width:20px;height:20px}.plan-review-title{font-size:16px;font-weight:600}.plan-review-subtitle{margin-top:2px;font-size:12px;color:var(--gray-400)}.plan-content{margin-bottom:16px;max-height:400px;overflow-y:auto;padding:16px;background:#f8fafc;border:1px solid var(--gray-200);border-radius:12px}.plan-content-markdown{font-size:13px;line-height:1.7;color:var(--gray-700)}.plan-content-markdown h1,.plan-content-markdown h2,.plan-content-markdown h3{color:var(--gray-800)}.plan-content-markdown p,.plan-content-markdown ul,.plan-content-markdown ol{margin:.5em 0}.plan-markdown-textarea{min-height:400px;resize:vertical;font-family:var(--mono);font-size:13px;line-height:1.7;margin-bottom:16px}.plan-review .plan-markdown-textarea,.plan-review.plan-editing .plan-content{display:none}.plan-review.plan-editing .plan-markdown-textarea{display:block}.plan-mode-toggle{display:inline-flex;align-items:center;gap:4px;padding:4px 10px;font-size:12px;white-space:nowrap}.plan-mode-toggle svg{width:14px;height:14px}.plan-review .when-editing{display:none}.plan-review .when-preview{display:inline-flex;align-items:center;gap:4px}.plan-review.plan-editing .when-preview{display:none}.plan-review.plan-editing .when-editing{display:inline-flex;align-items:center;gap:4px}.plan-optimize{padding-top:16px;margin-top:4px;border-top:1px solid var(--gray-200)}.plan-optimize-row{display:flex;gap:10px;align-items:center}.plan-optimize-input{flex:1}.project-wizard .btn.btn-optimize{padding:7px 16px;border-radius:8px;font-size:13px}.init-phases.wizard-init-phases{padding:8px 0 16px;background:transparent;border:0;justify-content:flex-start}.init-phase-dot-wrapper{min-width:96px}.init-phase-dot{width:28px;height:28px;border-radius:50%;border:2px solid var(--gray-300);background:#fff;color:var(--gray-400);display:inline-flex;align-items:center;justify-content:center;font-size:12px;font-weight:600}.init-phase-dot.active{border-color:var(--primary-color);background:#007aff1a;color:var(--primary-color)}.init-phase-dot.completed{border-color:var(--success-color);background:var(--success-color);color:#fff}.init-phase-dot.error{border-color:var(--danger-color);background:var(--danger-color);color:#fff}.init-phase-dot svg{width:12px;height:12px}.init-phase-line{width:44px;height:2px;background:var(--gray-200);margin:0 4px 24px}.init-phase-line.completed{background:var(--success-color)}.init-phase-label{font-size:11px;color:var(--gray-400)}.init-phase-label.active{color:var(--primary-color)}.init-phase-label.completed{color:var(--success-color)}.project-init-log{border:1px solid #dfe5ed;border-radius:12px;background:#1a1a2e;color:#e2e8f0;padding:12px;min-height:220px;max-height:320px;overflow-y:auto}.init-log-entry{display:flex;align-items:flex-start;gap:10px;padding:2px 0;font-family:var(--mono);font-size:12px}.init-log-time{min-width:40px;color:#ffffff59}.init-log-icon{width:14px;text-align:center}.init-log-message{flex:1;word-break:break-word}.init-log-entry.phase_start .init-log-icon,.init-log-entry.phase_start .init-log-message{color:#93c5fd}.init-log-entry.tool_call .init-log-icon,.init-log-entry.tool_call .init-log-message{color:#6ee7b7}.init-log-entry.phase_complete .init-log-icon,.init-log-entry.phase_complete .init-log-message{color:#86efac}.init-log-entry.error .init-log-icon,.init-log-entry.error .init-log-message{color:#fca5a5}.init-console-empty{padding:40px 0;text-align:center;color:#ffffff59}.completion-card{border:1px solid #d5efe0;background:#edf8f2;border-radius:12px;padding:14px}.completion-title{font-size:15px;font-weight:600;color:#166534}.completion-subtitle{margin-top:6px;font-size:13px;color:#2f6f44}@media(max-width:960px){.shell{grid-template-columns:180px minmax(0,1fr);grid-template-rows:1fr;grid-template-areas:"nav content"}.nav{position:static;display:flex;flex-direction:column;width:180px;max-height:none;overflow-x:visible;overflow-y:auto;border-right:1px solid var(--gray-200);border-bottom:none;padding:0;background:#fff}.nav-group{grid-auto-flow:row;grid-template-columns:1fr}.nav-label{display:block}.nav-group__items{display:grid}.nav-item{white-space:normal;flex-shrink:unset}.workbench-main-column{padding:12px}.projects-grid.codevox-project-grid{grid-template-columns:minmax(0,1fr);gap:12px}.file-tree-panel{width:220px}.project-wizard{width:calc(100vw - 12px);max-height:calc(100vh - 12px);border-radius:12px}.project-wizard .modal-header{padding:12px 12px 0;flex-wrap:wrap;gap:10px}.wizard-steps{margin:0;overflow-x:auto;width:100%;justify-content:flex-start;padding-bottom:2px}.project-wizard .modal-body{padding:12px;min-height:0}.project-wizard .modal-footer{padding:10px 12px 12px}.wizard-industry-grid{grid-template-columns:repeat(3,minmax(0,1fr))}.techstack-grid{grid-template-columns:minmax(0,1fr)}.plan-optimize-row{flex-direction:column;align-items:stretch}.init-phase-dot-wrapper{min-width:72px}}.project-task-board{margin-top:16px}.project-task-board-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:12px}.project-task-board-header__title{font-weight:600;font-size:14px;display:flex;align-items:center;gap:10px}.project-task-board-header__back{border:1px solid var(--gray-200);background:#fff;color:var(--gray-600);border-radius:6px;padding:4px 10px;font-size:12px;font-weight:500;cursor:pointer;display:inline-flex;align-items:center;gap:4px}.project-task-board-header__back:hover{background:var(--gray-50);color:var(--gray-800);border-color:var(--gray-300)}.project-task-board-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:12px;overflow-x:auto}.project-task-board-column{min-width:200px;background:var(--gray-50);border-radius:8px;padding:0 0 8px;border:1px solid var(--gray-200)}.project-task-board-column-header{font-weight:600;font-size:13px;color:var(--gray-600);padding:10px 12px;border-bottom:1px solid var(--gray-200);background:#fff;border-radius:8px 8px 0 0}.project-task-board-column-empty{padding:12px;font-size:12px;text-align:center;color:var(--gray-400)}.project-task-board-card{background:#fff;border:1px solid var(--gray-200);border-radius:6px;padding:10px 12px;margin:8px 8px 0;font-size:12px;box-shadow:var(--shadow-sm)}.project-task-board-card__title{font-weight:600;margin-bottom:6px;color:var(--gray-800)}.project-task-board-card__bdd{color:var(--gray-500);line-height:1.5;margin-bottom:4px}.bdd-label{font-weight:600;color:var(--gray-600);font-size:11px;text-transform:uppercase;letter-spacing:.02em;margin-right:4px}.project-task-board-card__files{margin-top:6px;color:var(--gray-400);font-size:11px}.project-task-board-card__action{margin-top:8px}.plan-generating-panel{display:flex;align-items:center;justify-content:center;min-height:200px}.plan-gen-status{width:100%;max-width:480px;display:flex;flex-direction:column;gap:12px}.plan-gen-label{font-size:14px;color:var(--muted-color);text-align:center}.plan-gen-bar{height:6px;background:var(--gray-200);border-radius:3px;overflow:hidden}.plan-gen-bar-fill{height:100%;background:var(--primary-color);border-radius:3px;transition:width .4s ease}.plan-gen-preview{font-size:12px;color:var(--muted-color);background:var(--bg-2);border:1px solid var(--border-color);border-radius:6px;padding:8px 12px;max-height:80px;overflow:hidden;white-space:pre-wrap;word-break:break-all;font-family:var(--font-mono, monospace);opacity:.7}:root[data-theme=dark] body,:root[data-theme=dark] .shell,:root[data-theme=dark] .content{background:var(--bg);color:var(--text)}:root[data-theme=dark] .nav,:root[data-theme=dark] .nav-sidehead,:root[data-theme=dark] .content-header,:root[data-theme=dark] .content-header--workbench,:root[data-theme=dark] .workbench-right-panel,:root[data-theme=dark] .chat-compose__row,:root[data-theme=dark] .project-card.codevox-project-card,:root[data-theme=dark] .codevox-project-files,:root[data-theme=dark] .file-toolbar,:root[data-theme=dark] .file-tree-panel,:root[data-theme=dark] .project-wizard,:root[data-theme=dark] .project-init-page,:root[data-theme=dark] .project-init-page-head,:root[data-theme=dark] .project-init-page-steps,:root[data-theme=dark] .project-init-page-actions,:root[data-theme=dark] .mock-canvas-footer,:root[data-theme=dark] .mock-preview-fullscreen-container,:root[data-theme=dark] .mock-preview-fullscreen-header{background:var(--bg-elevated);border-color:var(--border)}:root[data-theme=dark] .nav-item:hover,:root[data-theme=dark] .nav-label:hover,:root[data-theme=dark] .workbench-header-btn,:root[data-theme=dark] .workbench-action-btn,:root[data-theme=dark] .workbench-integration-item,:root[data-theme=dark] .workbench-module-item,:root[data-theme=dark] .workbench-user-pill,:root[data-theme=dark] .workbench-header-control-inline .chat-controls__session select,:root[data-theme=dark] .reference-file-trigger,:root[data-theme=dark] .techstack-item,:root[data-theme=dark] .wizard-step-dot,:root[data-theme=dark] .project-task-board-header__back,:root[data-theme=dark] .project-task-board-column,:root[data-theme=dark] .project-task-board-column-header,:root[data-theme=dark] .project-task-board-card,:root[data-theme=dark] .file-viewer-header,:root[data-theme=dark] .file-viewer-code,:root[data-theme=dark] .template-card,:root[data-theme=dark] .template-scroll-btn,:root[data-theme=dark] .upload-zone,:root[data-theme=dark] .upload-file-item,:root[data-theme=dark] .plan-content{background:var(--panel);border-color:var(--border);color:var(--text)}:root[data-theme=dark] .workbench-action-btn:hover,:root[data-theme=dark] .workbench-integration-item:hover,:root[data-theme=dark] .workbench-module-item:hover,:root[data-theme=dark] .workbench-header-btn:hover,:root[data-theme=dark] .template-scroll-btn:hover,:root[data-theme=dark] .template-card:hover,:root[data-theme=dark] .project-task-board-header__back:hover{background:var(--panel-hover);border-color:var(--border-strong)}:root[data-theme=dark] .nav-item.active{background:var(--primary-light);color:var(--accent)}:root[data-theme=dark] .chat-compose__field textarea::placeholder,:root[data-theme=dark] .reference-file-status,:root[data-theme=dark] .upload-zone-hint,:root[data-theme=dark] .template-preview-empty,:root[data-theme=dark] .project-task-board-column-empty{color:var(--muted)}:root[data-theme=dark] .workbench-chat-empty__title,:root[data-theme=dark] .wizard-generating-title,:root[data-theme=dark] .project-init-page-title,:root[data-theme=dark] .template-selection-title,:root[data-theme=dark] .wizard-template-selection-title{color:var(--text-strong)}:root[data-theme=dark] .workbench-chat-empty__sub,:root[data-theme=dark] .wizard-generating-subtitle,:root[data-theme=dark] .template-selection-desc,:root[data-theme=dark] .wizard-template-selection-desc{color:var(--muted)}:root[data-theme=dark] .form-input,:root[data-theme=dark] .form-input:focus{background:var(--panel);color:var(--text);border-color:var(--border)}:root[data-theme=dark] .form-input:focus{box-shadow:0 0 0 3px #5aa8ff33}:root[data-theme=dark] .techstack-item.selected{background:var(--primary-light);border-color:var(--primary-color)}:root[data-theme=dark] .chat-compose__send-btn{background:var(--accent);box-shadow:0 8px 18px #5aa8ff59}:root[data-theme=dark] .chat-compose__send-btn:hover:not(:disabled){background:var(--accent-hover)}:root[data-theme=dark] .wizard-generating-overlay,:root[data-theme=dark] .project-wizard-overlay{background:#070b12b3}:root[data-theme=dark] .wizard-streaming-overlay{background:var(--bg-elevated)}:root[data-theme=dark] .mock-canvas-preview,:root[data-theme=dark] .wizard-template-preview-frame{background:#fff}.login-container{display:flex;align-items:center;justify-content:center;min-height:100vh;background:var(--bg);padding:20px}.login-card{width:100%;max-width:380px;background:var(--card);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);padding:40px 32px 32px;border:1px solid var(--border)}.login-brand{text-align:center;margin-bottom:28px}.login-avatar{width:64px;height:64px;border-radius:16px;object-fit:cover;margin-bottom:12px}.login-avatar-fallback{width:64px;height:64px;border-radius:16px;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;display:inline-flex;align-items:center;justify-content:center;font-size:28px;margin-bottom:12px}.login-title{font-size:22px;font-weight:700;color:var(--text-strong);margin:0 0 4px}.login-subtitle{font-size:13px;color:var(--muted);margin:0}.login-error{background:#ff3b301a;color:var(--danger);border:1px solid rgba(255,59,48,.2);border-radius:var(--radius-sm);padding:10px 14px;font-size:13px;margin-bottom:16px;text-align:center}.login-form{display:flex;flex-direction:column;gap:16px}.login-field{display:flex;flex-direction:column;gap:6px}.login-field label{font-size:13px;font-weight:500;color:var(--text)}.login-field input{padding:10px 14px;border:1px solid var(--border);border-radius:var(--radius-sm);background:var(--bg-accent);color:var(--text-strong);font-size:14px;outline:none;transition:border-color .15s}.login-field input:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-subtle)}.login-field input::placeholder{color:var(--muted)}.login-btn{padding:11px 0;background:var(--accent);color:var(--accent-foreground);border:none;border-radius:var(--radius-sm);font-size:15px;font-weight:600;cursor:pointer;transition:background .15s;margin-top:4px}.login-btn:hover{background:var(--accent-hover)}:root{--v2-nav-width: 240px;--v2-topbar-height: 52px;--v2-phase-ideation: #f59e0b;--v2-phase-design: #8b5cf6;--v2-phase-develop: #3b82f6;--v2-nav-bg: var(--bg-surface, #ffffff);--v2-nav-border: var(--border-subtle, #e5e7eb);--v2-text-primary: var(--fg-default, #1f2937);--v2-text-secondary: var(--fg-muted, #6b7280);--v2-accent: var(--accent-primary, #3b82f6);--v2-hover-bg: var(--bg-hover, #f3f4f6);--v2-active-bg: var(--accent-bg, #eff6ff)}.v2-shell{height:100vh;display:grid;grid-template-columns:var(--v2-nav-width) minmax(0,1fr);grid-template-rows:1fr;grid-template-areas:"nav main";overflow:hidden;animation:dashboard-enter .3s var(--ease-out, ease-out)}@supports (height: 100dvh){.v2-shell{height:100dvh}}.v2-nav{grid-area:nav;display:flex;flex-direction:column;background:var(--v2-nav-bg);border-right:1px solid var(--v2-nav-border);overflow-y:auto;overflow-x:hidden;padding:0}.v2-nav__brand{display:flex;align-items:center;gap:10px;padding:16px 16px 8px}.v2-nav__logo{display:flex;align-items:center;justify-content:center;width:32px;height:32px;color:var(--v2-accent)}.v2-nav__logo svg{width:24px;height:24px}.v2-nav__meta{display:flex;flex-direction:column}.v2-nav__title{font-size:16px;font-weight:700;color:var(--v2-text-primary);letter-spacing:-.01em}.v2-nav__sub{font-size:11px;color:var(--v2-text-secondary);margin-top:1px}.v2-nav__trial{display:inline-block;margin-top:4px;padding:1px 6px;font-size:10px;font-weight:600;letter-spacing:.02em;color:#fff;background:linear-gradient(135deg,#f59e0b,#ef4444);border-radius:4px;line-height:1.4;white-space:nowrap}.v2-nav__create-btn{display:flex;align-items:center;justify-content:center;gap:6px;margin:12px 16px;padding:10px 16px;border:none;border-radius:8px;background:var(--v2-accent);color:#fff;font-size:14px;font-weight:600;cursor:pointer;transition:background .15s,transform .1s}.v2-nav__create-btn:hover{background:color-mix(in srgb,var(--v2-accent) 85%,black)}.v2-nav__create-btn:active{transform:scale(.98)}.v2-nav__create-icon{font-size:18px;font-weight:300;line-height:1}.v2-nav__items{flex:1;padding:8px}.v2-nav__footer{padding:8px;border-top:1px solid var(--v2-nav-border);margin-top:auto}.v2-nav__item{display:flex;align-items:center;gap:10px;width:100%;padding:8px 12px;border:none;border-radius:6px;background:transparent;color:var(--v2-text-secondary);font-size:13px;cursor:pointer;transition:background .15s,color .15s}.v2-nav__item:hover{background:var(--v2-hover-bg);color:var(--v2-text-primary)}.v2-nav__item--active{background:var(--v2-active-bg);color:var(--v2-accent);font-weight:500}.v2-nav__item-icon{display:flex;align-items:center;width:18px;height:18px}.v2-nav__item-icon svg{width:16px;height:16px}.v2-nav__item-label{white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.v2-nav__back{display:flex;align-items:center;gap:4px;padding:10px 16px;border:none;background:transparent;color:var(--v2-text-secondary);font-size:12px;cursor:pointer;transition:color .15s}.v2-nav__back:hover{color:var(--v2-accent)}.v2-nav__project-info{padding:4px 16px 12px;border-bottom:1px solid var(--v2-nav-border)}.v2-nav__project-name{font-size:15px;font-weight:600;color:var(--v2-text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.v2-nav__project-tech{font-size:11px;color:var(--v2-text-secondary);margin-top:2px}.v2-nav__phases{flex:1;padding:8px 0;overflow-y:auto}.v2-phase{margin:0}.v2-phase__header{display:flex;align-items:center;gap:8px;width:100%;padding:8px 16px;border:none;background:transparent;color:var(--v2-text-secondary);font-size:13px;font-weight:500;cursor:pointer;transition:background .15s,color .15s}.v2-phase__header:hover{background:var(--v2-hover-bg);color:var(--v2-text-primary)}.v2-phase--current>.v2-phase__header{color:var(--v2-text-primary)}.v2-phase__icon{font-size:14px;width:20px;text-align:center}.v2-phase__label{flex:1;text-align:left}.v2-phase__status{font-size:10px;line-height:1}.v2-phase__status--completed{color:#10b981}.v2-phase__status--active{color:var(--v2-accent);animation:v2-pulse 2s infinite}.v2-phase__status--pending{color:var(--v2-text-secondary);opacity:.4}@keyframes v2-pulse{0%,to{opacity:1}50%{opacity:.4}}.v2-phase__children{padding:2px 0 4px}.v2-step{display:flex;align-items:center;gap:8px;width:100%;padding:6px 16px 6px 44px;border:none;background:transparent;color:var(--v2-text-secondary);font-size:13px;cursor:pointer;transition:background .15s,color .15s}.v2-step:hover{background:var(--v2-hover-bg);color:var(--v2-text-primary)}.v2-step--active{background:var(--v2-active-bg);color:var(--v2-accent);font-weight:500}.v2-step__icon{display:flex;align-items:center;width:16px;height:16px}.v2-step__icon svg{width:14px;height:14px}.v2-step__label{white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.v2-main{grid-area:main;display:flex;flex-direction:column;overflow:hidden;min-width:0}.v2-content{flex:1;overflow:auto;min-height:0}.v2-topbar{display:flex;align-items:center;justify-content:space-between;height:var(--v2-topbar-height);padding:0 20px;border-bottom:1px solid var(--v2-nav-border);background:var(--v2-nav-bg);flex-shrink:0}.v2-topbar__search{display:flex;align-items:center;gap:8px;background:var(--v2-hover-bg);border-radius:8px;padding:6px 12px;max-width:360px;flex:1}.v2-topbar__search-icon{display:flex;align-items:center;color:var(--v2-text-secondary);width:16px;height:16px}.v2-topbar__search-icon svg{width:16px;height:16px}.v2-topbar__search-input{border:none;background:transparent;outline:none;font-size:13px;color:var(--v2-text-primary);flex:1}.v2-topbar__search-input::placeholder{color:var(--v2-text-secondary)}.v2-topbar__phases{display:flex;align-items:center;gap:4px}.v2-topbar__phase{display:flex;align-items:center;gap:4px;padding:6px 10px;border:none;border-radius:6px;background:transparent;color:var(--v2-text-secondary);font-size:12px;cursor:pointer;transition:background .15s,color .15s;position:relative}.v2-topbar__phase:hover{background:var(--v2-hover-bg);color:var(--v2-text-primary)}.v2-topbar__phase--active{color:var(--v2-accent);font-weight:600}.v2-topbar__phase--active:after{content:"";position:absolute;bottom:-1px;left:8px;right:8px;height:2px;background:var(--v2-accent);border-radius:1px}.v2-topbar__phase--completed{color:#10b981}.v2-topbar__phase-icon{font-size:12px}.v2-topbar__phase-label{white-space:nowrap}.v2-topbar__phase-arrow{color:var(--v2-text-secondary);opacity:.3;font-size:11px;margin:0 2px}.v2-topbar__actions{display:flex;align-items:center;gap:8px}.v2-topbar__icon-btn{display:flex;align-items:center;justify-content:center;width:32px;height:32px;border:none;border-radius:6px;background:transparent;color:var(--v2-text-secondary);cursor:pointer;transition:background .15s}.v2-topbar__icon-btn:hover{background:var(--v2-hover-bg)}.v2-topbar__icon-btn--active{background:var(--v2-active-bg);color:var(--v2-accent)}.v2-topbar__icon-btn svg{width:16px;height:16px}.v2-nav__top-bar{display:flex;align-items:center;justify-content:space-between;padding:0}.v2-nav__toggle{width:32px;height:32px;padding:0;border-radius:6px;background:transparent;border:1px solid transparent;color:var(--v2-text-secondary);cursor:pointer;transition:all .15s ease-out;flex-shrink:0;display:inline-flex;align-items:center;justify-content:center}.v2-nav__toggle:hover{background:var(--v2-hover-bg);color:var(--v2-text-primary);border-color:var(--v2-nav-border)}.v2-nav__toggle svg{width:18px;height:18px;fill:none;stroke:currentColor;stroke-width:2px;stroke-linecap:round;stroke-linejoin:round}.v2-shell{transition:grid-template-columns .2s ease-out}.v2-shell--nav-collapsed{grid-template-columns:48px minmax(0,1fr)}.v2-nav--collapsed{width:48px;min-width:48px;overflow:hidden}.v2-nav--collapsed .v2-nav__top-bar{flex-direction:column;gap:4px;padding:8px 0 4px;align-items:center}.v2-nav--collapsed .v2-nav__back{font-size:0;padding:8px;justify-content:center;width:32px;margin:0 auto}.v2-nav--collapsed .v2-nav__project-info,.v2-nav--collapsed .v2-phase__label,.v2-nav--collapsed .v2-phase__status,.v2-nav--collapsed .v2-phase__children,.v2-nav--collapsed .v2-nav__item-label{display:none}.v2-nav--collapsed .v2-phase__header{padding:8px 12px;justify-content:center}.v2-nav--collapsed .v2-nav__footer{padding:8px 4px}.v2-nav--collapsed .v2-nav__item{justify-content:center;padding:8px}:root[data-theme=dark]{--v2-nav-bg: var(--bg-surface, #1a1a2e);--v2-nav-border: var(--border-subtle, #2d2d44);--v2-text-primary: var(--fg-default, #e2e8f0);--v2-text-secondary: var(--fg-muted, #94a3b8);--v2-hover-bg: var(--bg-hover, #2d2d44);--v2-active-bg: var(--accent-bg, #1e3a5f)}@media(max-width:768px){:root{--v2-nav-width: 60px}.v2-nav__meta{display:none}.v2-nav__brand{justify-content:center;padding:16px 8px 8px}.v2-nav__create-btn>span:not(.v2-nav__create-icon){display:none}.v2-nav__create-btn{margin:12px 8px;padding:10px}.v2-nav__back{font-size:0;justify-content:center;padding:10px 0}.v2-nav__back:before{content:"←";font-size:14px;color:var(--v2-text-secondary)}.v2-nav__project-name,.v2-nav__project-tech{display:none}.v2-nav__project-info{padding:4px 8px 12px}.v2-phase__label{display:none}.v2-phase__header{padding:8px 12px;justify-content:center}.v2-step__label{display:none}.v2-step{padding:6px 12px;justify-content:center}.v2-nav__item-label{display:none}.v2-nav__item{justify-content:center;padding:8px}.v2-nav__items,.v2-nav__footer{padding:8px 4px}.v2-topbar__phase-label{display:none}.v2-topbar__search{max-width:none}}.v2-bell-wrapper{position:relative}.v2-bell-badge{position:absolute;top:2px;right:2px;min-width:16px;height:16px;padding:0 4px;border-radius:8px;background:#ef4444;color:#fff;font-size:10px;font-weight:600;line-height:16px;text-align:center;pointer-events:none;animation:bell-badge-pulse 2s ease-in-out infinite}@keyframes bell-badge-pulse{0%,to{opacity:1}50%{opacity:.7}}.v2-port-panel{position:absolute;top:calc(100% + 8px);right:0;z-index:1000;width:320px;background:var(--v2-nav-bg);border:1px solid var(--v2-nav-border);border-radius:12px;box-shadow:0 8px 30px #0f172a1f;overflow:hidden}.v2-port-panel__header{padding:12px 16px;font-size:13px;font-weight:600;color:var(--v2-text-primary);border-bottom:1px solid var(--v2-nav-border)}.v2-port-panel__body{padding:12px 16px;max-height:300px;overflow-y:auto}.v2-port-panel__summary{font-size:12px;color:var(--v2-text-secondary);margin-bottom:8px}.v2-port-panel__warning{font-size:12px;color:#ef4444;font-weight:500;margin-bottom:8px}.v2-port-panel__list{display:flex;flex-direction:column;gap:4px}.v2-port-panel__item{display:flex;align-items:center;gap:8px;padding:6px 0;font-size:12px;border-bottom:1px solid var(--v2-nav-border)}.v2-port-panel__item:last-child{border-bottom:none}.v2-port-panel__port{font-family:monospace;font-weight:600;color:var(--v2-accent);min-width:48px}.v2-port-panel__name{flex:1;color:var(--v2-text-primary);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.v2-port-panel__time{color:var(--v2-text-secondary);font-size:11px}.v2-port-panel__empty{font-size:12px;color:var(--v2-text-secondary);margin:0;text-align:center;padding:8px 0}.v2-port-panel__footer{padding:8px 16px;border-top:1px solid var(--v2-nav-border);text-align:right}.v2-port-panel__close{padding:4px 12px;font-size:12px;border:1px solid var(--v2-nav-border);border-radius:6px;background:transparent;color:var(--v2-text-secondary);cursor:pointer;transition:background .15s}.v2-port-panel__close:hover{background:var(--v2-hover-bg)}:root{--v2-canvas-min-width: 280px;--v2-canvas-bg: var(--bg-surface, #ffffff);--v2-canvas-border: var(--border-subtle, #e5e7eb);--v2-canvas-header-height: 44px;--v2-canvas-footer-height: 40px}.v2-canvas{display:flex;flex-direction:column;background:var(--v2-canvas-bg);border-left:1px solid var(--v2-canvas-border);overflow:hidden;animation:v2-canvas-slide-in .2s ease-out;min-width:var(--v2-canvas-min-width);flex:1}@keyframes v2-canvas-slide-in{0%{opacity:0;transform:translate(24px)}to{opacity:1;transform:translate(0)}}.v2-canvas--maximized{position:fixed;inset:0;z-index:1000;min-width:0;border-left:none;animation:v2-canvas-maximize .2s ease-out}@keyframes v2-canvas-maximize{0%{opacity:.8;transform:scale(.95)}to{opacity:1;transform:scale(1)}}.v2-canvas__header{display:flex;align-items:center;justify-content:space-between;height:var(--v2-canvas-header-height);padding:0 8px 0 12px;border-bottom:1px solid var(--v2-canvas-border);flex-shrink:0}.v2-canvas__header-title{font-size:13px;font-weight:600;color:var(--v2-text-primary)}.v2-canvas__header-actions{display:flex;align-items:center;gap:2px}.v2-canvas__header-btn{display:flex;align-items:center;justify-content:center;width:28px;height:28px;border:none;border-radius:4px;background:transparent;color:var(--v2-text-secondary);cursor:pointer;transition:background .15s,color .15s}.v2-canvas__header-btn:hover{background:var(--v2-hover-bg);color:var(--v2-text-primary)}.v2-canvas__header-btn svg{width:14px;height:14px}.v2-canvas__header-left{display:flex;align-items:center;gap:8px}.v2-canvas__status-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}.v2-canvas__status-dot--live{background:#22c55e;box-shadow:0 0 4px #22c55e66}.v2-canvas__status-dot--mock{background:#9ca3af}.v2-canvas__navbar{display:flex;align-items:center;gap:4px;height:36px;padding:0 8px;border-bottom:1px solid var(--v2-canvas-border);flex-shrink:0;background:var(--v2-canvas-bg)}.v2-canvas__nav-btns{display:flex;align-items:center;gap:2px;flex-shrink:0}.v2-canvas__nav-btn{display:flex;align-items:center;justify-content:center;width:24px;height:24px;border:none;border-radius:4px;background:transparent;color:var(--v2-text-secondary);cursor:pointer;padding:0;transition:background .15s,color .15s}.v2-canvas__nav-btn:hover:not(:disabled){background:var(--v2-hover-bg);color:var(--v2-text-primary)}.v2-canvas__nav-btn:disabled{opacity:.35;cursor:default}.v2-canvas__nav-btn svg{width:14px;height:14px}.v2-canvas__nav-text-btn{padding:2px 10px;border:1px solid var(--v2-canvas-border);border-radius:4px;background:transparent;color:var(--v2-text-secondary);font-size:12px;cursor:pointer;white-space:nowrap;flex-shrink:0;transition:background .15s,color .15s}.v2-canvas__nav-text-btn:hover:not(:disabled){background:var(--v2-hover-bg);color:var(--v2-text-primary)}.v2-canvas__nav-text-btn:disabled{opacity:.35;cursor:default}.v2-canvas__url-input{flex:1;height:26px;padding:0 8px;border:1px solid var(--v2-canvas-border);border-radius:6px;background:var(--bg-input, #f3f4f6);color:var(--v2-text-primary);font-size:12px;font-family:ui-monospace,SF Mono,Cascadia Code,Segoe UI Mono,monospace;outline:none;transition:border-color .15s,box-shadow .15s;min-width:0}.v2-canvas__url-input:focus{border-color:var(--v2-accent, #6366f1);box-shadow:0 0 0 2px #6366f126}.v2-canvas__body{flex:1;overflow:auto;min-height:0}.v2-canvas__empty{color:var(--v2-text-secondary);text-align:center;padding:40px 20px;font-size:14px}.v2-canvas__iframe-wrap{width:100%;height:100%;display:flex;justify-content:center;background:#f9fafb}.v2-canvas__iframe{width:100%;height:100%;border:none;background:#fff;animation:v2-canvas-refresh .3s ease-out}@keyframes v2-canvas-refresh{0%{opacity:.4}to{opacity:1}}.v2-canvas__footer{display:flex;align-items:center;gap:8px;height:var(--v2-canvas-footer-height);padding:0 12px;border-top:1px solid var(--v2-canvas-border);flex-shrink:0}.v2-canvas__viewport-toggle{display:flex;align-items:center;gap:2px}.v2-canvas__footer-btn{display:flex;align-items:center;gap:4px;padding:4px 8px;border:none;border-radius:4px;background:transparent;color:var(--v2-text-secondary);font-size:12px;cursor:pointer;transition:background .15s,color .15s}.v2-canvas__footer-btn:hover{background:var(--v2-hover-bg);color:var(--v2-text-primary)}.v2-canvas__footer-btn--active{background:var(--v2-active-bg);color:var(--v2-accent)}.v2-canvas__footer-btn svg{width:14px;height:14px}.v2-content-split{display:flex;flex:1;min-height:0;height:100%}.v2-content-split__main{min-width:280px;display:flex;flex-direction:column;overflow:hidden;transition:flex .2s ease-out}:root[data-theme=dark]{--v2-canvas-bg: var(--bg-surface, #1a1a2e);--v2-canvas-border: var(--border-subtle, #2d2d44)}:root[data-theme=dark] .v2-canvas__iframe-wrap{background:#111827}:root[data-theme=dark] .v2-canvas__url-input{background:var(--bg-input, #1f2937);border-color:var(--border-subtle, #374151)}@media(max-width:1100px){.v2-canvas{position:fixed;inset:0;z-index:1000;min-width:0;border-left:none}}.v2-phase-view{display:flex;flex-direction:column;height:100%;overflow:auto}.v2-phase-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:16px;padding:60px 24px;text-align:center;flex:1}.v2-phase-empty__icon{font-size:48px;opacity:.6}.v2-phase-empty__title{font-size:18px;font-weight:600;color:var(--v2-text-primary)}.v2-phase-empty__desc{font-size:14px;color:var(--v2-text-secondary);max-width:400px;line-height:1.6}.v2-phase-empty__cta{display:inline-flex;align-items:center;gap:6px;margin-top:8px;padding:10px 20px;border:none;border-radius:8px;background:var(--v2-accent);color:#fff;font-size:14px;font-weight:600;cursor:pointer;transition:background .15s,transform .1s}.v2-phase-empty__cta:hover{background:color-mix(in srgb,var(--v2-accent) 85%,black)}.v2-phase-empty__cta:active{transform:scale(.98)}.v2-phase-header{display:flex;align-items:center;justify-content:space-between;padding:16px 20px;border-bottom:1px solid var(--v2-nav-border);flex-shrink:0}.v2-phase-header__title{font-size:16px;font-weight:600;color:var(--v2-text-primary)}.v2-phase-header__actions{display:flex;align-items:center;gap:8px}.v2-phase-card{margin:16px 20px;padding:20px;border-radius:10px;border:1px solid var(--v2-nav-border);background:var(--v2-nav-bg)}.v2-phase-card__title{font-size:14px;font-weight:600;color:var(--v2-text-primary);margin-bottom:12px}.v2-phase-table{width:100%;border-collapse:collapse;font-size:13px}.v2-phase-table th{text-align:left;padding:8px 12px;border-bottom:1px solid var(--v2-nav-border);color:var(--v2-text-secondary);font-weight:500;font-size:12px}.v2-phase-table td{padding:10px 12px;border-bottom:1px solid var(--v2-nav-border);color:var(--v2-text-primary)}.v2-phase-table tr:last-child td{border-bottom:none}.v2-phase-table tr:hover td{background:var(--v2-hover-bg)}.v2-status-badge{display:inline-flex;align-items:center;gap:4px;padding:2px 8px;border-radius:10px;font-size:11px;font-weight:500}.v2-status-badge--pending{background:var(--v2-hover-bg);color:var(--v2-text-secondary)}.v2-status-badge--active,.v2-status-badge--in_progress{background:#eff6ff;color:#3b82f6}.v2-status-badge--done,.v2-status-badge--completed{background:#ecfdf5;color:#10b981}.v2-status-badge--accepted{background:#f0fdf4;color:#16a34a}.v2-file-browser{display:flex;flex:1;min-height:0;overflow:hidden}.v2-file-browser__tree{width:300px;border-right:1px solid var(--v2-nav-border);overflow-y:auto;padding:4px 0;flex-shrink:0;scrollbar-width:thin}.v2-file-browser__tree::-webkit-scrollbar{width:6px}.v2-file-browser__tree::-webkit-scrollbar-thumb{background:#00000026;border-radius:3px}.v2-file-browser__tree::-webkit-scrollbar-thumb:hover{background:#00000040}.v2-file-browser__viewer{flex:1;overflow:auto;min-width:0}.v2-mock-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:16px;padding:16px 20px}.v2-mock-card{border-radius:8px;border:1px solid var(--v2-nav-border);overflow:hidden;cursor:pointer;transition:border-color .15s,box-shadow .15s}.v2-mock-card:hover{border-color:var(--v2-accent)}.v2-mock-card--active{border-color:var(--v2-accent);box-shadow:0 0 0 2px color-mix(in srgb,var(--v2-accent) 20%,transparent)}.v2-mock-card__preview{height:140px;overflow:hidden;background:#f8fafc}.v2-mock-card__preview iframe{width:200%;height:200%;transform:scale(.5);transform-origin:top left;border:none;pointer-events:none}.v2-mock-card__info{padding:10px 12px;border-top:1px solid var(--v2-nav-border)}.v2-mock-card__name{font-size:13px;font-weight:500;color:var(--v2-text-primary)}.v2-mock-card__desc{font-size:11px;color:var(--v2-text-secondary);margin-top:2px}.v2-brief-btn{display:inline-flex;align-items:center;gap:4px;padding:5px 14px;border:none;border-radius:6px;font-size:13px;font-weight:500;cursor:pointer;transition:background .15s,border-color .15s,color .15s,transform .1s;white-space:nowrap}.v2-brief-btn svg{width:14px;height:14px}.v2-brief-btn--primary{background:var(--v2-accent);color:#fff}.v2-brief-btn--primary:hover{background:color-mix(in srgb,var(--v2-accent) 85%,black)}.v2-brief-btn--secondary{background:color-mix(in srgb,var(--v2-accent) 12%,transparent);color:var(--v2-accent);border:1px solid color-mix(in srgb,var(--v2-accent) 25%,transparent)}.v2-brief-btn--secondary:hover:not(:disabled){background:color-mix(in srgb,var(--v2-accent) 20%,transparent);border-color:color-mix(in srgb,var(--v2-accent) 40%,transparent);color:var(--v2-accent)}.v2-brief-btn--secondary:active:not(:disabled){background:color-mix(in srgb,var(--v2-accent) 28%,transparent);transform:scale(.97)}.v2-brief-btn:disabled{opacity:.5;cursor:not-allowed}.v2-brief-textarea{flex:1;width:100%;padding:20px;border:none;background:var(--v2-nav-bg);color:var(--v2-text-primary);font-size:14px;font-family:ui-monospace,SFMono-Regular,SF Mono,Menlo,monospace;line-height:1.7;resize:none;outline:none;box-sizing:border-box}:root[data-theme=dark] .v2-status-badge--active,:root[data-theme=dark] .v2-status-badge--in_progress{background:#1e3a5f}:root[data-theme=dark] .v2-status-badge--done,:root[data-theme=dark] .v2-status-badge--completed{background:#064e3b}:root[data-theme=dark] .v2-status-badge--accepted{background:#14532d}:root[data-theme=dark] .v2-mock-card__preview{background:#1e293b}:root[data-theme=dark] .v2-file-node__row--active{background:#0058d0}:root[data-theme=dark] .v2-file-node__row--active:hover{background:#004bb5}:root[data-theme=dark] .v2-file-node__folder-icon svg{color:#5aafff}:root[data-theme=dark] .v2-file-browser__tree::-webkit-scrollbar-thumb{background:#ffffff26}:root[data-theme=dark] .v2-file-browser__tree::-webkit-scrollbar-thumb:hover{background:#ffffff40}.v2-file-node__row{display:flex;align-items:center;gap:4px;height:26px;width:calc(100% - 8px);margin:0 4px;padding:0 8px;border:none;border-radius:6px;background:transparent;color:var(--v2-text-primary);font-size:13px;font-family:-apple-system,BlinkMacSystemFont,SF Pro Text,system-ui,sans-serif;cursor:pointer;transition:background .1s}.v2-file-node__row:hover{background:var(--v2-hover-bg)}.v2-file-node__row--active{background:#007aff;color:#fff}.v2-file-node__row--active:hover{background:#006adf}.v2-file-node__row--active svg{color:#fff}.v2-file-node__row--active .v2-file-node__count{color:#ffffffb3}.v2-file-node__row svg{width:16px;height:16px;flex-shrink:0;fill:none;stroke:currentColor;stroke-width:2;stroke-linecap:round;stroke-linejoin:round}.v2-file-node__folder-icon svg{color:#3b9eff}.v2-file-browser__viewer-icon{display:inline-flex;flex-shrink:0}.v2-file-browser__viewer-icon svg{width:16px;height:16px;fill:none;stroke:currentColor;stroke-width:2;stroke-linecap:round;stroke-linejoin:round}.v2-file-node__row--active .v2-file-node__folder-icon svg{color:#fff}.v2-file-node__file-icon svg{opacity:.7}.v2-file-node__row--active .v2-file-node__file-icon svg{opacity:1;color:#fff}.v2-file-node__count{color:var(--v2-text-tertiary, #999);font-size:11px;margin-left:auto;flex-shrink:0}.v2-files-disk-badge{display:inline-block;margin-left:8px;padding:1px 6px;font-size:11px;font-weight:500;line-height:1.4;border-radius:4px;background:#10b98120;color:#10b981;vertical-align:middle}.v2-file-node__chevron{display:inline-flex;align-items:center;justify-content:center;width:14px;transition:transform .15s ease;flex-shrink:0}.v2-file-node__chevron svg{width:10px;height:10px;opacity:.6}.v2-file-node__chevron--open{transform:rotate(90deg)}.v2-file-node__row--active .v2-file-node__chevron svg{opacity:.9;color:#fff}.v2-file-node__name{overflow:hidden;text-overflow:ellipsis;white-space:nowrap;min-width:0}.v2-file-node__children{padding-left:20px}.v2-file-browser__statusbar{display:flex;align-items:center;justify-content:space-between;height:24px;padding:0 12px;border-top:1px solid var(--v2-nav-border);background:var(--v2-nav-bg);color:var(--v2-text-secondary);font-size:11px;flex-shrink:0}.v2-file-browser__statusbar-path{overflow:hidden;text-overflow:ellipsis;white-space:nowrap;max-width:60%;text-align:right;font-family:ui-monospace,SFMono-Regular,SF Mono,Menlo,monospace;font-size:10px;opacity:.8}.v2-settings{display:flex;height:100%;overflow:hidden}.v2-settings__nav{width:200px;border-right:1px solid var(--v2-nav-border);padding:16px 0;flex-shrink:0;overflow-y:auto}.v2-settings__nav-title{display:flex;align-items:center;gap:6px;padding:0 20px 12px;font-size:14px;font-weight:600;color:var(--v2-text-primary)}.v2-settings__nav-title svg{width:16px;height:16px;flex-shrink:0}.v2-settings__nav-item{display:flex;align-items:center;gap:8px;width:100%;padding:8px 20px;border:none;background:transparent;color:var(--v2-text-secondary);font-size:13px;cursor:pointer;transition:background .1s,color .1s}.v2-settings__nav-item:hover{background:var(--v2-hover-bg);color:var(--v2-text-primary)}.v2-settings__nav-item--active{background:var(--v2-active-bg);color:var(--v2-accent);font-weight:500}.v2-settings__content{flex:1;overflow:auto;min-width:0}.v2-settings__section{border-bottom:1px solid var(--v2-nav-border);padding:16px 0}.v2-settings__section:last-child{border-bottom:none}.v2-settings__section-title{font-size:14px;font-weight:600;color:var(--v2-text-primary);padding:0 20px 12px}.v2-port-pool-bar{height:8px;border-radius:4px;background:var(--v2-hover-bg);overflow:hidden;margin:12px 0 8px}.v2-port-pool-bar__fill{height:100%;border-radius:4px;transition:width .3s ease,background .3s ease}.v2-port-pool-bar__fill--green{background:#10b981}.v2-port-pool-bar__fill--yellow{background:#f59e0b}.v2-port-pool-bar__fill--red{background:#ef4444}.v2-port-pool-stats{display:flex;justify-content:space-between;font-size:13px;color:var(--v2-text-secondary)}.v2-port-pool-stats strong{color:var(--v2-text-primary);font-weight:600}.v2-port-pool-alert{margin-top:12px;padding:10px 14px;border-radius:8px;background:#fef2f2;border:1px solid #fecaca;color:#dc2626;font-size:13px;display:flex;align-items:center;gap:6px}:root[data-theme=dark] .v2-port-pool-alert{background:#450a0a;border-color:#7f1d1d;color:#fca5a5}.v2-port-pool-alloc{display:flex;align-items:center;padding:8px 0;border-bottom:1px solid var(--v2-nav-border);font-size:13px;gap:12px}.v2-port-pool-alloc:last-child{border-bottom:none}.v2-port-pool-alloc__port{font-family:ui-monospace,SFMono-Regular,SF Mono,Menlo,monospace;font-size:13px;font-weight:600;color:var(--v2-accent);min-width:52px}.v2-port-pool-alloc__name{flex:1;color:var(--v2-text-primary);min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.v2-port-pool-alloc__time{color:var(--v2-text-secondary);font-size:12px;flex-shrink:0}.v2-settings__dev-banner{display:flex;align-items:center;gap:8px;margin:16px 20px 0;padding:10px 14px;border-radius:8px;background:#fffbeb;border:1px solid #fde68a;color:#92400e;font-size:13px;line-height:1.5;position:sticky;top:0;z-index:1}:root[data-theme=dark] .v2-settings__dev-banner{background:#451a03;border-color:#78350f;color:#fde68a}.v2-settings__field{display:flex;align-items:center;justify-content:space-between;padding:10px 20px;gap:16px;min-height:44px}.v2-settings__field-left{display:flex;flex-direction:column;gap:2px;min-width:0}.v2-settings__field-label{font-size:13px;font-weight:500;color:var(--v2-text-primary)}.v2-settings__field-desc{font-size:12px;color:var(--v2-text-secondary)}.v2-settings__field input[type=text]{padding:6px 10px;border:1px solid var(--v2-nav-border);border-radius:6px;background:var(--v2-nav-bg);color:var(--v2-text-primary);font-size:13px;width:180px;outline:none;transition:border-color .15s}.v2-settings__field input[type=text]:focus{border-color:var(--v2-accent)}.v2-settings__field select{padding:6px 10px;border:1px solid var(--v2-nav-border);border-radius:6px;background:var(--v2-nav-bg);color:var(--v2-text-primary);font-size:13px;outline:none;cursor:pointer}.v2-settings__toggle{position:relative;width:40px;height:22px;border-radius:11px;background:var(--v2-nav-border);cursor:pointer;transition:background .2s;flex-shrink:0;border:none;padding:0}.v2-settings__toggle:after{content:"";position:absolute;top:2px;left:2px;width:18px;height:18px;border-radius:50%;background:#fff;transition:transform .2s;box-shadow:0 1px 3px #0003}.v2-settings__toggle--on{background:var(--v2-accent)}.v2-settings__toggle--on:after{transform:translate(18px)}.v2-settings__btn-group{display:flex;border:1px solid var(--v2-nav-border);border-radius:6px;overflow:hidden}.v2-settings__btn-group-item{padding:5px 12px;border:none;background:transparent;color:var(--v2-text-secondary);font-size:12px;cursor:pointer;transition:background .15s,color .15s;border-right:1px solid var(--v2-nav-border)}.v2-settings__btn-group-item:last-child{border-right:none}.v2-settings__btn-group-item:hover{background:var(--v2-hover-bg);color:var(--v2-text-primary)}.v2-settings__btn-group-item--active,.v2-settings__btn-group-item--active:hover{background:var(--v2-accent);color:#fff}.v2-settings__color-preview{display:flex;align-items:center;gap:8px}.v2-settings__color-dot{width:24px;height:24px;border-radius:50%;border:2px solid var(--v2-nav-border);flex-shrink:0}.v2-settings__color-hex{font-size:12px;font-family:ui-monospace,SFMono-Regular,SF Mono,Menlo,monospace;color:var(--v2-text-secondary)}.v2-settings__model-card{margin:0 20px;padding:16px;border-radius:10px;border:1px solid var(--v2-nav-border);background:var(--v2-nav-bg)}.v2-settings__model-card-name{font-size:16px;font-weight:600;color:var(--v2-text-primary);margin-bottom:12px}.v2-settings__model-card-grid{display:grid;grid-template-columns:1fr 1fr;gap:8px 24px}.v2-settings__model-card-item{display:flex;justify-content:space-between;align-items:center;font-size:13px;padding:4px 0}.v2-settings__model-card-label{color:var(--v2-text-secondary)}.v2-settings__model-card-value{color:var(--v2-text-primary);font-weight:500}.v2-settings__provider-row{display:flex;align-items:center;padding:10px 20px;gap:12px;border-bottom:1px solid var(--v2-nav-border);font-size:13px}.v2-settings__provider-row:last-child{border-bottom:none}.v2-settings__provider-name{font-weight:500;color:var(--v2-text-primary);min-width:80px}.v2-settings__provider-endpoint{flex:1;color:var(--v2-text-secondary);font-family:ui-monospace,SFMono-Regular,SF Mono,Menlo,monospace;font-size:12px;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.v2-settings__provider-status{display:inline-flex;align-items:center;gap:4px;padding:2px 8px;border-radius:10px;font-size:11px;font-weight:500;flex-shrink:0}.v2-settings__provider-status--ok{background:#ecfdf5;color:#059669}.v2-settings__provider-status--missing{background:var(--v2-hover-bg);color:var(--v2-text-secondary)}:root[data-theme=dark] .v2-settings__provider-status--ok{background:#064e3b;color:#6ee7b7}:root[data-theme=dark] .v2-settings__provider-status--missing{background:#1e293b;color:#94a3b8}.v2-settings__usage-stats{display:grid;grid-template-columns:repeat(3,1fr);gap:12px;margin:0 20px 16px}.v2-settings__usage-stat{padding:12px;border-radius:8px;border:1px solid var(--v2-nav-border);text-align:center}.v2-settings__usage-stat-value{font-size:18px;font-weight:600;color:var(--v2-text-primary);font-family:ui-monospace,SFMono-Regular,SF Mono,Menlo,monospace}.v2-settings__usage-stat-label{font-size:11px;color:var(--v2-text-secondary);margin-top:4px}.v2-settings__usage-chart{margin:0 20px;padding:12px 0}.v2-settings__usage-chart-title{font-size:12px;color:var(--v2-text-secondary);margin-bottom:12px}.v2-settings__usage-bars{display:flex;align-items:flex-end;gap:6px;height:80px}.v2-settings__usage-bar-col{flex:1;display:flex;flex-direction:column;align-items:center;gap:4px;height:100%;justify-content:flex-end}.v2-settings__usage-bar{width:100%;border-radius:3px 3px 0 0;background:var(--v2-accent);opacity:.7;min-height:2px;transition:height .3s}.v2-settings__usage-bar-label{font-size:10px;color:var(--v2-text-secondary)}.v2-settings__usage-ranking{margin:16px 20px 0;padding:12px 0 0;border-top:1px solid var(--v2-nav-border)}.v2-settings__usage-ranking-title{font-size:12px;color:var(--v2-text-secondary);margin-bottom:10px}.v2-settings__usage-ranking-row{display:flex;align-items:center;gap:8px;margin-bottom:6px;font-size:12px}.v2-settings__usage-ranking-name{flex:0 0 80px;color:var(--v2-text-primary);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.v2-settings__usage-ranking-bar-track{flex:1;height:6px;background:var(--v2-nav-border);border-radius:3px;overflow:hidden}.v2-settings__usage-ranking-bar-fill{height:100%;background:var(--v2-accent);border-radius:3px;min-width:2px;transition:width .3s}.v2-settings__usage-ranking-tokens{flex:0 0 70px;text-align:right;color:var(--v2-text-primary);font-family:ui-monospace,SFMono-Regular,SF Mono,Menlo,monospace}.v2-settings__usage-ranking-cost{flex:0 0 55px;text-align:right;color:var(--v2-text-secondary);font-family:ui-monospace,SFMono-Regular,SF Mono,Menlo,monospace}.v2-brainstorm-steps{display:flex;align-items:center;gap:4px;padding:12px 20px;border-bottom:1px solid var(--v2-nav-border);flex-shrink:0}.v2-brainstorm-step{display:flex;align-items:center;gap:6px;padding:6px 14px;border:none;border-radius:20px;background:transparent;color:var(--v2-text-secondary);font-size:13px;cursor:default;transition:background .15s,color .15s}.v2-brainstorm-step--active{background:var(--v2-accent);color:#fff;font-weight:600}.v2-brainstorm-step--completed{background:var(--v2-hover-bg);color:var(--v2-text-primary);cursor:pointer}.v2-brainstorm-step--completed:hover{background:var(--v2-active-bg)}.v2-brainstorm-step__num{display:inline-flex;align-items:center;justify-content:center;width:20px;height:20px;border-radius:50%;font-size:11px;font-weight:600;background:var(--v2-nav-border);color:var(--v2-text-secondary)}.v2-brainstorm-step--active .v2-brainstorm-step__num{background:#ffffff40;color:#fff}.v2-brainstorm-step--completed .v2-brainstorm-step__num{background:#10b981;color:#fff}.v2-brainstorm-step__label{white-space:nowrap}.v2-brainstorm-step__reset{margin-left:auto;padding:4px 10px;border:1px solid var(--v2-nav-border);border-radius:6px;background:transparent;color:var(--v2-text-secondary);font-size:12px;cursor:pointer;transition:background .15s,color .15s}.v2-brainstorm-step__reset:hover{background:var(--v2-hover-bg);color:var(--v2-text-primary)}.v2-brainstorm-content{flex:1;overflow:auto;min-height:0;display:flex;flex-direction:column}.v2-brainstorm-form{display:flex;align-items:center;justify-content:center;flex:1;padding:40px 24px}.v2-brainstorm-form__card{max-width:520px;width:100%;text-align:center}.v2-brainstorm-form__icon{font-size:48px;margin-bottom:8px}.v2-brainstorm-form__title{font-size:20px;font-weight:600;color:var(--v2-text-primary);margin:0 0 6px}.v2-brainstorm-form__subtitle{font-size:14px;color:var(--v2-text-secondary);margin:0 0 28px;line-height:1.5}.v2-brainstorm-form__field{text-align:left;margin-bottom:20px}.v2-brainstorm-form__label{display:block;font-size:13px;font-weight:500;color:var(--v2-text-primary);margin-bottom:6px}.v2-brainstorm-form__input,.v2-brainstorm-form__textarea{width:100%;padding:10px 14px;border:1px solid var(--v2-nav-border);border-radius:8px;background:var(--v2-nav-bg);color:var(--v2-text-primary);font-size:14px;font-family:inherit;outline:none;transition:border-color .15s;box-sizing:border-box}.v2-brainstorm-form__input:focus,.v2-brainstorm-form__textarea:focus{border-color:var(--v2-accent)}.v2-brainstorm-form__textarea{resize:vertical;min-height:72px}.v2-brainstorm-form__cta{display:inline-flex;align-items:center;gap:6px;margin-top:8px;padding:10px 24px;border:none;border-radius:8px;background:var(--v2-accent);color:#fff;font-size:14px;font-weight:600;cursor:pointer;transition:background .15s,transform .1s}.v2-brainstorm-form__cta:hover{background:color-mix(in srgb,var(--v2-accent) 85%,black)}.v2-brainstorm-form__cta:active{transform:scale(.98)}.v2-brainstorm-form__cta:disabled{opacity:.5;cursor:not-allowed}.v2-brainstorm-picker{display:flex;flex-direction:column;flex:1;min-height:0}.v2-brainstorm-picker__header{display:flex;align-items:center;justify-content:space-between;padding:16px 20px 0}.v2-brainstorm-picker__title{font-size:16px;font-weight:600;color:var(--v2-text-primary);margin:0}.v2-brainstorm-picker__actions{display:flex;gap:8px}.v2-brainstorm-picker__quick-btn{padding:5px 12px;border:1px solid var(--v2-nav-border);border-radius:6px;background:transparent;color:var(--v2-text-secondary);font-size:12px;cursor:pointer;transition:background .15s,color .15s,border-color .15s}.v2-brainstorm-picker__quick-btn:hover{background:var(--v2-hover-bg);color:var(--v2-accent);border-color:var(--v2-accent)}.v2-brainstorm-tabs{display:flex;gap:4px;padding:12px 20px;overflow-x:auto;flex-shrink:0}.v2-brainstorm-tab{display:flex;align-items:center;gap:4px;padding:5px 12px;border:1px solid var(--v2-nav-border);border-radius:16px;background:transparent;color:var(--v2-text-secondary);font-size:12px;white-space:nowrap;cursor:pointer;transition:background .15s,color .15s,border-color .15s}.v2-brainstorm-tab:hover{background:var(--v2-hover-bg);color:var(--v2-text-primary)}.v2-brainstorm-tab--active{background:var(--v2-accent);color:#fff;border-color:var(--v2-accent)}.v2-brainstorm-tab--active:hover{background:var(--v2-accent);color:#fff}.v2-brainstorm-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:12px;padding:0 20px 16px;overflow-y:auto;flex:1}.v2-brainstorm-technique{display:flex;flex-direction:column;gap:4px;padding:14px;border:1px solid var(--v2-nav-border);border-radius:10px;background:var(--v2-nav-bg);text-align:left;cursor:pointer;transition:border-color .15s,box-shadow .15s}.v2-brainstorm-technique:hover{border-color:var(--v2-accent)}.v2-brainstorm-technique--selected{border-color:var(--v2-accent);box-shadow:0 0 0 2px color-mix(in srgb,var(--v2-accent) 20%,transparent)}.v2-brainstorm-technique__name{font-size:14px;font-weight:600;color:var(--v2-text-primary)}.v2-brainstorm-technique__en{font-size:11px;color:var(--v2-text-secondary);opacity:.7}.v2-brainstorm-technique__desc{font-size:12px;color:var(--v2-text-secondary);line-height:1.5;margin-top:4px;display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden}.v2-brainstorm-picker__footer{display:flex;align-items:center;justify-content:space-between;padding:12px 20px;border-top:1px solid var(--v2-nav-border);flex-shrink:0}.v2-brainstorm-picker__count{font-size:13px;color:var(--v2-text-secondary)}.v2-brainstorm-session{display:flex;flex-direction:column;flex:1;min-height:0}.v2-brainstorm-session-header{display:flex;align-items:center;justify-content:space-between;padding:10px 20px;border-bottom:1px solid var(--v2-nav-border);background:var(--v2-nav-bg);flex-shrink:0;gap:12px}.v2-brainstorm-session-header__info{display:flex;align-items:center;gap:10px;min-width:0;flex:1}.v2-brainstorm-session-header__topic{font-size:14px;font-weight:600;color:var(--v2-text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.v2-brainstorm-session-header__techniques{display:flex;gap:4px;flex-wrap:wrap}.v2-brainstorm-tag{display:inline-block;padding:2px 8px;border-radius:10px;background:var(--v2-hover-bg);color:var(--v2-text-secondary);font-size:11px;white-space:nowrap}.v2-brainstorm-session-header__actions-group{display:flex;gap:8px;flex-shrink:0}.v2-brainstorm-session-header__action{padding:5px 14px;border:none;border-radius:6px;background:var(--v2-accent);color:#fff;font-size:13px;font-weight:500;cursor:pointer;transition:background .15s;white-space:nowrap}.v2-brainstorm-session-header__action:hover{background:color-mix(in srgb,var(--v2-accent) 85%,black)}.v2-brainstorm-session-header__action--secondary{background:transparent;color:var(--v2-text-secondary);border:1px solid var(--v2-nav-border)}.v2-brainstorm-session-header__action--secondary:hover{background:var(--v2-hover-bg);color:var(--v2-text-primary)}.v2-brainstorm-session-header__action--phase{background:transparent;color:var(--v2-accent);border:1px solid var(--v2-accent)}.v2-brainstorm-session-header__action--phase:hover{background:color-mix(in srgb,var(--v2-accent) 12%,transparent)}.v2-brainstorm-session-header__action--primary{background:var(--v2-accent);color:#fff;font-weight:600}.v2-brainstorm-session-header__action--primary:hover{background:color-mix(in srgb,var(--v2-accent) 85%,black)}.v2-brainstorm-session-header__divider{width:1px;height:20px;background:var(--v2-nav-border);align-self:center}.v2-brainstorm-chat-wrap{flex:1;min-height:0;display:flex;flex-direction:column}:root[data-theme=dark] .v2-brainstorm-technique{background:color-mix(in srgb,var(--v2-nav-bg) 80%,black)}:root[data-theme=dark] .v2-brainstorm-session-header{background:color-mix(in srgb,var(--v2-nav-bg) 90%,black)}@media(max-width:768px){.v2-file-browser__tree{width:180px}.v2-settings__nav{width:60px}.v2-settings__nav-title{font-size:0;justify-content:center;padding:0 8px 12px}.v2-settings__nav-item>span+span{display:none}.v2-settings__nav-item{justify-content:center;padding:8px}.v2-mock-grid{grid-template-columns:repeat(auto-fill,minmax(150px,1fr))}.v2-settings__field{flex-direction:column;align-items:flex-start;gap:8px}.v2-settings__field input[type=text]{width:100%}.v2-settings__model-card-grid,.v2-settings__usage-stats{grid-template-columns:1fr}.v2-settings__provider-row{flex-wrap:wrap}.v2-settings__provider-endpoint{width:100%;order:3}}
