:root{--bg:#0e1015;--bg-accent:#13151b;--bg-elevated:#191c24;--bg-hover:#1f2330;--bg-muted:#1f2330;--card:#161920;--card-foreground:#f0f0f2;--card-highlight:#ffffff0a;--popover:#191c24;--popover-foreground:#f0f0f2;--panel:#0e1015;--panel-strong:#191c24;--panel-hover:#1f2330;--chrome:#0e1015f5;--chrome-strong:#0e1015fa;--text:#d4d4d8;--text-strong:#f4f4f5;--chat-text:#d4d4d8;--muted:#636370;--muted-strong:#4e4e5a;--muted-foreground:#636370;--border:#1e2028;--border-strong:#2e3040;--border-hover:#3e4050;--input:#1e2028;--ring:#ff5c5c;--accent:#ff5c5c;--accent-hover:#ff7070;--accent-muted:#ff5c5c;--accent-subtle:#ff5c5c1a;--accent-foreground:#fafafa;--accent-glow:#ff5c5c33;--primary:#ff5c5c;--primary-foreground:#fff;--secondary:#161920;--secondary-foreground:#f0f0f2;--accent-2:#14b8a6;--accent-2-muted:#14b8a6b3;--accent-2-subtle:#14b8a61a;--ok:#22c55e;--ok-muted:#22c55ebf;--ok-subtle:#22c55e14;--destructive:#ef4444;--destructive-foreground:#fafafa;--warn:#f59e0b;--warn-muted:#f59e0bbf;--warn-subtle:#f59e0b14;--danger:#ef4444;--danger-muted:#ef4444bf;--danger-subtle:#ef444414;--info:#3b82f6;--focus:#ff5c5c33;--focus-ring:0 0 0 2px var(--bg), 0 0 0 3px color-mix(in srgb, var(--ring) 60%, transparent);--focus-glow:0 0 0 2px var(--bg), 0 0 0 3px var(--ring), 0 0 16px var(--accent-glow);--grid-line:#ffffff08;--theme-switch-x:50%;--theme-switch-y:50%;--mono:"JetBrains Mono", ui-monospace, SFMono-Regular, "SF Mono", Menlo, Monaco, Consolas, monospace;--font-body:"Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif;--font-display:var(--font-body);--shadow-sm:0 1px 2px #00000040;--shadow-md:0 4px 16px #0000004d;--shadow-lg:0 12px 32px #0006;--shadow-xl:0 24px 48px #00000080;--shadow-glow:0 0 24px var(--accent-glow);--radius-sm:6px;--radius-md:10px;--radius-lg:14px;--radius-xl:20px;--radius-full:9999px;--radius:10px;--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:.1s;--duration-normal:.18s;--duration-slow:.3s;--lightningcss-light: ;--lightningcss-dark:initial;color-scheme:dark}:root[data-theme-mode=light]{--bg:#f8f9fa;--bg-accent:#f1f3f5;--bg-elevated:#fff;--bg-hover:#eceef0;--bg-muted:#eceef0;--bg-content:#f1f3f5;--card:#fff;--card-foreground:#1a1a1e;--card-highlight:#00000005;--popover:#fff;--popover-foreground:#1a1a1e;--panel:#f8f9fa;--panel-strong:#f1f3f5;--panel-hover:#e6e8eb;--chrome:#f8f9faf5;--chrome-strong:#f8f9fafa;--text:#3c3c43;--text-strong:#1a1a1e;--chat-text:#3c3c43;--muted:#8e8e93;--muted-strong:#636366;--muted-foreground:#8e8e93;--border:#e5e5ea;--border-strong:#d1d1d6;--border-hover:#aeaeb2;--input:#e5e5ea;--accent:#dc2626;--accent-hover:#ef4444;--accent-muted:#dc2626;--accent-subtle:#dc262614;--accent-foreground:#fff;--accent-glow:#dc26261a;--primary:#dc2626;--primary-foreground:#fff;--secondary:#f1f3f5;--secondary-foreground:#3c3c43;--accent-2:#0d9488;--accent-2-muted:#0d9488bf;--accent-2-subtle:#0d948814;--ok:#16a34a;--ok-muted:#16a34abf;--ok-subtle:#16a34a14;--destructive:#dc2626;--destructive-foreground:#fafafa;--warn:#d97706;--warn-muted:#d97706bf;--warn-subtle:#d9770614;--danger:#dc2626;--danger-muted:#dc2626bf;--danger-subtle:#dc262614;--info:#2563eb;--focus:#dc262626;--focus-ring:0 0 0 2px var(--bg), 0 0 0 3px color-mix(in srgb, var(--ring) 50%, transparent);--focus-glow:0 0 0 2px var(--bg), 0 0 0 3px var(--ring), 0 0 12px var(--accent-glow);--grid-line:#0000000a;--shadow-sm:0 1px 2px #0000000a;--shadow-md:0 4px 12px #0000000f;--shadow-lg:0 12px 28px #00000014;--shadow-xl:0 24px 48px #0000001a;--shadow-glow:0 0 20px var(--accent-glow);--lightningcss-light:initial;--lightningcss-dark: ;color-scheme:light}:root[data-theme=openknot]{--ring:#14b8a6;--accent:#14b8a6;--accent-hover:#2dd4bf;--accent-muted:#14b8a6;--accent-subtle:#14b8a61f;--accent-glow:#14b8a638;--primary:#14b8a6}:root[data-theme=openknot-light]{--ring:#0d9488;--accent:#0d9488;--accent-hover:#0f766e;--accent-muted:#0d9488;--accent-subtle:#0d94881a;--accent-glow:#0d948824;--primary:#0d9488}:root[data-theme=dash]{--ring:#3b82f6;--accent:#3b82f6;--accent-hover:#60a5fa;--accent-muted:#3b82f6;--accent-subtle:#3b82f624;--accent-glow:#3b82f638;--primary:#3b82f6}:root[data-theme=dash-light]{--ring:#2563eb;--accent:#2563eb;--accent-hover:#1d4ed8;--accent-muted:#2563eb;--accent-subtle:#2563eb1a;--accent-glow:#2563eb24;--primary:#2563eb}*{box-sizing:border-box}html,body{height:100%}body{font:400 13.5px/1.55 var(--font-body);letter-spacing:-.01em;background:var(--bg);color:var(--text);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;margin:0}@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;z-index:1;animation:none}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){animation:none!important}html.theme-transition::view-transition-new(theme){animation:none!important}}openclaw-app{z-index:1;min-height:100vh;display:block;position:relative}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:6px;height:6px}::-webkit-scrollbar-track{background:0 0}::-webkit-scrollbar-thumb{border-radius:var(--radius-full);background:#ffffff14}::-webkit-scrollbar-thumb:hover{background:#ffffff24}@keyframes rise{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}@keyframes fade-in{0%{opacity:0;transform:translateY(4px)}to{opacity:1;transform:translateY(0)}}@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}}.skeleton{background:linear-gradient(90deg, var(--bg-muted) 25%, var(--bg-hover) 50%, var(--bg-muted) 75%);border-radius:var(--radius-md);background-size:200% 100%;animation:1.5s ease-in-out infinite shimmer}.skeleton-line{border-radius:var(--radius-sm);height:14px}.skeleton-line--short{width:40%}.skeleton-line--medium{width:65%}.skeleton-line--long{width:85%}.skeleton-stat{border-radius:var(--radius-sm);width:60px;height:28px}.skeleton-block{border-radius:var(--radius-md);height:48px}@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:0s}.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{box-shadow:var(--focus-ring);outline:none}.shell{--shell-pad:16px;--shell-gap:16px;--shell-nav-width:220px;--shell-nav-rail-width:72px;--shell-topbar-height:52px;--shell-focus-duration:.2s;--shell-focus-ease:var(--ease-out);grid-template-columns:var(--shell-nav-width) minmax(0, 1fr);grid-template-rows:var(--shell-topbar-height) 1fr;height:100vh;animation:dashboard-enter .3s var(--ease-out);transition:grid-template-columns var(--shell-focus-duration) var(--shell-focus-ease);grid-template-areas:"topbar topbar""nav content";gap:0;display:grid;overflow:hidden}@supports (height:100dvh){.shell{height:100dvh}}.shell--chat{height:100vh;min-height:100vh;overflow:hidden}@supports (height:100dvh){.shell--chat{height:100dvh}}.shell--nav-collapsed{grid-template-columns:var(--shell-nav-rail-width) minmax(0, 1fr)}.shell--chat-focus{grid-template-columns:0 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{z-index:40;height:var(--shell-topbar-height);border-bottom:1px solid var(--border);background:color-mix(in srgb, var(--bg) 85%, transparent);-webkit-backdrop-filter:blur(12px)saturate(1.6);grid-area:topbar;justify-content:space-between;align-items:center;gap:16px;padding:0 20px;display:flex;position:sticky;top:0}.topbar-left{align-items:center;gap:12px;display:flex}.topbar .nav-collapse-toggle{width:36px;height:36px;margin-bottom:0}.topbar .nav-collapse-toggle__icon,.topbar .nav-collapse-toggle__icon svg{width:20px;height:20px}.brand{align-items:center;gap:8px;display:flex}.brand-logo{flex-shrink:0;width:26px;height:26px}.brand-logo img{object-fit:contain;width:100%;height:100%}.brand-text{flex-direction:column;gap:0;display:flex}.brand-title{letter-spacing:-.03em;color:var(--text-strong);font-size:15px;font-weight:700;line-height:1.1}.brand-sub{color:var(--muted);letter-spacing:.06em;text-transform:uppercase;font-size:9px;font-weight:500;line-height:1}.topbar-status{align-items:center;gap:8px;display:flex}.topbar-status .pill{box-sizing:border-box;gap:6px;height:32px;padding:6px 10px;font-size:12px;font-weight:500}.topbar-status .pill .mono{align-items:center;margin-top:0;line-height:1;display:flex}.topbar-status .statusDot{width:6px;height:6px}.topbar-status .theme-orb__trigger{width:26px;height:26px;font-size:13px}.topbar-search{border:1px solid var(--border);border-radius:var(--radius-md);background:var(--bg-elevated);color:var(--muted);cursor:pointer;transition:border-color var(--duration-fast) ease, background var(--duration-fast) ease, color var(--duration-fast) ease;align-items:center;gap:12px;min-width:180px;padding:7px 12px;font-size:13px;display:inline-flex}.topbar-search:hover{border-color:var(--border-strong);background:var(--bg-hover);color:var(--text)}.topbar-search:focus-visible{box-shadow:var(--focus-ring);outline:none}.topbar-search__label{text-align:left;flex:1}.topbar-search__kbd{border:1px solid var(--border);border-radius:var(--radius-sm);background:var(--bg);font-family:var(--mono);color:var(--muted);justify-content:center;align-items:center;padding:2px 6px;font-size:11px;line-height:1;display:inline-flex}.topbar-theme-mode{border:1px solid var(--border);border-radius:var(--radius-lg);background:color-mix(in srgb, var(--bg-elevated) 70%, transparent);align-items:center;gap:2px;padding:3px;display:inline-flex}.topbar-theme-mode__btn{border-radius:calc(var(--radius-md) - 1px);width:30px;height:30px;color:var(--muted);cursor:pointer;transition:color var(--duration-fast) ease, background var(--duration-fast) ease, border-color var(--duration-fast) ease;background:0 0;border:1px solid #0000;justify-content:center;align-items:center;padding:0;display:inline-flex}.topbar-theme-mode__btn:hover{color:var(--text);background:var(--bg-hover)}.topbar-theme-mode__btn:focus-visible{box-shadow:var(--focus-ring);outline:none}.topbar-theme-mode__btn--active{color:var(--accent);background:var(--accent-subtle);border-color:color-mix(in srgb, var(--accent) 25%, transparent)}.topbar-theme-mode__btn svg{stroke:currentColor;fill:none;stroke-width:1.75px;stroke-linecap:round;stroke-linejoin:round;width:14px;height:14px}.shell-nav{min-height:0;transition:width var(--shell-focus-duration) var(--shell-focus-ease);grid-area:nav;display:flex;overflow:hidden}.sidebar{background:var(--bg);flex-direction:column;flex:1;min-width:0;min-height:0;display:flex;overflow:hidden}:root[data-theme-mode=light] .sidebar{background:var(--panel)}.sidebar--collapsed{width:var(--shell-nav-rail-width);min-width:var(--shell-nav-rail-width);flex:0 0 var(--shell-nav-rail-width);border-right:1px solid color-mix(in srgb, var(--border-strong) 72%, transparent)}.sidebar-header{flex-shrink:0;justify-content:space-between;align-items:center;gap:8px;padding:14px 14px 6px;display:flex}.sidebar--collapsed .sidebar-header{justify-content:center;padding:12px 10px 6px}.sidebar-brand{align-items:center;gap:8px;min-width:0;display:flex}.sidebar-brand__logo{border-radius:6px;flex-shrink:0;width:22px;height:22px}.sidebar-brand__title{letter-spacing:-.025em;color:var(--text-strong);white-space:nowrap;text-overflow:ellipsis;font-size:14px;font-weight:700;overflow:hidden}.sidebar-nav{scrollbar-width:none;flex:1;padding:4px 8px;overflow:hidden auto}.sidebar-nav::-webkit-scrollbar{display:none}.sidebar--collapsed .sidebar-nav{flex-direction:column;gap:24px;padding:4px 8px;display:flex}.sidebar--collapsed .nav-group__label{display:none}.sidebar--collapsed .nav-group{gap:4px;margin-bottom:0}.sidebar--collapsed .nav-group--collapsed .nav-group__items{display:grid}.sidebar--collapsed .nav-item{border-radius:16px;justify-content:center;width:44px;height:42px;margin:0 auto;padding:0}.sidebar--collapsed .nav-item__icon{opacity:.78;width:18px;height:18px}.sidebar--collapsed .nav-item__icon svg{width:18px;height:18px}.sidebar--collapsed .nav-item__text,.sidebar--collapsed .nav-item__external-icon{display:none}.sidebar-footer{border-top:1px solid var(--border);flex-shrink:0;padding:8px}.sidebar--collapsed .sidebar-footer{padding:12px 8px 10px}.sidebar-footer__docs-block{flex-direction:column;align-items:center;gap:4px;display:flex}.sidebar--collapsed .sidebar-footer__docs-block{align-items:center;gap:10px}.sidebar--collapsed .sidebar-footer .nav-item{justify-content:center;width:44px;height:44px;padding:0}.sidebar-version{justify-content:center;align-items:center;padding:4px 10px;display:flex}.sidebar-version__text{color:var(--muted);letter-spacing:.02em;font-size:11px;font-weight:500}.sidebar-version__dot{border-radius:var(--radius-full);background:color-mix(in srgb, var(--accent) 78%, white 22%);width:8px;height:8px;box-shadow:0 0 0 4px color-mix(in srgb, var(--accent) 14%, transparent);opacity:1;margin:0 auto}.sidebar-resizer{cursor:col-resize;width:3px;transition:background var(--duration-fast) ease;background:0 0;flex-shrink:0;position:relative}.sidebar-resizer:after{content:"";width:3px;transition:background var(--duration-fast) ease;background:0 0;position:absolute;top:0;bottom:0;left:0}.sidebar-resizer:hover:after{background:var(--accent);opacity:.35}.sidebar-resizer:active:after{background:var(--accent);opacity:.6}.shell--nav-collapsed .shell-nav{width:var(--shell-nav-rail-width);min-width:var(--shell-nav-rail-width)}.shell--chat-focus .shell-nav{pointer-events:none;opacity:0;width:0;min-width:0;overflow:hidden}.nav-collapse-toggle{border-radius:var(--radius-sm);cursor:pointer;width:28px;height:28px;transition:background var(--duration-fast) ease, border-color var(--duration-fast) ease, color var(--duration-fast) ease;color:var(--muted);background:0 0;border:1px solid #0000;justify-content:center;align-items:center;margin-bottom:0;display:flex}.nav-collapse-toggle:hover{background:var(--bg-hover);color:var(--text)}.nav-collapse-toggle__icon{width:16px;height:16px;color:inherit;justify-content:center;align-items:center;display:flex}.nav-collapse-toggle__icon svg{stroke:currentColor;fill:none;stroke-width:1.5px;stroke-linecap:round;stroke-linejoin:round;width:16px;height:16px}.nav-collapse-toggle:hover .nav-collapse-toggle__icon{color:inherit}.nav-group{gap:1px;margin-bottom:12px;display:grid}.nav-group:last-child{margin-bottom:0}.nav-group__items{gap:1px;display:grid}.nav-group--collapsed .nav-group__items{display:none}.nav-group__label{width:100%;color:var(--muted);cursor:pointer;text-align:left;text-transform:uppercase;letter-spacing:.06em;border-radius:var(--radius-sm);transition:color var(--duration-fast) ease, background var(--duration-fast) ease;background:0 0;border:none;justify-content:space-between;align-items:center;gap:8px;margin-bottom:2px;padding:5px 10px;font-size:10px;font-weight:600;display:flex}.nav-group__label:hover{color:var(--text);background:var(--bg-hover)}.nav-group__label--static{cursor:default}.nav-group__label--static:hover{color:var(--muted);background:0 0}.nav-group__label-text{flex:1}.nav-group__chevron{opacity:.5;transition:transform var(--duration-fast) ease;justify-content:center;align-items:center;font-size:10px;display:inline-flex}.nav-group__chevron svg{stroke:currentColor;fill:none;stroke-width:1.5px;stroke-linecap:round;stroke-linejoin:round;width:12px;height:12px}.nav-group--collapsed .nav-group__chevron{transform:rotate(-90deg)}.nav-item{border-radius:var(--radius-md);color:var(--muted);cursor:pointer;transition:border-color var(--duration-fast) ease, background var(--duration-fast) ease, color var(--duration-fast) ease;background:0 0;border:1px solid #0000;justify-content:flex-start;align-items:center;gap:8px;padding:7px 10px;text-decoration:none;display:flex;position:relative}.nav-item__icon{opacity:.6;width:15px;height:15px;transition:opacity var(--duration-fast) ease;flex-shrink:0;justify-content:center;align-items:center;display:flex}.nav-item__icon svg{stroke:currentColor;fill:none;stroke-width:1.5px;stroke-linecap:round;stroke-linejoin:round;width:15px;height:15px}.nav-item__text{white-space:nowrap;font-size:13px;font-weight:450}.nav-item:hover{color:var(--text);background:var(--bg-hover);text-decoration:none}.nav-item:hover .nav-item__icon{opacity:.9}.nav-item.active,.nav-item--active{color:var(--text-strong);background:var(--accent-subtle);border-color:color-mix(in srgb, var(--accent) 15%, transparent)}.nav-item.active .nav-item__icon,.nav-item--active .nav-item__icon{opacity:1;color:var(--accent)}.sidebar--collapsed .nav-item--active:before,.sidebar--collapsed .nav-item.active:before{content:"";background:color-mix(in srgb, var(--accent) 78%, transparent);border-radius:999px;width:2px;position:absolute;top:11px;bottom:11px;left:6px}.sidebar--collapsed .nav-item.active,.sidebar--collapsed .nav-item--active{background:color-mix(in srgb, var(--accent-subtle) 88%, var(--bg-elevated) 12%);border-color:color-mix(in srgb, var(--accent) 12%, var(--border) 88%);box-shadow:inset 0 1px 0 color-mix(in srgb, var(--text) 6%, transparent)}.sidebar--collapsed .nav-collapse-toggle{border-color:color-mix(in srgb, var(--border-strong) 74%, transparent);border-radius:var(--radius-full);background:color-mix(in srgb, var(--bg-elevated) 92%, transparent);width:44px;height:34px;box-shadow:inset 0 1px 0 color-mix(in srgb, var(--text) 8%, transparent), 0 8px 18px #00000029;margin-bottom:0}.sidebar--collapsed .nav-collapse-toggle:hover{border-color:color-mix(in srgb, var(--border-strong) 72%, transparent);background:color-mix(in srgb, var(--bg-elevated) 96%, transparent)}.nav-item__external-icon{opacity:0;width:12px;height:12px;transition:opacity var(--duration-fast) ease;flex-shrink:0;justify-content:center;align-items:center;margin-left:auto;display:inline-flex}.nav-item__external-icon svg{stroke:currentColor;fill:none;stroke-width:1.5px;stroke-linecap:round;stroke-linejoin:round;width:12px;height:12px}.nav-item:hover .nav-item__external-icon{opacity:.5}.content{grid-area:content;min-height:0;padding:16px 20px 32px;display:block;overflow:hidden auto}.content>*+*{margin-top:20px}:root[data-theme-mode=light] .content{background:var(--bg-content)}.content--chat{flex-direction:column;gap:24px;padding-bottom:0;display:flex;overflow:hidden}.content--chat>*+*{margin-top:0}.content-header{transform-origin:top;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);justify-content:space-between;align-items:flex-end;gap:16px;max-height:80px;padding:4px 8px;display:flex;overflow:hidden}.shell--chat-focus .content-header{opacity:0;pointer-events:none;max-height:0;padding:0;transform:translateY(-8px)}.page-title{letter-spacing:-.03em;color:var(--text-strong);font-size:22px;font-weight:650;line-height:1.2}.page-sub{color:var(--muted);letter-spacing:-.005em;margin-top:4px;font-size:13px;font-weight:400}.page-meta{gap:8px;display:flex}.content--chat .content-header{flex-direction:row;justify-content:space-between;align-items:center;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{gap:20px;display:grid}.grid-cols-2{grid-template-columns:repeat(2,minmax(0,1fr))}.grid-cols-3{grid-template-columns:repeat(3,minmax(0,1fr))}.stat-grid{grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:14px;display:grid}.note-grid{grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:16px;display:grid}.row{align-items:center;gap:12px;display:flex}.stack{grid-template-columns:minmax(0,1fr);gap:12px;display:grid}.filters{flex-wrap:wrap;align-items:center;gap:8px;display:flex}@media (width<=1100px){.shell{--shell-pad:12px;--shell-gap:12px;grid-template:"topbar""nav""content"1fr/1fr}.nav-group{grid-template-columns:repeat(auto-fit,minmax(100px,1fr));grid-auto-flow:column;margin-bottom:0}.grid-cols-2,.grid-cols-3{grid-template-columns:1fr}.topbar{gap:10px;padding:12px 14px;position:static}.topbar-status{flex-wrap:wrap}.table-head,.table-row,.list-item{grid-template-columns:1fr}.shell,.shell--nav-collapsed{grid-template-columns:minmax(0,1fr);grid-template-rows:var(--shell-topbar-height) auto minmax(0, 1fr);grid-template-areas:"topbar""nav""content"}.shell--chat-focus{grid-template-rows:var(--shell-topbar-height) 0 minmax(0, 1fr)}.shell-nav,.shell--nav-collapsed .shell-nav{border-bottom:1px solid var(--border);width:auto;min-width:0}.sidebar,.sidebar--collapsed{border-right:none;flex-direction:row;flex:auto;align-items:center;width:auto;min-width:0}.sidebar-header,.sidebar--collapsed .sidebar-header{flex:none;justify-content:flex-start;padding:8px 10px}.sidebar-brand{display:none}.sidebar-nav,.sidebar--collapsed .sidebar-nav{-webkit-overflow-scrolling:touch;scrollbar-width:none;flex-flow:row;flex:auto;gap:8px;padding:8px 10px 8px 0;display:flex;overflow:auto hidden}.sidebar-nav::-webkit-scrollbar{display:none}.sidebar--collapsed .sidebar-nav::-webkit-scrollbar{display:none}.nav-group,.nav-group__items,.sidebar--collapsed .nav-group,.sidebar--collapsed .nav-group__items{display:contents}.nav-group{margin-bottom:0}.sidebar-nav .nav-group__label{display:none}.nav-item,.sidebar--collapsed .nav-item{border-radius:var(--radius-md);white-space:nowrap;flex:none;margin:0;padding:8px 14px;font-size:13px}.sidebar--collapsed .nav-item--active:before,.sidebar--collapsed .nav-item.active:before{content:none}.sidebar-footer,.sidebar--collapsed .sidebar-footer{display:none}}@media (width<=600px){.shell{--shell-pad:8px;--shell-gap:8px}.topbar{flex-flow:wrap;justify-content:space-between;align-items:center;gap:8px;padding:10px 12px}.brand{flex:1;min-width:0}.brand-title{font-size:14px}.brand-sub{display:none}.topbar-status{flex-wrap:nowrap;gap:6px;width:auto}.topbar-status .pill{gap:4px;padding:4px 8px;font-size:11px}.topbar-status .pill .mono,.topbar-status .pill span:nth-child(2){display:none}.shell-nav{border-bottom-width:0}.sidebar-header{padding:6px 8px}.sidebar-nav{gap:6px;padding:6px 8px 6px 0}.nav-item{border-radius:var(--radius-md);white-space:nowrap;flex-shrink:0;padding:6px 10px;font-size:12px}.content-header{display:none}.content{gap:12px;padding:4px 4px 16px}.card{border-radius:var(--radius-md);padding:12px}.card-title{font-size:13px}.stat-grid{grid-template-columns:repeat(2,1fr);gap:8px}.stat{border-radius:var(--radius-md);padding:10px}.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{border-radius:var(--radius-md);padding:8px 10px;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{border-radius:var(--radius-md);padding:8px 12px}.chat-compose{gap:8px}.chat-compose__field textarea{border-radius:var(--radius-md);min-height:60px;padding:8px 10px;font-size:14px}.agent-chat__input{margin:0 8px 10px}.agent-chat__toolbar{padding:4px 8px}.agent-chat__input-btn,.agent-chat__toolbar .btn-ghost{width:28px;height:28px}.agent-chat__input-btn svg,.agent-chat__toolbar .btn-ghost svg{width:14px;height: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{border-radius:var(--radius-md);padding:10px}.list-title{font-size:13px}.list-sub{font-size:11px}.code-block{border-radius:var(--radius-md);padding:8px;font-size:11px}.theme-orb__trigger{width:26px;height:26px;font-size:13px}}@media (width<=400px){.shell{--shell-pad:4px}.topbar{padding:8px 10px}.brand-title{font-size:13px}.nav-item{padding:6px 8px;font-size:11px}.content{gap:10px;padding:4px 4px 12px}.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-orb__trigger{width:24px;height:24px;font-size:12px}}.chat{flex-direction:column;flex:1 1 0;height:100%;min-height:0;display:flex;position:relative;overflow:hidden;box-shadow:none!important;background:0 0!important;border:none!important}.chat-header{background:0 0;flex-wrap:nowrap;flex-shrink:0;justify-content:space-between;align-items:center;gap:12px;margin-bottom:12px;padding-bottom:12px;display:flex}.chat-thread{background:0 0;border-radius:12px;flex:1 1 0;min-height:0;margin:0 -4px;padding:12px 4px;overflow:hidden auto}.chat-focus-exit{z-index:100;border:1px solid var(--border);background:var(--panel);width:32px;height:32px;color:var(--muted);cursor:pointer;border-radius:50%;justify-content:center;align-items:center;font-size:20px;line-height:1;transition:background .15s ease-out,color .15s ease-out,border-color .15s ease-out;display:flex;position:absolute;top:12px;right:12px;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{stroke:currentColor;fill:none;stroke-width:2px;stroke-linecap:round;stroke-linejoin:round;width:16px;height:16px}.chat-new-messages{font-size:13px;font-family:var(--font-body);color:var(--text);background:var(--panel-strong);border:1px solid var(--border);cursor:pointer;white-space:nowrap;z-index:10;border-radius:999px;align-self:center;align-items:center;gap:6px;margin:8px auto;padding:6px 14px;transition:background .15s ease-out,border-color .15s ease-out;display:inline-flex}.chat-new-messages:hover{background:var(--panel);border-color:var(--accent)}.chat-new-messages svg{stroke:currentColor;fill:none;stroke-width:1.5px;stroke-linecap:round;stroke-linejoin:round;flex-shrink:0;width:16px;height:16px}.chat-compose{background:linear-gradient(to bottom, transparent, var(--bg) 20%);z-index:10;flex-direction:column;flex-shrink:0;gap:12px;margin-top:auto;padding:12px 4px 4px;display:flex;position:sticky;bottom:0}.chat-attachments{background:var(--panel);border:1px solid var(--border);border-radius:8px;flex-wrap:wrap;align-self:flex-start;gap:8px;width:fit-content;max-width:100%;padding:8px;display:inline-flex}.chat-attachment{border:1px solid var(--border);background:var(--bg);border-radius:6px;width:80px;height:80px;position:relative;overflow:hidden}.chat-attachment__img{object-fit:contain;width:100%;height:100%}.chat-attachment__remove{color:#fff;cursor:pointer;opacity:0;background:#000000b3;border:none;border-radius:50%;justify-content:center;align-items:center;width:20px;height:20px;font-size:12px;line-height:1;transition:opacity .15s ease-out;display:flex;position:absolute;top:4px;right:4px}.chat-attachment:hover .chat-attachment__remove{opacity:1}.chat-attachment__remove:hover{background:#dc2626e6}.chat-attachment__remove svg{stroke:currentColor;fill:none;stroke-width:2px;width:12px;height:12px}:root[data-theme-mode=light] .chat-attachments{background:#f8fafc;border-color:#1018281a}:root[data-theme-mode=light] .chat-attachment{background:#fff;border-color:#10182826}:root[data-theme-mode=light] .chat-attachment__remove{background:#0009}.chat-message-images{flex-wrap:wrap;gap:8px;margin-bottom:8px;display:flex}.chat-message-image{object-fit:contain;cursor:pointer;border-radius:8px;max-width:300px;max-height:200px;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{flex:1;align-items:stretch;gap:12px;display:flex}:root[data-theme-mode=light] .chat-compose{background:linear-gradient(to bottom, transparent, var(--bg-content) 20%)}.chat-compose__field{flex:auto;align-items:stretch;min-width:0;display:flex}.chat-compose__field>span{display:none}.chat-compose .chat-compose__field textarea{resize:none;white-space:pre-wrap;width:100%;height:40px;min-height:40px;max-height:150px;font-family:var(--font-body);border-radius:8px;padding:9px 12px;font-size:14px;line-height:1.45;overflow-y:auto}.chat-compose__actions{flex-shrink:0;align-items:stretch;gap:8px;display:flex}.chat-compose .chat-compose__actions .btn{white-space:nowrap;box-sizing:border-box;height:40px;min-height:40px;max-height:40px;padding:0 16px;font-size:13px;line-height:1}.agent-chat__input{background:var(--card);border:1px solid var(--border);border-radius:var(--radius-lg);transition:border-color var(--duration-fast) ease, box-shadow var(--duration-fast) ease;flex-direction:column;flex-shrink:0;margin:0 18px 14px;padding:0;display:flex;position:relative;overflow:hidden}.agent-chat__input:focus-within{border-color:color-mix(in srgb, var(--accent) 40%, transparent);box-shadow:0 0 0 2px color-mix(in srgb, var(--accent) 8%, transparent)}@supports ((-webkit-backdrop-filter:blur(1px)) or (backdrop-filter:blur(1px))){.agent-chat__input{-webkit-backdrop-filter:blur(12px)saturate(1.6)}}.agent-chat__input>textarea{resize:none;width:100%;min-height:40px;max-height:150px;color:var(--text);box-sizing:border-box;background:0 0;border:none;outline:none;padding:12px 14px 8px;font-family:inherit;font-size:.92rem;line-height:1.4}.agent-chat__input>textarea::placeholder{color:var(--muted)}.agent-chat__toolbar{border-top:1px solid color-mix(in srgb, var(--border) 50%, transparent);justify-content:space-between;align-items:center;padding:6px 10px;display:flex}.agent-chat__toolbar-left,.agent-chat__toolbar-right{align-items:center;gap:4px;display:flex}.agent-chat__input-btn,.agent-chat__toolbar .btn-ghost{border-radius:var(--radius-sm);width:30px;height:30px;color:var(--muted);cursor:pointer;transition:all var(--duration-fast) ease;background:0 0;border:none;flex-shrink:0;justify-content:center;align-items:center;padding:0;display:inline-flex}.agent-chat__input-btn svg,.agent-chat__toolbar .btn-ghost svg{stroke:currentColor;fill:none;stroke-width:1.5px;stroke-linecap:round;stroke-linejoin:round;width:16px;height:16px}.agent-chat__input-btn:hover:not(:disabled),.agent-chat__toolbar .btn-ghost:hover:not(:disabled){color:var(--text);background:var(--bg-hover)}.agent-chat__input-btn:disabled,.agent-chat__toolbar .btn-ghost:disabled{opacity:.4;cursor:not-allowed}.agent-chat__input-btn--active{color:var(--accent);background:color-mix(in srgb, var(--accent) 12%, transparent)}.agent-chat__input-divider{background:var(--border);width:1px;height:16px;margin:0 4px}.agent-chat__token-count{color:var(--muted);white-space:nowrap;flex-shrink:0;align-self:center;font-size:.7rem}.chat-send-btn{border-radius:var(--radius-md);background:var(--accent);width:30px;height:30px;color:var(--accent-foreground);cursor:pointer;transition:background var(--duration-fast) ease, box-shadow var(--duration-fast) ease;border:none;flex-shrink:0;justify-content:center;align-items:center;padding:0;display:inline-flex}.chat-send-btn svg{stroke:currentColor;fill:none;stroke-width:1.5px;stroke-linecap:round;stroke-linejoin:round;width:15px;height:15px}.chat-send-btn:hover:not(:disabled){background:var(--accent-hover);box-shadow:0 2px 10px #ff5c5c40}.chat-send-btn:disabled{opacity:.3;cursor:not-allowed}.chat-send-btn--stop{background:var(--danger)}.chat-send-btn--stop:hover:not(:disabled){background:color-mix(in srgb, var(--danger) 85%, #fff)}.slash-menu{background:var(--popover);border:1px solid var(--border-strong);border-radius:var(--radius-lg);max-height:320px;box-shadow:var(--shadow-lg);z-index:30;scrollbar-width:thin;margin-bottom:4px;padding:6px;position:absolute;bottom:100%;left:0;right:0;overflow-y:auto}.slash-menu-group+.slash-menu-group{border-top:1px solid color-mix(in srgb, var(--border) 50%, transparent);margin-top:4px;padding-top:4px}.slash-menu-group__label{text-transform:uppercase;letter-spacing:.06em;color:var(--accent);opacity:.7;padding:4px 10px 2px;font-size:.68rem;font-weight:700}.slash-menu-item{border-radius:var(--radius-sm);cursor:pointer;transition:background var(--duration-fast) ease, color var(--duration-fast) ease;align-items:center;gap:8px;padding:7px 10px;display:flex}.slash-menu-item:hover,.slash-menu-item--active{background:color-mix(in srgb, var(--accent) 10%, var(--bg-hover))}.slash-menu-icon{width:20px;height:20px;color:var(--accent);opacity:.7;flex-shrink:0;justify-content:center;align-items:center;display:flex}.slash-menu-icon svg{stroke:currentColor;fill:none;stroke-width:1.5px;stroke-linecap:round;stroke-linejoin:round;width:14px;height:14px}.slash-menu-item--active .slash-menu-icon,.slash-menu-item:hover .slash-menu-icon{opacity:1}.slash-menu-name{font-size:.82rem;font-weight:600;font-family:var(--mono);color:var(--accent);white-space:nowrap}.slash-menu-args{color:var(--muted);font-size:.75rem;font-family:var(--mono);opacity:.65}.slash-menu-desc{text-overflow:ellipsis;white-space:nowrap;text-align:right;color:var(--muted);flex:1;font-size:.75rem;overflow:hidden}.slash-menu-item--active .slash-menu-name{color:var(--accent-hover)}.slash-menu-item--active .slash-menu-desc{color:var(--text)}.chat-attachments-preview{flex-wrap:wrap;gap:8px;margin-bottom:8px;display:flex}.chat-attachment-thumb{border-radius:var(--radius-sm);border:1px solid var(--border);width:60px;height:60px;position:relative;overflow:hidden}.chat-attachment-thumb img{object-fit:cover;width:100%;height:100%}.chat-attachment-remove{color:#fff;cursor:pointer;background:#0009;border:none;border-radius:50%;justify-content:center;align-items:center;width:18px;height:18px;font-size:12px;line-height:1;display:flex;position:absolute;top:2px;right:2px}.chat-attachment-file{text-overflow:ellipsis;white-space:nowrap;color:var(--muted);align-items:center;gap:4px;padding:4px;font-size:.72rem;display:flex;overflow:hidden}.agent-chat__file-input{display:none}.chat-controls{flex-wrap:wrap;justify-content:flex-start;align-items:center;gap:12px;display:flex}.chat-controls__session{min-width:140px;max-width:300px}.chat-controls__thinking{align-items:center;gap:6px;font-size:13px;display:flex}.btn--icon{border:1px solid var(--border);background:#ffffff0f;justify-content:center;align-items:center;min-width:36px;height:36px;display:inline-flex;padding:8px!important}.chat-controls__separator{color:#fff6;margin:0 8px;font-size:18px;font-weight:300}:root[data-theme-mode=light] .chat-controls__separator{color:#1018284d}.btn--icon:hover{background:#ffffff1f;border-color:#fff3}:root[data-theme-mode=light] .btn--icon{border-color:var(--border);color:var(--muted);background:#fff;box-shadow:0 1px 2px #1018280d}:root[data-theme-mode=light] .btn--icon:hover{border-color:var(--border-strong);color:var(--text);background:#fff}:root[data-theme-mode=light] .chat-controls .btn--icon.active{border-color:var(--accent);background:var(--accent-subtle);color:var(--accent);box-shadow:0 0 0 1px var(--accent-subtle)}.btn--icon svg{stroke:currentColor;fill:none;stroke-width:1.5px;stroke-linecap:round;stroke-linejoin:round;width:18px;height:18px;display:block}.chat-controls__session select{text-overflow:ellipsis;max-width:300px;padding:6px 10px;font-size:13px;overflow:hidden}.chat-controls__thinking{border:1px solid var(--border);background:#ffffff0a;border-radius:6px;align-items:center;gap:4px;padding:4px 10px;font-size:12px;display:flex}:root[data-theme-mode=light] .chat-controls__thinking{background:#ffffffe6;border-color:#10182826}@media (width<=640px){.chat-session{min-width:140px}.chat-compose{grid-template-columns:1fr}.chat-compose__row{flex-direction:column;gap:8px}.chat-compose__actions{flex-direction:column;gap:8px;width:100%}.chat-compose .chat-compose__actions .btn{width:100%}.chat-controls{flex-wrap:wrap;gap:8px}.chat-controls__session{min-width:120px}}.chat-loading-skeleton{animation:fade-in .3s var(--ease-out);padding:4px 0}.agent-chat__welcome{text-align:center;flex-direction:column;flex:1;justify-content:center;align-items:center;gap:12px;min-height:0;padding:48px 24px;display:flex}.agent-chat__welcome-glow{display:none}.agent-chat__welcome h2{color:var(--foreground);margin:0;font-size:20px;font-weight:600}.agent-chat__avatar--logo{background:var(--panel-strong);border:1px solid var(--border);border-radius:14px;place-items:center;width:48px;height:48px;display:grid;overflow:hidden}.agent-chat__avatar--logo img{object-fit:contain;width:32px;height:32px}.agent-chat__badges{flex-wrap:wrap;justify-content:center;gap:8px;display:flex}.agent-chat__badge{color:var(--muted);background:var(--panel);border:1px solid var(--border);border-radius:100px;align-items:center;gap:6px;padding:4px 12px;font-size:12px;font-weight:500;display:inline-flex}.agent-chat__badge img{object-fit:contain;width:14px;height:14px}.agent-chat__hint{color:var(--muted);margin:0;font-size:13px}.agent-chat__hint kbd{font-size:11px;font-family:var(--font-mono);background:var(--panel-strong);border:1px solid var(--border);border-radius:4px;padding:1px 6px;display:inline-block}.agent-chat__suggestions{flex-wrap:wrap;justify-content:center;gap:8px;max-width:480px;margin-top:8px;display:flex}.agent-chat__suggestion{border:1px solid var(--border);background:var(--panel);color:var(--foreground);cursor:pointer;border-radius:100px;padding:8px 16px;font-size:13px;transition:background .15s,border-color .15s}.agent-chat__suggestion:hover{background:var(--panel-strong);border-color:var(--accent)}.chat-thinking{color:var(--muted);background:#ffffff0a;border:1px dashed #ffffff2e;border-radius:10px;margin-bottom:10px;padding:10px 12px;font-size:12px;line-height:1.4}:root[data-theme-mode=light] .chat-thinking{background:#1018280a;border-color:#10182840}.chat-text{word-wrap:break-word;overflow-wrap:break-word;font-size:14px;line-height:1.5}.chat-text :where(p+p,p+ul,p+ol,p+pre,p+blockquote){margin-top:.75em}.chat-text :where(a){color:var(--accent);text-underline-offset:2px;text-decoration:underline}.chat-text :where(a:hover){opacity:.8}.chat-text :where(:not(pre)>code){overflow-wrap:normal;word-break:keep-all;background:#00000026;border-radius:4px;padding:.15em .4em}.chat-text :where(pre){background:#00000026;border-radius:6px;padding:10px 12px;overflow-x:auto}.chat-text :where(pre code){background:0 0;padding:0}.chat-text :where(blockquote){border-left:3px solid var(--border-strong);color:var(--muted);border-radius:0 var(--radius-sm) var(--radius-sm) 0;background:#ffffff05;margin-left:0;padding:8px 12px}.chat-text :where(blockquote blockquote){border-left-color:var(--border-hover);background:#ffffff08;margin-top:8px}.chat-text :where(blockquote blockquote blockquote){border-left-color:var(--muted-strong);background:#ffffff0a}:root[data-theme-mode=light] .chat-text :where(blockquote){background:#00000008}:root[data-theme-mode=light] .chat-text :where(blockquote blockquote){background:#0000000d}:root[data-theme-mode=light] .chat-text :where(blockquote blockquote blockquote){background:#0000000a}:root[data-theme-mode=light] .chat-text :where(:not(pre)>code){background:#00000014;border:1px solid #0000001a}:root[data-theme-mode=light] .chat-text :where(pre){background:#0000000d;border:1px solid #0000001a}.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{align-items:flex-start;gap:10px;margin-bottom:14px;margin-left:4px;margin-right:16px;display:flex}.chat-group.user{flex-direction:row-reverse;justify-content:flex-start}.chat-group-messages{flex-direction:column;gap:2px;max-width:min(900px,100% - 60px);display:flex}.chat-group.user .chat-group-messages{align-items:flex-end}.chat-group.user .chat-group-footer{justify-content:flex-end}.chat-group-footer{align-items:baseline;gap:8px;margin-top:6px;display:flex}.chat-sender-name{color:var(--muted);font-size:12px;font-weight:500}.chat-group-timestamp{color:var(--muted);opacity:.7;font-size:11px}.chat-group-footer button{cursor:pointer;border-radius:var(--radius-sm,4px);color:var(--muted);opacity:0;pointer-events:none;background:0 0;border:none;justify-content:center;align-items:center;padding:2px;transition:opacity .12s ease-out,color .12s ease-out,background .12s ease-out;display:inline-flex}.chat-group:hover .chat-group-footer button{opacity:.6;pointer-events:auto}.chat-group-footer button:hover{background:var(--bg-hover,#ffffff14);opacity:1!important}.chat-group-footer button svg{fill:none;stroke:currentColor;stroke-width:2px;stroke-linecap:round;stroke-linejoin:round;width:14px;height:14px}.chat-tts-btn--active{color:var(--accent,#3b82f6);opacity:1!important;pointer-events:auto!important}.chat-group-delete:hover{color:var(--danger,#ef4444)!important}.chat-divider{color:var(--muted);letter-spacing:.08em;text-transform:uppercase;-webkit-user-select:none;user-select:none;align-items:center;gap:10px;margin:18px 8px;font-size:11px;display:flex}.chat-divider__line{background:var(--border);opacity:.9;flex:1 1 0;height:1px}.chat-divider__label{border:1px solid var(--border);background:#ffffff05;border-radius:999px;padding:2px 10px}.chat-avatar{background:var(--panel-strong);border:1px solid var(--border);border-radius:10px;flex-shrink:0;align-self:flex-end;place-items:center;width:36px;height:36px;margin-bottom:4px;font-size:13px;font-weight:600;display:grid}.chat-avatar.user{background:var(--accent-subtle);color:var(--accent);border-color:color-mix(in srgb, var(--accent) 20%, transparent)}.chat-avatar.assistant,.chat-avatar.other,.chat-avatar.tool{background:var(--secondary);color:var(--muted)}img.chat-avatar{object-fit:cover;object-position:center;display:block}.chat-bubble{border:1px solid var(--border);background:var(--card);border-radius:var(--radius-lg);box-shadow:none;transition:background var(--duration-fast) ease-out, border-color var(--duration-fast) ease-out;word-wrap:break-word;max-width:100%;padding:10px 14px;display:inline-block;position:relative}.chat-bubble.has-copy{padding-right:36px}.chat-copy-btn{border:1px solid var(--border);background:var(--bg);color:var(--muted);border-radius:var(--radius-md);cursor:pointer;opacity:0;pointer-events:none;padding:4px 6px;font-size:14px;line-height:1;transition:opacity .12s ease-out,background .12s ease-out;position:absolute;top:6px;right:8px}.chat-copy-btn__icon{width:14px;height:14px;display:inline-flex;position:relative}.chat-copy-btn__icon svg{stroke:currentColor;fill:none;stroke-width:1.5px;stroke-linecap:round;stroke-linejoin:round;width:14px;height:14px}.chat-copy-btn__icon-copy,.chat-copy-btn__icon-check{transition:opacity .15s;position:absolute;top:0;left:0}.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-mode=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:#0000}:root[data-theme-mode=light] .chat-group.user .chat-bubble{background:#fb923c1f;border-color:#ea580c33}.chat-group.user .chat-bubble:hover{background:#ff4d4d26}@keyframes pulsing-border{0%,to{border-color:var(--border)}50%{border-color:var(--accent)}}.chat-bubble.fade-in{animation:.2s ease-out fade-in}.msg-meta{color:var(--muted);flex-wrap:wrap;align-items:center;gap:8px;margin-top:4px;font-size:11px;line-height:1;display:inline-flex}.msg-meta__tokens,.msg-meta__cache,.msg-meta__cost,.msg-meta__ctx,.msg-meta__model{white-space:nowrap;align-items:center;gap:2px;display:inline-flex}.msg-meta__model{background:var(--bg-hover,#ffffff0f);border-radius:var(--radius-sm,4px);font-family:var(--font-mono,monospace);padding:1px 6px}.msg-meta__cost{color:var(--ok,#22c55e)}.msg-meta__ctx--warn{color:var(--warning,#eab308)}.msg-meta__ctx--danger{color:var(--danger,#ef4444)}.chat-delete-wrap{display:inline-flex;position:relative}.chat-delete-confirm{background:var(--card,#1a1a1a);border:1px solid var(--border,#ffffff1a);border-radius:var(--radius-md,8px);z-index:100;min-width:200px;padding:12px;animation:.15s ease-out scale-in;position:absolute;bottom:calc(100% + 6px);left:0;box-shadow:0 8px 24px #0006}.chat-delete-confirm__text{color:var(--fg,#fff);margin:0 0 8px;font-size:13px;font-weight:500}.chat-delete-confirm__remember{color:var(--muted,#888);cursor:pointer;-webkit-user-select:none;user-select:none;align-items:center;gap:6px;margin-bottom:10px;font-size:11px;display:flex}.chat-delete-confirm__check{width:14px;height:14px;accent-color:var(--accent,#3b82f6);cursor:pointer}.chat-delete-confirm__actions{justify-content:flex-end;gap:6px;display:flex}.chat-delete-confirm__cancel,.chat-delete-confirm__yes{border-radius:var(--radius-sm,4px);cursor:pointer;border:none;padding:4px 12px;font-size:12px;font-weight:500;transition:background .12s ease-out}.chat-delete-confirm__cancel{background:var(--bg-hover,#ffffff14);color:var(--muted,#888)}.chat-delete-confirm__cancel:hover{background:#ffffff1f}.chat-delete-confirm__yes{background:var(--danger,#ef4444);color:#fff}.chat-delete-confirm__yes:hover{background:#dc2626}.chat-tool-card{border:1px solid var(--border);border-radius:var(--radius-md);background:var(--card);transition:border-color var(--duration-fast) ease-out, background var(--duration-fast) ease-out;max-height:120px;margin-top:6px;padding:10px 12px;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{justify-content:space-between;align-items:center;gap:8px;display:flex}.chat-tool-card__title{align-items:center;gap:6px;font-size:13px;font-weight:600;line-height:1.2;display:inline-flex}.chat-tool-card__icon{flex-shrink:0;justify-content:center;align-items:center;width:16px;height:16px;display:inline-flex}.chat-tool-card__icon svg{stroke:currentColor;fill:none;stroke-width:1.5px;stroke-linecap:round;stroke-linejoin:round;width:14px;height:14px}.chat-tool-card__action{color:var(--accent);opacity:.8;align-items:center;gap:4px;font-size:12px;transition:opacity .15s ease-out;display:inline-flex}.chat-tool-card__action svg{stroke:currentColor;fill:none;stroke-width:1.5px;stroke-linecap:round;stroke-linejoin:round;width:12px;height:12px}.chat-tool-card--clickable:hover .chat-tool-card__action{opacity:1}.chat-tool-card__status{color:var(--ok);align-items:center;display:inline-flex}.chat-tool-card__status svg{stroke:currentColor;fill:none;stroke-width:2px;stroke-linecap:round;stroke-linejoin:round;width:14px;height:14px}.chat-tool-card__status-text{margin-top:4px;font-size:11px}.chat-tool-card__detail{color:var(--muted);margin-top:4px;font-size:12px}.chat-tool-card__preview{color:var(--muted);background:var(--secondary);border-radius:var(--radius-md);white-space:pre-wrap;border:1px solid var(--border);max-height:44px;margin-top:8px;padding:8px 10px;font-size:11px;line-height:1.4;overflow:hidden}.chat-tool-card--clickable:hover .chat-tool-card__preview{background:var(--bg-hover);border-color:var(--border-strong)}.chat-tool-card__inline{color:var(--text);background:var(--secondary);border-radius:var(--radius-sm);white-space:pre-wrap;word-break:break-word;margin-top:6px;padding:6px 8px;font-size:11px}.chat-tools-summary{cursor:pointer;color:var(--muted);-webkit-user-select:none;user-select:none;align-items:center;gap:6px;padding:8px 12px;font-size:12px;font-weight:500;list-style:none;transition:color .15s,background .15s;display:flex}.chat-tools-summary::-webkit-details-marker{display:none}.chat-tools-summary:before{content:"▸";flex-shrink:0;font-size:10px;transition:transform .15s}.chat-tools-collapse[open]>.chat-tools-summary:before{transform:rotate(90deg)}.chat-tools-summary:hover{color:var(--text);background:color-mix(in srgb, var(--bg-hover) 50%, transparent)}.chat-tools-summary__icon{width:14px;height:14px;color:var(--accent);opacity:.7;flex-shrink:0;align-items:center;display:inline-flex}.chat-tools-summary__icon svg{stroke:currentColor;fill:none;stroke-width:1.5px;stroke-linecap:round;stroke-linejoin:round;width:14px;height:14px}.chat-tools-summary__count{color:var(--text);font-weight:600}.chat-tools-summary__names{color:var(--muted);text-overflow:ellipsis;white-space:nowrap;font-weight:400;overflow:hidden}.chat-tools-collapse__body{border-top:1px solid color-mix(in srgb, var(--border) 60%, transparent);padding:4px 12px 12px}.chat-tools-collapse__body .chat-tool-card:first-child{margin-top:8px}.chat-json-collapse{border:1px solid color-mix(in srgb, var(--border) 80%, transparent);border-radius:var(--radius-md);background:color-mix(in srgb, var(--secondary) 60%, transparent);margin-top:4px;overflow:hidden}.chat-json-summary{cursor:pointer;color:var(--muted);-webkit-user-select:none;user-select:none;align-items:center;gap:6px;padding:6px 10px;font-size:12px;list-style:none;transition:color .15s,background .15s;display:flex}.chat-json-summary::-webkit-details-marker{display:none}.chat-json-summary:before{content:"▸";flex-shrink:0;font-size:10px;transition:transform .15s}.chat-json-collapse[open]>.chat-json-summary:before{transform:rotate(90deg)}.chat-json-summary:hover{color:var(--text);background:color-mix(in srgb, var(--bg-hover) 50%, transparent)}.chat-json-badge{border-radius:var(--radius-sm);background:color-mix(in srgb, var(--accent) 15%, transparent);color:var(--accent);text-transform:uppercase;letter-spacing:.04em;flex-shrink:0;align-items:center;padding:1px 5px;font-size:10px;font-weight:600;line-height:1.4;display:inline-flex}.chat-json-label{font-family:var(--mono);text-overflow:ellipsis;white-space:nowrap;font-size:11px;overflow:hidden}.chat-json-content{border-top:1px solid color-mix(in srgb, var(--border) 60%, transparent);font-family:var(--mono);color:var(--text);max-height:400px;margin:0;padding:10px 12px;font-size:12px;line-height:1.5;overflow:auto}.chat-json-content code{font-family:inherit;font-size:inherit}.chat-tool-msg-collapse{margin-top:2px}.chat-tool-msg-summary{cursor:pointer;color:var(--muted);-webkit-user-select:none;user-select:none;border:1px solid color-mix(in srgb, var(--border) 75%, transparent);border-radius:var(--radius-md);background:color-mix(in srgb, var(--bg-hover) 35%, transparent);align-items:center;gap:6px;padding:6px 10px;font-size:12px;list-style:none;transition:color .15s,background .15s,border-color .15s;display:flex}.chat-tool-msg-summary::-webkit-details-marker{display:none}.chat-tool-msg-summary:before{content:"▸";flex-shrink:0;font-size:10px;transition:transform .15s}.chat-tool-msg-collapse[open]>.chat-tool-msg-summary:before{transform:rotate(90deg)}.chat-tool-msg-summary:hover{color:var(--text);background:color-mix(in srgb, var(--bg-hover) 60%, transparent);border-color:color-mix(in srgb, var(--border-strong) 70%, transparent)}.chat-tool-msg-summary__icon{width:14px;height:14px;color:var(--accent);opacity:.75;flex-shrink:0;justify-content:center;align-items:center;display:inline-flex}.chat-tool-msg-summary__icon svg{stroke:currentColor;fill:none;stroke-width:1.5px;stroke-linecap:round;stroke-linejoin:round;width:14px;height:14px}.chat-tool-msg-summary__label{color:var(--text);flex-shrink:0;font-weight:600}.chat-tool-msg-summary__names,.chat-tool-msg-summary__preview{font-family:var(--mono);opacity:.85;text-overflow:ellipsis;white-space:nowrap;flex:1 1 0;min-width:0;font-size:11px;overflow:hidden}.chat-tool-msg-body{padding-top:8px}.chat-reading-indicator{border:1px solid var(--border);background:0 0;padding:12px;display:inline-flex}.chat-reading-indicator__dots{align-items:center;gap:6px;display:flex}.chat-reading-indicator__dots span{background:var(--muted);border-radius:50%;width:6px;height:6px;animation:1.4s ease-in-out infinite reading-pulse}.chat-reading-indicator__dots span:first-child{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{flex:1;gap:0;height:100%;min-height:0;display:flex}.chat-main{flex-direction:column;min-width:400px;transition:flex .25s ease-out;display:flex;overflow:hidden}.chat-sidebar{border-left:1px solid var(--border);flex-direction:column;flex:1;min-width:300px;animation:.2s ease-out slide-in;display:flex;overflow:hidden}@keyframes slide-in{0%{opacity:0;transform:translate(20px)}to{opacity:1;transform:translate(0)}}.sidebar-panel{background:var(--panel);flex-direction:column;height:100%;display:flex}.sidebar-header{border-bottom:1px solid var(--border);z-index:10;background:var(--panel);flex-shrink:0;justify-content:space-between;align-items:center;padding:12px 16px;display:flex;position:sticky;top:0}.sidebar-header .btn{min-width:auto;padding:4px 8px;font-size:14px;line-height:1}.sidebar-title{font-size:14px;font-weight:600}.sidebar-content{flex:1;padding:16px;overflow:auto}.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 (width<=768px){.chat-split-container--open{z-index:1000;position:fixed;inset:0}.chat-split-container--open .chat-main{display:none}.chat-split-container--open .chat-sidebar{border-left:none;width:100%;min-width:0}}.login-gate{background:var(--bg);justify-content:center;align-items:center;min-height:100dvh;padding:24px;display:flex}.login-gate__theme{z-index:10;position:fixed;top:16px;right:16px}.login-gate__card{background:var(--card);border:1px solid var(--border);border-radius:var(--radius-lg);width:min(520px,100%);animation:scale-in .25s var(--ease-out);padding:32px}.login-gate__header{text-align:center;margin-bottom:24px}.login-gate__logo{width:48px;height:48px;margin-bottom:12px}.login-gate__title{letter-spacing:-.02em;font-size:22px;font-weight:700}.login-gate__sub{color:var(--muted);margin-top:4px;font-size:14px}.login-gate__form{flex-direction:column;gap:12px;display:flex}.login-gate__secret-row{align-items:center;gap:8px;display:flex}.login-gate__secret-row input{flex:1}.login-gate__secret-row .btn--icon{width:40px;min-width:40px;height:40px}.login-gate__connect{justify-content:center;width:100%;margin-top:4px;padding:10px 16px;font-size:15px;font-weight:600}.login-gate__help{border-top:1px solid var(--border);margin-top:20px;padding-top:16px}.login-gate__help-title{color:var(--fg);margin-bottom:10px;font-size:12px;font-weight:600}.login-gate__steps{color:var(--muted);margin:0;padding-left:20px;font-size:12px;line-height:1.6}.login-gate__steps li{margin-bottom:6px}.login-gate__steps li:last-child{margin-bottom:0}.login-gate__steps code{font-family:var(--font-mono);background:var(--bg);border:1px solid var(--border);border-radius:var(--radius);color:var(--fg);-webkit-user-select:all;user-select:all;margin:4px 0 2px;padding:5px 10px;font-size:11px;display:block}.login-gate__docs{margin-top:10px;font-size:11px}.update-banner{z-index:10;margin:0 calc(-1 * var(--shell-pad)) 0;text-align:center;border-left:none;border-right:none;border-radius:0;padding:10px 16px;font-weight:500;position:sticky;top:0}.update-banner__btn{border-color:var(--danger);color:var(--danger);margin-left:8px;padding:4px 12px;font-size:12px}.update-banner__btn:hover:not(:disabled){background:#ef444426}.update-banner__close{cursor:pointer;color:var(--danger);opacity:.7;background:0 0;border:none;justify-content:center;align-items:center;margin-left:8px;padding:2px;transition:opacity .15s;display:inline-flex}.update-banner__close:hover{opacity:1}.update-banner__close svg{fill:none;stroke:currentColor;stroke-width:2px;stroke-linecap:round;width:16px;height:16px}.card{border:1px solid var(--border);background:var(--card);border-radius:var(--radius-lg);animation:rise .25s var(--ease-out) backwards;transition:border-color var(--duration-normal) var(--ease-out), box-shadow var(--duration-normal) var(--ease-out);padding:18px}.card:hover{border-color:var(--border-strong);box-shadow:var(--shadow-sm)}.card-title{letter-spacing:-.02em;color:var(--text-strong);font-size:15px;font-weight:600}.card-sub{color:var(--muted);margin-top:6px;font-size:13px;line-height:1.5}.stat{background:var(--card);border-radius:var(--radius-md);border:1px solid var(--border);transition:border-color var(--duration-normal) var(--ease-out), box-shadow var(--duration-normal) var(--ease-out);padding:14px 16px}.stat:hover{border-color:var(--border-strong)}.stat-label{color:var(--muted);text-transform:uppercase;letter-spacing:.04em;font-size:11px;font-weight:500}.stat-value{letter-spacing:-.03em;margin-top:6px;font-size:24px;font-weight:700;line-height:1.1}.stat-value.ok{color:var(--ok)}.stat-value.warn{color:var(--warn)}.stat-card{gap:6px;display:grid}.note-title{letter-spacing:-.01em;font-weight:600}.status-list{gap:8px;display:grid}.status-list div{border-bottom:1px solid var(--border);justify-content:space-between;gap:12px;padding:8px 0;display:flex}.status-list div:last-child{border-bottom:none}.account-count{color:var(--muted);margin-top:10px;font-size:12px;font-weight:500}.account-card-list{gap:12px;margin-top:16px;display:grid}.account-card{border:1px solid var(--border);border-radius:var(--radius-md);background:var(--bg-elevated);transition:border-color var(--duration-fast) ease;padding:12px}.account-card:hover{border-color:var(--border-strong)}.account-card-header{justify-content:space-between;align-items:baseline;gap:12px;display:flex}.account-card-title{font-weight:500}.account-card-id{font-family:var(--mono);color:var(--muted);font-size:12px}.account-card-status{margin-top:10px;font-size:13px}.account-card-status div{padding:4px 0}.account-card-error{color:var(--danger);margin-top:8px;font-size:12px}.label{color:var(--muted);font-size:12px;font-weight:500}.pill{border:1px solid var(--border);border-radius:var(--radius-full);background:var(--secondary);transition:border-color var(--duration-fast) ease;align-items:center;gap:5px;padding:5px 11px;font-size:12px;font-weight:500;display:inline-flex}.pill:hover{border-color:var(--border-strong)}.pill.danger{border-color:var(--danger-subtle);background:var(--danger-subtle);color:var(--danger)}.theme-orb{align-items:center;display:inline-flex;position:relative}.theme-orb__trigger{border-radius:var(--radius-full);border:1px solid var(--border);background:var(--card);cursor:pointer;width:28px;height:28px;transition:border-color var(--duration-fast) var(--ease-out), box-shadow var(--duration-fast) var(--ease-out), transform var(--duration-fast) var(--ease-out);justify-content:center;align-items:center;padding:0;font-size:14px;line-height:1;display:flex}.theme-orb__trigger:hover{border-color:var(--border-strong);transform:scale(1.08)}.theme-orb__trigger:focus-visible{border-color:var(--ring);box-shadow:var(--focus-ring);outline:none}.theme-orb__menu{border-radius:var(--radius-full);background:var(--card);border:1px solid var(--border);box-shadow:var(--shadow-md);opacity:0;visibility:hidden;transform-origin:100% 0;pointer-events:none;transition:opacity var(--duration-normal) var(--ease-out), transform var(--duration-normal) var(--ease-out);gap:2px;padding:4px;display:flex;position:absolute;top:calc(100% + 6px);right:0;transform:scale(.4)translateY(-8px)}.theme-orb--open .theme-orb__menu{opacity:1;visibility:visible;pointer-events:auto;transform:scale(1)translateY(0)}.theme-orb__option{border-radius:var(--radius-full);cursor:pointer;width:28px;height:28px;transition:background var(--duration-fast) var(--ease-out), border-color var(--duration-fast) var(--ease-out), transform var(--duration-fast) var(--ease-out);background:0 0;border:1.5px solid #0000;justify-content:center;align-items:center;padding:0;font-size:14px;line-height:1;display:flex}.theme-orb__option:hover{background:var(--bg-hover);transform:scale(1.12)}.theme-orb__option--active{border-color:var(--accent);background:var(--accent-subtle)}.theme-orb__option:focus-visible{box-shadow:var(--focus-ring);outline:none}.theme-icon{stroke:currentColor;fill:none;stroke-width:1.5px;stroke-linecap:round;stroke-linejoin:round;width:14px;height:14px}.statusDot{border-radius:var(--radius-full);background:var(--danger);width:8px;height:8px;animation:2s ease-in-out infinite pulse-subtle;box-shadow:0 0 8px #ef444480}.statusDot.ok{background:var(--ok);animation:none;box-shadow:0 0 8px #22c55e80}.statusDot.warn{background:var(--warn);animation:none;box-shadow:0 0 8px #f59e0b80}.btn{border:1px solid var(--border);background:var(--bg-elevated);border-radius:var(--radius-md);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);justify-content:center;align-items:center;gap:6px;padding:8px 14px;font-size:13px;font-weight:500;display:inline-flex}.btn:hover{background:var(--bg-hover);border-color:var(--border-strong)}.btn:active{background:var(--secondary)}.btn svg{stroke:currentColor;fill:none;stroke-width:1.5px;stroke-linecap:round;stroke-linejoin:round;flex-shrink:0;width:16px;height:16px}.btn.primary{border-color:var(--accent);background:var(--accent);color:var(--primary-foreground);box-shadow:0 1px 3px #ff5c5c40}.btn.primary:hover{background:var(--accent-hover);border-color:var(--accent-hover);box-shadow:0 2px 12px #ff5c5c4d}.btn-kbd{font-family:var(--mono);color:inherit;opacity:.8;background:#ffffff26;border-radius:4px;justify-content:center;align-items:center;margin-left:6px;padding:2px 5px;font-size:11px;font-weight:500;line-height:1;display:inline-flex}.btn.primary .btn-kbd{background:#fff3}:root[data-theme-mode=light] .btn-kbd{background:#00000014}:root[data-theme-mode=light] .btn.primary .btn-kbd{background:#ffffff40}.btn.active{border-color:var(--accent);background:var(--accent-subtle);color:var(--accent)}.btn.danger{background:var(--danger-subtle);color:var(--danger);border-color:#0000}.btn.danger:hover{background:#ef444426}.btn--sm{padding:6px 10px;font-size:12px}.btn:disabled{opacity:.5;cursor:not-allowed}.field{gap:6px;display:grid}.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);box-shadow:inset 0 1px 0 var(--card-highlight);transition:border-color var(--duration-fast) ease, box-shadow var(--duration-fast) ease;outline:none;padding:8px 12px}.field input:focus,.field textarea:focus,.field select:focus{border-color:var(--ring);box-shadow:var(--focus-ring)}.field select{appearance:none;cursor:pointer;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-position:right 10px center;background-repeat:no-repeat;padding-right:36px}.field textarea{font-family:var(--mono);resize:vertical;white-space:pre;min-height:160px;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]{width:16px;height:16px;accent-color:var(--accent);margin:0}.form-grid{grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:12px;display:grid}.cron-summary-strip{justify-content:space-between;align-items:flex-start;gap:12px 18px;padding:14px 16px;display:flex}.cron-summary-strip__left{flex:auto;grid-template-columns:repeat(3,minmax(0,1fr));gap:8px 14px;min-width:0;display:grid}.cron-summary-item{border:1px solid var(--border);border-radius:var(--radius-md);background:var(--bg-elevated);gap:6px;min-height:62px;padding:10px 12px;display:grid}.cron-summary-item--wide{grid-column:span 1}.cron-summary-label{color:var(--muted);text-transform:uppercase;letter-spacing:.04em;font-size:11px;font-weight:600}.cron-summary-value{color:var(--text-strong);align-items:center;gap:8px;font-size:15px;font-weight:600;line-height:1.3;display:flex}.cron-summary-strip__actions{justify-content:flex-end;align-items:center;gap:10px;min-width:0;display:flex}.cron-workspace{grid-template-columns:minmax(0,1.2fr) minmax(340px,.8fr);align-items:start;gap:16px;margin-top:16px;display:grid}.cron-workspace-main{gap:16px;display:grid}.cron-workspace-form{max-height:calc(100vh - 106px);position:sticky;top:74px;overflow-y:auto}.cron-form{gap:14px;margin-top:16px;display:grid}.cron-form-section{border:1px solid var(--border);border-radius:var(--radius-md);background:var(--bg-elevated);gap:12px;padding:14px;display:grid}.cron-form-section__title{letter-spacing:-.01em;color:var(--text-strong);font-size:13px;font-weight:600}.cron-form-section__sub{color:var(--muted);font-size:12px;line-height:1.45}.cron-form-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:14px 16px}.cron-help{color:var(--muted);margin-top:2px;font-size:12px;line-height:1.45}.cron-error{color:var(--danger-color)}.cron-required-legend{color:var(--muted);font-size:12px;line-height:1.4}.cron-required-marker{color:var(--danger-color);margin-left:3px;font-weight:700}.cron-required-sr{clip:rect(0, 0, 0, 0);white-space:nowrap;border:0;width:1px;height:1px;margin:-1px;padding:0;position:absolute;overflow:hidden}.field input[aria-invalid=true],.field textarea[aria-invalid=true],.field select[aria-invalid=true]{border-color:var(--danger);box-shadow:inset 0 1px 0 var(--card-highlight), 0 0 0 1px #ef444433}.cron-form-status{border:1px solid var(--danger-subtle);background:var(--danger-subtle);border-radius:var(--radius-md);margin-top:4px;padding:10px 12px}.cron-form-status__title{color:var(--text-strong);margin-bottom:6px;font-size:13px;font-weight:600}.cron-form-status__list{gap:6px;margin:8px 0 0;padding:0;list-style:none;display:grid}.cron-form-status__link{color:var(--text);cursor:pointer;text-align:left;text-underline-offset:2px;background:0 0;border:0;padding:0;font-size:12px;line-height:1.4;text-decoration:underline}.cron-form-status__link:hover{color:var(--text-strong)}.cron-span-2{grid-column:1/-1}.cron-checkbox{grid-template-columns:16px minmax(0,1fr);align-items:center;column-gap:10px}.cron-checkbox input[type=checkbox]{width:16px;height:16px;accent-color:var(--accent);margin:2px 0 0}.cron-checkbox .field-checkbox__label{color:var(--text-strong);font-size:13px;font-weight:500}.cron-checkbox .cron-help{grid-column:2}.cron-checkbox-inline{align-content:start;align-items:start;padding-top:28px}.cron-advanced{border:1px solid var(--border);border-radius:var(--radius-md);background:var(--bg-elevated);gap:10px;padding:12px;display:grid}.cron-advanced__summary{cursor:pointer;color:var(--muted);font-size:13px;font-weight:500}.cron-stagger-group{grid-template-columns:minmax(0,1fr) 180px;align-items:start;gap:14px 16px;display:grid}.cron-form-actions{flex-wrap:wrap;justify-content:flex-start;align-items:center;gap:10px 14px;margin-top:14px}.cron-submit-reason{color:var(--muted);font-size:12px;line-height:1.4}.cron-filter-search{flex:320px;min-width:280px}.cron-workspace .filters .field{min-width:160px}.cron-run-filters{gap:12px;margin-top:12px;display:grid}.cron-run-filters__row{gap:12px;display:grid}.cron-run-filters__row--primary{grid-template-columns:minmax(160px,220px) minmax(240px,1fr) minmax(160px,220px)}.cron-run-filters__row--secondary{grid-template-columns:repeat(2,minmax(220px,1fr))}.cron-run-filter-search,.cron-filter-dropdown{min-width:0}.cron-filter-dropdown__details{position:relative}.cron-filter-dropdown__details>summary{list-style:none}.cron-filter-dropdown__details>summary::-webkit-details-marker{display:none}.cron-filter-dropdown__trigger{text-align:left;justify-content:space-between;width:100%}.cron-filter-dropdown__panel{z-index:30;border:1px solid var(--border);border-radius:var(--radius-md);background:var(--bg-elevated);width:min(360px,100vw - 48px);box-shadow:var(--shadow-card);gap:10px;padding:10px;display:grid;position:absolute;top:calc(100% + 8px);left:0}.cron-filter-dropdown__list{gap:6px;display:grid}.cron-filter-dropdown__option{color:var(--text);grid-template-columns:16px minmax(0,1fr);align-items:center;gap:8px;font-size:13px;display:grid}.cron-filter-dropdown__option input[type=checkbox]{width:16px;height:16px;accent-color:var(--accent);margin:0}.cron-run-entry{align-items:start}.cron-run-entry__meta{text-align:right;min-width:220px}.cron-run-entry__summary{white-space:pre-wrap;line-height:1.45}@media (width<=1100px){.cron-summary-strip{flex-direction:column}.cron-summary-strip__left{grid-template-columns:repeat(2,minmax(0,1fr));width:100%}.cron-summary-strip__actions{flex-wrap:wrap;justify-content:flex-start;width:100%}.cron-workspace{grid-template-columns:1fr}.cron-workspace-form{order:-1;position:static}.cron-form-grid{grid-template-columns:1fr;gap:12px}.cron-span-2{grid-column:auto}.cron-checkbox-inline{padding-top:0}.cron-stagger-group{grid-template-columns:1fr;gap:12px}.cron-filter-search{flex:100%;min-width:0}.cron-run-filters__row--primary,.cron-run-filters__row--secondary{grid-template-columns:1fr}.cron-filter-dropdown__panel{width:100%;max-width:none;margin-top:8px;position:static}.cron-run-entry__meta{text-align:left;min-width:0}}:root[data-theme-mode=light] .field input,:root[data-theme-mode=light] .field textarea,:root[data-theme-mode=light] .field select{background:var(--card);border-color:var(--input)}:root[data-theme-mode=light] .btn{background:var(--bg);border-color:var(--input)}:root[data-theme-mode=light] .btn:hover{background:var(--bg-hover)}:root[data-theme-mode=light] .btn.active{border-color:var(--accent);background:var(--accent-subtle);color:var(--accent)}:root[data-theme-mode=light] .btn.primary{background:var(--accent);border-color:var(--accent)}.muted{color:var(--muted)}.mono{font-family:var(--mono)}.callout{border-radius:var(--radius-md);background:var(--secondary);border:1px solid var(--border);padding:14px 16px;font-size:13px;line-height:1.5;position:relative}.callout.danger{color:var(--danger);background:linear-gradient(135deg,#ef444414 0%,#ef44440a 100%);border-color:#ef444440}.callout.info{color:var(--info);background:linear-gradient(135deg,#3b82f614 0%,#3b82f60a 100%);border-color:#3b82f640}.callout.success{color:var(--ok);background:linear-gradient(135deg,#22c55e14 0%,#22c55e0a 100%);border-color:#22c55e40}.compaction-indicator{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);border-radius:999px;align-self:center;align-items:center;gap:6px;margin-bottom:8px;padding:6px 14px;font-size:13px;line-height:1.2;display:inline-flex}.compaction-indicator svg{stroke:currentColor;fill:none;stroke-width:1.5px;stroke-linecap:round;stroke-linejoin:round;flex-shrink:0;width:16px;height:16px}.compaction-indicator--active{color:var(--info);border-color:#3b82f659}.compaction-indicator--active svg{animation:1s linear infinite compaction-spin}.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);background:var(--secondary);border-radius:var(--radius-md);border:1px solid var(--border);max-width:100%;max-height:360px;padding:12px;font-size:13px;line-height:1.5;overflow:auto}:root[data-theme-mode=light] .code-block,:root[data-theme-mode=light] .list-item,:root[data-theme-mode=light] .table-row,:root[data-theme-mode=light] .chip{background:var(--bg)}.list{gap:8px;display:grid;container-type:inline-size}.list-item{border:1px solid var(--border);border-radius:var(--radius-md);background:var(--card);transition:border-color var(--duration-fast) ease;grid-template-columns:minmax(0,1fr) minmax(200px,260px);align-items:start;gap:16px;padding:12px;display:grid}.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{gap:4px;min-width:0;display:grid}.list-title{font-weight:500}.list-sub{color:var(--muted);font-size:12px}.list-meta{text-align:right;color:var(--muted);gap:4px;min-width:200px;font-size:12px;display:grid}.list-meta .btn{padding:6px 10px}.list-meta .field input,.list-meta .field textarea,.list-meta .field select{width:100%}.debug-event-log__item{grid-template-columns:minmax(0,1fr)}.debug-event-log__meta{text-align:left;min-width:0}.debug-event-log__payload{max-width:100%;margin:0}.cron-job-payload,.cron-job-agent,.cron-job-state{overflow-wrap:anywhere;word-break:break-word}.cron-job .list-title{letter-spacing:-.015em;font-size:15px;font-weight:600}.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;gap:8px;min-width:240px}.cron-job-footer{border-top:1px solid var(--border);grid-area:footer;justify-content:space-between;align-items:center;gap:12px;padding-top:10px;display:flex}.cron-job-chips{flex:auto}.cron-job-detail{gap:3px;margin-top:2px;display:grid}.cron-job-detail-label{color:var(--muted);letter-spacing:.03em;text-transform:uppercase;font-size:11px;font-weight:600}.cron-job-detail-value{font-size:13px;line-height:1.35}.cron-job-state{gap:4px;display:grid}.cron-job-state-row{justify-content:space-between;align-items:baseline;gap:10px;display:flex}.cron-job-state-key{color:var(--muted);letter-spacing:.05em;text-transform:uppercase;font-size:10px;font-weight:600}.cron-job-state-value{color:var(--text);white-space:nowrap;font-size:12px}.cron-job-status-pill{border:1px solid var(--border);border-radius:var(--radius-full);text-transform:lowercase;padding:2px 8px;font-size:11px;font-weight:600}.cron-job-status-ok{color:var(--ok);background:var(--ok-subtle);border-color:#22c55e59}.cron-job-status-error{color:var(--danger);background:var(--danger-subtle);border-color:#ef444459}.cron-job-status-skipped{color:var(--warn);background:var(--warn-subtle);border-color:#f59e0b59}.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:none}@container (width<=560px){.list-item{grid-template-columns:1fr}.list-meta{text-align:left;min-width:0}.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{flex-wrap:wrap;gap:8px;display:flex}.chip{border:1px solid var(--border);border-radius:var(--radius-full);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);padding:5px 12px;font-size:12px;font-weight:500}.chip:hover{border-color:var(--border-strong);transform:translateY(-1px)}.chip input{margin-right:6px}.chip-ok{color:var(--ok);background:var(--ok-subtle);border-color:#22c55e4d}.chip-warn{color:var(--warn);background:var(--warn-subtle);border-color:#f59e0b4d}.chip-danger{color:var(--danger);background:var(--danger-subtle);border-color:#ef44444d}.table{gap:6px;display:grid;container-type:inline-size}.table-head,.table-row{grid-template-columns:1.4fr 1fr .8fr .7fr .8fr .8fr .8fr .8fr .6fr;align-items:center;gap:12px;display:grid}.table-head{color:var(--muted);padding:0 12px;font-size:12px;font-weight:500}.table-row{border:1px solid var(--border);border-radius:var(--radius-md);background:var(--card);transition:border-color var(--duration-fast) ease;padding:10px 12px}.table-row:hover{border-color:var(--border-strong)}@media (width<=1100px){.table-head,.table-row{grid-template-columns:1fr}}@container (width<=1100px){.table-head,.table-row{grid-template-columns:1fr}}.session-link{color:var(--accent);font-weight:500;text-decoration:none}.session-link:hover{text-decoration:underline}.session-key-cell{gap:4px;min-width:0;display:grid}.session-key-cell .session-link,.session-key-display-name{overflow-wrap:anywhere;word-break:break-word}.session-key-display-name{font-size:11px}.data-table-wrapper{border:1px solid var(--border);border-radius:var(--radius-md);overflow:hidden}.data-table-toolbar{border-bottom:1px solid var(--border);background:var(--bg-elevated);align-items:center;gap:8px;padding:10px 12px;display:flex}.data-table-search{flex:1;min-width:0}.data-table-search input{width:100%;color:var(--text);background:var(--card);border:1px solid var(--border);border-radius:var(--radius-sm);transition:border-color var(--duration-fast) ease;outline:none;padding:6px 10px;font-size:13px}.data-table-search input:focus{border-color:var(--border-strong);box-shadow:var(--focus-ring)}.data-table-search input::placeholder{color:var(--muted)}.data-table-container{overflow-x:auto}.data-table{border-collapse:collapse;width:100%;font-size:13px}.data-table thead{z-index:1;position:sticky;top:0}.data-table th{text-align:left;color:var(--muted);background:var(--bg-elevated);border-bottom:1px solid var(--border);white-space:nowrap;-webkit-user-select:none;user-select:none;text-transform:uppercase;letter-spacing:.04em;padding:10px 12px;font-size:12px;font-weight:600}.data-table th[data-sortable]{cursor:pointer;transition:color var(--duration-fast) ease}.data-table th[data-sortable]:hover{color:var(--text)}.data-table-sort-icon{vertical-align:middle;opacity:.4;transition:opacity var(--duration-fast) ease;margin-left:4px;display:inline-flex}.data-table-sort-icon svg{stroke:currentColor;fill:none;stroke-width:1.5px;width:14px;height:14px}.data-table th[data-sortable]:hover .data-table-sort-icon{opacity:.7}.data-table th[data-sort-dir=asc] .data-table-sort-icon,.data-table th[data-sort-dir=desc] .data-table-sort-icon{opacity:1;color:var(--text)}.data-table th[data-sort-dir=desc] .data-table-sort-icon svg{transform:rotate(180deg)}.data-table td{border-bottom:1px solid var(--border);color:var(--text);vertical-align:middle;padding:10px 12px}.data-table tbody tr{transition:background var(--duration-fast) ease}.data-table tbody tr:hover{background:var(--bg-hover)}.data-table tbody tr:last-child td{border-bottom:none}.data-table-badge{border-radius:var(--radius-full);letter-spacing:.02em;padding:2px 8px;font-size:11px;font-weight:600;display:inline-block}.data-table-badge--direct{color:var(--accent-2);background:var(--accent-2-subtle)}.data-table-badge--group{color:var(--info);background:#3b82f61a}.data-table-badge--global{color:var(--warn);background:var(--warn-subtle)}.data-table-badge--unknown{color:var(--muted);background:var(--bg-hover)}.data-table-pagination{border-top:1px solid var(--border);background:var(--bg-elevated);color:var(--muted);justify-content:space-between;align-items:center;gap:12px;padding:10px 12px;font-size:13px;display:flex}.data-table-pagination__controls{align-items:center;gap:8px;display:flex}.data-table-pagination__controls button{border:1px solid var(--border);border-radius:var(--radius-sm);background:var(--card);color:var(--text);cursor:pointer;transition:background var(--duration-fast) ease, border-color var(--duration-fast) ease;padding:4px 12px;font-size:13px}.data-table-pagination__controls button:hover:not(:disabled){background:var(--bg-hover);border-color:var(--border-strong)}.data-table-pagination__controls button:disabled{opacity:.4;cursor:not-allowed}.data-table-row-actions{position:relative}.data-table-row-actions__trigger{border-radius:var(--radius-sm);width:32px;height:32px;color:var(--muted);cursor:pointer;transition:background var(--duration-fast) ease, color var(--duration-fast) ease, border-color var(--duration-fast) ease;background:0 0;border:1px solid #0000;justify-content:center;align-items:center;display:inline-flex}.data-table-row-actions__trigger svg{stroke:currentColor;fill:none;stroke-width:2px;width:16px;height:16px}.data-table-row-actions__trigger:hover{background:var(--bg-hover);color:var(--text);border-color:var(--border)}.data-table-row-actions__menu{z-index:42;background:var(--popover);border:1px solid var(--border-strong);border-radius:var(--radius-md);min-width:140px;box-shadow:var(--shadow-md);animation:fade-in var(--duration-fast) ease;padding:4px;position:absolute;top:100%;right:0}.data-table-row-actions__menu a,.data-table-row-actions__menu button{text-align:left;width:100%;color:var(--text);border-radius:var(--radius-sm);cursor:pointer;transition:background var(--duration-fast) ease;background:0 0;border:none;padding:8px 12px;font-size:13px;text-decoration:none;display:block}.data-table-row-actions__menu a:hover,.data-table-row-actions__menu button:hover{background:var(--bg-hover)}.data-table-row-actions__menu button.danger{color:var(--danger)}.data-table-row-actions__menu button.danger:hover{background:var(--danger-subtle)}.data-table-overlay{z-index:40;background:0 0;position:fixed;inset:0}.field-inline{color:var(--text);align-items:center;gap:6px;font-size:13px;display:inline-flex}.field-inline span{color:var(--muted);white-space:nowrap;font-weight:500}.field-inline input[type=text],.field-inline input:not([type]){color:var(--text);background:var(--card);border:1px solid var(--border);border-radius:var(--radius-sm);transition:border-color var(--duration-fast) ease;outline:none;padding:6px 10px;font-size:13px}.field-inline input:focus{border-color:var(--border-strong);box-shadow:var(--focus-ring)}.field-inline.checkbox{cursor:pointer;gap:4px}.field-inline.checkbox input[type=checkbox]{accent-color:var(--accent)}.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{border-bottom:1px solid var(--border);transition:background var(--duration-fast) ease;grid-template-columns:90px 70px minmax(140px,200px) minmax(0,1fr);align-items:start;gap:12px;padding:8px 12px;font-size:12px;display:grid}.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{border:1px solid var(--border);border-radius:var(--radius-sm);width:fit-content;padding:2px 6px;font-size:11px;font-weight:500}.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 (width<=620px){.log-row{grid-template-columns:70px 60px minmax(0,1fr)}.log-subsystem{display:none}}.chat{flex-direction:column;min-height:0;display:flex}.shell--chat .chat{flex:1}.chat-header{flex-wrap:wrap;justify-content:space-between;align-items:flex-end;gap:16px;display:flex}.chat-header__left{flex-wrap:wrap;align-items:flex-end;gap:12px;min-width:0;display:flex}.chat-header__right{align-items:center;gap:8px;display:flex}.chat-session{min-width:240px}.chat-thread{background:0 0;border:none;border-radius:0;flex-direction:column;flex:1;gap:12px;min-width:0;min-height:0;margin-top:16px;padding:16px 12px;display:flex;overflow:hidden auto}.chat-queue{border-radius:var(--radius-lg);border:1px solid var(--border);background:var(--card);gap:8px;margin-top:12px;padding:12px;display:grid}.chat-queue__title{font-family:var(--mono);color:var(--muted);font-size:12px;font-weight:500}.chat-queue__list{gap:8px;display:grid}.chat-queue__item{border-radius:var(--radius-md);border:1px dashed var(--border-strong);background:var(--secondary);grid-template-columns:minmax(0,1fr) auto;align-items:start;gap:12px;padding:10px 12px;display:grid}.chat-queue__text{color:var(--chat-text);white-space:pre-wrap;line-clamp:3;-webkit-line-clamp:3;-webkit-box-orient:vertical;font-size:13px;line-height:1.45;display:-webkit-box;overflow:hidden}.chat-queue__remove{align-self:start;padding:4px 10px;font-size:12px;line-height:1}.chat-new-messages{border-radius:999px;align-self:center;margin:8px auto 0;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{gap:6px;max-width:min(700px,82%);display:grid}.chat-line.user .chat-msg{justify-items:end}.chat-bubble{background:var(--card);border-radius:var(--radius-lg);border:1px solid #0000;min-width:0;padding:10px 14px}:root[data-theme-mode=light] .chat-bubble{border-color:var(--border);background:var(--bg)}.chat-line.user .chat-bubble{background:var(--accent-subtle);border-color:#0000}:root[data-theme-mode=light] .chat-line.user .chat-bubble{background:#fb923c1f;border-color:#ea580c33}.chat-line.assistant .chat-bubble{background:var(--secondary);border-color:#0000}:root[data-theme-mode=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:1.5s ease-in-out infinite chatStreamPulse}@media (prefers-reduced-motion:reduce){.chat-bubble.streaming{border-color:var(--accent);animation:none}}.chat-bubble.chat-reading-indicator{width:fit-content;padding:10px 16px}.chat-reading-indicator__dots{align-items:center;gap:4px;height:12px;display:inline-flex}.chat-reading-indicator__dots>span{border-radius:var(--radius-full);background:var(--muted);opacity:.6;will-change:transform, opacity;width:6px;height:6px;animation:1.2s ease-in-out infinite chatReadingDot;display:inline-block;transform:translateY(0)}.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{opacity:.6;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);color:var(--muted);padding-left:12px}.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){border-radius:var(--radius-sm);border:1px solid var(--border);background:var(--secondary);padding:.15em .35em}:root[data-theme-mode=light] .chat-text :where(:not(pre)>code){background:var(--bg-muted)}.chat-text :where(pre){border-radius:var(--radius-md);border:1px solid var(--border);background:var(--secondary);margin-top:.75em;padding:10px 12px;overflow:auto}:root[data-theme-mode=light] .chat-text :where(pre){background:var(--bg-muted)}.chat-text :where(pre code){white-space:pre;font-size:12px}.chat-text :where(table){border-collapse:collapse;width:100%;max-width:100%;margin-top:.75em;font-size:13px;display:block;overflow-x:auto}.chat-text :where(th,td){border:1px solid var(--border);vertical-align:top;padding:6px 10px}.chat-text :where(th){font-family:var(--mono);color:var(--muted);background:var(--secondary);font-weight:500}.chat-tool-card{border-radius:var(--radius-md);border:1px solid var(--border);background:var(--secondary);gap:4px;margin-top:8px;padding:10px 12px;display:grid}:root[data-theme-mode=light] .chat-tool-card{background:var(--bg-muted)}.chat-tool-card__title{font-family:var(--mono);color:var(--text);font-size:12px;font-weight:500}.chat-tool-card__detail{font-family:var(--mono);color:var(--muted);font-size:11px}.chat-tool-card__details{margin-top:6px}.chat-tool-card__summary{font-family:var(--mono);color:var(--muted);cursor:pointer;align-items:center;gap:6px;font-size:11px;list-style:none;display:inline-flex}.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{font-family:var(--mono);white-space:pre-wrap;color:var(--chat-text);border-radius:var(--radius-md);border:1px solid var(--border);background:var(--card);margin-top:8px;padding:8px 10px;font-size:11px;line-height:1.5}:root[data-theme-mode=light] .chat-tool-card__output{background:var(--bg)}.chat-stamp{color:var(--muted);font-size:11px}.chat-line.user .chat-stamp{text-align:right}.chat-compose{flex-direction:column;gap:10px;margin-top:12px;display:flex}.shell--chat .chat-compose{z-index:5;background:linear-gradient(180deg, transparent 0%, var(--bg) 40%);margin-top:0;padding-top:12px;position:sticky;bottom:0}.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{border-radius:var(--radius-lg);resize:vertical;white-space:pre-wrap;min-height:72px;font-family:var(--font-body);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;padding:10px 14px;line-height:1.5}.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 (width<=900px){.chat-session{min-width:180px}.chat-compose{grid-template-columns:1fr}}.qr-wrap{border-radius:var(--radius-md);background:var(--card);border:1px dashed var(--border-strong);margin-top:16px;padding:16px;display:inline-flex}.qr-wrap img{border-radius:var(--radius-sm);width:160px;height:160px;image-rendering:pixelated}.exec-approval-overlay{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:200;background:#000c;justify-content:center;align-items:center;padding:24px;display:flex;position:fixed;inset:0}.exec-approval-card{background:var(--card);border:1px solid var(--border);border-radius:var(--radius-lg);width:min(540px,100%);animation:scale-in .2s var(--ease-out);padding:20px}.exec-approval-header{justify-content:space-between;align-items:center;gap:16px;display:flex}.exec-approval-title{font-size:14px;font-weight:600}.exec-approval-sub{color:var(--muted);margin-top:4px;font-size:13px}.exec-approval-queue{color:var(--muted);border:1px solid var(--border);border-radius:var(--radius-full);padding:4px 10px;font-size:11px;font-weight:500}.exec-approval-command{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);margin-top:12px;padding:10px 12px;font-size:13px}.exec-approval-meta{color:var(--muted);gap:6px;margin-top:12px;font-size:13px;display:grid}.exec-approval-meta-row{justify-content:space-between;gap:12px;display:flex}.exec-approval-meta-row span:last-child{color:var(--text);font-family:var(--mono)}.exec-approval-error{color:var(--danger);margin-top:10px;font-size:13px}.exec-approval-actions{flex-wrap:wrap;gap:8px;margin-top:16px;display:flex}.agents-layout{grid-template-columns:1fr;gap:14px;display:grid}.agents-sidebar{align-self:start;gap:12px;display:grid}.agents-toolbar{flex-wrap:wrap;align-items:center;gap:12px;display:flex}.agents-toolbar-row{flex:1;align-items:center;gap:10px;min-width:0;display:flex}.agents-toolbar-label{color:var(--muted);text-transform:uppercase;letter-spacing:.04em;flex-shrink:0;font-size:12px;font-weight:600}.agents-control-row{flex:1;align-items:center;gap:8px;min-width:0;display:flex}.agents-control-select{flex:1;min-width:0;max-width:280px}.agents-select{border:1px solid var(--border-strong);border-radius:var(--radius-md);background-color:var(--bg-accent);cursor:pointer;appearance:none;width:100%;transition:border-color var(--duration-fast) ease, box-shadow var(--duration-fast) ease;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='14' height='14' 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-position:right 8px center;background-repeat:no-repeat;outline:none;padding:7px 32px 7px 10px;font-size:13px;font-weight:500}:root[data-theme-mode=light] .agents-select{background-color:#fff}.agents-select:focus{border-color:var(--accent);box-shadow:var(--focus-ring)}.agents-control-actions{flex-shrink:0;align-items:center;gap:6px;display:flex}.agents-refresh-btn{white-space:nowrap}.agent-actions-wrap{position:relative}.agent-actions-toggle{border:1px solid var(--border);border-radius:var(--radius-sm);background:var(--bg-elevated);width:28px;height:28px;color:var(--muted);cursor:pointer;transition:background var(--duration-fast) ease, border-color var(--duration-fast) ease;justify-content:center;align-items:center;font-size:14px;display:flex}.agent-actions-toggle:hover{background:var(--bg-hover);border-color:var(--border-strong)}.agent-actions-menu{z-index:10;border:1px solid var(--border);border-radius:var(--radius-md);background:var(--bg-elevated);min-width:160px;box-shadow:var(--shadow-md);gap:1px;padding:4px;display:grid;position:absolute;top:calc(100% + 4px);right:0}.agent-actions-menu button{border-radius:var(--radius-sm);width:100%;color:var(--text);text-align:left;cursor:pointer;transition:background var(--duration-fast) ease;background:0 0;border:none;padding:7px 10px;font-size:12px;display:block}.agent-actions-menu button:hover:not(:disabled){background:var(--bg-hover)}.agent-actions-menu button:disabled{color:var(--muted);cursor:not-allowed;opacity:.5}.agents-main{gap:14px;display:grid}.agent-list{gap:8px;display:grid}.agent-row{text-align:left;border:1px solid var(--border);border-radius:var(--radius-md);background:var(--card);cursor:pointer;width:100%;transition:border-color var(--duration-fast) ease;grid-template-columns:auto minmax(0,1fr) auto;align-items:center;gap:10px;padding:8px 12px;display:grid}.agent-row:hover{border-color:var(--border-strong)}.agent-row.active{border-color:var(--accent);box-shadow:var(--focus-ring)}.agent-avatar{background:var(--secondary);border-radius:50%;place-items:center;width:32px;height:32px;font-weight:600;display:grid}.agent-avatar--lg{width:48px;height:48px;font-size:20px}.agent-info{gap:2px;min-width:0;display:grid}.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);color:var(--muted);background:var(--secondary);text-transform:uppercase;letter-spacing:.04em;padding:4px 10px;font-size:11px}.agent-pill.warn{color:var(--warn);border-color:var(--warn)}.agent-header{grid-template-columns:minmax(0,1fr) auto;align-items:center;gap:12px;display:grid}.agent-header-main{align-items:center;gap:12px;display:flex}.agent-header-meta{color:var(--muted);justify-items:end;gap:6px;display:grid}.agent-tabs{border-bottom:1px solid var(--border);flex-wrap:wrap;gap:6px;padding-bottom:2px;display:flex}.agent-tab{border-radius:var(--radius-sm);color:var(--muted);cursor:pointer;transition:border-color var(--duration-fast) ease, background var(--duration-fast) ease, color var(--duration-fast) ease;background:0 0;border:1px solid #0000;padding:6px 12px;font-size:12px;font-weight:600}.agent-tab:hover{color:var(--text);background:var(--bg-hover)}.agent-tab.active{background:var(--accent-subtle);border-color:color-mix(in srgb, var(--accent) 25%, transparent);color:var(--accent)}.agent-tab-count{opacity:.7;margin-left:4px;font-size:10px;font-weight:700}.agents-overview-grid{grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:12px;display:grid}.agent-kv{gap:6px;min-width:0;display:grid}.agent-kv>div{overflow-wrap:anywhere;word-break:break-word;min-width:0}.agent-kv-sub{font-size:12px}.agent-model-select,.agent-model-fields{gap:10px;display:grid}.workspace-link{color:var(--accent);font-family:var(--mono);cursor:pointer;word-break:break-all;text-align:left;transition:opacity var(--duration-fast) ease;background:0 0;border:none;align-items:center;gap:4px;padding:2px 0;font-size:12px;display:inline-flex}.workspace-link:hover{opacity:.75;text-decoration:underline}.agent-model-actions{flex-wrap:wrap;align-items:center;gap:8px;display:flex}.agent-chip-input{border:1px solid var(--border-strong);border-radius:var(--radius-md);background:var(--bg-accent);cursor:text;min-height:38px;transition:border-color var(--duration-fast) ease;flex-wrap:wrap;align-items:center;gap:6px;padding:6px 10px;display:flex}.agent-chip-input:focus-within{border-color:var(--accent);box-shadow:var(--focus-ring)}.agent-chip-input input{background:0 0;border:none;outline:none;flex:1;min-width:120px;padding:0;font-size:13px}.agent-model-meta{gap:6px;min-width:200px;display:grid}.agent-files-grid{grid-template-columns:minmax(180px,240px) minmax(0,1fr);gap:14px;display:grid}.agent-files-list{gap:8px;display:grid}.agent-file-row{text-align:left;border:1px solid var(--border);border-radius:var(--radius-md);background:var(--card);cursor:pointer;width:100%;transition:border-color var(--duration-fast) ease;justify-content:space-between;align-items:center;gap:12px;padding:10px 12px;display:flex}.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);margin-top:4px;font-size:12px}.agent-files-editor{border:1px solid var(--border);border-radius:var(--radius-lg);background:var(--card);padding:16px}.agent-file-field{min-height:clamp(320px,56vh,720px)}.field textarea.agent-file-textarea{min-height:clamp(320px,56vh,720px);transition:filter var(--duration-fast) ease}.field textarea.agent-file-textarea:not(:focus){filter:blur(6px)}.agent-file-header{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:12px;display:flex}.agent-file-title{font-weight:600}.agent-file-sub{color:var(--muted);margin-top:4px;font-size:12px}.agent-file-actions{gap:8px;display:flex}.agent-tools-meta{grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:12px;display:grid}.agent-tools-buttons{flex-wrap:wrap;gap:8px;margin-top:8px;display:flex}.agent-tools-grid{gap:16px;display:grid}.agent-tools-section{border:1px solid var(--border);border-radius:var(--radius-md);background:var(--bg-elevated);padding:10px}.agent-tools-header{margin-bottom:10px;font-weight:600}.agent-tools-list{grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:8px 12px;display:grid}.agent-tool-row{border:1px solid var(--border);border-radius:var(--radius-md);background:var(--card);justify-content:space-between;align-items:center;gap:12px;padding:6px 8px;display:flex}.agent-tool-title{font-size:13px;font-weight:600}.agent-tool-sub{color:var(--muted);margin-top:2px;font-size:11px}.agent-skills-groups{gap:16px;display:grid}.agent-skills-group{gap:10px;display:grid}.agent-skills-group summary{list-style:none}.agent-skills-header{text-transform:uppercase;letter-spacing:.04em;color:var(--muted);cursor:pointer;align-items:center;gap:8px;font-size:13px;font-weight:600;display:flex}.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:"▸";color:var(--muted);transition:transform var(--duration-fast) ease;margin-left:8px;font-size:12px}.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{justify-content:flex-end;align-items:flex-start;min-width:auto;display:flex}.skills-grid{grid-template-columns:1fr}@container (width>=900px){.skills-grid{grid-template-columns:repeat(2,minmax(0,1fr))}}@media (width<=980px){.agent-header{grid-template-columns:1fr}.agent-header-meta{justify-items:start}.agent-files-grid,.agent-tools-list{grid-template-columns:1fr}}@media (width<=600px){.agents-toolbar-row{flex-direction:column;align-items:stretch;gap:6px}.agents-control-select{max-width:none}.agents-toolbar-label{display:none}}.cmd-palette-overlay{z-index:1000;background:#00000080;justify-content:center;align-items:flex-start;padding-top:min(20vh,160px);animation:.12s ease-out fade-in;display:flex;position:fixed;inset:0}.cmd-palette{background:var(--card);border:1px solid var(--border);border-radius:var(--radius-lg);width:min(560px,90vw);box-shadow:var(--shadow-lg);animation:.15s ease-out scale-in;overflow:hidden}.cmd-palette__input{border:none;border-bottom:1px solid var(--border);width:100%;color:var(--text);background:0 0;outline:none;padding:14px 18px;font-size:15px}.cmd-palette__input::placeholder{color:var(--muted)}.cmd-palette__results{max-height:320px;padding:6px 0;overflow-y:auto}.cmd-palette__group-label{color:var(--muted);text-transform:uppercase;letter-spacing:.05em;padding:8px 18px 4px;font-size:11px;font-weight:600}.cmd-palette__item{cursor:pointer;transition:background var(--duration-fast) ease;align-items:center;gap:10px;padding:8px 18px;font-size:14px;display:flex}.cmd-palette__item:hover,.cmd-palette__item--active{background:var(--bg-hover)}.cmd-palette__item .nav-item__icon{flex-shrink:0;width:16px;height:16px}.cmd-palette__item .nav-item__icon svg{width:100%;height:100%}.cmd-palette__item-desc{margin-left:auto;font-size:12px}.cmd-palette__empty{color:var(--muted);align-items:center;gap:8px;padding:16px 18px;font-size:13px;display:flex}.cmd-palette__footer{border-top:1px solid var(--border);color:var(--muted);justify-content:flex-end;align-items:center;gap:12px;padding:8px 18px;font-size:11px;display:flex}.cmd-palette__footer kbd{border:1px solid var(--border);border-radius:var(--radius-sm);background:var(--bg);font-family:var(--mono);justify-content:center;align-items:center;padding:1px 5px;font-size:10px;line-height:1.4;display:inline-flex}.ov-cards{grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:12px;display:grid}.ov-card{border:1px solid var(--border);border-radius:var(--radius-lg);background:var(--card);cursor:pointer;text-align:left;transition:border-color var(--duration-normal) var(--ease-out), box-shadow var(--duration-normal) var(--ease-out), transform var(--duration-fast) var(--ease-out);animation:rise .25s var(--ease-out) backwards;gap:6px;padding:16px;display:grid}.ov-card:hover{border-color:var(--border-strong);box-shadow:var(--shadow-sm);transform:translateY(-1px)}.ov-card:focus-visible{box-shadow:var(--focus-ring);outline:none}.ov-card__label{color:var(--muted);text-transform:uppercase;letter-spacing:.04em;font-size:11px;font-weight:600}.ov-card__value{letter-spacing:-.03em;color:var(--text-strong);font-size:22px;font-weight:700;line-height:1.15}.ov-card__hint{color:var(--muted);font-size:12px;line-height:1.35}.ov-card__hint .danger{color:var(--danger)}.ov-cards .ov-card:first-child{animation-delay:0s}.ov-cards .ov-card:nth-child(2){animation-delay:50ms}.ov-cards .ov-card:nth-child(3){animation-delay:.1s}.ov-cards .ov-card:nth-child(4){animation-delay:.15s}.ov-attention-list{flex-direction:column;gap:8px;display:flex}.ov-attention-item{border-radius:var(--radius-md);background:var(--bg-hover);border:1px solid var(--border);align-items:flex-start;gap:10px;padding:10px 12px;display:flex}.ov-attention-item.warn{border-color:var(--warning-subtle,#eab30833);background:#eab3080d}.ov-attention-item.danger{border-color:var(--danger-subtle,#ef444433);background:#ef44440d}.ov-attention-icon{width:18px;height:18px;color:var(--muted);flex-shrink:0;justify-content:center;align-items:center;margin-top:1px;display:inline-flex}.ov-attention-item.warn .ov-attention-icon{color:var(--warning,#eab308)}.ov-attention-item.danger .ov-attention-icon{color:var(--danger,#ef4444)}.ov-attention-icon svg{fill:none;stroke:currentColor;stroke-width:2px;stroke-linecap:round;stroke-linejoin:round;width:16px;height:16px}.ov-attention-body{flex:1;min-width:0}.ov-attention-title{font-size:13px;font-weight:500}.ov-attention-link{color:var(--accent,#3b82f6);font-size:12px;text-decoration:none}.ov-attention-link:hover{text-decoration:underline}.ov-recent{margin-top:18px}.ov-recent__title{color:var(--muted);text-transform:uppercase;letter-spacing:.04em;margin:0 0 10px;font-size:13px;font-weight:600}.ov-recent__list{gap:6px;margin:0;padding:0;list-style:none;display:grid}.ov-recent__row{border:1px solid var(--border);border-radius:var(--radius-md);background:var(--card);transition:border-color var(--duration-fast) ease;grid-template-columns:minmax(0,1fr) auto auto;align-items:center;gap:12px;padding:8px 12px;font-size:13px;display:grid}.ov-recent__row:hover{border-color:var(--border-strong)}.ov-recent__key{white-space:nowrap;text-overflow:ellipsis;min-width:0;font-weight:500;overflow:hidden}.ov-recent__model{color:var(--muted);font-size:12px;font-family:var(--mono)}.ov-recent__time{color:var(--muted);white-space:nowrap;font-size:12px}.blur-digits{filter:blur(4px);-webkit-user-select:none;user-select:none}.ov-section-divider{border-top:1px solid var(--border);margin:18px 0 0}.ov-access-grid{grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:12px;display:grid}.ov-access-grid__full{grid-column:1/-1}.ov-bottom-grid{grid-template-columns:repeat(auto-fit,minmax(340px,1fr));gap:20px;display:grid}@media (width<=600px){.ov-cards{grid-template-columns:repeat(2,1fr);gap:8px}.ov-card{padding:12px}.ov-card__value{font-size:18px}.ov-bottom-grid,.ov-access-grid{grid-template-columns:1fr}.ov-recent__row{grid-template-columns:1fr;gap:4px}}.config-layout{border-radius:var(--radius-xl);border:1px solid var(--border);background:var(--panel);height:calc(100vh - 160px);animation:config-enter .3s var(--ease-out);grid-template-columns:minmax(0,1fr);gap:0;margin:0 -16px -32px;display:grid;overflow:clip}@keyframes config-enter{0%{opacity:0;transform:translateY(6px)}to{opacity:1;transform:translateY(0)}}@media (width<=600px){.config-layout{margin:0}}@media (width<=400px){.config-layout{margin:0}}.config-search{border-bottom:1px solid var(--border);gap:5px;padding:10px 12px 8px;display:grid}.config-search__input-row{position:relative}.config-search__icon{width:16px;height:16px;color:var(--muted);pointer-events:none;position:absolute;top:50%;left:14px;transform:translateY(-50%)}.config-search__input{border:1px solid var(--border);border-radius:var(--radius-md);background:var(--bg-elevated);width:100%;transition:border-color var(--duration-fast) ease, box-shadow var(--duration-fast) ease, background var(--duration-fast) ease;outline:none;padding:8px 34px 8px 38px;font-size:12.5px}.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-mode=light] .config-search__input,:root[data-theme-mode=light] .config-search__input:focus{background:#fff}.config-search__clear{border-radius:var(--radius-full);background:var(--bg-hover);width:22px;height:22px;color:var(--muted);cursor:pointer;transition:background var(--duration-fast) ease, color var(--duration-fast) ease;border:none;justify-content:center;align-items:center;font-size:14px;line-height:1;display:flex;position:absolute;top:50%;right:8px;transform:translateY(-50%)}.config-search__clear:hover{background:var(--border-strong);color:var(--text)}.config-mode-toggle{background:var(--bg-elevated);border-radius:var(--radius-md);border:1px solid var(--border);gap:1px;padding:3px;display:flex}:root[data-theme-mode=light] .config-mode-toggle{background:#fff}.config-mode-toggle__btn{border-radius:calc(var(--radius-md) - 3px);color:var(--muted);cursor:pointer;transition:background var(--duration-fast) ease, color var(--duration-fast) ease, box-shadow var(--duration-fast) ease;background:0 0;border:none;flex:1;padding:6px 12px;font-size:11px;font-weight:600}.config-mode-toggle__btn:hover:not(.active){color:var(--text);background:var(--bg-hover)}.config-mode-toggle__btn.active{background:var(--accent);color:#fff;box-shadow:0 1px 3px #ff5c5c33}.config-main{background:var(--panel);flex-direction:column;min-width:0;min-height:0;display:flex;overflow:clip}.config-actions{background:var(--bg-accent);border-bottom:1px solid var(--border);z-index:2;flex-shrink:0;justify-content:space-between;align-items:center;gap:12px;padding:10px 20px;display:flex;position:relative}:root[data-theme-mode=light] .config-actions{background:var(--bg-hover)}.config-actions__left,.config-actions__right{align-items:center;gap:8px;display:flex}.config-changes-badge{border-radius:var(--radius-full);background:var(--accent-subtle);border:1px solid color-mix(in srgb, var(--accent) 25%, transparent);color:var(--accent);animation:badge-enter .2s var(--ease-out);padding:4px 10px;font-size:11px;font-weight:600}@keyframes badge-enter{0%{opacity:0;transform:scale(.9)}to{opacity:1;transform:scale(1)}}.config-status{color:var(--muted);font-size:12.5px}.config-top-tabs{background:var(--bg-accent);border-bottom:1px solid var(--border);flex-shrink:0;align-items:center;gap:10px;padding:10px 20px;display:flex}:root[data-theme-mode=light] .config-top-tabs{background:var(--bg-hover)}.config-search--top{border-bottom:none;flex:0 320px;min-width:200px;max-width:320px;padding:0}.config-top-tabs__scroller{flex-wrap:wrap;flex:auto;align-items:center;gap:6px;min-width:0;display:flex}.config-top-tabs__tab{border:1px solid var(--border);border-radius:var(--radius-full);background:var(--bg-elevated);color:var(--muted);white-space:nowrap;cursor:pointer;transition:border-color var(--duration-fast) ease, background var(--duration-fast) ease, color var(--duration-fast) ease, box-shadow var(--duration-fast) ease;flex:none;padding:5px 12px;font-size:11.5px;font-weight:600}:root[data-theme-mode=light] .config-top-tabs__tab{background:#fff}.config-top-tabs__tab:hover{color:var(--text);border-color:var(--border-strong);background:var(--bg-hover)}.config-top-tabs__tab.active{color:var(--accent);border-color:color-mix(in srgb, var(--accent) 30%, transparent);background:var(--accent-subtle)}.config-top-tabs__right{flex-shrink:0;justify-content:flex-end;min-width:0;display:flex}.config-diff{border:1px solid color-mix(in srgb, var(--accent) 20%, transparent);border-radius:var(--radius-lg);background:var(--accent-subtle);animation:badge-enter .2s var(--ease-out);margin:12px 20px 0;overflow:hidden}.config-diff__summary{cursor:pointer;color:var(--accent);justify-content:space-between;align-items:center;padding:10px 16px;font-size:12px;font-weight:600;list-style:none;display:flex}.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{gap:8px;padding:0 16px 16px;display:grid}.config-diff__item{border-radius:var(--radius-md);background:var(--bg-elevated);font-size:11.5px;font-family:var(--mono);align-items:baseline;gap:12px;padding:8px 12px;display:flex}:root[data-theme-mode=light] .config-diff__item{background:#fff}.config-diff__path{color:var(--text);flex-shrink:0;font-weight:600}.config-diff__values{flex-wrap:wrap;align-items:baseline;gap:10px;min-width:0;display:flex}.config-diff__from{color:var(--danger);opacity:.85}.config-diff__arrow{color:var(--muted)}.config-diff__to{color:var(--ok)}.config-section-hero{border-bottom:1px solid var(--border);background:var(--bg-accent);align-items:center;gap:14px;padding:16px 22px;display:flex}:root[data-theme-mode=light] .config-section-hero{background:var(--bg-hover)}.config-section-hero__icon{width:28px;height:28px;color:var(--accent);border-radius:var(--radius-md);background:var(--accent-subtle);flex-shrink:0;justify-content:center;align-items:center;padding:5px;display:flex}.config-section-hero__icon svg{stroke:currentColor;fill:none;width:100%;height:100%}.config-section-hero__text{gap:2px;min-width:0;display:grid}.config-section-hero__title{letter-spacing:-.02em;white-space:nowrap;text-overflow:ellipsis;font-size:15px;font-weight:650;overflow:hidden}.config-section-hero__desc{color:var(--muted);font-size:12px;line-height:1.4}.config-content{scroll-behavior:smooth;flex:1;min-width:0;padding:20px 22px;overflow-y:auto}.settings-appearance{gap:18px;display:grid}.settings-appearance__section{border:1px solid var(--border);border-radius:var(--radius-lg);background:var(--bg-elevated);gap:14px;padding:18px;display:grid}.settings-appearance__heading{letter-spacing:-.02em;color:var(--text-strong);margin:0;font-size:15px;font-weight:650}.settings-appearance__hint{color:var(--muted);margin:-8px 0 0;font-size:12.5px;line-height:1.45}.settings-theme-grid{grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:12px;display:grid}.settings-theme-card{border:1px solid var(--border);border-radius:var(--radius-lg);background:var(--bg);min-height:64px;color:var(--text);text-align:left;cursor:pointer;transition:border-color var(--duration-fast) ease, background var(--duration-fast) ease, box-shadow var(--duration-fast) ease, transform var(--duration-fast) ease;grid-template-columns:auto 1fr auto;align-items:center;gap:10px;padding:14px 16px;display:grid;position:relative}.settings-theme-card:hover{border-color:var(--border-strong);background:var(--bg-hover);transform:translateY(-1px)}.settings-theme-card--active{border-color:color-mix(in srgb, var(--accent) 35%, transparent);background:color-mix(in srgb, var(--accent) 10%, var(--bg-elevated));box-shadow:0 0 0 1px color-mix(in srgb, var(--accent) 14%, transparent)}.settings-theme-card__icon,.settings-theme-card__check{width:18px;height:18px;color:var(--accent);justify-content:center;align-items:center;display:inline-flex}.settings-theme-card__icon svg,.settings-theme-card__check svg{stroke:currentColor;fill:none;width:18px;height:18px}.settings-theme-card__label{color:var(--text-strong);font-size:13px;font-weight:600}.settings-info-grid{gap:10px;display:grid}.settings-info-row{border:1px solid var(--border);border-radius:var(--radius-md);background:var(--bg);justify-content:space-between;align-items:center;gap:16px;padding:12px 14px;display:flex}.settings-info-row__label{color:var(--muted);text-transform:uppercase;letter-spacing:.04em;font-size:12px;font-weight:600}.settings-info-row__value{min-width:0;color:var(--text);text-align:right;align-items:center;gap:8px;font-size:13px;font-weight:500;display:inline-flex}.settings-status-dot{border-radius:var(--radius-full);background:var(--muted);width:8px;height:8px;box-shadow:0 0 0 4px color-mix(in srgb, var(--muted) 14%, transparent)}.settings-status-dot--ok{background:var(--ok);box-shadow:0 0 0 4px color-mix(in srgb, var(--ok) 14%, transparent)}.config-raw-field textarea{min-height:500px;font-family:var(--mono);font-size:13px;line-height:1.55}.config-loading{color:var(--muted);animation:fade-in .2s var(--ease-out);flex-direction:column;justify-content:center;align-items:center;gap:14px;padding:80px 24px;display:flex}.config-loading__spinner{border:2.5px solid var(--border);border-top-color:var(--accent);border-radius:var(--radius-full);width:32px;height:32px;animation:.7s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}.config-empty{text-align:center;animation:fade-in .3s var(--ease-out);flex-direction:column;justify-content:center;align-items:center;gap:16px;padding:80px 24px;display:flex}.config-empty__icon{opacity:.25;font-size:48px}.config-empty__text{color:var(--muted);max-width:320px;font-size:14px;line-height:1.5}.config-form--modern{gap:14px;width:100%;min-width:0;display:grid}.config-section-card{border:1px solid var(--border);border-radius:var(--radius-lg);background:var(--bg-elevated);width:100%;transition:border-color var(--duration-normal) ease, box-shadow var(--duration-normal) ease;animation:section-card-enter .25s var(--ease-out) backwards;overflow:hidden}@keyframes section-card-enter{0%{opacity:0;transform:translateY(4px)}to{opacity:1;transform:translateY(0)}}.config-section-card:hover{border-color:var(--border-strong);box-shadow:var(--shadow-sm)}:root[data-theme-mode=light] .config-section-card{background:#fff}:root[data-theme-mode=light] .config-section-card:hover{box-shadow:0 2px 8px #0000000a}.config-section-card__header{background:var(--bg-accent);border-bottom:1px solid var(--border);align-items:center;gap:14px;padding:18px 20px;display:flex}:root[data-theme-mode=light] .config-section-card__header{background:var(--bg-hover)}.config-section-card__icon{width:30px;height:30px;color:var(--accent);border-radius:var(--radius-md);background:var(--accent-subtle);flex-shrink:0;justify-content:center;align-items:center;padding:6px;display:flex}.config-section-card__icon svg{width:100%;height:100%}.config-section-card__titles{flex:1;min-width:0}.config-section-card__title{letter-spacing:-.015em;white-space:nowrap;text-overflow:ellipsis;margin:0;font-size:14px;font-weight:650;overflow:hidden}.config-section-card__desc{color:var(--muted);margin:3px 0 0;font-size:12px;line-height:1.45}.config-section-card__content{min-width:0;padding:16px 18px}.config-form--modern .config-section-card:first-child{animation-delay:0s}.config-form--modern .config-section-card:nth-child(2){animation-delay:40ms}.config-form--modern .config-section-card:nth-child(3){animation-delay:80ms}.config-form--modern .config-section-card:nth-child(4){animation-delay:.12s}.config-form--modern .config-section-card:nth-child(5){animation-delay:.16s}.config-form--modern .config-section-card:nth-child(n+6){animation-delay:.2s}.cfg-fields{gap:14px;display:grid}.cfg-fields--inline{gap:10px}.cfg-field{gap:6px;display:grid}.cfg-field--error{border-radius:var(--radius-md);background:var(--danger-subtle);border:1px solid #ef44444d;padding:14px}.cfg-field__label{color:var(--text);letter-spacing:-.005em;font-size:12.5px;font-weight:600}.cfg-field__help{color:var(--muted);font-size:11.5px;line-height:1.45}.cfg-tags{flex-wrap:wrap;gap:6px;display:flex}.cfg-tag{border:1px solid var(--border);border-radius:var(--radius-full);color:var(--muted);background:var(--bg-elevated);white-space:nowrap;align-items:center;padding:2px 8px;font-size:11px;display:inline-flex}:root[data-theme-mode=light] .cfg-tag{background:#fff}.cfg-field__error{color:var(--danger);font-size:12px}.cfg-input-wrap{gap:10px;display:flex}.cfg-input{border:1px solid var(--border);border-radius:var(--radius-md);background:var(--bg-accent);transition:border-color var(--duration-fast) ease, box-shadow var(--duration-fast) ease, background var(--duration-fast) ease;outline:none;flex:1;padding:8px 12px;font-size:13px}.cfg-input::placeholder{color:var(--muted);opacity:.6}.cfg-input:hover:not(:focus){border-color:var(--border-strong)}.cfg-input:focus{border-color:var(--accent);box-shadow:var(--focus-ring);background:var(--bg-hover)}:root[data-theme-mode=light] .cfg-input{border-color:var(--border);background:#fff}:root[data-theme-mode=light] .cfg-input:hover:not(:focus){border-color:var(--border-strong)}:root[data-theme-mode=light] .cfg-input:focus{background:#fff}.cfg-input--sm{padding:6px 10px;font-size:12px}.cfg-input__reset{border:1px solid var(--border);border-radius:var(--radius-md);background:var(--bg-elevated);color:var(--muted);cursor:pointer;transition:background var(--duration-fast) ease, color var(--duration-fast) ease;padding:9px 12px;font-size:13px}.cfg-input__reset:hover:not(:disabled){background:var(--bg-hover);color:var(--text)}.cfg-input__reset:disabled{opacity:.5;cursor:not-allowed}.cfg-textarea{border:1px solid var(--border);border-radius:var(--radius-md);background:var(--bg-accent);width:100%;font-family:var(--mono);resize:vertical;transition:border-color var(--duration-fast) ease, box-shadow var(--duration-fast) ease;outline:none;padding:10px 14px;font-size:13px;line-height:1.55}.cfg-textarea:hover:not(:focus){border-color:var(--border-strong)}.cfg-textarea:focus{border-color:var(--accent);box-shadow:var(--focus-ring)}:root[data-theme-mode=light] .cfg-textarea{border-color:var(--border);background:#fff}.cfg-textarea--sm{padding:8px 12px;font-size:12px}.cfg-number{border:1px solid var(--border);border-radius:var(--radius-md);background:var(--bg-accent);transition:border-color var(--duration-fast) ease;display:inline-flex;overflow:hidden}.cfg-number:hover{border-color:var(--border-strong)}:root[data-theme-mode=light] .cfg-number{background:#fff}.cfg-number__btn{background:var(--bg-elevated);width:38px;color:var(--text);cursor:pointer;transition:background var(--duration-fast) ease;border:none;font-size:16px;font-weight:300}.cfg-number__btn:hover:not(:disabled){background:var(--bg-hover)}.cfg-number__btn:disabled{opacity:.4;cursor:not-allowed}:root[data-theme-mode=light] .cfg-number__btn{background:var(--bg-hover)}:root[data-theme-mode=light] .cfg-number__btn:hover:not(:disabled){background:var(--border)}.cfg-number__input{border:none;border-left:1px solid var(--border);border-right:1px solid var(--border);text-align:center;appearance:textfield;background:0 0;outline:none;width:72px;padding:9px;font-size:13px}.cfg-number__input::-webkit-outer-spin-button{-webkit-appearance:none;margin:0}.cfg-number__input::-webkit-inner-spin-button{-webkit-appearance:none;margin:0}.cfg-select{border:1px solid var(--border);border-radius:var(--radius-md);background-color:var(--bg-accent);cursor:pointer;appearance:none;transition:border-color var(--duration-fast) ease, box-shadow var(--duration-fast) ease;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='14' height='14' 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-position:right 10px center;background-repeat:no-repeat;outline:none;padding:8px 36px 8px 12px;font-size:13px}.cfg-select:hover:not(:focus){border-color:var(--border-strong)}.cfg-select:focus{border-color:var(--accent);box-shadow:var(--focus-ring)}:root[data-theme-mode=light] .cfg-select{border-color:var(--border);background-color:#fff}.cfg-segmented{border:1px solid var(--border);border-radius:var(--radius-md);background:var(--bg-accent);gap:1px;padding:3px;display:inline-flex}:root[data-theme-mode=light] .cfg-segmented{background:var(--bg-hover)}.cfg-segmented__btn{border-radius:calc(var(--radius-md) - 3px);color:var(--muted);cursor:pointer;transition:background var(--duration-fast) ease, color var(--duration-fast) ease, box-shadow var(--duration-fast) ease;background:0 0;border:none;padding:6px 14px;font-size:12px;font-weight:500}.cfg-segmented__btn:hover:not(:disabled):not(.active){color:var(--text);background:var(--bg-hover)}.cfg-segmented__btn.active{background:var(--accent);color:#fff;box-shadow:0 1px 3px #ff5c5c33}.cfg-segmented__btn:disabled{opacity:.5;cursor:not-allowed}.cfg-toggle-row{border:1px solid var(--border);border-radius:var(--radius-md);background:var(--bg-accent);cursor:pointer;transition:background var(--duration-fast) ease, border-color var(--duration-fast) ease;justify-content:space-between;align-items:center;gap:14px;padding:12px 14px;display:flex}.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-mode=light] .cfg-toggle-row{background:#fff}:root[data-theme-mode=light] .cfg-toggle-row:hover:not(.disabled){background:var(--bg-hover)}.cfg-toggle-row__content{flex:1;min-width:0}.cfg-toggle-row__label{color:var(--text);font-size:12.5px;font-weight:500;display:block}.cfg-toggle-row__help{color:var(--muted);margin-top:2px;font-size:11px;line-height:1.45;display:block}.cfg-toggle{flex-shrink:0;position:relative}.cfg-toggle input{opacity:0;width:0;height:0;position:absolute}.cfg-toggle__track{background:var(--bg-elevated);border:1px solid var(--border-strong);border-radius:var(--radius-full);width:40px;height:22px;transition:background var(--duration-normal) var(--ease-out), border-color var(--duration-normal) var(--ease-out);display:block;position:relative}:root[data-theme-mode=light] .cfg-toggle__track{background:var(--border)}.cfg-toggle__track:after{content:"";background:var(--text);border-radius:var(--radius-full);width:16px;height:16px;box-shadow:var(--shadow-sm);transition:transform var(--duration-normal) var(--ease-spring), background var(--duration-normal) ease;position:absolute;top:2px;left:2px}.cfg-toggle input:checked+.cfg-toggle__track{background:var(--ok-subtle);border-color:#22c55e66}.cfg-toggle input:checked+.cfg-toggle__track:after{background:var(--ok);transform:translate(18px)}.cfg-toggle input:focus+.cfg-toggle__track{box-shadow:var(--focus-ring)}.cfg-object{border:1px solid var(--border);border-radius:var(--radius-md);transition:border-color var(--duration-fast) ease;background:0 0;overflow:hidden}.cfg-object:hover{border-color:var(--border-strong)}:root[data-theme-mode=light] .cfg-object{background:0 0}.cfg-object__header{cursor:pointer;transition:background var(--duration-fast) ease;border-radius:calc(var(--radius-md) - 1px);justify-content:space-between;align-items:center;padding:10px 12px;list-style:none;display:flex}.cfg-object__header:hover{background:var(--bg-hover)}.cfg-object__header::-webkit-details-marker{display:none}.cfg-object__title{color:var(--text);font-size:13px;font-weight:600}.cfg-object__title-wrap{gap:6px;min-width:0;display:grid}.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{color:var(--muted);padding:0 12px 10px;font-size:12px}.cfg-object__content{border-top:1px solid var(--border);gap:12px;padding:12px;display:grid}.cfg-array{border:1px solid var(--border);border-radius:var(--radius-lg);overflow:hidden}.cfg-array__header{background:var(--bg-accent);border-bottom:1px solid var(--border);align-items:center;gap:14px;padding:10px 12px;display:flex}:root[data-theme-mode=light] .cfg-array__header{background:var(--bg-hover)}.cfg-array__label{color:var(--text);font-size:14px;font-weight:600}.cfg-array__title{flex:1;gap:6px;min-width:0;display:grid}.cfg-array__count{color:var(--muted);background:var(--bg-elevated);border-radius:var(--radius-full);padding:4px 10px;font-size:12px}:root[data-theme-mode=light] .cfg-array__count{background:#fff}.cfg-array__add{border:1px solid var(--border);border-radius:var(--radius-md);background:var(--bg-elevated);color:var(--text);cursor:pointer;transition:background var(--duration-fast) ease;align-items:center;gap:6px;padding:7px 14px;font-size:12px;font-weight:500;display:inline-flex}.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{color:var(--muted);border-bottom:1px solid var(--border);padding:10px 12px;font-size:12px}.cfg-array__empty{text-align:center;color:var(--muted);padding:36px 18px;font-size:13px}.cfg-array__items{background:var(--border);gap:1px;display:grid}.cfg-array__item{background:var(--panel)}.cfg-array__item-header{background:var(--bg-accent);border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;padding:10px 12px;display:flex}:root[data-theme-mode=light] .cfg-array__item-header{background:var(--bg-hover)}.cfg-array__item-index{color:var(--muted);text-transform:uppercase;letter-spacing:.05em;font-size:11px;font-weight:600}.cfg-array__item-remove{border-radius:var(--radius-md);width:30px;height:30px;color:var(--muted);cursor:pointer;transition:background var(--duration-fast) ease, color var(--duration-fast) ease;background:0 0;border:none;justify-content:center;align-items:center;display:flex}.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:12px}.cfg-map{border:1px solid var(--border);border-radius:var(--radius-lg);overflow:hidden}.cfg-map__header{background:var(--bg-accent);border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;gap:14px;padding:10px 12px;display:flex}:root[data-theme-mode=light] .cfg-map__header{background:var(--bg-hover)}.cfg-map__label{color:var(--muted);font-size:13px;font-weight:600}.cfg-map__add{border:1px solid var(--border);border-radius:var(--radius-md);background:var(--bg-elevated);color:var(--text);cursor:pointer;transition:background var(--duration-fast) ease;align-items:center;gap:6px;padding:7px 14px;font-size:12px;font-weight:500;display:inline-flex}.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{text-align:center;color:var(--muted);padding:28px 18px;font-size:13px}.cfg-map__items{gap:8px;padding:10px 12px 12px;display:grid}.cfg-map__item{border:1px solid var(--border);border-radius:var(--radius-md);background:var(--bg-accent);gap:8px;padding:10px;display:grid}:root[data-theme-mode=light] .cfg-map__item{background:#fff}.cfg-map__item-header{grid-template-columns:minmax(0,300px) auto;align-items:center;gap:8px;display:grid}.cfg-map__item-key,.cfg-map__item-value{min-width:0}.cfg-map__item-value>.cfg-fields{gap:10px}.cfg-map__item-remove{border-radius:var(--radius-md);width:32px;height:32px;color:var(--muted);cursor:pointer;transition:background var(--duration-fast) ease, color var(--duration-fast) ease;background:0 0;border:none;justify-content:center;align-items:center;display:flex}.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{color:var(--ok);border-color:#22c55e59}.pill--danger{color:var(--danger);border-color:#ef444459}@media (width<=768px){.config-actions{flex-wrap:wrap;padding:14px 16px}.config-actions__left,.config-actions__right{justify-content:center;width:100%}.config-top-tabs{flex-wrap:wrap;padding:12px 16px}.config-search--top{flex:100%;max-width:none}.config-top-tabs__scroller,.config-top-tabs__right{flex:100%}.config-top-tabs__right .config-mode-toggle{width:100%}.config-top-tabs__right .config-mode-toggle__btn{flex:50%}.config-section-hero{padding:14px 16px}.config-content{padding:16px}.settings-theme-grid{grid-template-columns:1fr}.settings-info-row{flex-direction:column;align-items:flex-start}.settings-info-row__value{text-align:left}.config-section-card__header,.config-section-card__content{padding:14px 16px}.cfg-toggle-row{padding:12px 14px}.cfg-map__item{grid-template-columns:1fr;gap:10px}.cfg-map__item-header{grid-template-columns:1fr auto}.cfg-map__item-remove{justify-self:end}}@media (width<=480px){.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}}

/* === OpenClaw 功能面板样式 === */
/* ============================================================
 * OpenClaw 汉化版 - 功能面板样式
 * 武汉晴辰天下网络科技有限公司 | https://qingchencloud.com/
 * ============================================================ */

/* ========== 浅色模式变量 ========== */
:root {
  --panel-bg: #18181b;
  --panel-border: #27272a;
  --panel-text: #fafafa;
  --panel-text-muted: #a1a1aa;
  --panel-hover: rgba(255, 255, 255, 0.05);
  --panel-code-bg: #09090b;
  --panel-code-text: #d4d4d8;
  --panel-accent: #ef4444;
  --panel-overlay: rgba(0, 0, 0, 0.6);
}

/* 浅色模式适配 - 检测系统主题或 Dashboard 主题 */
@media (prefers-color-scheme: light) {
  :root:not([data-theme="dark"]) {
    --panel-bg: #ffffff;
    --panel-border: #e4e4e7;
    --panel-text: #18181b;
    --panel-text-muted: #71717a;
    --panel-hover: rgba(0, 0, 0, 0.05);
    --panel-code-bg: #f4f4f5;
    --panel-code-text: #3f3f46;
    --panel-overlay: rgba(0, 0, 0, 0.4);
  }
}

/* Dashboard 浅色模式类名适配 */
html.light .feature-panel-overlay,
html[data-theme="light"] .feature-panel-overlay,
body.light .feature-panel-overlay,
:root[data-theme="light"] .feature-panel-overlay {
  --panel-bg: #ffffff;
  --panel-border: #e4e4e7;
  --panel-text: #18181b;
  --panel-text-muted: #71717a;
  --panel-hover: rgba(0, 0, 0, 0.05);
  --panel-code-bg: #f4f4f5;
  --panel-code-text: #3f3f46;
  --panel-overlay: rgba(0, 0, 0, 0.4);
}

/* 入口按钮 */
.panel-trigger {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 32px;
  height: 32px;
  margin-left: 8px;
  padding: 0;
  border: none;
  border-radius: 6px;
  background: transparent;
  color: var(--text, #a1a1aa);
  cursor: pointer;
  transition: all 0.2s ease;
}

.panel-trigger:hover {
  background: var(--hover, rgba(255, 255, 255, 0.1));
  color: var(--accent, #ef4444);
}

.panel-trigger svg {
  width: 18px;
  height: 18px;
}

/* 遮罩层 */
.feature-panel-overlay {
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  background: var(--panel-overlay);
  backdrop-filter: blur(4px);
  display: flex;
  align-items: center;
  justify-content: center;
  z-index: 9999;
  opacity: 0;
  visibility: hidden;
  transition: all 0.3s ease;
}

.feature-panel-overlay.active {
  opacity: 1;
  visibility: visible;
}

/* 面板容器 */
.feature-panel {
  width: 90%;
  max-width: 640px;
  max-height: 80vh;
  background: var(--panel-bg);
  border: 1px solid var(--panel-border);
  border-radius: 12px;
  box-shadow: 0 25px 50px -12px rgba(0, 0, 0, 0.25);
  display: flex;
  flex-direction: column;
  transform: scale(0.95) translateY(10px);
  transition: transform 0.3s ease;
}

.feature-panel-overlay.active .feature-panel {
  transform: scale(1) translateY(0);
}

/* 面板头部 */
.panel-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 16px 20px;
  border-bottom: 1px solid var(--panel-border);
}

.panel-header h2 {
  margin: 0;
  font-size: 18px;
  font-weight: 600;
  color: var(--panel-text);
}

.panel-close {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 28px;
  height: 28px;
  padding: 0;
  border: none;
  border-radius: 6px;
  background: transparent;
  color: var(--panel-text-muted);
  font-size: 20px;
  cursor: pointer;
  transition: all 0.2s ease;
}

.panel-close:hover {
  background: var(--panel-hover);
  color: var(--panel-text);
}

/* Tab 导航 */
.panel-tabs {
  display: flex;
  padding: 0 20px;
  border-bottom: 1px solid var(--panel-border);
  gap: 4px;
}

.panel-tab {
  padding: 12px 16px;
  border: none;
  background: transparent;
  color: var(--panel-text-muted);
  font-size: 14px;
  font-weight: 500;
  cursor: pointer;
  position: relative;
  transition: color 0.2s ease;
}

.panel-tab:hover {
  color: var(--panel-text);
}

.panel-tab.active {
  color: var(--panel-accent);
}

.panel-tab.active::after {
  content: '';
  position: absolute;
  bottom: -1px;
  left: 0;
  right: 0;
  height: 2px;
  background: var(--panel-accent);
  border-radius: 1px 1px 0 0;
}

/* 面板内容区 */
.panel-content {
  flex: 1;
  overflow-y: auto;
  padding: 20px;
}

/* FAQ 样式 */
.faq-item {
  margin-bottom: 12px;
  border: 1px solid var(--panel-border);
  border-radius: 8px;
  overflow: hidden;
}

.faq-question {
  display: flex;
  align-items: center;
  justify-content: space-between;
  width: 100%;
  padding: 14px 16px;
  border: none;
  background: transparent;
  color: var(--panel-text);
  font-size: 14px;
  font-weight: 500;
  text-align: left;
  cursor: pointer;
  transition: background 0.2s ease;
}

.faq-question:hover {
  background: var(--panel-hover);
}

.faq-question svg {
  width: 16px;
  height: 16px;
  color: var(--panel-text-muted);
  transition: transform 0.2s ease;
  flex-shrink: 0;
}

.faq-item.expanded .faq-question svg {
  transform: rotate(180deg);
}

.faq-answer {
  max-height: 0;
  overflow: hidden;
  transition: max-height 0.3s ease;
}

.faq-item.expanded .faq-answer {
  max-height: 800px;
}

.faq-answer-inner {
  padding: 0 16px 14px;
  color: var(--panel-text-muted);
  font-size: 13px;
  line-height: 1.7;
}

/* 代码块样式 */
.faq-answer-inner pre {
  display: block;
  margin: 8px 0;
  padding: 12px 14px;
  background: var(--panel-code-bg);
  border: 1px solid var(--panel-border);
  border-radius: 8px;
  overflow-x: auto;
}

.faq-answer-inner pre code {
  display: block;
  padding: 0;
  margin: 0;
  border: none;
  background: transparent;
  font-family: 'SF Mono', 'Fira Code', 'Consolas', monospace;
  font-size: 12px;
  color: var(--panel-code-text);
  white-space: pre-wrap;
  word-break: break-word;
  line-height: 1.5;
}

/* 行内代码 */
.faq-answer-inner code.inline-code,
.faq-answer-inner code:not(pre code) {
  display: inline;
  padding: 2px 6px;
  margin: 0;
  background: var(--panel-code-bg);
  border: 1px solid var(--panel-border);
  border-radius: 4px;
  font-family: 'SF Mono', 'Fira Code', 'Consolas', monospace;
  font-size: 12px;
  color: var(--panel-code-text);
}

/* 快捷指令样式 */
.commands-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 12px;
}

@media (max-width: 500px) {
  .commands-grid {
    grid-template-columns: 1fr;
  }
}

.command-btn {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 8px;
  padding: 20px 16px;
  border: 1px solid var(--panel-border);
  border-radius: 10px;
  background: transparent;
  color: var(--panel-text);
  cursor: pointer;
  transition: all 0.2s ease;
}

.command-btn:hover {
  background: var(--panel-hover);
  border-color: var(--panel-accent);
}

.command-btn:disabled {
  opacity: 0.5;
  cursor: not-allowed;
}

.command-btn svg {
  width: 24px;
  height: 24px;
  color: var(--panel-accent);
}

.command-btn span {
  font-size: 13px;
  font-weight: 500;
}

.command-btn .command-desc {
  font-size: 11px;
  color: var(--panel-text-muted);
  font-weight: 400;
}

/* ========== 插件列表样式 - 折叠式 ========== */
.plugin-item {
  margin-bottom: 8px;
  border: 1px solid var(--panel-border);
  border-radius: 8px;
  overflow: hidden;
  transition: border-color 0.2s ease;
}

.plugin-item:hover {
  border-color: var(--panel-accent);
}

/* 插件头部 - 可点击展开 */
.plugin-header {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 12px 14px;
  background: transparent;
  border: none;
  width: 100%;
  cursor: pointer;
  transition: background 0.2s ease;
}

.plugin-header:hover {
  background: var(--panel-hover);
}

.plugin-icon {
  width: 36px;
  height: 36px;
  display: flex;
  align-items: center;
  justify-content: center;
  background: var(--panel-accent);
  border-radius: 8px;
  color: white;
  font-size: 16px;
  flex-shrink: 0;
}

.plugin-icon-img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  border-radius: 6px;
}

