*,:before,:after{box-sizing:border-box;margin:0;padding:0}:root{--bg:#0f172a;--surface:#1e293b;--surface2:#293548;--surface3:#1b2331;--border:#334155;--accent:#6366f1;--accent-h:#818cf8;--danger:#ef4444;--success:#10b981;--warn:#f59e0b;--info:#3b82f6;--text:#f1f5f9;--text-2:#94a3b8;--text-3:#64748b;--radius:10px;--radius-sm:6px;--radius-xs:4px;--shadow:0 4px 24px #0006;--shadow-sm:0 2px 8px #0000004d;--font:"Inter", system-ui, -apple-system, sans-serif;--mono:"JetBrains Mono", "Fira Code", monospace;--sidebar-w:240px;--header-h:56px;--transition:.16s ease}html,body,#app{height:100%}body{background:var(--bg);color:var(--text);font-family:var(--font);-webkit-font-smoothing:antialiased;font-size:14px;line-height:1.6}a{color:var(--accent-h);text-decoration:none}a:hover{color:var(--text)}h1{font-size:1.6rem;font-weight:700}h2{font-size:1.25rem;font-weight:600}h3{font-size:1rem;font-weight:600}h4{font-size:.875rem;font-weight:600}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:0 0}::-webkit-scrollbar-thumb{background:var(--border);border-radius:3px}.btn{border-radius:var(--radius-sm);cursor:pointer;font-size:13px;font-weight:500;font-family:var(--font);white-space:nowrap;transition:background var(--transition), opacity var(--transition), color var(--transition);border:none;justify-content:center;align-items:center;gap:6px;padding:8px 16px;display:inline-flex}.btn:disabled{opacity:.45;cursor:not-allowed;pointer-events:none}.btn-primary{background:var(--accent);color:#fff}.btn-primary:hover:not(:disabled){background:var(--accent-h)}.btn-ghost{color:var(--text-2);border:1px solid var(--border);background:0 0}.btn-ghost:hover{background:var(--surface2);color:var(--text)}.btn-danger{background:var(--danger);color:#fff}.btn-danger:hover:not(:disabled){opacity:.85}.btn-success{background:var(--success);color:#fff}.btn-success:hover:not(:disabled){opacity:.85}.btn-warn{background:var(--warn);color:#1a1a1a}.btn-warn:hover:not(:disabled){opacity:.85}.btn-sm{padding:5px 10px;font-size:12px}.btn-xs{padding:3px 8px;font-size:11px}.btn-lg{padding:10px 20px;font-size:14px}.btn-icon{width:32px;height:32px;padding:6px}.btn-icon.btn-sm{width:26px;height:26px;padding:4px}.secondary{background:var(--surface3);color:var(--text-2)}.secondary:hover{background:var(--surface2);color:var(--text)}.btn-group{display:inline-flex}.btn-group .btn{border-radius:0}.btn-group .btn:first-child{border-radius:var(--radius-sm) 0 0 var(--radius-sm)}.btn-group .btn:last-child{border-radius:0 var(--radius-sm) var(--radius-sm) 0}.btn-group .btn+.btn{border-left:1px solid #ffffff1a}.input,.select,.textarea{border-radius:var(--radius-sm);background:var(--surface2);border:1px solid var(--border);width:100%;color:var(--text);font-size:13px;font-family:var(--font);transition:border-color var(--transition);outline:none;padding:8px 12px}.input:focus,.select:focus,.textarea:focus{border-color:var(--accent)}.input::placeholder,.textarea::placeholder{color:var(--text-3)}.input-sm,.select-sm{padding:5px 10px;font-size:12px}.textarea{resize:vertical;min-height:80px;line-height:1.5}.textarea-mono{font-family:var(--mono);font-size:12px}.select{appearance:none;cursor:pointer;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' fill='%2394a3b8'%3E%3Cpath d='M6 8.5L1 3.5h10z'/%3E%3C/svg%3E");background-position:right 10px center;background-repeat:no-repeat;padding-right:28px}.checkbox,.radio{cursor:pointer;color:var(--text-2);user-select:none;align-items:center;gap:8px;font-size:13px;display:inline-flex}.checkbox input,.radio input{display:none}.checkbox-box,.radio-box{border:1.5px solid var(--border);background:var(--surface2);width:16px;height:16px;transition:all var(--transition);flex-shrink:0;justify-content:center;align-items:center;display:flex}.checkbox-box{border-radius:var(--radius-xs)}.radio-box{border-radius:50%}.checkbox-box:after{content:"";opacity:0;width:9px;height:5px;transition:opacity var(--transition);border-top:none;border-bottom:2px solid #fff;border-left:2px solid #fff;border-right:none;display:block;transform:rotate(-45deg)translateY(-1px)}.radio-box:after{content:"";opacity:0;width:8px;height:8px;transition:opacity var(--transition);background:#fff;border-radius:50%;display:block}.checkbox input:checked~.checkbox-box,.radio input:checked~.radio-box{background:var(--accent);border-color:var(--accent)}.checkbox input:checked~.checkbox-box:after,.radio input:checked~.radio-box:after{opacity:1}.checkbox:hover .checkbox-box,.radio:hover .radio-box{border-color:var(--accent-h)}.checkbox input:disabled~.checkbox-box,.radio input:disabled~.radio-box{opacity:.4;cursor:not-allowed}.toggle{width:36px;height:20px;display:inline-block;position:relative}.toggle input{opacity:0;width:0;height:0}.toggle-slider{background:var(--border);cursor:pointer;transition:background var(--transition);border-radius:20px;position:absolute;inset:0}.toggle-slider:before{content:"";width:14px;height:14px;transition:transform var(--transition);background:#fff;border-radius:50%;position:absolute;top:3px;left:3px}.toggle input:checked+.toggle-slider{background:var(--accent)}.toggle input:checked+.toggle-slider:before{transform:translate(16px)}.card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:20px}.card-flush{padding:0}.card-flush>.card-header,.card-flush>.card-body,.card-flush>.card-footer{padding:16px 20px}.card-header{justify-content:space-between;align-items:center;margin-bottom:16px;display:flex}.card-flush>.card-header{border-bottom:1px solid var(--border);margin-bottom:0}.card-title{color:var(--text);font-size:14px;font-weight:600}.card-body{flex:1;min-height:0}.card-footer{border-top:1px solid var(--border)}.card-flush>.card-footer{margin-top:0}.panel{background:var(--surface2);border:1px solid var(--border);border-radius:var(--radius-sm)}.panel-header{color:var(--text-2);text-transform:uppercase;letter-spacing:.04em;border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;padding:10px 14px;font-size:12px;font-weight:600;display:flex}.panel-body{padding:12px 14px}.panel-row{border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;padding:8px 14px;font-size:13px;display:flex}.panel-row:last-child{border-bottom:none}.panel-collapse>.panel-header{cursor:pointer;user-select:none}.panel-collapse>.panel-header:after{content:"▸";transition:transform var(--transition)}.panel-collapse.is-open>.panel-header:after{transform:rotate(90deg)}.table{border-collapse:collapse;width:100%}.table th{text-align:left;color:var(--text-3);text-transform:uppercase;letter-spacing:.05em;border-bottom:1px solid var(--border);background:var(--surface2);z-index:1;padding:8px 12px;font-size:11px;font-weight:600;position:sticky;top:0}.table td{border-bottom:1px solid var(--border);color:var(--text-2);padding:10px 12px;font-size:13px}.table tr:last-child td{border-bottom:none}.table tbody tr:hover td{background:var(--surface2);color:var(--text)}.table-compact th{padding:6px 10px}.table-compact td{padding:6px 10px;font-size:12px}.table-striped tbody tr:nth-child(2n) td{background:#ffffff05}.table-fixed{table-layout:fixed}.table-wrap{min-height:0;overflow:auto}.table-wrap .table th{z-index:1;position:sticky;top:0}.table .cell-r{text-align:right}.table .cell-c{text-align:center}.table .cell-mono{font-family:var(--mono);font-size:12px}.table .cell-nowrap{white-space:nowrap}.table .cell-truncate{text-overflow:ellipsis;white-space:nowrap;max-width:0;overflow:hidden}.table .th-sort{cursor:pointer;user-select:none}.table .th-sort:hover{color:var(--text)}.table .th-sort:after{content:" ↕";opacity:.3}.table .th-sort.asc:after{content:" ↑";opacity:1}.table .th-sort.desc:after{content:" ↓";opacity:1}.table .row-active td{background:#6366f114}.table .row-danger td{background:#ef44440f}.table .row-success td{background:#10b9810f}.table .row-warn td{background:#f59e0b0f}.badge{border-radius:99px;align-items:center;gap:4px;padding:2px 8px;font-size:11px;font-weight:600;display:inline-flex}.badge-green{color:var(--success);background:#10b98126}.badge-red{color:var(--danger);background:#ef444426}.badge-indigo{color:var(--accent-h);background:#6366f126}.badge-yellow{color:var(--warn);background:#f59e0b26}.badge-blue{color:var(--info);background:#3b82f626}.badge-gray{color:var(--text-3);background:#94a3b81f}.badge-outline{background:0 0;border:1px solid}.badge-sm{padding:1px 6px;font-size:10px}.badge-lg{padding:3px 10px;font-size:12px}.status-dot{border-radius:50%;flex-shrink:0;width:8px;height:8px;display:inline-block}.dot-green{background:var(--success)}.dot-red{background:var(--danger)}.dot-yellow{background:var(--warn)}.dot-blue{background:var(--info)}.dot-gray{background:var(--text-3)}.dot-pulse{animation:1.5s ease-in-out infinite dotPulse}@keyframes dotPulse{0%,to{opacity:1}50%{opacity:.3}}.tabs{border-bottom:1px solid var(--border);gap:0;display:flex}.tab{color:var(--text-3);cursor:pointer;transition:all var(--transition);font-size:13px;font-weight:500;font-family:var(--font);background:0 0;border:none;border-bottom:2px solid #0000;padding:8px 16px}.tab:hover{color:var(--text-2)}.tab.is-active{color:var(--accent-h);border-bottom-color:var(--accent)}.tab-sm{padding:6px 12px;font-size:12px}.tabs-pill{background:var(--surface2);border-radius:var(--radius-sm);border-bottom:none;gap:4px;padding:3px}.tabs-pill .tab{border-radius:var(--radius-xs);border-bottom:none;padding:5px 12px}.tabs-pill .tab.is-active{background:var(--accent);color:#fff}.form-group{flex-direction:column;gap:6px;display:flex}.form-label{color:var(--text-2);font-size:12px;font-weight:500}.form-hint{color:var(--text-3);font-size:11px}.form-error{color:var(--danger);font-size:11px}.form-row{grid-template-columns:1fr 1fr;gap:12px;display:grid}.form-row-3{grid-template-columns:1fr 1fr 1fr;gap:12px;display:grid}.form-actions{justify-content:flex-end;gap:8px;display:flex}.form-inline{align-items:center;gap:8px;display:flex}.input-group{display:flex}.input-group .input{border-radius:0}.input-group .input:first-child{border-radius:var(--radius-sm) 0 0 var(--radius-sm)}.input-group .input:last-child{border-radius:0 var(--radius-sm) var(--radius-sm) 0}.input-group .btn{border-radius:0}.input-group .btn:last-child{border-radius:0 var(--radius-sm) var(--radius-sm) 0}.input-group-text{background:var(--surface3);border:1px solid var(--border);color:var(--text-3);white-space:nowrap;align-items:center;padding:0 12px;font-size:12px;display:flex}.input-group-text:first-child{border-radius:var(--radius-sm) 0 0 var(--radius-sm);border-right:none}.input-group-text:last-child{border-radius:0 var(--radius-sm) var(--radius-sm) 0;border-left:none}.input-search{background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='14' height='14' fill='%2364748b'%3E%3Ccircle cx='6' cy='6' r='5' fill='none' stroke='%2364748b' stroke-width='1.5'/%3E%3Cline x1='9.5' y1='9.5' x2='13' y2='13' stroke='%2364748b' stroke-width='1.5' stroke-linecap='round'/%3E%3C/svg%3E");background-position:10px;background-repeat:no-repeat;padding-left:30px}.dropdown{display:inline-block;position:relative}.dropdown-menu{z-index:100;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-sm);min-width:160px;box-shadow:var(--shadow);margin-top:4px;padding:4px 0;display:none;position:absolute;top:100%;left:0}.dropdown.is-open>.dropdown-menu{display:block}.dropdown-menu-right{left:auto;right:0}.dropdown-item{color:var(--text-2);cursor:pointer;text-align:left;width:100%;font-size:13px;font-family:var(--font);transition:background var(--transition), color var(--transition);background:0 0;border:none;align-items:center;gap:8px;padding:7px 14px;display:flex}.dropdown-item:hover{background:var(--surface2);color:var(--text)}.dropdown-item-danger{color:var(--danger)}.dropdown-item-danger:hover{background:#ef44441a}.dropdown-divider{border:none;border-top:1px solid var(--border);margin:4px 0}.dropdown-header{color:var(--text-3);text-transform:uppercase;padding:6px 14px;font-size:11px;font-weight:600}.toolbar{flex-wrap:wrap;align-items:center;gap:8px;padding:8px 0;display:flex}.toolbar-separator{background:var(--border);flex-shrink:0;width:1px;height:20px}.toolbar-spacer{flex:1}.kv-list{grid-template-columns:auto 1fr;gap:2px 16px;font-size:13px;display:grid}.kv-key{color:var(--text-3);white-space:nowrap;padding:4px 0;font-weight:500}.kv-val{color:var(--text);padding:4px 0}.dl{flex-direction:column;gap:12px;display:flex}.dl-label{color:var(--text-3);text-transform:uppercase;letter-spacing:.04em;margin-bottom:2px;font-size:11px;font-weight:600}.dl-value{color:var(--text);font-size:13px}.list{list-style:none}.list-item{color:var(--text-2);border-bottom:1px solid var(--border);transition:background var(--transition);align-items:center;gap:10px;padding:8px 12px;font-size:13px;display:flex}.list-item:last-child{border-bottom:none}.list-item:hover{background:var(--surface2);color:var(--text)}.list-item.is-active{color:var(--accent-h);background:#6366f114}.code{font-family:var(--mono);background:var(--bg);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text-2);white-space:pre;padding:12px 14px;font-size:12px;line-height:1.6;overflow:auto}.code-inline{font-family:var(--mono);background:var(--surface2);border-radius:var(--radius-xs);color:var(--accent-h);padding:2px 6px;font-size:12px}.log{font-family:var(--mono);border:1px solid var(--border);border-radius:var(--radius-sm);color:#c8d0dc;background:#0a0e1a;padding:10px 12px;font-size:11px;line-height:1.7;overflow:auto}.log-line{white-space:pre-wrap;word-break:break-all}.log-line:hover{background:#ffffff08}.log-ts{color:var(--text-3);user-select:none;margin-right:8px}.log-info{color:var(--info)}.log-warn{color:var(--warn)}.log-error{color:var(--danger)}.log-debug{color:var(--text-3)}.progress{background:var(--surface2);border-radius:3px;height:6px;overflow:hidden}.progress-bar{background:var(--accent);border-radius:3px;height:100%;transition:width .3s}.progress-bar-green{background:var(--success)}.progress-bar-red{background:var(--danger)}.progress-bar-yellow{background:var(--warn)}.progress-lg{border-radius:5px;height:10px}.tag{background:var(--surface2);color:var(--text-2);border-radius:99px;align-items:center;gap:4px;padding:3px 10px;font-size:12px;font-weight:500;display:inline-flex}.tag-remove{color:var(--text-3);cursor:pointer;background:0 0;border:none;padding:0 2px;font-size:10px;line-height:1}.tag-remove:hover{color:var(--danger)}[data-tooltip]{position:relative}[data-tooltip]:after{content:attr(data-tooltip);border-radius:var(--radius-xs);background:var(--text);color:var(--bg);white-space:nowrap;pointer-events:none;opacity:0;transition:opacity var(--transition);z-index:200;padding:4px 10px;font-size:11px;font-weight:500;position:absolute;bottom:calc(100% + 6px);left:50%;transform:translate(-50%)}[data-tooltip]:hover:after{opacity:1}[data-tooltip-pos=bottom]:after{top:calc(100% + 6px);bottom:auto}[data-tooltip-pos=left]:after{inset:50% calc(100% + 6px) auto auto;transform:translateY(-50%)}[data-tooltip-pos=right]:after{top:50%;bottom:auto;left:calc(100% + 6px);transform:translateY(-50%)}.modal-backdrop{z-index:500;backdrop-filter:blur(2px);background:#0000008c;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.modal{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow);flex-direction:column;width:90%;max-width:520px;max-height:85vh;display:flex}.modal-lg{max-width:720px}.modal-sm{max-width:360px}.modal-header{border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;padding:16px 20px;font-size:15px;font-weight:600;display:flex}.modal-body{flex:1;min-height:0;padding:20px;overflow-y:auto}.modal-footer{border-top:1px solid var(--border);justify-content:flex-end;align-items:center;gap:8px;padding:12px 20px;display:flex}.alert{border-radius:var(--radius-sm);border-left:3px solid;padding:12px 16px;font-size:13px}.alert-danger{border-color:var(--danger);color:#fca5a5;background:#ef44441a}.alert-success{border-color:var(--success);color:#6ee7b7;background:#10b9811a}.alert-warn{border-color:var(--warn);color:#fcd34d;background:#f59e0b1a}.alert-info{border-color:var(--info);color:#93c5fd;background:#3b82f61a}@keyframes shimmer{to{background-position:200%}}.skeleton{background:linear-gradient(90deg, var(--surface2) 25%, var(--surface) 50%, var(--surface2) 75%);border-radius:var(--radius-sm);background-size:200%;animation:1.5s linear infinite shimmer}.skeleton-text{width:80%;height:14px;margin-bottom:8px}.skeleton-title{width:50%;height:20px;margin-bottom:12px}.skeleton-avatar{border-radius:50%;width:32px;height:32px}.skeleton-row{width:100%;height:36px;margin-bottom:4px}@keyframes spin{to{transform:rotate(360deg)}}.spinner{border:2px solid var(--border);border-top-color:var(--accent);border-radius:50%;width:20px;height:20px;animation:.6s linear infinite spin}.spinner-sm{width:14px;height:14px}.spinner-lg{border-width:3px;width:28px;height:28px}.empty-state{color:var(--text-3);text-align:center;flex-direction:column;align-items:center;gap:8px;padding:48px 16px;display:flex}.empty-state .icon{opacity:.4;font-size:2.5rem}.divider{border:none;border-top:1px solid var(--border);margin:16px 0}.divider-sm{margin:8px 0}.text-primary{color:var(--accent-h)}.text-danger{color:var(--danger)}.text-success{color:var(--success)}.text-warn{color:var(--warn)}.text-info{color:var(--info)}.text-muted{color:var(--text-3)}.text-secondary{color:var(--text-2)}.text-xs{font-size:11px}.text-sm{font-size:12px}.text-md{font-size:14px}.text-lg{font-size:16px}.text-bold{font-weight:600}.text-mono{font-family:var(--mono)}.text-truncate{text-overflow:ellipsis;white-space:nowrap;overflow:hidden}.text-nowrap{white-space:nowrap}.text-center{text-align:center}.text-right{text-align:right}.text-upper{text-transform:uppercase;letter-spacing:.04em}.gap-2{gap:2px}.gap-4{gap:4px}.gap-6{gap:6px}.gap-8{gap:8px}.gap-12{gap:12px}.gap-16{gap:16px}.gap-24{gap:24px}.mt-4{margin-top:4px}.mt-8{margin-top:8px}.mt-12{margin-top:12px}.mt-16{margin-top:16px}.mt-24{margin-top:24px}.mb-4{margin-bottom:4px}.mb-8{margin-bottom:8px}.mb-12{margin-bottom:12px}.mb-16{margin-bottom:16px}.mb-24{margin-bottom:24px}.p-8{padding:8px}.p-12{padding:12px}.p-16{padding:16px}.p-0{padding:0}.flex{display:flex}.flex-col{flex-direction:column}.flex-wrap{flex-wrap:wrap}.flex-1{flex:1;min-width:0;min-height:0}.flex-none{flex:none}.flex-shrink-0{flex-shrink:0}.items-center{align-items:center}.items-start{align-items:flex-start}.items-end{align-items:flex-end}.items-stretch{align-items:stretch}.justify-between{justify-content:space-between}.justify-center{justify-content:center}.justify-end{justify-content:flex-end}.self-start{align-self:flex-start}.self-end{align-self:flex-end}.self-center{align-self:center}.w-full{width:100%}.h-full{height:100%}.min-h-0{min-height:0}.overflow-auto{overflow:auto}.overflow-hidden{overflow:hidden}.overflow-y-auto{overflow-y:auto}.hidden{display:none}.block{display:block}.inline-block{display:inline-block}.relative{position:relative}.absolute{position:absolute}.sticky{position:sticky}.inset-0{inset:0}.z-10{z-index:10}.z-50{z-index:50}.border{border:1px solid var(--border)}.border-t{border-top:1px solid var(--border)}.border-b{border-bottom:1px solid var(--border)}.rounded{border-radius:var(--radius)}.rounded-sm{border-radius:var(--radius-sm)}.rounded-full{border-radius:9999px}.fade-enter-active,.fade-leave-active{transition:opacity var(--transition)}.fade-enter-from,.fade-leave-to{opacity:0}.slide-enter-active,.slide-leave-active{transition:all .2s}.slide-enter-from,.slide-leave-to{opacity:0;transform:translateY(-8px)}@media (width<=768px){.form-row,.form-row-3{grid-template-columns:1fr}.hide-mobile{display:none!important}}@media (width<=480px){.hide-sm{display:none!important}}
