@import "https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700;800&family=JetBrains+Mono:wght@400;500;600&display=swap";.app{min-height:100vh;display:flex}.side{background:hsl(var(--sidebar));border-right:1px solid hsl(var(--border));flex-direction:column;flex-shrink:0;width:236px;padding:18px 14px;display:flex}.brand{align-items:center;gap:9px;margin-bottom:22px;font-size:15px;font-weight:700;display:flex}.brand .logo{background:hsl(var(--primary));color:#fff;width:28px;height:28px;box-shadow:var(--shadow-soft);border-radius:8px;place-items:center;display:grid}.nav{flex-direction:column;gap:2px;display:flex}.nav-group{margin-top:16px}.nav-group:first-of-type{margin-top:0}.nav-group-label{letter-spacing:.12em;text-transform:uppercase;color:hsl(var(--muted));margin:0 0 6px;padding:0 11px;font-size:10.5px;font-weight:700}.navitem{color:hsl(var(--foreground));transition:background var(--t-fast) var(--spring), border-color var(--t-fast) var(--spring);border:1px solid #0000;border-radius:8px;align-items:center;gap:9px;padding:9px 11px;font-size:14px;font-weight:500;text-decoration:none;display:flex}.navitem:hover{background:hsl(var(--surface-2))}.navitem .nav-ico{flex-shrink:0;width:16px;height:16px;display:inline-flex}.navitem .nav-ico svg{width:16px;height:16px}.navitem.sub{color:hsl(var(--muted));padding-left:30px;font-size:13px;font-weight:400}.navitem.active{background:hsl(var(--primary)/.16);border-color:hsl(var(--primary)/.55);color:hsl(var(--foreground))}.navitem.active .nav-ico{color:hsl(var(--primary))}.main{flex:1;max-width:1320px;padding:26px 30px}.topbar{justify-content:flex-end;align-items:center;gap:10px;margin-bottom:18px;display:flex}.pill{border-radius:var(--radius-pill);background:hsl(var(--surface)/.7);border:1px solid hsl(var(--border));color:hsl(var(--foreground));align-items:center;gap:7px;padding:6px 13px;font-size:13px;font-weight:500;display:inline-flex}select.pill{appearance:none;cursor:pointer}.pill.lock{border-color:hsl(var(--status-n8n)/.5);color:hsl(var(--muted))}.pill.lock.on{border-color:hsl(var(--status-dual)/.7);color:hsl(var(--status-dual));background:hsl(var(--status-dual)/.08)}.page-header{align-items:center;gap:13px;margin-bottom:22px;display:flex}.page-header .ico{background:hsl(var(--primary)/.12);width:42px;height:42px;color:hsl(var(--primary));border-radius:12px;place-items:center;font-size:20px;display:grid}.page-header h1{letter-spacing:-.02em;margin:0;font-size:26px;font-weight:800}.page-header p{color:hsl(var(--muted));margin:2px 0 0;font-size:13px}.card{background:hsl(var(--surface));border:1px solid hsl(var(--border));border-radius:var(--radius);box-shadow:var(--shadow-soft);padding:18px 20px}.card.elev{background:hsl(var(--surface-2))}.card.glow{box-shadow:var(--glow-edge);border-color:hsl(var(--status-edge)/.5)}.card.interactive{transition:border-color var(--t-fast) var(--spring), transform var(--t-fast) var(--spring)}.card.interactive:hover{border-color:hsl(var(--border-strong));transform:translateY(-1px)}.card-title{color:hsl(var(--muted));letter-spacing:.02em;margin:0 0 4px;font-size:12px;font-weight:600}.card-metric{letter-spacing:-.02em;font-size:30px;font-weight:800;line-height:1.05}.card-metric.mono{font-family:var(--font-mono)}.bento{grid-template-columns:repeat(12,minmax(0,1fr));align-items:stretch;gap:16px;display:grid}.bento>*{grid-column:span var(--span,4);grid-row:span var(--row,1);min-width:0}@media (width<=1100px){.bento>*{grid-column:span 6}}@media (width<=720px){.bento>*{grid-column:span 12}}.status-pill{border-radius:var(--radius-pill);border:1px solid hsl(var(--tone)/.25);background:hsl(var(--tone)/.15);color:hsl(var(--tone));align-items:center;gap:6px;padding:2px 10px;font-size:12px;font-weight:600;line-height:1.5;display:inline-flex}.status-pill .sp-ico{width:13px;height:13px;display:inline-flex}.status-pill .sp-ico svg{width:13px;height:13px}.status-pill[data-status=n8n],.status-pill[data-status=off],.status-pill[data-status=pending]{--tone:var(--status-n8n)}.status-pill[data-status=dual_write]{--tone:var(--status-dual)}.status-pill[data-status=running]{--tone:var(--primary)}.status-pill[data-status=edge]{--tone:var(--status-edge);box-shadow:var(--shadow-soft)}.status-pill[data-status=done]{--tone:var(--status-edge)}.status-pill[data-status=dead_letter],.status-pill[data-status=error]{--tone:var(--status-danger)}.loading-block{color:hsl(var(--muted));align-items:center;gap:12px;padding:28px 20px;display:flex}.spinner{border:2px solid hsl(var(--border-strong));border-top-color:hsl(var(--primary));border-radius:50%;width:18px;height:18px;animation:.7s linear infinite spin}.skel{background:linear-gradient(90deg, hsl(var(--surface-2)) 25%, hsl(var(--border)) 37%, hsl(var(--surface-2)) 63%);background-size:280% 100%;border-radius:6px;animation:1.4s ease-in-out infinite shimmer}.empty-state{text-align:center;color:hsl(var(--muted));flex-direction:column;align-items:center;gap:8px;padding:40px 24px;display:flex}.empty-state .es-ico{color:hsl(var(--muted));opacity:.7}.empty-state .es-title{color:hsl(var(--foreground));font-size:15px;font-weight:600}.empty-state .es-desc{max-width:380px;font-size:13px}.error-banner{border-radius:var(--radius);border:1px solid hsl(var(--status-danger)/.5);background:hsl(var(--status-danger)/.1);color:hsl(var(--foreground));align-items:center;gap:12px;margin-bottom:16px;padding:12px 16px;display:flex}.error-banner .eb-ico{color:hsl(var(--status-danger));flex-shrink:0}.error-banner .eb-msg{flex:1;font-size:13.5px}.error-banner .eb-msg .eb-code{font-family:var(--font-mono);color:hsl(var(--muted));font-size:12.5px}.error-banner .eb-retry{font:inherit;cursor:pointer;color:hsl(var(--foreground));background:hsl(var(--surface-2));border:1px solid hsl(var(--border-strong));transition:border-color var(--t-fast) var(--spring), background var(--t-fast) var(--spring);border-radius:7px;flex-shrink:0;padding:6px 12px;font-size:13px;font-weight:600}.error-banner .eb-retry:hover{background:hsl(var(--surface));border-color:hsl(var(--status-danger)/.6)}.banner-err{border:1px solid hsl(var(--status-danger)/.5);border-radius:var(--radius);color:hsl(var(--foreground));background:hsl(var(--status-danger)/.1);margin-bottom:16px;padding:12px 16px}@media (width<=900px){.side{display:none}}.global-write{border:1px solid hsl(var(--status-n8n)/.45);transition:border-color var(--t-mid) var(--ease-out), box-shadow var(--t-mid) var(--ease-out);justify-content:space-between;align-items:center;gap:18px;margin-bottom:20px;padding:20px 24px;display:flex}.global-write.on{border-color:hsl(var(--status-edge)/.6);box-shadow:var(--glow-edge)}.global-write .gw-left{align-items:center;gap:16px;display:flex}.global-write .gw-ico{width:48px;height:48px;color:hsl(var(--status-n8n));background:hsl(var(--status-n8n)/.12);transition:color var(--t-mid) var(--ease-out), background var(--t-mid) var(--ease-out);border-radius:12px;place-items:center;display:grid}.global-write.on .gw-ico{color:hsl(var(--status-edge));background:hsl(var(--status-edge)/.14)}.global-write .gw-title{letter-spacing:-.01em;font-size:17px;font-weight:800}.global-write .gw-sub{color:hsl(var(--muted));max-width:560px;margin-top:3px;font-size:12.5px}.global-write .gw-right{flex-shrink:0;align-items:center;gap:14px;display:flex}.switch-toggle{border-radius:var(--radius-pill);border:1px solid hsl(var(--border-strong));background:hsl(var(--surface-2));cursor:pointer;width:52px;height:28px;transition:background var(--t-mid) var(--ease-out), border-color var(--t-mid) var(--ease-out);flex-shrink:0;padding:0;position:relative}.switch-toggle.on{background:hsl(var(--status-edge)/.85);border-color:hsl(var(--status-edge))}.switch-toggle:disabled{opacity:.55;cursor:default}.switch-toggle .st-knob{background:hsl(var(--foreground));width:22px;height:22px;transition:transform var(--t-mid) var(--spring);border-radius:50%;position:absolute;top:2px;left:2px;box-shadow:0 1px 4px #0006}.switch-toggle.on .st-knob{transform:translate(24px)}.cutover-grid{grid-template-columns:repeat(auto-fill,minmax(340px,1fr));gap:16px;margin-top:4px;display:grid}.tenant-cutover{flex-direction:column;gap:14px;display:flex}.tenant-cutover .tc-head{justify-content:space-between;align-items:center;gap:10px;display:flex}.tenant-cutover .tc-name{font-size:16px;font-weight:700}.mode-switch{flex-wrap:wrap;align-items:center;gap:2px;display:flex}.mode-switch .ms-cell{align-items:center;gap:2px;display:inline-flex}.mode-switch .ms-sep{color:hsl(var(--muted));opacity:.6;margin:0 2px;display:inline-flex}.ms-step{font:inherit;cursor:pointer;white-space:nowrap;border:1px solid hsl(var(--border));background:hsl(var(--surface-2)/.6);color:hsl(var(--muted));transition:border-color var(--t-fast) var(--spring), background var(--t-fast) var(--spring), color var(--t-fast) var(--spring), transform var(--t-fast) var(--spring);border-radius:8px;padding:7px 12px;font-size:12.5px;font-weight:600}.ms-step:hover:not(:disabled):not(.active){border-color:hsl(var(--border-strong));color:hsl(var(--foreground));transform:translateY(-1px)}.ms-step:disabled{opacity:.45;cursor:not-allowed}.ms-step.active.tone-n8n{background:hsl(var(--status-n8n)/.18);border-color:hsl(var(--status-n8n)/.6);color:hsl(var(--status-n8n))}.ms-step.active.tone-dual_write{background:hsl(var(--status-dual)/.16);border-color:hsl(var(--status-dual)/.6);color:hsl(var(--status-dual))}.ms-step.active.tone-edge{background:hsl(var(--status-edge)/.16);border-color:hsl(var(--status-edge)/.6);color:hsl(var(--status-edge));box-shadow:var(--shadow-soft)}.gates{flex-wrap:wrap;gap:7px;display:flex}.gate-chip{border-radius:var(--radius-pill);border:1px solid hsl(var(--tone)/.4);background:hsl(var(--tone)/.1);color:hsl(var(--tone));align-items:center;gap:5px;padding:4px 9px;font-size:11.5px;font-weight:600;line-height:1.3;display:inline-flex}.gate-chip.ok{--tone:var(--status-edge)}.gate-chip.pending{--tone:var(--status-n8n);opacity:.82}.gate-chip.blocker{--tone:var(--status-danger)}.gate-chip .gc-ico{display:inline-flex}.tenant-cutover .tc-foot{margin-top:auto}.rollback-btn{font:inherit;cursor:pointer;border:1px solid hsl(var(--border-strong));background:hsl(var(--surface-2));color:hsl(var(--foreground));transition:border-color var(--t-fast) var(--spring), background var(--t-fast) var(--spring);border-radius:8px;align-items:center;gap:6px;padding:7px 12px;font-size:12.5px;font-weight:600;display:inline-flex}.rollback-btn:hover:not(:disabled){border-color:hsl(var(--accent)/.6);background:hsl(var(--accent)/.08);color:hsl(var(--accent))}.rollback-btn:disabled{opacity:.4;cursor:not-allowed}.modal-overlay{z-index:50;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);animation:rise var(--t-fast) var(--ease-out);background:#030407b8;place-items:center;padding:20px;display:grid;position:fixed;inset:0}.modal-card{background:hsl(var(--surface-2));border:1px solid hsl(var(--status-danger)/.45);border-radius:var(--radius-lg);width:100%;max-width:480px;max-height:90vh;padding:22px 24px;overflow-y:auto;box-shadow:0 24px 60px -12px #000000b3}.modal-head{align-items:center;gap:10px;margin-bottom:12px;display:flex}.modal-head h2{letter-spacing:-.01em;margin:0;font-size:18px;font-weight:800}.modal-ico.danger{width:36px;height:36px;color:hsl(var(--status-danger));background:hsl(var(--status-danger)/.14);border-radius:9px;flex-shrink:0;place-items:center;display:grid}.modal-warn{color:hsl(var(--foreground));margin:0 0 14px;font-size:13.5px;line-height:1.5}.modal-gates{background:hsl(var(--surface)/.6);border:1px solid hsl(var(--border));border-radius:var(--radius);margin-bottom:12px;padding:12px 14px}.modal-gates .mg-title{color:hsl(var(--muted));text-transform:uppercase;letter-spacing:.08em;margin-bottom:8px;font-size:11.5px;font-weight:700}.mg-row{align-items:center;gap:8px;padding:3px 0;font-size:12.5px;display:flex}.mg-row.ok{color:hsl(var(--status-edge))}.mg-row.pending{color:hsl(var(--muted))}.mg-row.blocker{color:hsl(var(--status-danger))}.mg-row .mg-detail{color:hsl(var(--muted));margin-left:auto;font-size:11.5px}.modal-block{color:hsl(var(--status-dual));align-items:center;gap:7px;margin-bottom:12px;font-size:12.5px;display:flex}.modal-error{color:hsl(var(--status-danger));background:hsl(var(--status-danger)/.1);border:1px solid hsl(var(--status-danger)/.4);border-radius:8px;align-items:center;gap:7px;margin-bottom:12px;padding:8px 12px;font-size:12.5px;display:flex}.modal-confirm-field{flex-direction:column;gap:7px;margin-bottom:18px;font-size:13px;display:flex}.modal-input{background:hsl(var(--surface));border:1px solid hsl(var(--border-strong));color:hsl(var(--foreground));border-radius:8px;padding:9px 12px;font-size:14px}.modal-input:focus{border-color:hsl(var(--primary)/.7);box-shadow:0 0 0 3px hsl(var(--primary)/.18);outline:none}.modal-actions{justify-content:flex-end;gap:10px;display:flex}.btn-ghost{font:inherit;cursor:pointer;border:1px solid hsl(var(--border-strong));color:hsl(var(--foreground));transition:background var(--t-fast) var(--spring);background:0 0;border-radius:8px;padding:9px 16px;font-size:13.5px;font-weight:600}.btn-ghost:hover:not(:disabled){background:hsl(var(--surface))}.btn-danger{font:inherit;cursor:pointer;color:#fff;background:hsl(var(--status-danger));box-shadow:var(--shadow-soft);transition:filter var(--t-fast) var(--spring);border:none;border-radius:8px;padding:9px 16px;font-size:13.5px;font-weight:700}.btn-danger:hover:not(:disabled){filter:brightness(1.08)}.btn-danger:disabled,.btn-ghost:disabled{opacity:.5;cursor:not-allowed}@media (width<=640px){.global-write{flex-direction:column;align-items:flex-start}.cutover-grid{grid-template-columns:1fr}}.page-header .fila-refresh{font:inherit;cursor:pointer;border:1px solid hsl(var(--border-strong));background:hsl(var(--surface-2));color:hsl(var(--foreground));transition:border-color var(--t-fast) var(--spring), background var(--t-fast) var(--spring);border-radius:8px;align-items:center;gap:6px;margin-left:auto;padding:7px 13px;font-size:12.5px;font-weight:600;display:inline-flex}.page-header .fila-refresh:hover:not(:disabled){border-color:hsl(var(--primary)/.6);color:hsl(var(--primary))}.page-header .fila-refresh:disabled{opacity:.5;cursor:default}.fila-filters{flex-wrap:wrap;gap:8px;margin-bottom:16px;display:flex}.filter-chip{font:inherit;cursor:pointer;border-radius:var(--radius-pill);border:1px solid hsl(var(--border));background:hsl(var(--surface-2)/.6);color:hsl(var(--muted));transition:border-color var(--t-fast) var(--spring), background var(--t-fast) var(--spring), color var(--t-fast) var(--spring);align-items:center;gap:6px;padding:6px 12px;font-size:12.5px;font-weight:600;display:inline-flex}.filter-chip:hover:not(:disabled):not(.active){border-color:hsl(var(--border-strong));color:hsl(var(--foreground))}.filter-chip:disabled{opacity:.4;cursor:not-allowed}.filter-chip .fc-count{border-radius:var(--radius-pill);background:hsl(var(--border)/.7);color:hsl(var(--foreground));padding:1px 6px;font-size:11.5px;font-weight:700}.filter-chip.active{background:hsl(var(--primary)/.16);border-color:hsl(var(--primary)/.6);color:hsl(var(--foreground))}.filter-chip.active .fc-count{background:hsl(var(--primary)/.3)}.filter-chip.tone-dead_letter.alarm{border-color:hsl(var(--status-danger)/.55);color:hsl(var(--status-danger))}.filter-chip.tone-dead_letter.alarm .fc-count{background:hsl(var(--status-danger)/.22);color:hsl(var(--status-danger))}.filter-chip.tone-dead_letter.alarm.active{background:hsl(var(--status-danger)/.16)}.fila-table-card{padding:0;overflow:hidden}.fila-table{border-collapse:collapse;width:100%;font-size:13px}.fila-table thead th{text-align:left;letter-spacing:.08em;text-transform:uppercase;color:hsl(var(--muted));border-bottom:1px solid hsl(var(--border));white-space:nowrap;padding:11px 14px;font-size:10.5px;font-weight:700}.fila-table th.num,.fila-table td.num{text-align:right;font-variant-numeric:tabular-nums}.fila-table th.actions-col,.fila-table td.actions-col{text-align:right;white-space:nowrap}.fila-table tbody td{border-bottom:1px solid hsl(var(--border)/.5);vertical-align:middle;padding:10px 14px}.fila-table tbody tr:last-child td{border-bottom:none}.fila-table .mono{font-family:var(--font-mono);font-variant-numeric:tabular-nums}.fila-table .muted{color:hsl(var(--muted))}.fila-row{cursor:pointer;transition:background var(--t-fast) var(--ease-out)}.fila-row:hover{background:hsl(var(--surface-2)/.5)}.fila-row:focus-visible{outline:2px solid hsl(var(--primary)/.6);outline-offset:-2px}.fila-row.is-dead{background:hsl(var(--status-danger)/.06);box-shadow:inset 3px 0 0 hsl(var(--status-danger))}.fila-row.is-dead:hover{background:hsl(var(--status-danger)/.1)}.fila-table .job-type{color:hsl(var(--foreground));font-size:12px}.fila-table td.num.exhausted,.drawer-meta dd.exhausted{color:hsl(var(--status-danger));font-weight:700}.fila-table .when{white-space:nowrap}.fila-table .when-rel{display:block}.fila-table .when-sub{color:hsl(var(--muted));align-items:center;gap:4px;margin-top:2px;font-size:11px;display:inline-flex}.fila-table .lock .lock-on{color:hsl(var(--status-dual));align-items:center;gap:4px;font-size:11.5px;display:inline-flex}.fila-table .err-cell{max-width:320px}.fila-table .err-snippet{text-overflow:ellipsis;white-space:nowrap;max-width:320px;color:hsl(var(--status-danger));background:hsl(var(--status-danger)/.08);border-radius:6px;padding:2px 7px;font-size:11.5px;display:block;overflow:hidden}.requeue-btn{font:inherit;cursor:pointer;border:1px solid hsl(var(--accent)/.5);background:hsl(var(--accent)/.12);color:hsl(var(--accent));transition:filter var(--t-fast) var(--spring), background var(--t-fast) var(--spring);border-radius:7px;align-items:center;gap:5px;padding:5px 11px;font-size:12px;font-weight:700;display:inline-flex}.requeue-btn:hover:not(:disabled){background:hsl(var(--accent)/.2)}.requeue-btn:disabled{opacity:.55;cursor:default}.inspect-link{font:inherit;cursor:pointer;color:hsl(var(--muted));transition:color var(--t-fast) var(--spring), border-color var(--t-fast) var(--spring);background:0 0;border:1px solid #0000;border-radius:7px;align-items:center;gap:5px;padding:5px 9px;font-size:12px;font-weight:600;display:inline-flex}.inspect-link:hover{color:hsl(var(--primary));border-color:hsl(var(--primary)/.4)}.drawer-overlay{z-index:50;-webkit-backdrop-filter:blur(3px);backdrop-filter:blur(3px);animation:rise var(--t-fast) var(--ease-out);background:#03040799;justify-content:flex-end;display:flex;position:fixed;inset:0}.drawer-panel{background:hsl(var(--surface-2));border-left:1px solid hsl(var(--border-strong));flex-direction:column;width:100%;max-width:520px;height:100%;display:flex;box-shadow:-24px 0 60px -12px #0009}.drawer-head{border-bottom:1px solid hsl(var(--border));flex-shrink:0;justify-content:space-between;align-items:center;gap:12px;padding:16px 20px;display:flex}.drawer-head .dh-title{align-items:center;gap:10px;min-width:0;display:flex}.drawer-head .dh-type{font-family:var(--font-mono);color:hsl(var(--foreground));text-overflow:ellipsis;font-size:13px;font-weight:600;overflow:hidden}.drawer-close{border:1px solid hsl(var(--border));background:hsl(var(--surface));width:30px;height:30px;color:hsl(var(--muted));cursor:pointer;transition:color var(--t-fast) var(--spring), border-color var(--t-fast) var(--spring);border-radius:8px;flex-shrink:0;place-items:center;display:grid}.drawer-close:hover{color:hsl(var(--foreground));border-color:hsl(var(--border-strong))}.drawer-body{flex-direction:column;flex:1;gap:18px;padding:18px 20px;display:flex;overflow-y:auto}.drawer-meta{grid-template-columns:1fr 1fr;gap:10px 18px;margin:0;display:grid}.drawer-meta>div{flex-direction:column;gap:2px;min-width:0;display:flex}.drawer-meta dt{letter-spacing:.06em;text-transform:uppercase;color:hsl(var(--muted));font-size:10.5px;font-weight:700}.drawer-meta dd{color:hsl(var(--foreground));word-break:break-all;margin:0;font-size:12.5px}.drawer-meta dd.mono{font-family:var(--font-mono);font-variant-numeric:tabular-nums}.drawer-section h3{letter-spacing:.04em;text-transform:uppercase;color:hsl(var(--muted));align-items:center;gap:7px;margin:0 0 8px;font-size:12px;font-weight:700;display:flex}.drawer-pre{border-radius:var(--radius);max-height:280px;font-family:var(--font-mono);white-space:pre-wrap;word-break:break-word;background:hsl(var(--surface)/.8);border:1px solid hsl(var(--border));color:hsl(var(--foreground));margin:0;padding:12px 14px;font-size:12px;line-height:1.55;overflow:auto}.drawer-pre.err{color:hsl(var(--status-danger));background:hsl(var(--status-danger)/.08);border-color:hsl(var(--status-danger)/.35)}.drawer-empty{color:hsl(var(--muted));padding:6px 0;font-size:12.5px}.drawer-foot{border-top:1px solid hsl(var(--border));flex-shrink:0;justify-content:flex-end;gap:10px;padding:14px 20px;display:flex}.btn-requeue{font:inherit;cursor:pointer;color:hsl(var(--accent-foreground));background:hsl(var(--accent));box-shadow:var(--shadow-soft);transition:filter var(--t-fast) var(--spring);border:none;border-radius:8px;align-items:center;gap:7px;padding:9px 16px;font-size:13.5px;font-weight:700;display:inline-flex}.btn-requeue:hover:not(:disabled){filter:brightness(1.08)}.btn-requeue:disabled{opacity:.55;cursor:default}@media (width<=640px){.drawer-panel{max-width:100%}.fila-table .err-cell,.fila-table .err-snippet{max-width:160px}.drawer-meta{grid-template-columns:1fr}}.login{place-items:center;min-height:100vh;padding:24px;display:grid}.login-card{width:100%;max-width:360px;animation:rise .4s var(--spring);flex-direction:column;gap:14px;display:flex}.login-card .brand{margin-bottom:0}.login-sub{color:hsl(var(--muted));margin:-6px 0 6px;font-size:13px}.login-field{flex-direction:column;gap:6px;font-size:13px;font-weight:500;display:flex}.login-field input{font:inherit;background:hsl(var(--surface-2));border:1px solid hsl(var(--border));color:hsl(var(--foreground));border-radius:8px;padding:9px 12px;font-size:14px}.login-field input:focus{border-color:hsl(var(--primary)/.7);box-shadow:0 0 0 3px hsl(var(--primary)/.18);outline:none}.login-btn{font:inherit;cursor:pointer;color:hsl(var(--primary-foreground));background:hsl(var(--primary));box-shadow:var(--shadow-soft);transition:filter var(--t-fast) var(--spring);border:none;border-radius:8px;margin-top:4px;padding:10px 14px;font-size:14px;font-weight:600}.login-btn:hover:not(:disabled){filter:brightness(1.08)}.login-btn:disabled{opacity:.6;cursor:default}.ghost-btn{font:inherit;cursor:pointer;color:hsl(var(--muted));background:hsl(var(--surface));border:1px solid hsl(var(--border));transition:all var(--t-fast) var(--spring);border-radius:8px;align-items:center;gap:6px;margin-left:auto;padding:7px 12px;font-size:13px;font-weight:500;display:inline-flex}.ghost-btn:hover{color:hsl(var(--foreground));border-color:hsl(var(--border-strong))}.ghost-btn svg{width:14px;height:14px}[data-tone=edge]{--tc:var(--status-edge)}[data-tone=dual]{--tc:var(--status-dual)}[data-tone=danger]{--tc:var(--status-danger)}[data-tone=n8n]{--tc:var(--status-n8n)}[data-tone=info]{--tc:var(--info)}b[data-tone],span[data-tone]{color:hsl(var(--tc,var(--foreground)))}.card.glow-soft{border-color:hsl(var(--border-strong));box-shadow:var(--shadow-soft)}.card.as-link{color:inherit;flex-direction:column;text-decoration:none;display:flex}.muted{color:hsl(var(--muted))}.row-between{justify-content:space-between;align-items:center;gap:8px;display:flex}.gauge-wrap{flex:1;justify-content:center;align-items:center;padding:14px 0 10px;display:flex}.gauge{--val:0;--ring:var(--status-edge);background:conic-gradient(hsl(var(--ring)) calc(var(--val) * 1%), hsl(var(--border)/.55) 0);width:168px;height:168px;transition:background var(--t-slow) var(--ease-out);border-radius:50%;place-items:center;display:grid;position:relative}.gauge:after{content:"";background:hsl(var(--surface));box-shadow:inset 0 0 24px hsl(var(--ring)/.15);border-radius:50%;position:absolute;inset:16px}.g-center{z-index:1;text-align:center;position:relative}.g-val{letter-spacing:-.02em;font-size:32px;font-weight:800}.g-sub{color:hsl(var(--muted));margin-top:2px;font-size:11px}.cov-legend{flex-direction:column;align-items:center;gap:2px;font-size:13px;display:flex}.cov-legend b{font-size:14px}.metric-row{color:hsl(var(--foreground));align-items:center;gap:10px;margin:6px 0 12px;display:flex}.metric-row svg{color:hsl(var(--muted))}.dot{background:hsl(var(--tc,var(--muted)));width:11px;height:11px;box-shadow:0 0 0 3px hsl(var(--tc,var(--muted))/.15);border-radius:50%;flex-shrink:0}.dot-line{color:hsl(var(--tc,var(--muted)));margin-top:8px;font-size:12px;font-weight:600;display:inline-block}.dot-line:before{content:"● "}.kv{color:hsl(var(--muted));border-top:1px solid hsl(var(--border)/.5);justify-content:space-between;align-items:center;gap:10px;padding:6px 0;font-size:13px;display:flex}.kv:first-of-type{border-top:none}.kv b{color:hsl(var(--foreground));font-weight:600}.kv.big{padding:9px 0}.kv.big b{font-size:18px}.tile-link{color:hsl(var(--primary));margin-top:auto;padding-top:10px;font-size:12.5px;font-weight:600}.err-list{flex-direction:column;gap:9px;margin-top:10px;display:flex}.err-row{grid-template-columns:44px 1fr 120px;align-items:center;gap:12px;display:grid}.err-count{color:hsl(var(--status-danger));text-align:right;font-size:16px;font-weight:700}.err-msg{color:hsl(var(--foreground));white-space:nowrap;text-overflow:ellipsis;background:hsl(var(--surface-2));border-radius:6px;padding:4px 9px;font-size:12.5px;overflow:hidden}.err-bar{background:hsl(var(--border)/.5);border-radius:999px;height:8px;overflow:hidden}.err-bar span{background:linear-gradient(90deg, hsl(var(--status-danger)/.6), hsl(var(--status-danger)));border-radius:999px;height:100%;display:block}.cutover-flow{margin-top:22px}.cf-title{color:hsl(var(--muted));letter-spacing:.04em;text-transform:uppercase;margin-bottom:12px;font-size:12px;font-weight:600}.cf-grid{grid-template-columns:repeat(3,1fr);gap:16px;display:grid}@media (width<=900px){.cf-grid{grid-template-columns:1fr}}.flow-card{border-left:3px solid hsl(var(--tone,var(--border)));flex-direction:column;gap:10px;display:flex}.flow-card.tone-n8n{--tone:var(--status-n8n)}.flow-card.tone-dual_write{--tone:var(--status-dual)}.flow-card.tone-edge{--tone:var(--status-edge)}.cf-step{align-items:center;gap:10px;display:flex}.cf-num{background:hsl(var(--tone)/.15);width:24px;height:24px;color:hsl(var(--tone));border-radius:50%;flex-shrink:0;place-items:center;font-size:13px;font-weight:700;display:grid}.cf-explain{color:hsl(var(--muted));margin:0;font-size:13px;line-height:1.5}.badge-pill{border-radius:var(--radius-pill);white-space:nowrap;background:hsl(var(--tc,var(--muted))/.15);color:hsl(var(--tc,var(--muted)));align-items:center;gap:5px;padding:2px 10px;font-size:12px;font-weight:600;line-height:1.5;display:inline-flex}.kpi-grid{grid-template-columns:repeat(4,minmax(0,1fr));gap:16px;margin-bottom:16px;display:grid}@media (width<=1100px){.kpi-grid{grid-template-columns:repeat(2,1fr)}}@media (width<=560px){.kpi-grid{grid-template-columns:1fr}}.kpi-label{letter-spacing:.08em;text-transform:uppercase;color:hsl(var(--muted));margin-bottom:6px;font-size:10.5px;font-weight:700}.kpi-value{letter-spacing:-.01em;font-variant-numeric:tabular-nums;color:hsl(var(--tc,var(--foreground)));font-size:1.5rem;font-weight:700;line-height:1.15}.kpi-sub{color:hsl(var(--muted));margin-top:4px;font-size:12px}.sources{flex-direction:column;gap:4px;margin-top:6px;display:flex}.source-row{border-top:1px solid hsl(var(--border)/.5);align-items:flex-start;gap:12px;padding:10px 0;display:flex}.source-row:first-of-type{border-top:none}.source-name{align-items:center;gap:9px;font-size:14px;font-weight:600;display:flex}.source-sub{color:hsl(var(--muted));margin-top:3px;font-size:12.5px}.source-ico{background:hsl(var(--tc,var(--muted))/.12);width:34px;height:34px;color:hsl(var(--tc,var(--muted)));border-radius:9px;flex-shrink:0;place-items:center;display:grid}.toolbar{flex-wrap:wrap;align-items:center;gap:8px;margin-bottom:16px;display:flex}.toolbar .search-input{border-radius:var(--radius);min-width:200px;max-width:340px;font:inherit;background:hsl(var(--surface));border:1px solid hsl(var(--border));color:hsl(var(--foreground));flex:1;padding:7px 12px;font-size:13px}.toolbar .search-input::placeholder{color:hsl(var(--muted)/.8)}.toolbar .search-input:focus{border-color:hsl(var(--primary)/.7);box-shadow:0 0 0 3px hsl(var(--primary)/.15);outline:none}.pager{color:hsl(var(--muted));border-top:1px solid hsl(var(--border));justify-content:flex-end;align-items:center;gap:10px;padding:12px 14px;font-size:12.5px;display:flex}.pager button{font:inherit;cursor:pointer;border:1px solid hsl(var(--border-strong));background:hsl(var(--surface-2));color:hsl(var(--foreground));transition:border-color var(--t-fast) var(--spring);border-radius:7px;padding:5px 11px;font-size:12.5px;font-weight:600}.pager button:hover:not(:disabled){border-color:hsl(var(--primary)/.6)}.pager button:disabled{opacity:.4;cursor:default}.page-note{color:hsl(var(--muted));margin-top:14px;font-size:12.5px}.brand-img{-webkit-user-select:none;user-select:none;width:auto;height:28px}.switcher{margin:4px 10px 10px;position:relative}.switcher-trigger{cursor:pointer;text-align:left;width:100%;color:hsl(var(--foreground));background:0 0;border:0;border-radius:10px;align-items:center;gap:10px;padding:8px;transition:background .15s;display:flex}.switcher-trigger:hover,.switcher-trigger[aria-expanded=true]{background:hsl(var(--surface-2,var(--surface)))}.sw-badge{background:hsl(var(--primary,var(--accent)));color:#fff;letter-spacing:.02em;border-radius:10px;flex:none;justify-content:center;align-items:center;width:36px;height:36px;font-size:12px;font-weight:800;display:flex}.sw-badge.sm{border:1px solid hsl(var(--border));width:24px;height:24px;color:hsl(var(--foreground));background:0 0;border-radius:7px;font-size:10px}.sw-text{flex:1;min-width:0;line-height:1.2;display:grid}.sw-title{white-space:nowrap;text-overflow:ellipsis;font-size:13.5px;font-weight:650;overflow:hidden}.sw-sub{color:hsl(var(--muted));font-size:11px}.sw-chevrons{color:hsl(var(--muted));display:flex}.switcher-panel{z-index:40;background:hsl(var(--surface));border:1px solid hsl(var(--border));border-radius:12px;position:absolute;top:calc(100% + 6px);left:0;right:0;overflow:hidden;box-shadow:0 8px 24px #00000059}.sw-search{box-sizing:border-box;border:0;border-bottom:1px solid hsl(var(--border));width:100%;color:hsl(var(--foreground));font:inherit;background:0 0;outline:none;padding:10px 12px;font-size:13px}.sw-search::placeholder{color:hsl(var(--muted))}.sw-list{max-height:240px;padding:4px;overflow-y:auto}.sw-item{cursor:pointer;text-align:left;width:100%;color:hsl(var(--foreground));font:inherit;background:0 0;border:0;border-radius:8px;align-items:center;gap:9px;padding:7px 8px;font-size:13px;display:flex}.sw-item:hover{background:hsl(var(--surface-2,var(--border)))}.sw-item-name{white-space:nowrap;text-overflow:ellipsis;flex:1;min-width:0;overflow:hidden}.sw-check{color:hsl(var(--primary,var(--accent)));display:flex}.sw-empty{color:hsl(var(--muted));padding:12px;font-size:12.5px}.btn-sync{cursor:pointer;background:hsl(var(--primary));color:#fff;font:inherit;border:0;border-radius:8px;margin-left:auto;padding:8px 14px;font-size:13px;font-weight:650;transition:filter .15s}.btn-sync:hover{filter:brightness(1.08)}.btn-sync:disabled{opacity:.55;cursor:default}.sync-msg{border-radius:10px;margin:10px 0 0;padding:10px 14px;font-size:13px}.sync-msg.ok{color:#6ee7b7;background:#10b9811f;border:1px solid #10b98159}.sync-msg.err{color:#fca5a5;background:#ef44441f;border:1px solid #ef444459}.modal-overlay{z-index:60;background:#0000008c;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.modal{width:calc(100% - 48px);max-width:460px;padding:22px}.modal h2{margin:0 0 8px;font-size:17px}.modal p{margin:0 0 10px;font-size:13.5px;line-height:1.5}.modal-actions{justify-content:flex-end;gap:10px;margin-top:14px;display:flex}.btn-ghost{border:1px solid hsl(var(--border));cursor:pointer;color:hsl(var(--foreground));font:inherit;background:0 0;border-radius:8px;padding:8px 14px;font-size:13px}:root{--background:228 9% 10%;--surface:216 14% 14%;--surface-2:216 14% 18%;--foreground:220 23% 97%;--muted:218 25% 73%;--border:221 18% 24%;--border-strong:221 18% 32%;--primary:359 84% 58%;--primary-foreground:0 0% 100%;--accent:359 84% 58%;--accent-foreground:0 0% 100%;--status-n8n:220 9% 46%;--status-dual:38 92% 50%;--status-edge:160 84% 39%;--status-danger:0 84% 60%;--success:var(--status-edge);--warning:var(--status-dual);--danger:var(--status-danger);--info:199 89% 48%;--card:var(--surface);--card-elev:var(--surface-2);--sidebar:210 25% 8%;--radius:.5rem;--radius-lg:.75rem;--radius-pill:999px;--spring:cubic-bezier(.16, 1, .3, 1);--ease-out:cubic-bezier(.22, 1, .36, 1);--t-fast:.15s;--t-mid:.22s;--t-slow:.3s;--shadow-soft:0 1px 3px #0000001a;--glow-edge:0 0 0 1px hsl(var(--status-edge)/.35), 0 1px 3px #0000001a;--font-ui:"Inter", system-ui, sans-serif;--font-mono:"JetBrains Mono", ui-monospace, "SF Mono", Menlo, monospace}*{box-sizing:border-box}body{font-family:var(--font-ui);color:hsl(var(--foreground));background:hsl(var(--background));font-variant-numeric:tabular-nums;-webkit-font-smoothing:antialiased;text-rendering:optimizelegibility;min-height:100vh;margin:0}code,kbd,samp,pre,.mono{font-family:var(--font-mono);font-variant-numeric:tabular-nums}:where(a,button,select,input,[tabindex]):focus-visible{outline:2px solid hsl(var(--primary));outline-offset:2px;border-radius:6px}.sr-only{clip:rect(0 0 0 0);white-space:nowrap;border:0;width:1px;height:1px;margin:-1px;padding:0;position:absolute;overflow:hidden}@keyframes rise{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:none}}@keyframes glowPulse{0%,to{box-shadow:0 0 0 1px hsl(var(--status-edge)/.3), var(--shadow-soft)}50%{box-shadow:0 0 0 1px hsl(var(--status-edge)/.45), var(--shadow-soft)}}@keyframes shimmer{0%{background-position:-180% 0}to{background-position:180% 0}}@keyframes spin{to{transform:rotate(360deg)}}@media (prefers-reduced-motion:reduce){*,:before,:after{transition-duration:.001ms!important;animation-duration:.001ms!important;animation-iteration-count:1!important}}
