:root{--bg-darkest: #16181d;--bg-darker: #1c1f26;--bg-dark: #232730;--bg-mid: #2a2f3a;--bg-hover: #323844;--bg-active: #3a4150;--text-primary: #e6e8ee;--text-secondary: #a8adb9;--text-muted: #707684;--text-faint: #4f545e;--accent: #6f7bff;--accent-hover: #8089ff;--accent-soft: rgba(111, 123, 255, .15);--success: #43b581;--warning: #f0a936;--danger: #e25c5c;--info: #4cc1d5;--border: #2c313b;--border-light: #353b48;--shadow-1: 0 2px 10px rgba(0,0,0,.25);--shadow-2: 0 8px 24px rgba(0,0,0,.4);--radius-sm: 4px;--radius: 8px;--radius-lg: 12px;--side-w: 240px;--font-sans: "Inter", "Helvetica Neue", "Noto Sans TC", system-ui, -apple-system, sans-serif;--font-mono: "JetBrains Mono", "Menlo", "Consolas", monospace}*{box-sizing:border-box}html,body,#root{height:100%;margin:0}body{background:var(--bg-darkest);color:var(--text-primary);font-family:var(--font-sans);font-size:14px;line-height:1.4;-webkit-font-smoothing:antialiased;overflow:hidden}button{font-family:inherit;cursor:pointer;border:none;background:none;color:inherit}input,select,textarea{font-family:inherit;font-size:14px}.app-layout{display:grid;grid-template-columns:var(--side-w) 1fr;height:100vh;background:var(--bg-darkest)}.sidebar{background:var(--bg-darker);display:flex;flex-direction:column;border-right:1px solid var(--border);min-width:0;min-height:0;overflow:hidden}.sidebar-header{height:48px;padding:0 16px;display:flex;align-items:center;gap:10px;border-bottom:1px solid var(--border);box-shadow:0 1px #0003;font-weight:700;font-size:15px;color:var(--text-primary);flex-shrink:0}.sidebar-header .brand-mark{width:28px;height:28px;border-radius:8px;background:var(--accent);display:flex;align-items:center;justify-content:center;color:#fff;font-weight:800;font-size:14px;flex-shrink:0}.sidebar-header .brand-text{display:flex;flex-direction:column;min-width:0;flex:1;line-height:1.1}.sidebar-header .brand-text .t1{font-size:14px;font-weight:700;color:var(--text-primary);display:flex;align-items:center;gap:6px}.sidebar-header .brand-text .t2{font-size:11px;color:var(--text-muted);font-family:var(--font-mono);margin-top:2px}.sidebar-section-title{padding:16px 8px 4px;font-size:11px;font-weight:700;letter-spacing:.04em;color:var(--text-muted);text-transform:uppercase;display:flex;align-items:center;justify-content:space-between}.sidebar-list{padding:0 8px;flex:1;overflow-y:auto}.nav-item{width:100%;display:flex;align-items:center;gap:8px;padding:7px 8px;border-radius:var(--radius-sm);color:var(--text-secondary);margin-bottom:1px;font-size:14px;font-weight:500;text-align:left;text-decoration:none}.nav-item:hover{background:var(--bg-hover);color:var(--text-primary)}.nav-item.active{background:var(--bg-active);color:var(--text-primary)}.nav-item .ico{width:20px;height:20px;display:flex;align-items:center;justify-content:center;color:var(--text-muted);flex-shrink:0}.nav-item.active .ico,.nav-item:hover .ico{color:var(--text-primary)}.nav-item .badge{margin-left:auto;background:var(--bg-mid);color:var(--text-secondary);font-size:11px;font-weight:600;padding:2px 6px;border-radius:10px}.nav-item .dot{margin-left:auto;width:8px;height:8px;border-radius:50%}.dot.green{background:var(--success)}.dot.yellow{background:var(--warning)}.dot.red{background:var(--danger)}.dot.gray{background:var(--text-muted)}.sidebar-footer{height:52px;background:#0003;border-top:1px solid var(--border);display:flex;align-items:center;padding:0 8px;gap:8px}.user-chip{display:flex;align-items:center;gap:8px;padding:4px 8px;border-radius:var(--radius-sm);flex:1;min-width:0}.user-chip:hover{background:var(--bg-hover)}.avatar{width:32px;height:32px;border-radius:50%;background:linear-gradient(135deg,var(--accent),#b16fff);display:flex;align-items:center;justify-content:center;font-weight:700;color:#fff;font-size:13px;position:relative;flex-shrink:0}.avatar:after{content:"";position:absolute;bottom:-2px;right:-2px;width:12px;height:12px;border-radius:50%;background:var(--success);border:3px solid var(--bg-darker)}.user-info{min-width:0;flex:1}.user-info .name{font-size:13px;font-weight:600;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.user-info .meta{font-size:11px;color:var(--text-muted)}.icon-btn{width:32px;height:32px;border-radius:var(--radius-sm);display:flex;align-items:center;justify-content:center;color:var(--text-secondary)}.icon-btn:hover{background:var(--bg-hover);color:var(--text-primary)}.main-area{display:flex;flex-direction:column;background:var(--bg-dark);min-width:0;min-height:0;overflow:hidden;position:relative}.topbar{height:48px;border-bottom:1px solid var(--border);background:var(--bg-dark);display:flex;align-items:center;padding:0 16px;gap:12px;box-shadow:0 1px #0003;flex-shrink:0}.topbar .crumb{display:flex;align-items:center;gap:8px;font-weight:600;color:var(--text-primary)}.topbar .crumb .hash{color:var(--text-muted);font-weight:400;font-size:20px;margin-right:2px}.topbar .divider{width:1px;height:20px;background:var(--border-light);margin:0 4px}.topbar .desc{color:var(--text-muted);font-size:13px}.topbar .actions{margin-left:auto;display:flex;align-items:center;gap:8px}.content{flex:1;overflow-y:auto;padding:24px 32px 80px}.card{background:var(--bg-darker);border:1px solid var(--border);border-radius:var(--radius);padding:16px}.card-h{display:flex;align-items:center;justify-content:space-between;margin-bottom:12px}.card-title{font-size:12px;font-weight:700;letter-spacing:.04em;text-transform:uppercase;color:var(--text-muted)}.kpi-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:12px}.kpi{background:var(--bg-darker);border:1px solid var(--border);border-radius:var(--radius);padding:16px;position:relative;overflow:hidden}.kpi .label{font-size:11px;font-weight:700;letter-spacing:.05em;text-transform:uppercase;color:var(--text-muted);display:flex;align-items:center;gap:6px}.kpi .value{font-size:28px;font-weight:700;color:var(--text-primary);margin-top:6px;font-variant-numeric:tabular-nums;display:flex;align-items:baseline;gap:4px}.kpi .value .unit{font-size:14px;font-weight:500;color:var(--text-muted)}.kpi .delta{margin-top:4px;font-size:12px;color:var(--text-secondary)}.kpi .delta.up{color:var(--success)}.kpi .delta.down{color:var(--danger)}.kpi-spark{position:absolute;right:10px;top:14px;bottom:14px;width:80px;opacity:.7}.bar{height:6px;background:var(--bg-mid);border-radius:3px;overflow:hidden;margin-top:10px}.bar>span{display:block;height:100%;background:var(--accent);border-radius:3px;transition:width .3s}.bar.success>span{background:var(--success)}.bar.warning>span{background:var(--warning)}.bar.danger>span{background:var(--danger)}.btn{height:32px;padding:0 14px;border-radius:var(--radius-sm);display:inline-flex;align-items:center;gap:6px;background:var(--bg-mid);color:var(--text-primary);font-weight:500;font-size:14px;transition:background .12s,transform .06s}.btn:hover{background:var(--bg-hover)}.btn:active{transform:translateY(1px)}.btn.primary{background:var(--accent);color:#fff}.btn.primary:hover{background:var(--accent-hover)}.btn.success{background:var(--success);color:#fff}.btn.danger{background:var(--danger);color:#fff}.btn.ghost{background:transparent}.btn.ghost:hover{background:var(--bg-hover)}.btn.sm{height:28px;padding:0 10px;font-size:13px}.btn:disabled{opacity:.5;cursor:not-allowed}.field{margin-bottom:18px}.field-label{display:block;font-size:11px;font-weight:700;letter-spacing:.04em;text-transform:uppercase;color:var(--text-secondary);margin-bottom:8px}.field-hint{font-size:12px;color:var(--text-muted);margin-top:6px}.input,.select,.textarea{width:100%;background:var(--bg-darkest);border:1px solid var(--border-light);color:var(--text-primary);border-radius:var(--radius-sm);padding:10px 12px;outline:none;transition:border-color .1s}.input:focus,.select:focus,.textarea:focus{border-color:var(--accent)}.input.mono,.textarea.mono{font-family:var(--font-mono);font-size:13px}.textarea{resize:vertical;min-height:80px}.select{-webkit-appearance:none;-moz-appearance:none;appearance:none;padding-right:32px;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath fill='%23a8adb9' d='M2 4l4 4 4-4z'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 10px center}.toggle{position:relative;width:40px;height:22px;border-radius:11px;background:var(--bg-mid);transition:background .15s;cursor:pointer;flex-shrink:0}.toggle:after{content:"";position:absolute;top:3px;left:3px;width:16px;height:16px;border-radius:50%;background:#fff;transition:transform .15s}.toggle.on{background:var(--accent)}.toggle.on:after{transform:translate(18px)}.row{display:flex;align-items:center;justify-content:space-between;padding:12px 0;border-bottom:1px solid var(--border)}.row:last-child{border-bottom:none}.row .label-block .l{font-size:14px;font-weight:600;color:var(--text-primary)}.row .label-block .h{font-size:12px;color:var(--text-muted);margin-top:2px}.pill{display:inline-flex;align-items:center;gap:6px;background:var(--bg-mid);padding:3px 8px;border-radius:12px;font-size:11px;font-weight:600;color:var(--text-secondary)}.pill.green{background:#43b58126;color:var(--success)}.pill.yellow{background:#f0a93626;color:var(--warning)}.pill.red{background:#e25c5c26;color:var(--danger)}.pill.blue{background:#4cc1d526;color:var(--info)}.pill .pdot{width:6px;height:6px;border-radius:50%;background:currentColor}.page-h{margin-bottom:24px;display:flex;align-items:end;justify-content:space-between;gap:16px}.page-h h1{font-size:22px;font-weight:700;margin:0 0 4px}.page-h p{margin:0;color:var(--text-muted);font-size:13px}.section-h{margin:28px 0 12px;font-size:12px;font-weight:700;letter-spacing:.04em;text-transform:uppercase;color:var(--text-muted);display:flex;align-items:center;gap:8px}.section-h:after{content:"";flex:1;height:1px;background:var(--border)}.g2{display:grid;grid-template-columns:1fr 1fr;gap:16px}.g3{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}.g-7-3{display:grid;grid-template-columns:7fr 3fr;gap:16px}.g-2-1{display:grid;grid-template-columns:2fr 1fr;gap:16px}.table{width:100%;border-collapse:collapse;font-size:13px}.table th{text-align:left;font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.04em;color:var(--text-muted);padding:8px 12px;border-bottom:1px solid var(--border)}.table td{padding:10px 12px;border-bottom:1px solid var(--border);color:var(--text-secondary)}.table tr:last-child td{border-bottom:none}.table tr:hover td{background:#ffffff05}.table .name{color:var(--text-primary);font-weight:500}.metric-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1px;background:var(--border);border:1px solid var(--border);border-radius:var(--radius);overflow:hidden}.metric-grid .m{background:var(--bg-darker);padding:14px 16px}.metric-grid .m .lbl{font-size:11px;color:var(--text-muted);text-transform:uppercase;letter-spacing:.04em;font-weight:700}.metric-grid .m .vl{font-size:20px;font-weight:700;color:var(--text-primary);margin-top:4px;font-variant-numeric:tabular-nums}.bot-card{background:var(--bg-darker);border:1px solid var(--border);border-radius:var(--radius);padding:16px}.bot-head{display:flex;align-items:center;gap:14px;margin-bottom:16px}.bot-avatar{width:64px;height:64px;border-radius:50%;background:linear-gradient(135deg,var(--accent),#5b67e0);display:flex;align-items:center;justify-content:center;font-size:26px;font-weight:800;color:#fff;position:relative;flex-shrink:0}.bot-avatar:after{content:"";position:absolute;right:-2px;bottom:-2px;width:18px;height:18px;border-radius:50%;background:var(--success);border:4px solid var(--bg-darker)}.bot-meta .nm{font-size:18px;font-weight:700;color:var(--text-primary);display:flex;align-items:center;gap:8px}.bot-meta .tg{font-size:12px;color:var(--text-muted);font-family:var(--font-mono)}.bot-meta .stat{margin-top:6px;display:flex;gap:8px}.module-card{background:var(--bg-darker);border:1px solid var(--border);border-radius:var(--radius);padding:16px;display:flex;flex-direction:column;gap:12px;transition:border-color .15s,transform .15s}.module-card:hover{border-color:var(--border-light)}.module-card .top{display:flex;align-items:flex-start;gap:12px}.module-card .icon-tile{width:44px;height:44px;border-radius:10px;background:var(--bg-mid);display:flex;align-items:center;justify-content:center;flex-shrink:0}.module-card .icon-tile svg{color:var(--text-secondary)}.module-card.on .icon-tile{background:var(--accent-soft)}.module-card.on .icon-tile svg{color:var(--accent)}.module-card .mod-name{font-weight:600;color:var(--text-primary);font-size:15px}.module-card .ver{font-size:12px;color:var(--text-muted);margin-top:2px;font-family:var(--font-mono)}.module-card .desc{font-size:13px;color:var(--text-secondary);line-height:1.5}.module-card .footer-row{display:flex;align-items:center;justify-content:space-between;padding-top:12px;border-top:1px solid var(--border)}.log-pane{background:#0f1115;border:1px solid var(--border);border-radius:var(--radius);font-family:var(--font-mono);font-size:12.5px;padding:12px;height:320px;overflow-y:auto;line-height:1.6}.log-line{display:flex;gap:12px}.log-line .t{color:var(--text-faint);flex-shrink:0}.log-line .lv{width:50px;flex-shrink:0;font-weight:700}.log-line .lv.info{color:var(--info)}.log-line .lv.warn{color:var(--warning)}.log-line .lv.error{color:var(--danger)}.log-line .lv.debug{color:var(--text-muted)}.log-line .msg{color:var(--text-secondary);word-break:break-word}.login-screen{display:flex;min-height:100vh;overflow:auto;align-items:center;justify-content:center;background:var(--bg-darkest);padding:16px}.login-card{width:100%;max-width:400px;background:var(--bg-darker);border:1px solid var(--border);border-radius:var(--radius-lg);padding:32px}.login-card h1{font-size:22px;font-weight:700;color:var(--text-primary);margin:0 0 4px;display:flex;align-items:center;gap:10px}.login-card .subtitle{font-size:13px;color:var(--text-muted);margin-bottom:24px}.loading-screen{display:flex;min-height:100vh;overflow:auto;align-items:center;justify-content:center;background:var(--bg-darkest)}.loading-card{background:var(--bg-darker);border:1px solid var(--border);border-radius:var(--radius-lg);padding:32px;text-align:center}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--bg-mid);border-radius:4px}::-webkit-scrollbar-thumb:hover{background:var(--bg-hover)}.slider{-webkit-appearance:none;-moz-appearance:none;appearance:none;width:100%;height:4px;background:var(--bg-mid);border-radius:2px;outline:none}.slider::-webkit-slider-thumb{-webkit-appearance:none;-moz-appearance:none;appearance:none;width:14px;height:14px;border-radius:50%;background:#fff;cursor:pointer;box-shadow:0 2px 4px #0006}.slider::-moz-range-thumb{width:14px;height:14px;border-radius:50%;background:#fff;border:0;cursor:pointer;box-shadow:0 2px 4px #0006}.taglist{display:flex;flex-wrap:wrap;gap:6px}.tag{background:var(--bg-mid);color:var(--text-secondary);padding:4px 10px;border-radius:12px;font-size:12px;display:inline-flex;align-items:center;gap:6px}.tag .x{color:var(--text-muted);cursor:pointer}.tag .x:hover{color:var(--danger)}.settings-modal{position:fixed;top:0;right:0;bottom:0;left:0;background:var(--bg-dark);z-index:1000;opacity:0;pointer-events:none;transition:opacity .18s ease}.settings-modal.show{opacity:1;pointer-events:auto}.settings-modal-inner{display:grid;grid-template-columns:240px 1fr;width:100%;height:100%;overflow:hidden}.sm-side{background:var(--bg-darker);display:flex;flex-direction:column;align-items:stretch;padding:60px 8px 60px 20px;overflow-y:auto;min-height:0}.sm-side-inner{width:100%;display:flex;flex-direction:column;gap:2px}.sm-side-title{padding:6px 10px;font-size:11px;font-weight:700;letter-spacing:.04em;text-transform:uppercase;color:var(--text-muted);margin-top:8px}.sm-nav{width:100%;display:flex;align-items:center;gap:8px;padding:6px 10px;border-radius:var(--radius-sm);color:var(--text-secondary);font-size:14px;font-weight:500;text-align:left;cursor:pointer}.sm-nav:hover{background:var(--bg-hover);color:var(--text-primary)}.sm-nav.active{background:var(--bg-active);color:var(--text-primary)}.sm-nav .ico{width:18px;height:18px;display:flex;align-items:center;justify-content:center;color:var(--text-muted);flex-shrink:0}.sm-nav.active .ico,.sm-nav:hover .ico{color:var(--text-primary)}.sm-nav .dot{margin-left:auto;width:8px;height:8px;border-radius:50%}.sm-divider{height:1px;background:var(--border);margin:8px 6px}.sm-side-footer{margin-top:auto;padding:12px 10px 0;width:100%;font-size:11px;color:var(--text-muted);font-family:var(--font-mono);border-top:1px solid var(--border)}.sm-main{background:var(--bg-dark);position:relative;overflow-y:auto;min-height:0;padding:60px 60px 80px 40px}.sm-main-inner{width:100%;max-width:740px;min-width:0}.sm-close{position:fixed;top:24px;right:24px;width:36px;height:36px;border-radius:50%;border:2px solid var(--text-muted);display:flex;align-items:center;justify-content:center;color:var(--text-muted);cursor:pointer;transition:border-color .15s,color .15s;background:transparent;z-index:10}.sm-close:hover{border-color:var(--text-primary);color:var(--text-primary)}.sm-close .esc{position:absolute;top:44px;left:50%;transform:translate(-50%);font-size:11px;font-weight:700;color:var(--text-muted);letter-spacing:.04em;white-space:nowrap}.sm-h1{font-size:20px;font-weight:700;color:var(--text-primary);margin:0 0 20px}.sm-section-h{font-size:12px;font-weight:700;letter-spacing:.04em;text-transform:uppercase;color:var(--text-muted);margin:24px 0 12px;padding-bottom:8px;border-bottom:1px solid var(--border)}.chan-pill{display:inline-flex;align-items:center;gap:6px;background:var(--bg-mid);padding:4px 10px;border-radius:4px;font-size:13px;color:var(--text-primary);font-family:var(--font-mono)}.chan-pill .h{color:var(--text-muted)}.unsaved-wrap{position:absolute;left:50%;bottom:24px;transform:translate(-50%);z-index:100;pointer-events:none;width:min(640px,calc(100% - 48px))}.unsaved-bar{pointer-events:auto;background:#2c313b;border:1px solid var(--border-light);border-radius:var(--radius);padding:10px 10px 10px 16px;display:flex;align-items:center;gap:12px;box-shadow:var(--shadow-2);opacity:0;transform:translateY(20px);transition:opacity .18s ease,transform .18s ease}.unsaved-bar.show{opacity:1;transform:translateY(0)}.unsaved-bar .msg{flex:1;color:var(--text-primary);font-size:14px;font-weight:500}.unsaved-bar.shake{animation:bar-shake .45s cubic-bezier(.36,.07,.19,.97);background:#4a2a2a;border-color:var(--danger)}@keyframes bar-shake{10%,90%{transform:translate3d(-1px,0,0)}20%,80%{transform:translate3d(2px,0,0)}30%,50%,70%{transform:translate3d(-6px,0,0)}40%,60%{transform:translate3d(6px,0,0)}}