.plugin-summary {
  flex: 1;
  text-align: left;
  min-width: 0;
}

.plugin-name {
  display: flex;
  align-items: center;
  gap: 8px;
  font-size: 14px;
  font-weight: 600;
  color: var(--panel-text);
  margin-bottom: 2px;
}

.plugin-version {
  padding: 2px 6px;
  background: var(--panel-code-bg);
  border-radius: 4px;
  font-size: 10px;
  font-weight: 400;
  color: var(--panel-text-muted);
}

.plugin-desc {
  font-size: 12px;
  color: var(--panel-text-muted);
  line-height: 1.4;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.plugin-status {
  padding: 4px 10px;
  border-radius: 4px;
  font-size: 11px;
  font-weight: 500;
  flex-shrink: 0;
}

.plugin-status.available {
  background: rgba(34, 197, 94, 0.15);
  color: #22c55e;
}

.plugin-status.coming-soon {
  background: rgba(234, 179, 8, 0.15);
  color: #eab308;
}

.plugin-expand-icon {
  width: 16px;
  height: 16px;
  color: var(--panel-text-muted);
  transition: transform 0.2s ease;
  flex-shrink: 0;
}

.plugin-item.expanded .plugin-expand-icon {
  transform: rotate(180deg);
}

/* 插件详情 - 展开内容 */
.plugin-details {
  max-height: 0;
  overflow: hidden;
  transition: max-height 0.3s ease;
}

.plugin-item.expanded .plugin-details {
  max-height: 300px;
}

.plugin-details-inner {
  padding: 0 14px 14px;
  border-top: 1px solid var(--panel-border);
}

.plugin-full-desc {
  font-size: 13px;
  color: var(--panel-text-muted);
  line-height: 1.5;
  margin: 12px 0;
}

/* 插件安装区域 */
.plugin-install-section {
  display: flex;
  flex-direction: column;
  gap: 10px;
}

.plugin-install-method {
  display: flex;
  flex-direction: column;
  gap: 6px;
}

.method-label {
  display: flex;
  align-items: center;
  gap: 6px;
  font-size: 12px;
  color: var(--panel-text-muted);
}

.method-label svg {
  width: 14px;
  height: 14px;
}

/* AI 提示语框 */
.ai-prompt-box {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 10px 12px;
  background: linear-gradient(135deg, rgba(239, 68, 68, 0.08) 0%, rgba(239, 68, 68, 0.03) 100%);
  border: 1px solid rgba(239, 68, 68, 0.2);
  border-radius: 8px;
}

.ai-prompt-text {
  flex: 1;
  font-size: 12px;
  color: var(--panel-text);
  line-height: 1.4;
}

.copy-btn {
  padding: 6px 14px;
  border: none;
  border-radius: 6px;
  background: var(--panel-accent);
  color: white;
  font-size: 12px;
  font-weight: 500;
  cursor: pointer;
  transition: all 0.2s ease;
  white-space: nowrap;
}

.copy-btn:hover {
  background: #dc2626;
}

/* 手动安装命令 */
.plugin-install-cmd {
  display: block;
  padding: 10px 12px;
  background: var(--panel-code-bg);
  border: 1px solid var(--panel-border);
  border-radius: 6px;
  font-family: 'SF Mono', 'Fira Code', 'Consolas', monospace;
  font-size: 12px;
  color: var(--panel-code-text);
  cursor: pointer;
  transition: all 0.2s ease;
  word-break: break-all;
}

.plugin-install-cmd:hover {
  border-color: var(--panel-accent);
}

/* 插件列表头部 */
.plugins-header {
  margin-bottom: 16px;
  padding: 14px 16px;
  background: var(--panel-code-bg);
  border-radius: 8px;
  border-left: 3px solid var(--panel-accent);
}

.plugins-header-top {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 12px;
}

.plugins-intro {
  display: flex;
  align-items: center;
  gap: 6px;
  font-size: 13px;
  color: var(--panel-text);
  margin: 0 0 6px 0;
  flex: 1;
}

.plugins-intro svg,
.plugins-note svg,
.method-label svg {
  width: 16px;
  height: 16px;
  flex-shrink: 0;
}

.plugins-note {
  font-size: 12px;
  color: var(--panel-text-muted);
  margin: 0;
}

/* 关于我们样式 */
.about-section {
  text-align: center;
  padding: 20px 0;
}

.about-logo {
  width: 64px;
  height: 64px;
  margin: 0 auto 16px;
}

.about-logo svg {
  width: 100%;
  height: 100%;
}

.about-title {
  font-size: 20px;
  font-weight: 700;
  color: var(--panel-text);
  margin-bottom: 4px;
}

.about-company {
  font-size: 14px;
  color: var(--panel-text-muted);
  margin-bottom: 24px;
}

.about-links {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: 12px;
  margin-bottom: 24px;
}

.about-link {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 10px 16px;
  border: 1px solid var(--panel-border);
  border-radius: 8px;
  background: transparent;
  color: var(--panel-text);
  font-size: 13px;
  text-decoration: none;
  transition: all 0.2s ease;
}

.about-link:hover {
  background: var(--panel-hover);
  border-color: var(--panel-accent);
}

.about-link svg {
  width: 16px;
  height: 16px;
}

.about-copyright {
  font-size: 12px;
  color: var(--panel-text-muted);
}

/* Toast 通知 */
.panel-toast {
  position: fixed;
  bottom: 24px;
  left: 50%;
  transform: translateX(-50%) translateY(100px);
  padding: 12px 20px;
  background: var(--panel-bg);
  border: 1px solid var(--panel-border);
  border-radius: 8px;
  color: var(--panel-text);
  font-size: 13px;
  box-shadow: 0 10px 25px rgba(0, 0, 0, 0.2);
  z-index: 10000;
  opacity: 0;
  transition: all 0.3s ease;
}

.panel-toast.show {
  transform: translateX(-50%) translateY(0);
  opacity: 1;
}

.panel-toast.success {
  border-color: #22c55e;
}

.panel-toast.error {
  border-color: #ef4444;
}

/* ========== 动态加载相关样式 ========== */

/* Loading 容器 */
.loading-container {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  padding: 40px 20px;
  color: var(--panel-text-muted);
}

.loading-container p {
  margin-top: 12px;
  font-size: 13px;
}

/* Loading 动画 */
.loading-spinner {
  width: 32px;
  height: 32px;
  border: 3px solid var(--panel-border);
  border-top-color: var(--panel-accent);
  border-radius: 50%;
  animation: spin 1s linear infinite;
}

@keyframes spin {
  to { transform: rotate(360deg); }
}

/* 刷新按钮 */
.refresh-btn {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 28px;
  height: 28px;
  padding: 0;
  border: 1px solid var(--panel-border);
  border-radius: 6px;
  background: transparent;
  color: var(--panel-text-muted);
  cursor: pointer;
  transition: all 0.2s ease;
  flex-shrink: 0;
}

.refresh-btn:hover {
  background: var(--panel-hover);
  color: var(--panel-accent);
  border-color: var(--panel-accent);
}

.refresh-btn svg {
  width: 14px;
  height: 14px;
}

/* ========== 更新日志样式 ========== */

.changelog-tab {
  display: flex;
  flex-direction: column;
}

.changelog-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: 16px;
  padding-bottom: 12px;
  border-bottom: 1px solid var(--panel-border);
}

