:root{--s-bg: #0d1d29;--s-bg-hover: #142836;--s-bg-active: #1a3040;--s-border: rgba(145, 192, 205, .14);--s-text-1: #f5f7fb;--s-text-2: #d8e4eb;--s-text-3: #84a1af;--s-accent: #49c4a2;--c-bg: #f5f1e8;--c-card: #ffffff;--c-card-2: #fbf7f0;--c-border: #e8dfcf;--c-hover: #faf5ed;--c-t1: #1d2b36;--c-t2: #536473;--c-t3: #94a2ad;--c-accent: #179c87;--c-shadow: 0 14px 40px rgba(33, 54, 71, .07), 0 3px 10px rgba(33, 54, 71, .04);--c-shadow-md: 0 24px 60px rgba(24, 46, 63, .12), 0 10px 24px rgba(24, 46, 63, .07);--c-table-head: #f7f1e7;--c-table-line: #efe6d7;--topbar-bg: rgba(255,255,255,.78);--topbar-border: rgba(219, 207, 190, .82);--color-primary: #179c87;--color-success: #179c87;--color-warning: #d79031;--color-error: #d9665b;--color-info: #3a7bff;--status-0: #d79031;--status-1: #179c87;--status-2: #d9665b;--bg-root: #091019;--bg-sidebar: #0f1117;--bg-card: #161622;--bg-hover: #1a1d2e;--border: #1e2130;--text-1: #e2e8f0;--text-2: #94a3b8;--text-3: #475569;--accent: #179c87;--radius: 8px;--font: "Avenir Next", "PingFang SC", "Hiragino Sans GB", "Segoe UI", sans-serif}*{margin:0;padding:0;box-sizing:border-box}html,body,#app{width:100%;height:100%}body{font-family:var(--font);font-size:14px;background:radial-gradient(circle at top right,rgba(23,156,135,.12),transparent 26%),radial-gradient(circle at 12% 18%,rgba(255,180,76,.13),transparent 20%),linear-gradient(180deg,#f9f4ea,#f4ede2 48%,#f1ebe0);color:var(--text-1);-webkit-font-smoothing:antialiased}input,select,button{font-family:var(--font);font-size:14px}a{color:inherit;text-decoration:none}::-webkit-scrollbar{width:5px;height:5px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:#cbd5e1;border-radius:3px}::-webkit-scrollbar-thumb:hover{background:#94a3b8}.list-page .info-banner,.list-page .filter-panel,.list-page .table-card{background:#ffffffeb;border:1px solid var(--c-border);border-radius:20px;box-shadow:var(--c-shadow)}.list-page .info-banner{padding:14px 18px;margin-bottom:18px;color:var(--c-t2);line-height:1.8;display:flex;align-items:center;gap:10px;flex-wrap:wrap}.list-page .filter-panel{padding:18px;margin-bottom:18px;position:relative}.list-page .filter-panel:before{content:"";position:absolute;inset:0 0 auto 0;height:72px;border-radius:20px 20px 0 0;background:linear-gradient(180deg,#179c8714,#179c8700);pointer-events:none}.list-page .filter-grid{position:relative;z-index:1;display:grid;grid-template-columns:repeat(auto-fill,minmax(190px,1fr));gap:12px;margin-bottom:14px}.list-page .fg{display:flex;flex-direction:column;gap:6px}.list-page .fg label{font-size:12px;font-weight:700;color:var(--c-t2)}.list-page .fg input,.list-page .fg select{width:100%;height:40px;padding:0 12px;border-radius:12px;border:1px solid var(--c-border);background:#ffffffe0;color:var(--c-t1);font-size:13px;outline:none;transition:border-color .18s,box-shadow .18s,background .18s}.list-page .fg input:focus,.list-page .fg select:focus{border-color:#179c878c;box-shadow:0 0 0 4px #179c871a;background:#fff}.list-page .filter-actions{position:relative;z-index:1;display:flex;justify-content:flex-end;gap:10px;padding-top:14px;border-top:1px solid var(--c-table-line)}.list-page .btn{height:38px;padding:0 16px;border-radius:12px;font-size:13px;font-weight:700;cursor:pointer;border:none;transition:transform .15s,box-shadow .15s,opacity .15s}.list-page .btn:hover{transform:translateY(-1px)}.list-page .btn-primary{background:linear-gradient(135deg,#1bb39a,#177fb8);color:#fff;box-shadow:0 14px 24px #179c8738}.list-page .btn-ghost{background:#fff;color:var(--c-t2);border:1px solid var(--c-border)}.list-page .table-card{overflow:hidden}.list-page .table-hd{padding:18px 20px 14px;display:flex;align-items:center;justify-content:space-between}.list-page .table-hd-title{font-size:18px;font-weight:800;color:var(--c-t1)}.list-page .table-hd-title:before{display:none}.list-page .total-count{font-size:12px;color:var(--c-t3);background:var(--c-card-2);border:1px solid var(--c-border);border-radius:999px;padding:6px 10px}.list-page .total-count strong{color:var(--c-t1);font-weight:800}.list-page .table-inner{padding:0 14px 14px}.list-page .table-wrap{overflow-x:auto;border:1px solid var(--c-table-line);border-radius:16px;background:#fff}.list-page table{width:100%;border-collapse:separate;border-spacing:0}.list-page th{padding:13px 14px;text-align:left;font-size:12px;font-weight:700;color:var(--c-t2);background:var(--c-table-head);border-bottom:1px solid var(--c-table-line);white-space:nowrap}.list-page th:first-child{border-top-left-radius:14px}.list-page th:last-child{border-top-right-radius:14px}.list-page td{padding:14px;font-size:13px;color:var(--c-t2);border-bottom:1px solid var(--c-table-line);white-space:nowrap;background:#ffffffe0}.list-page tr:last-child td{border-bottom:none}.list-page tr:hover td{background:#faf8f5}.list-page .loading,.list-page .empty{padding:34px;text-align:center;color:var(--c-t3)}.list-page .spinner{display:inline-block;width:14px;height:14px;border:2px solid rgba(23,156,135,.18);border-top-color:var(--c-accent);border-radius:50%;animation:spin .7s linear infinite}.list-page .text-primary{color:var(--c-t1);font-weight:700}.list-page .text-muted{color:var(--c-t3);font-size:12px}.list-page .mono{font-family:SF Mono,Fira Code,monospace;font-size:11px;color:#8c95a1}.list-page .ellipsis,.list-page .summary-cell{max-width:180px;overflow:hidden;text-overflow:ellipsis}.list-page .badge{display:inline-flex;align-items:center;min-height:24px;padding:0 10px;border-radius:999px;font-size:11px;font-weight:700;border:1px solid transparent}.list-page .badge-pending{background:#d790311f;color:#b96c15;border-color:#d7903133}.list-page .badge-success{background:#179c871f;color:#117468;border-color:#179c872e}.list-page .badge-fail{background:#d9665b1c;color:#bd5549;border-color:#d9665b2e}.list-page .btn-sm{min-width:56px;height:30px;padding:0 10px;border-radius:10px;font-size:12px;cursor:pointer;border:1px solid var(--c-border);background:#fff;color:var(--c-t2)}.list-page .btn-sm:hover{color:var(--c-t1);border-color:#179c8759;background:#f5fffb}@keyframes spin{to{transform:rotate(360deg)}}
