:root{--bg-0: #0a0c10;--bg-1: #11151c;--bg-2: #161b22;--bg-3: #1c232d;--bg-hover: #1f2937;--bg-active: #232f3e;--border-0: #1f2937;--border-1: #2a3441;--border-2: #3a4757;--border-focus: #4b5563;--text-0: #f0f6fc;--text-1: #e6edf3;--text-2: #c9d1d9;--text-3: #8b949e;--text-4: #6e7681;--text-muted: #484f58;--accent: #a6f5c5;--accent-strong: #5cf2b1;--accent-hover: #8ee8b3;--accent-fg: #0a0c10;--success: #3fb950;--success-bg: rgba(63, 185, 80, .12);--warning: #d29922;--warning-bg: rgba(210, 153, 34, .12);--danger: #f85149;--danger-bg: rgba(248, 81, 73, .12);--info: #58a6ff;--info-bg: rgba(88, 166, 255, .12);--space-0: 0;--space-1: 4px;--space-2: 8px;--space-3: 12px;--space-4: 16px;--space-5: 20px;--space-6: 24px;--space-7: 32px;--space-8: 40px;--space-9: 48px;--space-10: 64px;--radius-0: 0;--radius-1: 2px;--radius-2: 4px;--radius-3: 6px;--radius-4: 10px;--radius-full: 9999px;--font-sans: "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", "PingFang SC", "Microsoft YaHei", sans-serif;--font-mono: "JetBrains Mono", "SF Mono", Menlo, Consolas, monospace;--fs-0: 11px;--fs-1: 12px;--fs-2: 13px;--fs-3: 14px;--fs-4: 15px;--fs-5: 16px;--fs-6: 18px;--fs-7: 20px;--fs-8: 24px;--fs-9: 32px;--fw-regular: 400;--fw-medium: 500;--fw-semibold: 600;--fw-bold: 700;--shadow-0: none;--shadow-1: 0 1px 0 rgba(0, 0, 0, .3);--shadow-modal: 0 8px 32px rgba(0, 0, 0, .5);--sidebar-width: 220px;--sidebar-collapsed: 56px;--topbar-height: 48px;--content-max: 1280px;--t-fast: .1s ease;--t-base: .16s ease;--t-slow: .24s ease}*{box-sizing:border-box}html,body,#app{height:100%;margin:0;padding:0}body{background:var(--bg-0);color:var(--text-1);font-family:var(--font-sans);font-size:var(--fs-3);line-height:1.5;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;overflow:hidden}a{color:var(--accent);text-decoration:none}a:hover{color:var(--accent-strong)}button{font-family:inherit;font-size:inherit;color:inherit;cursor:pointer;background:none;border:none;padding:0}input,select,textarea{font-family:inherit;font-size:inherit;color:var(--text-1)}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--border-1);border-radius:var(--radius-full)}::-webkit-scrollbar-thumb:hover{background:var(--border-2)}::selection{background:#a6f5c533;color:var(--text-0)}.mono{font-family:var(--font-mono)}.muted{color:var(--text-3)}.muted-2{color:var(--text-4)}.h1,.h2,.h3,.h4{margin:0;font-weight:var(--fw-semibold);color:var(--text-0);letter-spacing:-.01em}.h1{font-size:var(--fs-8)}.h2{font-size:var(--fs-7)}.h3{font-size:var(--fs-6)}.h4{font-size:var(--fs-4)}.eyebrow{font-size:var(--fs-1);font-weight:var(--fw-semibold);color:var(--text-4);text-transform:uppercase;letter-spacing:.08em;margin:0}.divider{height:1px;background:var(--border-0);border:0;margin:var(--space-4) 0}.divider-soft{height:1px;background:var(--border-0);border:0;margin:var(--space-3) 0;opacity:.5}.grid-2{display:grid;grid-template-columns:1fr 1fr;gap:var(--space-4)}.grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--space-4)}.grid-4{display:grid;grid-template-columns:repeat(4,1fr);gap:var(--space-4)}@media (max-width: 900px){.grid-2,.grid-3,.grid-4{grid-template-columns:1fr}}.stack{display:flex;flex-direction:column;gap:var(--space-3)}.stack-2{display:flex;flex-direction:column;gap:var(--space-2)}.stack-4{display:flex;flex-direction:column;gap:var(--space-4)}.row{display:flex;align-items:center;gap:var(--space-3)}.row-2{display:flex;align-items:center;gap:var(--space-2)}.row-end{display:flex;align-items:center;justify-content:flex-end;gap:var(--space-3)}.row-between{display:flex;align-items:center;justify-content:space-between;gap:var(--space-3)}.wrap{flex-wrap:wrap}.grow{flex:1 1 auto;min-width:0}.text-right{text-align:right}.text-center{text-align:center}.nowrap{white-space:nowrap}.truncate{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.empty-hint{color:var(--text-4);font-size:var(--fs-2);font-style:italic;padding:var(--space-2) 0}.danger-text{color:var(--danger)}.success-text{color:var(--success)}.warning-text{color:var(--warning)}.accent-text{color:var(--accent)}.config-warning{color:var(--warning);font-size:var(--fs-2);margin-top:var(--space-1);display:block}.scroll-y{overflow-y:auto;overflow-x:hidden}.scroll-area{overflow:auto}.save-zone{position:sticky;bottom:0;background:linear-gradient(180deg,transparent,var(--bg-1) 30%);padding:var(--space-4) 0 var(--space-3)}.btn{display:inline-flex;align-items:center;gap:var(--space-2);padding:6px 12px;font-size:var(--fs-2);font-weight:var(--fw-medium);line-height:1.4;border:1px solid var(--border-1);border-radius:var(--radius-2);background:var(--bg-2);color:var(--text-1);transition:background var(--t-fast),border-color var(--t-fast),color var(--t-fast);white-space:nowrap;-webkit-user-select:none;user-select:none}.btn:hover{background:var(--bg-hover);border-color:var(--border-2)}.btn:active{background:var(--bg-active)}.btn:disabled{opacity:.4;cursor:not-allowed}.btn:focus-visible{outline:2px solid var(--accent);outline-offset:1px}.btn-primary{background:var(--accent);color:var(--accent-fg);border-color:var(--accent);font-weight:var(--fw-semibold)}.btn-primary:hover{background:var(--accent-hover);border-color:var(--accent-hover)}.btn-primary:disabled{background:var(--bg-2);color:var(--text-4);border-color:var(--border-0)}.btn-ghost{background:transparent;border-color:transparent;color:var(--text-2)}.btn-ghost:hover{background:var(--bg-hover);color:var(--text-0)}.btn-danger{color:var(--danger);border-color:var(--border-1);background:var(--bg-2)}.btn-danger:hover{background:var(--danger-bg);border-color:var(--danger)}.btn-sm{padding:4px 8px;font-size:var(--fs-1)}.btn-lg{padding:8px 16px;font-size:var(--fs-3)}.btn-block{width:100%;justify-content:center}.btn-icon{padding:6px}.btn-icon.btn-sm{padding:4px}.card{background:var(--bg-1);border:1px solid var(--border-0);border-radius:var(--radius-3);padding:var(--space-5)}.card-compact{padding:var(--space-4)}.card-header{display:flex;align-items:center;justify-content:space-between;gap:var(--space-3);margin-bottom:var(--space-4)}.card-title{font-size:var(--fs-5);font-weight:var(--fw-semibold);color:var(--text-0);margin:0}.card-subtitle{font-size:var(--fs-2);color:var(--text-3);margin-top:var(--space-1)}.card-featured{border-color:var(--border-1);background:linear-gradient(180deg,var(--bg-2) 0%,var(--bg-1) 100%)}.field{display:flex;flex-direction:column;gap:var(--space-1)}.field-label{font-size:var(--fs-2);font-weight:var(--fw-medium);color:var(--text-2)}.field-help{font-size:var(--fs-1);color:var(--text-4);line-height:1.4}.input,.select,.textarea{width:100%;padding:6px 10px;background:var(--bg-0);border:1px solid var(--border-1);border-radius:var(--radius-2);color:var(--text-1);font-size:var(--fs-3);transition:border-color var(--t-fast)}.input:hover,.select:hover,.textarea:hover{border-color:var(--border-2)}.input:focus,.select:focus,.textarea:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px #a6f5c51a}.input::placeholder{color:var(--text-4)}.textarea{resize:vertical;min-height:80px;font-family:inherit}.input-sm{padding:4px 8px;font-size:var(--fs-2)}.input-mono{font-family:var(--font-mono);font-size:var(--fs-2)}.toggle{display:inline-flex;align-items:center;gap:var(--space-2);cursor:pointer;-webkit-user-select:none;user-select:none;font-size:var(--fs-3);color:var(--text-1)}.toggle input{display:none}.toggle-track{width:32px;height:18px;background:var(--bg-3);border:1px solid var(--border-1);border-radius:var(--radius-full);position:relative;transition:background var(--t-base);flex-shrink:0}.toggle-track:after{content:"";position:absolute;top:2px;left:2px;width:12px;height:12px;background:var(--text-3);border-radius:50%;transition:transform var(--t-base),background var(--t-base)}.toggle input:checked+.toggle-track{background:var(--accent);border-color:var(--accent)}.toggle input:checked+.toggle-track:after{transform:translate(14px);background:var(--accent-fg)}.badge{display:inline-flex;align-items:center;gap:4px;padding:2px 8px;font-size:var(--fs-1);font-weight:var(--fw-medium);border-radius:var(--radius-full);border:1px solid var(--border-1);background:var(--bg-2);color:var(--text-2);white-space:nowrap}.badge-success{color:var(--success);background:var(--success-bg);border-color:#3fb9504d}.badge-warning{color:var(--warning);background:var(--warning-bg);border-color:#d299224d}.badge-danger{color:var(--danger);background:var(--danger-bg);border-color:#f851494d}.badge-info{color:var(--info);background:var(--info-bg);border-color:#58a6ff4d}.badge-accent{color:var(--accent);background:#a6f5c51a;border-color:#a6f5c54d}.pill{display:inline-flex;align-items:center;gap:4px;padding:4px 10px;font-size:var(--fs-2);background:var(--bg-2);border:1px solid var(--border-0);border-radius:var(--radius-full);color:var(--text-2);cursor:pointer;transition:all var(--t-fast)}.pill:hover{background:var(--bg-hover);border-color:var(--border-1)}.pill.selected{background:#a6f5c51a;border-color:var(--accent);color:var(--accent)}.pill-disabled{opacity:.5;cursor:not-allowed}.tabs{display:flex;gap:var(--space-1);border-bottom:1px solid var(--border-0);padding:0 var(--space-5);overflow-x:auto;scrollbar-width:none}.tabs::-webkit-scrollbar{display:none}.tab{padding:var(--space-3) var(--space-4);font-size:var(--fs-3);font-weight:var(--fw-medium);color:var(--text-3);border:none;background:none;cursor:pointer;position:relative;transition:color var(--t-fast);white-space:nowrap}.tab:hover{color:var(--text-1)}.tab.active{color:var(--text-0)}.tab.active:after{content:"";position:absolute;bottom:-1px;left:0;right:0;height:2px;background:var(--accent)}.tab-badge{margin-left:var(--space-1);padding:0 6px;font-size:var(--fs-0);background:var(--bg-3);border-radius:var(--radius-full);color:var(--text-3)}.tab.active .tab-badge{background:#a6f5c526;color:var(--accent)}.modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#0009;display:flex;align-items:center;justify-content:center;z-index:100;padding:var(--space-5)}.modal{background:var(--bg-1);border:1px solid var(--border-1);border-radius:var(--radius-4);max-width:560px;width:100%;max-height:80vh;display:flex;flex-direction:column;box-shadow:var(--shadow-modal)}.modal-header{display:flex;align-items:center;justify-content:space-between;padding:var(--space-4) var(--space-5);border-bottom:1px solid var(--border-0)}.modal-title{font-size:var(--fs-5);font-weight:var(--fw-semibold);color:var(--text-0);margin:0}.modal-body{padding:var(--space-5);overflow-y:auto;flex:1}.modal-footer{padding:var(--space-4) var(--space-5);border-top:1px solid var(--border-0);display:flex;justify-content:flex-end;gap:var(--space-2)}.toast{position:fixed;bottom:var(--space-5);left:50%;transform:translate(-50%);background:var(--bg-2);border:1px solid var(--border-1);color:var(--text-0);padding:var(--space-3) var(--space-5);border-radius:var(--radius-3);font-size:var(--fs-3);z-index:200;box-shadow:var(--shadow-modal)}.app-layout{display:grid;grid-template-columns:var(--sidebar-width) 1fr;height:100vh}.sidebar{background:var(--bg-1);border-right:1px solid var(--border-0);display:flex;flex-direction:column;overflow:hidden}.sidebar-header{padding:var(--space-4) var(--space-4);border-bottom:1px solid var(--border-0);display:flex;align-items:center;gap:var(--space-2)}.sidebar-brand{font-size:var(--fs-4);font-weight:var(--fw-bold);color:var(--text-0);letter-spacing:-.02em}.sidebar-brand-accent{color:var(--accent)}.sidebar-nav{flex:1;overflow-y:auto;padding:var(--space-2)}.nav-item{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-2) var(--space-3);margin:2px 0;border-radius:var(--radius-2);color:var(--text-2);font-size:var(--fs-3);cursor:pointer;transition:all var(--t-fast);border:1px solid transparent}.nav-item:hover{background:var(--bg-hover);color:var(--text-0)}.nav-item.active{background:#a6f5c514;color:var(--accent);border-color:#a6f5c533}.nav-item-icon{flex-shrink:0;opacity:.8}.nav-item.active .nav-item-icon{opacity:1}.nav-item-label{flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.nav-item-eyebrow{font-size:var(--fs-0);color:var(--text-4);font-weight:var(--fw-medium);text-transform:uppercase;letter-spacing:.05em}.sidebar-footer{padding:var(--space-3) var(--space-4);border-top:1px solid var(--border-0);font-size:var(--fs-1);color:var(--text-4)}.guild-switcher{display:inline-flex;align-items:center;gap:var(--space-2);padding:4px 10px;background:var(--bg-2);border:1px solid var(--border-1);border-radius:var(--radius-2);min-width:220px}.guild-switcher .select{flex:1;min-width:160px;padding:6px 10px;font-size:var(--fs-3);border-radius:var(--radius-2);border:1px solid var(--border-1);background:var(--bg-0);color:var(--text-0)}.guild-switcher .select:focus{border-color:var(--accent);box-shadow:0 0 0 3px #a6f5c51a}.guild-switcher .select option{background:var(--bg-0);color:var(--text-0)}.guild-switcher-status{flex:1;min-width:160px;padding:6px 10px;font-size:var(--fs-3);color:var(--text-3);text-align:left}.guild-switcher-status.danger{color:var(--danger)}.main-area{display:flex;flex-direction:column;overflow:hidden;background:var(--bg-0)}.topbar{height:var(--topbar-height);padding:0 var(--space-5);display:flex;align-items:center;gap:var(--space-4);border-bottom:1px solid var(--border-0);background:var(--bg-1);flex-shrink:0}.breadcrumb{display:flex;align-items:center;gap:var(--space-2);font-size:var(--fs-2);color:var(--text-3)}.breadcrumb-current{color:var(--text-0);font-weight:var(--fw-medium)}.breadcrumb-sep{color:var(--text-4)}.content{flex:1;overflow-y:auto;padding:var(--space-5)}.content-narrow{max-width:var(--content-max);margin:0 auto}.module-header{margin-bottom:var(--space-5)}.module-eyebrow{font-size:var(--fs-1);color:var(--text-4);text-transform:uppercase;letter-spacing:.08em;font-weight:var(--fw-semibold);margin:0 0 var(--space-1)}.module-title{font-size:var(--fs-8);font-weight:var(--fw-bold);color:var(--text-0);margin:0 0 var(--space-2);letter-spacing:-.02em}.module-desc{font-size:var(--fs-3);color:var(--text-3);margin:0;max-width:720px}.role-chip{display:inline-flex;align-items:center;gap:var(--space-2);padding:4px 10px;border:1px solid var(--border-1);border-radius:var(--radius-full);background:var(--bg-2);color:var(--text-2);font-size:var(--fs-2);cursor:pointer;transition:all var(--t-fast)}.role-chip:hover{background:var(--bg-hover);border-color:var(--border-2)}.role-chip.selected{background:#a6f5c514;border-color:var(--accent);color:var(--text-0)}.role-dot{width:10px;height:10px;border-radius:50%;flex-shrink:0;border:1px solid rgba(255,255,255,.1)}.picker-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:var(--space-2);max-height:280px;overflow-y:auto;padding:var(--space-2);background:var(--bg-0);border:1px solid var(--border-0);border-radius:var(--radius-2)}.picker-item{padding:6px 10px;font-size:var(--fs-2);border-radius:var(--radius-2);cursor:pointer;color:var(--text-2);border:1px solid transparent;transition:all var(--t-fast);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.picker-item:hover{background:var(--bg-hover);color:var(--text-0)}.picker-item.selected{background:#a6f5c514;color:var(--accent);border-color:#a6f5c533}.collapsible{border:1px solid var(--border-0);border-radius:var(--radius-3);background:var(--bg-1);overflow:hidden}.collapsible-head{display:flex;align-items:center;justify-content:space-between;padding:var(--space-3) var(--space-4);cursor:pointer;-webkit-user-select:none;user-select:none}.collapsible-head:hover{background:var(--bg-hover)}.collapsible-body{padding:0 var(--space-4) var(--space-4);border-top:1px solid var(--border-0)}.empty-state{text-align:center;padding:var(--space-7) var(--space-5);color:var(--text-4)}.empty-state-title{font-size:var(--fs-4);color:var(--text-2);margin-bottom:var(--space-2)}.empty-state-desc{font-size:var(--fs-2)}.save-bar{position:sticky;bottom:0;display:flex;align-items:center;justify-content:space-between;gap:var(--space-3);padding:var(--space-3) var(--space-5);background:var(--bg-1);border-top:1px solid var(--border-1)}.save-status{font-size:var(--fs-2);color:var(--text-3)}.save-status.dirty{color:var(--warning)}.save-status.saved{color:var(--success)}.help-block{font-size:var(--fs-1);color:var(--text-4);line-height:1.5;padding:var(--space-1) 0}.login-screen{height:100vh;display:flex;align-items:center;justify-content:center;background:var(--bg-0)}.login-card{width:320px;padding:var(--space-7);background:var(--bg-1);border:1px solid var(--border-1);border-radius:var(--radius-4)}.login-title{font-size:var(--fs-7);font-weight:var(--fw-bold);color:var(--text-0);margin:0 0 var(--space-2)}.login-sub{color:var(--text-3);margin:0 0 var(--space-5);font-size:var(--fs-3)}.runtime-pill{display:inline-flex;align-items:center;gap:6px;font-size:var(--fs-2);padding:3px 8px;border-radius:var(--radius-full);border:1px solid var(--border-1)}.runtime-pill .dot{width:6px;height:6px;border-radius:50%;background:var(--text-4)}.runtime-pill.running{color:var(--success);border-color:#3fb9504d;background:var(--success-bg)}.runtime-pill.running .dot{background:var(--success);box-shadow:0 0 6px var(--success)}.runtime-pill.stopped{color:var(--text-3)}.runtime-pill.error{color:var(--danger);border-color:#f851494d;background:var(--danger-bg)}.runtime-pill.error .dot{background:var(--danger)}.section-list{display:flex;flex-direction:column;gap:var(--space-3)}.list-item{display:flex;align-items:center;justify-content:space-between;gap:var(--space-3);padding:var(--space-3) var(--space-4);background:var(--bg-1);border:1px solid var(--border-0);border-radius:var(--radius-2)}.list-item:hover{border-color:var(--border-1)}.chip-group{display:flex;gap:var(--space-2);flex-wrap:wrap}.channel-block{padding:var(--space-4);background:var(--bg-1);border:1px solid var(--border-0);border-radius:var(--radius-3)}.channel-block-title{font-size:var(--fs-3);font-weight:var(--fw-semibold);color:var(--text-1);margin:0 0 var(--space-1)}.channel-block-desc{font-size:var(--fs-2);color:var(--text-3);margin:0 0 var(--space-3)}.section-header{display:flex;align-items:center;justify-content:space-between;gap:var(--space-3);margin-bottom:var(--space-3)}.section-title{font-size:var(--fs-4);font-weight:var(--fw-semibold);color:var(--text-0);margin:0}.footer-actions{display:flex;gap:var(--space-2);margin-top:var(--space-4);padding-top:var(--space-4);border-top:1px solid var(--border-0)}.log-box{font-family:var(--font-mono);font-size:var(--fs-1);background:var(--bg-0);border:1px solid var(--border-0);border-radius:var(--radius-2);padding:var(--space-3);max-height:320px;overflow-y:auto;color:var(--text-2);white-space:pre-wrap;line-height:1.6}