.changelog-header h3 {
  margin: 0;
  font-size: 16px;
  font-weight: 600;
  color: var(--panel-text);
}

.changelog-list {
  display: flex;
  flex-direction: column;
  gap: 12px;
}

.changelog-empty {
  text-align: center;
  padding: 30px 20px;
  color: var(--panel-text-muted);
}

.changelog-empty p {
  margin: 0 0 8px;
}

.changelog-hint {
  font-size: 12px;
}

.changelog-hint a {
  color: var(--panel-accent);
  text-decoration: none;
}

.changelog-hint a:hover {
  text-decoration: underline;
}

/* 提交项 */
.commit-item {
  display: flex;
  gap: 12px;
  padding: 12px;
  background: var(--panel-code-bg);
  border-radius: 8px;
  border: 1px solid var(--panel-border);
}

.commit-icon {
  flex-shrink: 0;
  width: 24px;
  height: 24px;
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--panel-accent);
}

.commit-icon svg {
  width: 18px;
  height: 18px;
}

.commit-content {
  flex: 1;
  min-width: 0;
}

.commit-message {
  font-size: 13px;
  color: var(--panel-text);
  margin-bottom: 6px;
  line-height: 1.4;
  word-break: break-word;
}

.commit-meta {
  display: flex;
  align-items: center;
  gap: 8px;
  flex-wrap: wrap;
  font-size: 11px;
  color: var(--panel-text-muted);
}

