:root{--background: #faf9f5;--foreground: #3d3929;--card: #f5f4ef;--card-foreground: #141413;--popover: #ffffff;--popover-foreground: #28261b;--primary: #c96442;--primary-foreground: #ffffff;--ring: #c96442;--secondary: #e9e6dc;--secondary-foreground: #535146;--muted: #ede9de;--muted-foreground: #6e6d68;--accent: #e9e6dc;--accent-foreground: #28261b;--border: #dad9d4;--input: #b4b2a7;--destructive: #dc2626;--destructive-foreground: #ffffff;--sidebar: #f5f4ee;--sidebar-foreground: #3d3d3a;--sidebar-primary: #c96442;--sidebar-primary-foreground: #fbfbfb;--sidebar-accent: #e9e6dc;--sidebar-accent-foreground: #343434;--sidebar-border: #ebebeb;--table-header: #efede3;--table-row: var(--background);--table-row-alt: #f3f1e8;--table-row-hover: var(--accent);--table-separator: var(--border);--status-success-bg: #dcfce7;--status-success-fg: #166534;--status-success-border: #bbf7d0;--status-warning-bg: #fef9c3;--status-warning-fg: #854d0e;--status-warning-border: #fef08a;--status-info-bg: #dbeafe;--status-info-fg: #1e40af;--status-info-border: #bfdbfe;--status-accent-bg: #f3e8ff;--status-accent-fg: #6b21a8;--status-accent-border: #e9d5ff;--status-danger-bg: #fee2e2;--status-danger-fg: #991b1b;--status-danger-border: #fecaca;--status-neutral-bg: #f3f4f6;--status-neutral-fg: #4b5563;--status-neutral-border: #e5e7eb;--feedback-success: #16a34a;--feedback-success-foreground: #ffffff;--feedback-info: #1f1e1d;--feedback-info-foreground: #fbfbfb;--feedback-danger: var(--destructive);--feedback-danger-foreground: var(--destructive-foreground);--font-sans: "Outfit", ui-sans-serif, system-ui, -apple-system, "Segoe UI", Roboto, sans-serif;--font-mono: "Geist Mono", ui-monospace, "SF Mono", Menlo, Consolas, monospace;--radius: 1rem;--radius-sm: calc(var(--radius) - 4px);--radius-md: calc(var(--radius) - 2px);--radius-lg: var(--radius);--shadow-xs: 0 1px 3px 0px hsl(0 0% 0% / .05);--shadow-sm: 0 1px 3px 0px hsl(0 0% 0% / .1), 0 1px 2px -1px hsl(0 0% 0% / .1);--shadow-md: 0 1px 3px 0px hsl(0 0% 0% / .1), 0 2px 4px -1px hsl(0 0% 0% / .1);--shadow-lg: 0 1px 3px 0px hsl(0 0% 0% / .1), 0 4px 6px -1px hsl(0 0% 0% / .1);--shadow-xl: 0 1px 3px 0px hsl(0 0% 0% / .1), 0 8px 10px -1px hsl(0 0% 0% / .1);--row-h: 40px}*{box-sizing:border-box}html,body,#root{margin:0;height:100%;font-family:var(--font-sans);color:var(--foreground);background:var(--background);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}a{color:inherit}button{font-family:inherit}.mono{font-family:var(--font-mono)}::selection{background:color-mix(in srgb,var(--primary) 25%,transparent)}.app{display:grid;grid-template-columns:240px 1fr;height:100vh;overflow:hidden}.app.nav-collapsed{grid-template-columns:64px 1fr}.sidebar{background:var(--sidebar);border-right:1px solid var(--border);display:flex;flex-direction:column;min-height:0}.sb-brand{display:flex;align-items:center;gap:10px;padding:16px 16px 14px;height:60px}.sb-logo{width:30px;height:30px;border-radius:9px;background:var(--primary);color:var(--primary-foreground);display:grid;place-items:center;flex:0 0 auto;box-shadow:var(--shadow-sm)}.sb-logo svg{width:17px;height:17px}.sb-brand .meta{min-width:0}.sb-brand .name{font-weight:700;font-size:15px;letter-spacing:-.01em;white-space:nowrap;line-height:1.2}.sb-brand .env{font-family:var(--font-mono);font-size:10px;color:var(--muted-foreground);letter-spacing:.04em;white-space:nowrap;margin-top:1px}.nav-collapsed .sb-brand .meta{display:none}.sb-section{padding:6px 12px;display:flex;flex-direction:column;gap:2px}.sb-section+.sb-section{margin-top:6px}.sb-heading{font-size:10.5px;font-weight:600;text-transform:uppercase;letter-spacing:.07em;color:var(--muted-foreground);padding:10px 10px 6px}.nav-collapsed .sb-heading{opacity:0;height:14px}.nav-item{display:flex;align-items:center;gap:10px;height:36px;padding:0 10px;border-radius:8px;color:var(--sidebar-foreground);font-size:13.5px;font-weight:500;cursor:pointer;border:0;background:transparent;width:100%;text-align:left;position:relative;text-decoration:none}.nav-item svg{width:17px;height:17px;flex:0 0 auto;color:var(--muted-foreground)}.nav-item:hover{background:var(--muted)}.nav-item:focus,.nav-item:focus-visible{outline:none;box-shadow:none}.nav-item.active{background:var(--background);color:var(--foreground);box-shadow:var(--shadow-xs)}.nav-item.active svg{color:var(--primary)}.nav-item .count{margin-left:auto;font:600 11px/1 var(--font-sans);background:color-mix(in srgb,var(--muted-foreground) 16%,transparent);color:var(--muted-foreground);min-width:20px;height:18px;padding:0 6px;border-radius:999px;display:grid;place-items:center}.nav-item.has-alert .count{background:var(--status-danger-bg);color:var(--status-danger-fg)}.nav-collapsed .nav-item{justify-content:center;padding:0}.nav-collapsed .nav-item .label,.nav-collapsed .nav-item .count{display:none}.sb-spacer{flex:1}.sb-foot{padding:10px 12px;border-top:1px solid var(--border)}.nav-collapsed .sb-foot{display:flex;justify-content:center}.sb-foot .cl-user{display:flex;align-items:center;gap:10px}.sb-foot .cl-user .who{min-width:0}.sb-foot .cl-user .who .nm{font-size:13px;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.sb-foot .cl-user .who .em{font-size:11px;color:var(--muted-foreground);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.nav-collapsed .sb-foot .cl-user .who{display:none}.main{display:flex;flex-direction:column;min-width:0;min-height:0}.topbar{height:60px;flex:0 0 auto;border-bottom:1px solid var(--border);background:color-mix(in srgb,var(--background) 86%,transparent);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);display:flex;align-items:center;gap:14px;padding:0 24px}.topbar .crumbs-wrap{display:flex;align-items:center;gap:12px;min-width:0}.topbar .grow{flex:1}.icon-btn{width:36px;height:36px;flex:0 0 auto;display:grid;place-items:center;border:1px solid var(--border);background:var(--background);color:var(--muted-foreground);border-radius:9px;cursor:pointer;position:relative}.icon-btn:hover{background:var(--accent);color:var(--foreground)}.icon-btn svg{width:17px;height:17px}.icon-btn .ping{position:absolute;top:7px;right:7px;width:7px;height:7px;border-radius:999px;background:var(--destructive);border:1.5px solid var(--background)}.content{flex:1;overflow:auto;min-height:0}.content-inner{padding:28px 32px 64px;max-width:1320px;margin:0 auto}.content-inner.wide{max-width:1480px}.page-head{display:flex;align-items:flex-start;gap:16px;margin-bottom:22px}.page-head .ph-text{min-width:0}.page-title{font-size:24px;font-weight:700;letter-spacing:-.02em;margin:0}.page-title.mono{font-family:var(--font-mono)}.page-sub{font-size:14px;color:var(--muted-foreground);margin:5px 0 0}.page-head .ph-actions{margin-left:auto;display:flex;gap:8px;align-items:center;flex:0 0 auto}.btn{display:inline-flex;align-items:center;gap:8px;height:36px;padding:0 15px;border-radius:10px;border:1px solid transparent;font:500 14px/1 var(--font-sans);cursor:pointer;transition:background-color .12s,border-color .12s,opacity .12s,color .12s;white-space:nowrap;text-decoration:none}.btn svg{width:16px;height:16px}.btn-primary{background:var(--primary);color:var(--primary-foreground)}.btn-primary:hover{background:color-mix(in srgb,var(--primary) 90%,black)}.btn-outline{background:var(--background);color:var(--foreground);border-color:var(--border)}.btn-outline:hover{background:var(--muted)}.btn-ghost{background:transparent;color:var(--foreground)}.btn-ghost:hover{background:var(--muted)}.btn-secondary{background:var(--secondary);color:var(--secondary-foreground)}.btn-secondary:hover{background:color-mix(in srgb,var(--secondary) 80%,black)}.btn-destructive{background:var(--destructive);color:var(--destructive-foreground)}.btn-destructive:hover{background:color-mix(in srgb,var(--destructive) 90%,black)}.btn-sm{height:30px;padding:0 12px;font-size:13px;border-radius:8px}.btn-sm svg{width:14px;height:14px}.btn:disabled{opacity:.5;cursor:not-allowed}.input{height:36px;padding:0 12px;border:1px solid var(--input);border-radius:10px;background:var(--background);color:var(--foreground);font:14px/1 var(--font-sans);width:100%;transition:border-color .12s,box-shadow .12s}.input::placeholder{color:var(--muted-foreground)}.input:focus-visible{outline:none;border-color:var(--ring);box-shadow:0 0 0 3px color-mix(in srgb,var(--ring) 35%,transparent)}.field{display:flex;flex-direction:column;gap:6px}.field label{font:500 13px/1 var(--font-sans)}.field .helper{font-size:12px;color:var(--muted-foreground);line-height:1.4}select.input{-webkit-appearance:none;-moz-appearance:none;appearance:none;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='%236e6d68' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='m6 9 6 6 6-6'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 10px center;padding-right:32px;cursor:pointer}.search{position:relative;display:inline-flex;align-items:center}.search input{width:100%;height:36px;padding:0 70px 0 34px;border:1px solid var(--input);border-radius:10px;background:var(--background);font:14px/1 var(--font-sans);color:var(--foreground)}.search input:focus{outline:none;border-color:var(--ring);box-shadow:0 0 0 3px color-mix(in srgb,var(--ring) 35%,transparent)}.search .ico{position:absolute;left:11px;width:15px;height:15px;color:var(--muted-foreground);pointer-events:none}.search .kbd{position:absolute;right:8px;font:11px/1 var(--font-mono);color:var(--muted-foreground);padding:3px 6px;border:1px solid var(--border);border-radius:4px;background:var(--background)}.badge{display:inline-flex;align-items:center;gap:5px;height:22px;padding:0 9px;font:500 12px/1 var(--font-sans);border-radius:999px;border:1px solid transparent;white-space:nowrap}.badge-success{background:var(--status-success-bg);color:var(--status-success-fg);border-color:var(--status-success-border)}.badge-warning{background:var(--status-warning-bg);color:var(--status-warning-fg);border-color:var(--status-warning-border)}.badge-danger{background:var(--status-danger-bg);color:var(--status-danger-fg);border-color:var(--status-danger-border)}.badge-info{background:var(--status-info-bg);color:var(--status-info-fg);border-color:var(--status-info-border)}.badge-accent{background:var(--status-accent-bg);color:var(--status-accent-fg);border-color:var(--status-accent-border)}.badge-neutral{background:var(--status-neutral-bg);color:var(--status-neutral-fg);border-color:var(--status-neutral-border)}.sbadge{display:inline-flex;align-items:center;gap:6px;height:22px;padding:0 9px 0 8px;border-radius:999px;border:1px solid transparent;font:500 12px/1 var(--font-sans);white-space:nowrap}.sbadge .dot{width:7px;height:7px;border-radius:999px;flex:0 0 auto;background:currentColor}.sbadge.has-icon{padding-left:7px}.sbadge svg{width:12px;height:12px;margin-right:-1px}.sbadge.minimal{background:transparent!important;border-color:transparent!important;padding-left:0}.sbadge.minimal .dot{width:8px;height:8px}.sbadge.square{border-radius:6px}.st-neutral{background:var(--status-neutral-bg);color:var(--status-neutral-fg);border-color:var(--status-neutral-border)}.st-info{background:var(--status-info-bg);color:var(--status-info-fg);border-color:var(--status-info-border)}.st-accent{background:var(--status-accent-bg);color:var(--status-accent-fg);border-color:var(--status-accent-border)}.st-success{background:var(--status-success-bg);color:var(--status-success-fg);border-color:var(--status-success-border)}.st-done{background:#eef0ee;color:#3f5141;border-color:#dde3dd}.st-danger{background:var(--status-danger-bg);color:var(--status-danger-fg);border-color:var(--status-danger-border)}.st-warning{background:var(--status-warning-bg);color:var(--status-warning-fg);border-color:var(--status-warning-border)}.chan{display:inline-flex;align-items:center;gap:7px;font-size:13px;font-weight:500}.chan .glyph{width:22px;height:22px;border-radius:6px;flex:0 0 auto;display:grid;place-items:center;font:700 11px/1 var(--font-sans);color:#fff}.tbl-wrap{border:1px solid var(--border);border-radius:12px;overflow:hidden;background:var(--background)}.tbl{width:100%;border-collapse:collapse;font-size:13px}.tbl thead th{background:var(--table-header);height:38px;font:600 12.5px/1 var(--font-sans);color:var(--foreground);text-align:left;padding:0 14px;border-bottom:1px solid var(--border);white-space:nowrap;-webkit-user-select:none;user-select:none;position:sticky;top:0;z-index:1}.tbl thead th.sortable{cursor:pointer}.tbl thead th.sortable:hover{color:var(--primary)}.tbl thead th .th-in{display:inline-flex;align-items:center;gap:5px}.tbl thead th svg{width:13px;height:13px;opacity:.7}.tbl tbody td{height:var(--row-h);padding:0 14px;border-bottom:1px solid var(--border);color:var(--foreground);white-space:nowrap}.tbl tbody tr:last-child td{border-bottom:0}.tbl tbody tr{cursor:pointer}.tbl tbody tr:hover td{background:var(--accent)}.tbl tbody tr.selected td{background:color-mix(in srgb,var(--primary) 8%,var(--background))}.tbl.zebra tbody tr:nth-child(odd) td{background:var(--table-row-alt)}.tbl.zebra tbody tr:nth-child(odd):hover td{background:var(--accent)}.tbl.zebra tbody tr.selected td{background:color-mix(in srgb,var(--primary) 8%,var(--background))}.tbl td.num,.tbl th.num{text-align:right;font-variant-numeric:tabular-nums}.tbl .cell-mono{font-family:var(--font-mono);font-size:12px}.tbl .cell-sub{color:var(--muted-foreground);font-size:12px}.tbl .cell-strong{font-weight:600}.col-check{width:40px}.tbl .row-chevron{color:var(--muted-foreground);opacity:0;transition:opacity .1s}.tbl tbody tr:hover .row-chevron{opacity:1}.check{width:16px;height:16px;border:1.5px solid var(--input);border-radius:4px;background:var(--background);flex:0 0 auto;position:relative;box-sizing:border-box;cursor:pointer;display:inline-block;transition:background-color .12s,border-color .12s}.check.checked{background:var(--primary);border-color:var(--primary)}.check.checked:after{content:"";position:absolute;left:4.5px;top:1px;width:4px;height:8px;border:solid #fff;border-width:0 2px 2px 0;transform:rotate(45deg)}.check.indeterminate{background:var(--primary);border-color:var(--primary)}.check.indeterminate:after{content:"";position:absolute;left:3px;top:6px;width:8px;height:2px;background:#fff;border-radius:1px}.switch{width:36px;height:20px;background:var(--input);border-radius:999px;position:relative;flex:0 0 auto;transition:background-color .15s;cursor:pointer;border:0;padding:0;display:inline-block}.switch:after{content:"";position:absolute;top:2px;left:2px;width:16px;height:16px;background:#fff;border-radius:999px;transition:transform .15s;box-shadow:var(--shadow-sm)}.switch.on{background:var(--primary)}.switch.on:after{transform:translate(16px)}.toolbar{display:flex;flex-wrap:wrap;gap:8px;align-items:center;margin-bottom:14px}.toolbar .grow{flex:1}.fpill{display:inline-flex;align-items:center;gap:6px;height:34px;padding:0 11px;border:1px solid var(--border);background:var(--background);border-radius:9px;font-size:13px;color:var(--foreground);cursor:pointer;white-space:nowrap}.fpill:hover{background:var(--accent)}.fpill .v{color:var(--muted-foreground)}.fpill.active{background:var(--accent);border-color:var(--primary)}.fpill svg{width:14px;height:14px;opacity:.6}.fpill .num{font-weight:600;color:var(--primary)}.clear-all{font-size:13px;color:var(--muted-foreground);cursor:pointer;padding:0 8px;background:transparent;border:0;height:34px}.clear-all:hover{color:var(--destructive);text-decoration:underline}.seg{display:inline-flex;gap:3px;padding:3px;background:var(--muted);border-radius:9px}.seg button{height:28px;padding:0 12px;border:0;background:transparent;color:var(--muted-foreground);font:500 13px/1 var(--font-sans);border-radius:7px;cursor:pointer;display:inline-flex;align-items:center;gap:6px}.seg button svg{width:14px;height:14px}.seg button:hover{color:var(--foreground)}.seg button.active{background:var(--background);color:var(--foreground);box-shadow:var(--shadow-xs)}.tabs-u{display:flex;gap:22px;border-bottom:1px solid var(--border)}.tab-u{height:40px;padding:0 2px;background:transparent;border:0;border-bottom:2px solid transparent;margin-bottom:-1px;color:var(--muted-foreground);font:500 14px/1 var(--font-sans);cursor:pointer;display:inline-flex;align-items:center;gap:8px}.tab-u:hover{color:var(--foreground)}.tab-u.active{color:var(--foreground);border-bottom-color:var(--primary)}.tab-u .count{font:600 11px/1 var(--font-sans);background:color-mix(in srgb,var(--muted-foreground) 16%,transparent);color:var(--muted-foreground);min-width:19px;height:18px;padding:0 6px;border-radius:999px;display:grid;place-items:center}.tab-u.active .count{background:var(--status-danger-bg);color:var(--status-danger-fg)}.card{background:var(--card);border:1px solid var(--border);border-radius:14px}.card-pad{padding:18px 20px}.card-head{display:flex;align-items:center;gap:10px;padding:15px 18px;border-bottom:1px solid var(--border)}.card-head h3{font-size:14.5px;font-weight:600;margin:0}.card-head .grow{flex:1}.stat-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:14px}.stat{background:var(--card);border:1px solid var(--border);border-radius:14px;padding:16px 18px;cursor:pointer;transition:border-color .12s,box-shadow .12s;position:relative;text-align:left}.stat:hover{border-color:color-mix(in srgb,var(--primary) 45%,var(--border));box-shadow:var(--shadow-sm)}.stat .st-top{display:flex;align-items:center;gap:8px}.stat .st-ico{width:30px;height:30px;border-radius:8px;display:grid;place-items:center;flex:0 0 auto}.stat .st-ico svg{width:16px;height:16px}.stat .st-label{font-size:13px;color:var(--muted-foreground);font-weight:500}.stat .st-num{font-size:30px;font-weight:700;letter-spacing:-.02em;line-height:1;margin:14px 0 6px;font-variant-numeric:tabular-nums}.stat .st-delta{font-size:12px;display:inline-flex;align-items:center;gap:4px}.stat .st-delta svg{width:13px;height:13px}.st-up{color:#16a34a}.st-down{color:var(--destructive)}.st-flat{color:var(--muted-foreground)}.stat.danger{background:color-mix(in srgb,var(--status-danger-bg) 40%,var(--card));border-color:var(--status-danger-border)}.detail-grid{display:grid;grid-template-columns:1fr 332px;gap:22px;align-items:start}@media (max-width: 1100px){.detail-grid{grid-template-columns:1fr}}.kv{display:grid;grid-template-columns:116px 1fr;gap:8px 14px;font-size:13px}.kv dt{color:var(--muted-foreground)}.kv dd{margin:0;color:var(--foreground)}.kv dd.mono{font-family:var(--font-mono);font-size:12px}.line-item{display:grid;grid-template-columns:44px 1fr auto;gap:12px;align-items:center;padding:11px 0;border-bottom:1px solid var(--border)}.line-item:last-child{border-bottom:0}.line-item .thumb{width:44px;height:44px;border-radius:8px;background:repeating-linear-gradient(135deg,var(--muted) 0 6px,color-mix(in srgb,var(--muted) 60%,var(--background)) 6px 12px);border:1px solid var(--border);flex:0 0 auto}.line-item .li-name{font-size:13.5px;font-weight:500}.line-item .li-sku{font:11px/1.4 var(--font-mono);color:var(--muted-foreground);margin-top:3px}.line-item .li-qty{font-size:13px;color:var(--muted-foreground);text-align:right}.line-item .li-price{font-size:13.5px;font-weight:600;text-align:right;font-variant-numeric:tabular-nums}.tl-vert{position:relative;padding-left:4px}.tl-node{position:relative;display:grid;grid-template-columns:28px 1fr;gap:14px;padding-bottom:4px}.tl-node .rail{display:flex;flex-direction:column;align-items:center}.tl-node .knob{width:26px;height:26px;border-radius:999px;border:2px solid var(--border);background:var(--background);display:grid;place-items:center;flex:0 0 auto;z-index:1;color:var(--muted-foreground)}.tl-node .knob svg{width:13px;height:13px}.tl-node .line{flex:1;width:2px;background:var(--border);margin:2px 0;min-height:22px}.tl-node.done .knob{background:var(--primary);border-color:var(--primary);color:var(--primary-foreground)}.tl-node.done .line{background:var(--primary)}.tl-node.current .knob{border-color:var(--primary);color:var(--primary);box-shadow:0 0 0 4px color-mix(in srgb,var(--primary) 15%,transparent)}.tl-node.failed .knob{background:var(--destructive);border-color:var(--destructive);color:#fff}.tl-node.failed .line{background:var(--destructive)}.tl-node.cancelled .knob{background:var(--status-neutral-fg);border-color:var(--status-neutral-fg);color:#fff}.tl-node.pending .knob{border-style:dashed}.tl-body{padding-bottom:18px;min-width:0}.tl-body .t-title{font-size:13.5px;font-weight:600;display:flex;align-items:center;gap:8px}.tl-body .t-time{font:11.5px/1 var(--font-mono);color:var(--muted-foreground);margin-top:4px}.tl-body .t-desc{font-size:12.5px;color:var(--muted-foreground);margin-top:6px;line-height:1.5}.tl-node.pending .t-title{color:var(--muted-foreground);font-weight:500}.tl-fail-box{margin-top:9px;background:var(--status-danger-bg);border:1px solid var(--status-danger-border);color:var(--status-danger-fg);border-radius:9px;padding:10px 12px;font-size:12.5px;line-height:1.5}.tl-fail-box .fb-head{display:flex;align-items:center;gap:6px;font-weight:600;margin-bottom:4px}.tl-fail-box .fb-head svg{width:14px;height:14px}.tl-fail-box code{font-family:var(--font-mono);font-size:11px}.tl-step{display:flex;align-items:flex-start;padding:6px 2px 2px;overflow-x:auto}.tl-step .s{display:flex;flex-direction:column;align-items:center;gap:8px;flex:0 0 auto;width:116px;text-align:center}.tl-step .s .knob{width:30px;height:30px;border-radius:999px;border:2px solid var(--border);background:var(--background);display:grid;place-items:center;color:var(--muted-foreground)}.tl-step .s .knob svg{width:15px;height:15px}.tl-step .s.done .knob{background:var(--primary);border-color:var(--primary);color:#fff}.tl-step .s.current .knob{border-color:var(--primary);color:var(--primary);box-shadow:0 0 0 4px color-mix(in srgb,var(--primary) 15%,transparent)}.tl-step .s.failed .knob{background:var(--destructive);border-color:var(--destructive);color:#fff}.tl-step .s .s-lbl{font-size:12px;font-weight:600;line-height:1.25}.tl-step .s .s-time{font:10.5px/1.3 var(--font-mono);color:var(--muted-foreground)}.tl-step .s.pending .s-lbl{color:var(--muted-foreground);font-weight:500}.tl-step .bar{flex:1 1 auto;height:2px;background:var(--border);margin-top:15px;min-width:18px}.tl-step .bar.done{background:var(--primary)}.tl-step .bar.failed{background:var(--destructive)}.tl-rail{padding:6px 0 2px}.tl-rail .track{position:relative;height:8px;border-radius:999px;background:var(--muted);overflow:hidden}.tl-rail .track .fill{position:absolute;left:0;top:0;bottom:0;border-radius:999px;background:var(--primary);transition:width .4s ease}.tl-rail .track .fill.failed{background:var(--destructive)}.tl-rail .marks{display:flex;justify-content:space-between;margin-top:10px}.tl-rail .m{display:flex;flex-direction:column;align-items:center;gap:4px;flex:1;text-align:center}.tl-rail .m .pt{width:12px;height:12px;border-radius:999px;background:var(--background);border:2px solid var(--border)}.tl-rail .m.done .pt{background:var(--primary);border-color:var(--primary)}.tl-rail .m.current .pt{border-color:var(--primary);box-shadow:0 0 0 3px color-mix(in srgb,var(--primary) 18%,transparent)}.tl-rail .m.failed .pt{background:var(--destructive);border-color:var(--destructive)}.tl-rail .m .ml{font-size:11px;color:var(--muted-foreground);line-height:1.2}.tl-rail .m.done .ml,.tl-rail .m.current .ml{color:var(--foreground);font-weight:500}.audit{border:1px solid var(--border);border-radius:12px;overflow:hidden}.audit-row{display:grid;grid-template-columns:150px 1fr;gap:14px;padding:10px 14px;border-bottom:1px solid var(--border);font-size:12.5px;align-items:start}.audit-row:nth-child(odd){background:var(--table-row-alt)}.audit-row:last-child{border-bottom:0}.audit-row .a-time{font:11.5px/1.4 var(--font-mono);color:var(--muted-foreground)}.audit-row .a-main{min-width:0}.audit-row .a-event{font-weight:600;display:flex;align-items:center;gap:7px;flex-wrap:wrap}.audit-row .a-meta{color:var(--muted-foreground);margin-top:4px;display:flex;gap:12px;flex-wrap:wrap}.audit-row .a-meta .cid{font-family:var(--font-mono);font-size:11px}.dot-out{width:7px;height:7px;border-radius:999px;flex:0 0 auto;display:inline-block}.dot-out.ok{background:#16a34a}.dot-out.fail{background:var(--destructive)}.dot-out.info{background:#2563eb}.dot-out.neutral{background:var(--muted-foreground)}.health-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(340px,1fr));gap:16px}.health-card{background:var(--card);border:1px solid var(--border);border-radius:14px;padding:18px;display:flex;flex-direction:column;gap:14px}.health-card.warn{border-color:var(--status-warning-border)}.health-card.down{border-color:var(--status-danger-border)}.health-card .hc-top{display:flex;align-items:center;gap:12px}.health-card .hc-logo{width:40px;height:40px;border-radius:10px;display:grid;place-items:center;color:#fff;font-weight:700;flex:0 0 auto}.health-card .hc-name{font-size:15px;font-weight:600}.health-card .hc-type{font-size:12px;color:var(--muted-foreground)}.health-card .hc-metrics{display:grid;grid-template-columns:1fr 1fr;gap:10px 14px}.health-card .hcm .k{font-size:11px;color:var(--muted-foreground)}.health-card .hcm .v{font-size:13px;font-weight:500;margin-top:2px;display:flex;align-items:center;gap:6px}.health-card .hc-foot{display:flex;gap:8px;align-items:center;border-top:1px solid var(--border);margin-top:2px;padding-top:14px}.pulse{width:8px;height:8px;border-radius:999px;flex:0 0 auto;display:inline-block}.pulse.ok{background:#16a34a;box-shadow:0 0 #16a34a80;animation:pulse 2s infinite}.pulse.warn{background:#ca8a04}.pulse.down{background:var(--destructive)}@keyframes pulse{0%{box-shadow:0 0 #16a34a80}70%{box-shadow:0 0 0 6px #16a34a00}to{box-shadow:0 0 #16a34a00}}.key-mono{font-family:var(--font-mono);font-size:12.5px;display:inline-flex;align-items:center;gap:8px}.key-mono .reveal{color:var(--muted-foreground);cursor:pointer;display:inline-flex}.ava{display:inline-grid;place-items:center;border-radius:999px;font-weight:600;flex:0 0 auto}.ava.sm{width:30px;height:30px;font-size:12px}.ava.xs{width:24px;height:24px;font-size:10px}.ava.c1{background:#e9d5ff;color:#6b21a8}.ava.c2{background:#dbeafe;color:#1e40af}.ava.c3{background:#dcfce7;color:#166534}.ava.c4{background:#fef9c3;color:#854d0e}.ava.c5{background:#fee2e2;color:#991b1b}.ava.c6{background:#f3f4f6;color:#4b5563}.menu{background:var(--popover);color:var(--popover-foreground);border:1px solid var(--border);border-radius:12px;padding:4px;box-shadow:var(--shadow-md);min-width:180px;font-size:14px}.menu-item{display:flex;align-items:center;gap:10px;height:34px;padding:0 9px;border-radius:8px;color:var(--foreground);cursor:pointer;-webkit-user-select:none;user-select:none;border:0;background:transparent;width:100%;text-align:left;font:13.5px/1 var(--font-sans)}.menu-item:hover{background:var(--accent)}.menu-item svg{width:15px;height:15px;color:var(--muted-foreground);flex:0 0 auto}.menu-item.danger{color:var(--destructive)}.menu-item.danger svg{color:var(--destructive)}.menu-item .check-i{margin-left:auto;color:var(--primary);width:15px;height:15px}.menu-item .check{margin-right:2px}.menu-sep{height:1px;background:var(--border);margin:4px}.menu-head{padding:8px 9px 6px;font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:var(--muted-foreground)}.overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#1414136b;z-index:50;display:grid;place-items:center;padding:24px;animation:fade .12s ease}@keyframes fade{0%{opacity:0}to{opacity:1}}.modal{width:100%;max-width:460px;background:var(--popover);border:1px solid var(--border);border-radius:16px;box-shadow:var(--shadow-xl);overflow:hidden;animation:pop .14s ease}@keyframes pop{0%{transform:translateY(8px) scale(.98);opacity:0}to{transform:none;opacity:1}}.modal-head{padding:20px 24px 10px}.modal-head h3{font-size:18px;font-weight:600;margin:0 0 5px}.modal-head p{font-size:14px;color:var(--muted-foreground);margin:0;line-height:1.5}.modal-body{padding:6px 24px 18px;font-size:14px;line-height:1.55}.modal-foot{display:flex;justify-content:flex-end;gap:8px;padding:14px 24px;background:var(--muted);border-top:1px solid var(--border)}.sheet-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#1414136b;z-index:50;animation:fade .12s ease}.sheet{position:fixed;right:0;top:0;bottom:0;width:460px;max-width:92vw;background:var(--background);border-left:1px solid var(--border);box-shadow:var(--shadow-xl);display:flex;flex-direction:column;z-index:51;animation:slidein .2s ease}@keyframes slidein{0%{transform:translate(100%)}to{transform:none}}.sheet-head{padding:18px 22px;border-bottom:1px solid var(--border);display:flex;align-items:flex-start;gap:12px}.sheet-body{flex:1;padding:20px 22px;overflow:auto}.sheet-foot{padding:14px 22px;border-top:1px solid var(--border);display:flex;gap:8px;justify-content:flex-end}.empty{display:grid;place-items:center;gap:13px;padding:56px 24px;text-align:center}.empty .ico-bg{width:54px;height:54px;border-radius:999px;background:var(--muted);display:grid;place-items:center;color:var(--muted-foreground)}.empty .ico-bg svg{width:23px;height:23px}.empty h3{font-size:16px;font-weight:600;margin:0}.empty p{font-size:14px;color:var(--muted-foreground);max-width:380px;margin:0;line-height:1.5}@keyframes shimmer{0%{background-position:-360px 0}to{background-position:360px 0}}.skel{display:block;border-radius:6px;background:linear-gradient(90deg,var(--muted) 0%,color-mix(in srgb,var(--muted) 45%,var(--background)) 50%,var(--muted) 100%);background-size:720px 100%;animation:shimmer 1.3s infinite linear}.alert{display:grid;grid-template-columns:20px 1fr auto;column-gap:12px;align-items:start;padding:13px 15px;border:1px solid;border-radius:12px;font-size:13.5px}.alert .ico{width:19px;height:19px;margin-top:1px}.alert .body strong{display:block;font-weight:600;margin-bottom:2px}.alert .body p{margin:0;line-height:1.5;opacity:.92}.alert.danger{background:var(--status-danger-bg);color:var(--status-danger-fg);border-color:var(--status-danger-border)}.alert.warning{background:var(--status-warning-bg);color:var(--status-warning-fg);border-color:var(--status-warning-border)}.alert.info{background:var(--status-info-bg);color:var(--status-info-fg);border-color:var(--status-info-border)}.alert.success{background:var(--status-success-bg);color:var(--status-success-fg);border-color:var(--status-success-border)}.alert .btn-link{background:transparent;border:0;color:inherit;font-weight:600;text-decoration:underline;cursor:pointer;font-size:13px}.toast-wrap{position:fixed;bottom:22px;right:22px;z-index:80;display:flex;flex-direction:column;gap:9px;align-items:flex-end}.toast{display:grid;grid-template-columns:18px 1fr auto;column-gap:10px;align-items:center;padding:11px 13px;background:var(--feedback-info);color:var(--feedback-info-foreground);border-radius:10px;box-shadow:var(--shadow-lg);font-size:13px;min-width:280px;max-width:380px;animation:toastin .2s ease}@keyframes toastin{0%{transform:translateY(8px);opacity:0}to{transform:none;opacity:1}}.toast.success{background:var(--feedback-success);color:var(--feedback-success-foreground)}.toast.danger{background:var(--feedback-danger);color:var(--feedback-danger-foreground)}.toast .ico{width:18px;height:18px}.toast .undo{background:transparent;border:0;color:inherit;font-weight:600;cursor:pointer;text-decoration:underline;font-size:13px}.crumbs{display:flex;align-items:center;gap:3px;font-size:13px;color:var(--muted-foreground)}.crumbs a{text-decoration:none;padding:3px 6px;border-radius:6px;cursor:pointer}.crumbs a:hover{color:var(--foreground);background:var(--accent)}.crumbs .sep{color:var(--border)}.crumbs .current{color:var(--foreground);font-weight:500;padding:3px 6px}.pagi{display:flex;align-items:center;justify-content:space-between;gap:16px;padding:14px 2px 2px;font-size:13px}.pagi .info{color:var(--muted-foreground)}.pagi .nums{display:inline-flex;gap:3px}.pagi-btn{min-width:32px;height:32px;padding:0 6px;display:grid;place-items:center;border:1px solid var(--border);background:var(--background);color:var(--foreground);border-radius:8px;cursor:pointer;font:500 13px/1 var(--font-sans)}.pagi-btn:hover:not(:disabled){background:var(--accent)}.pagi-btn.active{background:var(--primary);color:#fff;border-color:var(--primary)}.pagi-btn:disabled{opacity:.4;cursor:not-allowed}.spin{animation:spin 1s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.divider{height:1px;background:var(--border);border:0;margin:0}.mut{color:var(--muted-foreground)}.row{display:flex;align-items:center;gap:8px}.scroll-x{overflow-x:auto}.dev-banner{background:var(--status-warning-bg);color:var(--status-warning-fg);border-bottom:1px solid var(--status-warning-border);font-size:12.5px;padding:7px 16px;text-align:center}.dev-banner code{font-family:var(--font-mono)}.signin-screen{min-height:100vh;display:grid;place-items:center;gap:22px;padding:40px}.signin-brand{display:grid;place-items:center;gap:6px;text-align:center}.signin-brand .brand__mark{width:44px;height:44px;border-radius:12px;background:var(--primary);color:#fff;display:grid;place-items:center;box-shadow:var(--shadow-sm)}.signin-brand .brand__name{font-size:20px;font-weight:700;letter-spacing:-.01em}.signin-tagline{font-size:13px;color:var(--muted-foreground);margin:2px 0 0}.loading-screen{min-height:100vh;display:grid;place-items:center;color:var(--muted-foreground);font-size:14px}@media (max-width: 860px){.app{grid-template-columns:64px 1fr}.app .sidebar .label,.app .sidebar .meta,.app .sb-heading{display:none}.stat-grid{grid-template-columns:repeat(2,1fr)}}