.commit-avatar {
  width: 16px;
  height: 16px;
  border-radius: 50%;
}

.commit-author {
  font-weight: 500;
}

.commit-date {
  color: var(--panel-text-muted);
}

.commit-sha {
  font-family: 'SF Mono', 'Fira Code', 'Consolas', monospace;
  font-size: 11px;
  color: var(--panel-text-muted);
  text-decoration: none;
}

a.commit-sha:hover {
  color: var(--panel-accent);
}

/* 更新日志底部 */
.changelog-footer {
  margin-top: 16px;
  padding-top: 16px;
  border-top: 1px solid var(--panel-border);
  text-align: center;
}

.view-all-link {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 10px 16px;
  border: 1px solid var(--panel-border);
  border-radius: 8px;
  background: transparent;
  color: var(--panel-text);
  font-size: 13px;
  text-decoration: none;
  transition: all 0.2s ease;
}

.view-all-link:hover {
  background: var(--panel-hover);
  border-color: var(--panel-accent);
}

.view-all-link svg {
  width: 16px;
  height: 16px;
}

/* ========== AI 创作工具样式 (胜算云) ========== */

.ai-studio-tab {
  display: flex;
  flex-direction: column;
  gap: 16px;
}

/* 头部品牌区 */
.ssy-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 14px 16px;
  background: linear-gradient(135deg, rgba(99, 102, 241, 0.08) 0%, rgba(168, 85, 247, 0.08) 100%);
  border: 1px solid rgba(99, 102, 241, 0.15);
  border-radius: 10px;
}

.ssy-brand {
  display: flex;
  align-items: center;
  gap: 10px;
}

.ssy-logo {
  font-size: 28px;
  line-height: 1;
}

.ssy-brand h3 {
  margin: 0;
  font-size: 16px;
  font-weight: 700;
  color: var(--panel-text);
}

.ssy-subtitle {
  margin: 2px 0 0;
  font-size: 12px;
  color: var(--panel-text-muted);
}

.ssy-subtitle a {
  color: #8b5cf6;
  text-decoration: none;
  font-weight: 500;
}

.ssy-subtitle a:hover {
  text-decoration: underline;
}

.ssy-promo-badge {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  padding: 6px 12px;
  background: linear-gradient(135deg, #8b5cf6, #6366f1);
  color: white;
  font-size: 12px;
  font-weight: 600;
  border-radius: 20px;
  text-decoration: none;
  transition: all 0.2s ease;
  white-space: nowrap;
}

.ssy-promo-badge:hover {
  transform: translateY(-1px);
  box-shadow: 0 4px 12px rgba(99, 102, 241, 0.3);
}

/* API Key 配置区 */
.ssy-key-section {
  padding: 14px 16px;
  background: var(--panel-code-bg);
  border: 1px solid var(--panel-border);
  border-radius: 8px;
}

.ssy-label {
  display: block;
  font-size: 13px;
  font-weight: 600;
  color: var(--panel-text);
  margin-bottom: 8px;
}

.ssy-key-row {
  display: flex;
  gap: 8px;
}

.ssy-input {
  flex: 1;
  padding: 8px 12px;
  background: var(--panel-bg);
  border: 1px solid var(--panel-border);
  border-radius: 6px;
  color: var(--panel-text);
  font-size: 13px;
  font-family: 'SF Mono', 'Fira Code', 'Consolas', monospace;
  outline: none;
  transition: border-color 0.2s ease;
}

.ssy-input:focus {
  border-color: #8b5cf6;
}

.ssy-input::placeholder {
  color: var(--panel-text-muted);
  font-family: inherit;
}

.ssy-key-hint {
  margin: 6px 0 0;
  font-size: 12px;
  color: var(--panel-text-muted);
}

.ssy-key-hint a {
  color: #8b5cf6;
  text-decoration: none;
}

.ssy-key-hint a:hover {
  text-decoration: underline;
}

/* 通用按钮 */
.ssy-btn {
  padding: 8px 16px;
  border: none;
  border-radius: 6px;
  font-size: 13px;
  font-weight: 500;
  cursor: pointer;
  transition: all 0.2s ease;
  white-space: nowrap;
}

.ssy-btn-save {
  background: var(--panel-border);
  color: var(--panel-text);
}

.ssy-btn-save:hover {
  background: var(--panel-text-muted);
  color: var(--panel-bg);
}

.ssy-btn-primary {
  background: linear-gradient(135deg, #8b5cf6, #6366f1);
  color: white;
}

.ssy-btn-primary:hover {
  box-shadow: 0 4px 12px rgba(99, 102, 241, 0.3);
  transform: translateY(-1px);
}

.ssy-btn-primary:active {
  transform: translateY(0);
}

/* 工具列表 */
.ssy-tools {
  display: flex;
  flex-direction: column;
  gap: 4px;
}

/* 工具卡片 - 可点击展开 */
.ssy-tool-card {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 12px 14px;
  border: 1px solid var(--panel-border);
  border-radius: 8px;
  cursor: pointer;
  transition: all 0.2s ease;
}

.ssy-tool-card:hover {
  background: var(--panel-hover);
  border-color: rgba(99, 102, 241, 0.3);
}

.ssy-tool-card.expanded {
  border-bottom-left-radius: 0;
  border-bottom-right-radius: 0;
  border-bottom-color: transparent;
  background: var(--panel-hover);
}

.ssy-tool-card svg {
  width: 16px;
  height: 16px;
  color: var(--panel-text-muted);
  transition: transform 0.2s ease;
  flex-shrink: 0;
}

.ssy-tool-card.expanded svg {
  transform: rotate(180deg);
}

/* 禁用状态的工具卡片 */
.ssy-tool-card.ssy-tool-disabled {
  opacity: 0.6;
  cursor: not-allowed;
  background: var(--panel-code-bg);
}
.ssy-tool-card.ssy-tool-disabled:hover {
  transform: none;
  box-shadow: none;
  border-color: var(--panel-border);
}
.ssy-tool-card.ssy-tool-disabled .ssy-tool-icon {
  filter: grayscale(1);
}

/* 即将上线标签 */
.ssy-coming-soon {
  display: inline-block;
  font-size: 10px;
  font-weight: 500;
  padding: 2px 6px;
  border-radius: 4px;
  background: linear-gradient(135deg, #ff9500, #ff5e3a);
  color: white;
  margin-left: 6px;
  vertical-align: middle;
}

.ssy-beta-badge {
  display: inline-block;
  font-size: 10px;
  font-weight: 600;
  padding: 2px 6px;
  border-radius: 4px;
  background: linear-gradient(135deg, #0ea5e9, #2563eb);
  color: white;
  margin-left: 6px;
  vertical-align: middle;
}

.ssy-tool-icon {
  font-size: 24px;
  width: 40px;
  height: 40px;
  display: flex;
  align-items: center;
  justify-content: center;
  background: rgba(99, 102, 241, 0.1);
  border-radius: 8px;
  flex-shrink: 0;
}

.ssy-tool-info {
  flex: 1;
}

.ssy-tool-info h4 {
  margin: 0;
  font-size: 14px;
  font-weight: 600;
  color: var(--panel-text);
}

.ssy-tool-info p {
  margin: 2px 0 0;
  font-size: 12px;
  color: var(--panel-text-muted);
}

/* 工具展开面板 */
.ssy-tool-panel {
  display: none;
  border: 1px solid var(--panel-border);
  border-top: none;
  border-radius: 0 0 8px 8px;
  margin-top: -4px;
  margin-bottom: 4px;
}

.ssy-tool-panel.expanded {
  display: block;
  padding: 14px;
}

/* Textarea */
.ssy-textarea {
  width: 100%;
  padding: 10px 12px;
  background: var(--panel-bg);
  border: 1px solid var(--panel-border);
  border-radius: 6px;
  color: var(--panel-text);
  font-size: 13px;
  line-height: 1.5;
  resize: vertical;
  outline: none;
  transition: border-color 0.2s ease;
  box-sizing: border-box;
}

.ssy-textarea:focus {
  border-color: #8b5cf6;
}

.ssy-textarea::placeholder {
  color: var(--panel-text-muted);
}

/* 工具选项行 */
.ssy-tool-options {
  display: flex;
  align-items: center;
  gap: 8px;
  margin-top: 10px;
  flex-wrap: wrap;
}

/* Select 下拉框 */
.ssy-select {
  padding: 7px 10px;
  background: var(--panel-bg);
  border: 1px solid var(--panel-border);
  border-radius: 6px;
  color: var(--panel-text);
  font-size: 12px;
  outline: none;
  cursor: pointer;
  transition: border-color 0.2s ease;
}

.ssy-select:focus {
  border-color: #8b5cf6;
}

/* 结果区域 */
.ssy-result {
  margin-top: 12px;
  min-height: 0;
  clear: both;
  position: relative;
}

.ssy-result::after {
  content: "";
  display: table;
  clear: both;
}

.ssy-result:empty {
  display: none;
}

/* 生成的媒体结果容器 */
.ssy-media-result {
  clear: both;
  overflow: hidden;
  position: relative;
}

/* 生成的图片 */
.ssy-img-wrap {
  display: block;
  margin: 8px 0;
  border-radius: 8px;
  overflow: hidden;
  border: 1px solid var(--panel-border);
  max-width: 100%;
  clear: both;
}

.ssy-generated-img {
  max-width: 100%;
  max-height: 400px;
  display: block;
  border-radius: 8px;
  margin: 0 auto;
}

.ssy-download-link {
  position: absolute;
  bottom: 8px;
  right: 8px;
  padding: 4px 10px;
  background: rgba(0, 0, 0, 0.7);
  color: white;
  font-size: 11px;
  border-radius: 4px;
  text-decoration: none;
  opacity: 0;
  transition: opacity 0.2s ease;
}

.ssy-img-wrap:hover .ssy-download-link,
.ssy-video-wrap:hover .ssy-download-link {
  opacity: 1;
}

/* 生成的视频 */
.ssy-video-wrap {
  position: relative;
  margin: 8px 0;
  border-radius: 8px;
  overflow: hidden;
  border: 1px solid var(--panel-border);
}

.ssy-generated-video {
  width: 100%;
  max-height: 400px;
  display: block;
  border-radius: 8px;
}

/* 生成的音频 */
.ssy-audio-wrap {
  margin: 4px 0;
}

.ssy-generated-audio {
  width: 100%;
  border-radius: 8px;
}

.ssy-file-wrap {
  margin: 6px 0;
  padding: 10px 12px;
  border: 1px dashed var(--panel-border);
  border-radius: 8px;
  background: var(--panel-code-bg);
}

.ssy-file-link {
  color: #8b5cf6;
  text-decoration: none;
  font-size: 12px;
}

.ssy-file-link:hover {
  text-decoration: underline;
}

/* 错误信息 */
.ssy-error {
  padding: 10px 14px;
  background: rgba(239, 68, 68, 0.1);
  border: 1px solid rgba(239, 68, 68, 0.2);
  border-radius: 6px;
  color: #ef4444;
  font-size: 13px;
  line-height: 1.5;
}

/* 底部说明 */
.ssy-footer {
  text-align: center;
  padding-top: 8px;
}

.ssy-footer p {
  margin: 0;
  font-size: 11px;
  color: var(--panel-text-muted);
}

.ssy-footer a {
  color: #8b5cf6;
  text-decoration: none;
}

.ssy-footer a:hover {
  text-decoration: underline;
}

/* 测试连接按钮 */
.ssy-btn-test {
  background: var(--panel-border);
  color: var(--panel-text);
  white-space: nowrap;
}

.ssy-btn-test:hover {
  background: var(--panel-text-muted);
  color: var(--panel-bg);
}

/* 测试结果 */
.ssy-test-loading,
.ssy-test-ok,
.ssy-test-fail {
  margin: 6px 0 0;
  padding: 6px 10px;
  border-radius: 6px;
  font-size: 12px;
  line-height: 1.5;
}

.ssy-test-loading {
  color: var(--panel-text-muted);
  background: var(--panel-code-bg);
}

.ssy-test-ok {
  color: #22c55e;
  background: rgba(34, 197, 94, 0.1);
  border: 1px solid rgba(34, 197, 94, 0.2);
}

.ssy-test-fail {
  color: #ef4444;
  background: rgba(239, 68, 68, 0.1);
  border: 1px solid rgba(239, 68, 68, 0.2);
}

/* ========== 快速配置渠道样式 ========== */

.ssy-quick-config {
  padding: 14px 16px;
  background: var(--panel-code-bg);
  border: 1px solid var(--panel-border);
  border-radius: 8px;
  border-left: 3px solid #8b5cf6;
}

.ssy-config-desc {
  margin: 0 0 10px;
  font-size: 12px;
  color: var(--panel-text-muted);
}

.ssy-config-row {
  display: flex;
  flex-direction: column;
  gap: 8px;
  margin-bottom: 12px;
}

.ssy-model-select {
  width: 100%;
  padding: 8px 12px;
  font-size: 13px;
}

.ssy-custom-model-input {
  margin-top: 4px;
}

.ssy-config-cmd-block {
  display: flex;
  flex-direction: column;
  gap: 8px;
}

.ssy-config-cmd-label {
  font-size: 12px;
  color: var(--panel-text-muted);
  font-weight: 500;
}

.ssy-config-cmd {
  margin: 0;
  padding: 10px 12px;
  background: var(--panel-bg);
  border: 1px solid var(--panel-border);
  border-radius: 6px;
  font-family: 'SF Mono', 'Fira Code', 'Consolas', monospace;
  font-size: 11px;
  color: var(--panel-code-text);
  white-space: pre-wrap;
  word-break: break-all;
  line-height: 1.6;
  max-height: 160px;
  overflow-y: auto;
}

.ssy-config-actions {
  display: flex;
  gap: 8px;
  flex-wrap: wrap;
}

.ssy-btn-copy {
  background: linear-gradient(135deg, #8b5cf6, #6366f1);
  color: white;
  flex: 1;
}

.ssy-btn-copy:hover {
  box-shadow: 0 4px 12px rgba(99, 102, 241, 0.3);
  transform: translateY(-1px);
}

.ssy-btn-test-model {
  background: var(--panel-border);
  color: var(--panel-text);
  flex: 1;
}

.ssy-btn-test-model:hover {
  background: var(--panel-text-muted);
  color: var(--panel-bg);
}

/* 模型测试回复 */
.ssy-model-reply {
  margin: 4px 0 0;
  font-size: 12px;
  color: var(--panel-text-muted);
  font-style: italic;
}

/* 活动注释 */
.ssy-promo-note {
  margin: -8px 0 0;
  padding: 4px 16px;
  font-size: 11px;
  color: var(--panel-text-muted);
  text-align: right;
}

/* 多模态工具选项横向布局 */
.ssy-multimodal-row {
  display: flex;
  gap: 8px;
  align-items: center;
}

.ssy-model-input-wrap {
  flex: 1;
  display: flex;
  flex-direction: column;
  gap: 4px;
}

.ssy-model-input-wrap-full {
  flex: 1;
}

.ssy-custom-model {
  width: 100%;
  padding: 6px 10px;
  font-size: 12px;
  border: 1px solid var(--panel-border);
  border-radius: 6px;
  background: var(--panel-bg);
  color: var(--panel-text);
}

.ssy-custom-model:focus {
  outline: none;
  border-color: #8b5cf6;
  box-shadow: 0 0 0 2px rgba(139, 92, 246, 0.2);
}

.ssy-size-select,
.ssy-seconds-select {
  min-width: 110px;
}

.ssy-tool-actions {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  margin-top: 12px;
}

.ssy-default-model-label {
  display: flex;
  align-items: center;
  gap: 6px;
  font-size: 12px;
  color: var(--panel-text-muted);
  cursor: pointer;
  user-select: none;
}

.ssy-default-model-label input[type="checkbox"] {
  width: 16px;
  height: 16px;
  cursor: pointer;
  accent-color: #8b5cf6;
}

.ssy-default-model-label:hover {
  color: var(--panel-text);
}

/* 按钮加载状态 */
.ssy-btn-loading {
  opacity: 0.7;
  cursor: wait !important;
  pointer-events: none;
}

.ssy-btn-spinner {
  display: inline-block;
  width: 12px;
  height: 12px;
  border: 2px solid rgba(255,255,255,0.3);
  border-top-color: #fff;
  border-radius: 50%;
  animation: ssy-spin 0.8s linear infinite;
  vertical-align: middle;
  margin-right: 6px;
}

@keyframes ssy-spin {
  to { transform: rotate(360deg); }
}

/* 媒体结果样式 */
.ssy-media-result {
  margin-top: 12px;
  padding: 12px;
  background: var(--panel-code-bg);
  border: 1px solid var(--panel-border);
  border-radius: 8px;
}

.ssy-media-actions {
  display: flex;
  gap: 8px;
  margin-top: 10px;
  flex-wrap: wrap;
}

.ssy-action-btn {
  padding: 6px 12px;
  font-size: 12px;
  border: 1px solid var(--panel-border);
  border-radius: 6px;
  background: var(--panel-bg);
  color: var(--panel-text);
  cursor: pointer;
  transition: all 0.15s ease;
  display: inline-flex;
  align-items: center;
  gap: 4px;
}

.ssy-action-btn:hover {
  background: var(--panel-code-bg);
  border-color: var(--panel-accent);
  color: var(--panel-accent);
}

.ssy-generated-img {
  cursor: pointer;
  border-radius: 6px;
  max-width: 100%;
  transition: transform 0.2s ease;
}

.ssy-generated-img:hover {
  transform: scale(1.02);
}

/* 响应式适配 */
@media (max-width: 500px) {
  .ssy-header {
    flex-direction: column;
    align-items: flex-start;
    gap: 10px;
  }
  
  .ssy-tool-options {
    flex-direction: column;
    align-items: stretch;
  }

  .ssy-multimodal-row {
    flex-direction: column;
    align-items: stretch;
  }

  .ssy-size-select,
  .ssy-seconds-select {
    min-width: auto;
  }

  .ssy-key-row {
    flex-direction: column;
  }
}

/* ========== AI 创作 Tab 醒目样式 ========== */
.panel-tab[data-tab="ai-studio"] {
  color: #ef4444;
  font-weight: 600;
  position: relative;
}

.panel-tab[data-tab="ai-studio"]:hover {
  color: #dc2626;
}

.panel-tab[data-tab="ai-studio"].active {
  color: #ef4444;
}

.panel-tab[data-tab="ai-studio"].active::after {
  background: linear-gradient(90deg, #ef4444, #f59e0b);
}

/* HOT 徽章 */
.panel-tab[data-tab="ai-studio"] .hot-badge {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  margin-left: 4px;
  padding: 1px 5px;
  background: linear-gradient(135deg, #ef4444, #f59e0b);
  color: white;
  font-size: 9px;
  font-weight: 700;
  letter-spacing: 0.5px;
  border-radius: 4px;
  text-transform: uppercase;
  animation: hot-pulse 2s ease-in-out infinite;
}

@keyframes hot-pulse {
  0%, 100% { opacity: 1; transform: scale(1); }
  50% { opacity: 0.85; transform: scale(1.02); }
}

/* 火焰图标动画 */
.panel-tab[data-tab="ai-studio"] .fire-icon {
  display: inline-block;
  margin-right: 4px;
  animation: fire-flicker 0.8s ease-in-out infinite alternate;
}

@keyframes fire-flicker {
  0% { transform: scale(1) rotate(-2deg); }
  100% { transform: scale(1.05) rotate(2deg); }
}

/* ========== 动态表单样式 ========== */

.ssy-model-section {
  margin-bottom: 12px;
}

.ssy-model-select-full {
  width: 100%;
}

.ssy-model-select-row {
  display: flex;
  flex-direction: column;
  gap: 8px;
}

.ssy-dynamic-form {
  margin: 12px 0;
}

.ssy-dynamic-form-inner {
  display: flex;
  flex-direction: column;
  gap: 12px;
}

.ssy-form-group {
  display: flex;
  flex-direction: column;
  gap: 4px;
}

.ssy-form-label {
  font-size: 13px;
  font-weight: 500;
  color: var(--panel-text);
}

.ssy-required {
  color: #ef4444;
  margin-left: 2px;
}

.ssy-form-checkbox {
  flex-direction: row;
  align-items: center;
}

.ssy-checkbox-label {
  display: flex;
  align-items: center;
  gap: 8px;
  cursor: pointer;
  font-size: 13px;
}

.ssy-checkbox-label input[type="checkbox"] {
  width: 16px;
  height: 16px;
  cursor: pointer;
  accent-color: #8b5cf6;
}

.ssy-dyn-select,
.ssy-dyn-number,
.ssy-dyn-text,
.ssy-dyn-textarea {
  width: 100%;
}

/* 文件上传样式 */
.ssy-form-file {
  background: var(--panel-code-bg);
  border: 1px solid var(--panel-border);
  border-radius: 8px;
  padding: 12px;
}

.ssy-file-upload-wrap {
  display: flex;
  flex-direction: column;
  gap: 8px;
}

.ssy-file-input {
  display: none;
}

.ssy-file-btn {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 8px 16px;
  background: var(--panel-bg);
  border: 1px dashed var(--panel-border);
  border-radius: 6px;
  cursor: pointer;
  font-size: 13px;
  color: var(--panel-text);
  transition: all 0.15s ease;
}

.ssy-file-btn:hover {
  border-color: #8b5cf6;
  color: #8b5cf6;
  background: rgba(139, 92, 246, 0.05);
}

.ssy-file-preview {
  margin-top: 8px;
}

.ssy-file-preview-img img,
.ssy-file-preview-video video {
  max-width: 100%;
  max-height: 200px;
  border-radius: 6px;
  object-fit: contain;
}

.ssy-file-preview-audio audio {
  width: 100%;
  max-width: 300px;
}

.ssy-file-preview-img,
.ssy-file-preview-video,
.ssy-file-preview-audio {
  position: relative;
  display: inline-block;
}

.ssy-file-clear {
  position: absolute;
  top: 4px;
  right: 4px;
  width: 24px;
  height: 24px;
  border-radius: 50%;
  background: rgba(239, 68, 68, 0.9);
  color: white;
  border: none;
  cursor: pointer;
  font-size: 14px;
  line-height: 1;
  display: flex;
  align-items: center;
  justify-content: center;
}

.ssy-file-clear:hover {
  background: #ef4444;
}

.ssy-hint {
  padding: 12px;
  background: var(--panel-code-bg);
  border: 1px dashed var(--panel-border);
  border-radius: 8px;
  font-size: 12px;
  color: var(--panel-text-muted);
  text-align: center;
}

/* ========== 修复图片遮住内容问题 ========== */

.ssy-result {
  clear: both;
  overflow: hidden;
}

.ssy-img-wrap {
  display: block;
  width: 100%;
  margin: 8px 0;
  border-radius: 8px;
  overflow: hidden;
  border: 1px solid var(--panel-border);
  background: var(--panel-code-bg);
}

.ssy-generated-img {
  display: block;
  max-width: 100%;
  max-height: 400px;
  margin: 0 auto;
  border-radius: 8px;
}

.ssy-video-wrap {
  display: block;
  width: 100%;
  clear: both;
}

.ssy-generated-video {
  width: 100%;
  max-height: 400px;
  display: block;
  border-radius: 8px;
  background: #000;
}

.ssy-audio-wrap {
  display: block;
  width: 100%;
  clear: both;
}

.ssy-generated-audio {
  width: 100%;
  max-width: 100%;
}

/* optgroup 样式 */
.ssy-select optgroup {
  font-weight: 600;
  color: var(--panel-text);
}

.ssy-select option {
  font-weight: 400;
  color: var(--panel-text);
}

