:root{--bg:#f4f1ec;--panel:#fffdf8;--panel-strong:#fff7e8;--ink:#1e2524;--muted:#60706f;--line:#d9d3c8;--accent:#0f6b5b;--accent-strong:#0a4c40;--blue:#295f8f;--gold:#9b6b16;--red:#9b2d22;--green-soft:#e1f2ec;--blue-soft:#e6eef7;--gold-soft:#f5ead0;--red-soft:#f7ded9;--shadow:0 16px 40px rgba(30,37,36,0.08);--stage-1:var(--blue);--stage-1-soft:var(--blue-soft);--stage-2:#6b5a3a;--stage-2-soft:#efe7d3;--stage-3:var(--gold);--stage-3-soft:var(--gold-soft);--stage-4:var(--accent);--stage-4-soft:var(--green-soft);--stage-5:#6b3a52;--stage-5-soft:#f1dee7;--ink-strong:#0f1716;--surface-raised:#fffefa;--surface-sunken:#efeae0}*{box-sizing:border-box}body,html{min-height:100%}body{margin:0;background:var(--bg);color:var(--ink);font-family:Inter,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;letter-spacing:0}a{color:inherit;text-decoration:none}button,input,select,textarea{font:inherit}button{cursor:pointer}.app-shell{display:grid;grid-template-columns:268px minmax(0,1fr);min-height:100vh}.sidebar{display:flex;flex-direction:column;gap:26px;padding:22px 18px;background:#182422;color:#f7f2e8}.brand{display:flex;align-items:center;gap:12px;min-height:48px}.brand span,.brand strong{display:block}.brand strong{font-size:16px}.brand span,.eyebrow,.muted,.user-email{color:var(--muted)}.sidebar .brand span,.sidebar .user-email{color:#b9c7c2}.nav-list{display:grid;gap:6px}.danger-button,.icon-text-button,.nav-item,.primary-button,.secondary-button{display:inline-flex;align-items:center;justify-content:center;gap:8px;min-height:38px;border-radius:8px;border:1px solid transparent;font-weight:700}.nav-item{justify-content:flex-start;padding:0 12px;color:#dbe7e2}.nav-item:focus-visible,.nav-item:hover{background:rgba(255,255,255,.08);outline:none}.sidebar-footer{display:grid;gap:12px;margin-top:auto}.user-email{overflow-wrap:anywhere;font-size:13px}.icon-text-button{width:100%;padding:0 12px;background:rgba(255,255,255,.08);color:#fffaf1}.main-panel{min-width:0;padding:28px}.page-header{display:flex;align-items:flex-start;justify-content:space-between;gap:20px;margin-bottom:22px}.page-title{margin:0;font-size:30px;line-height:1.15}.page-subtitle{max-width:820px;margin:7px 0 0;color:var(--muted)}.grid{display:grid;gap:16px}.grid.two{grid-template-columns:repeat(2,minmax(0,1fr))}.grid.three{grid-template-columns:repeat(3,minmax(0,1fr))}.pipeline-grid,.stats-grid{display:grid;grid-template-columns:repeat(5,minmax(160px,1fr));gap:12px;margin-bottom:18px}.panel,.stat-card,.table-wrap{border:1px solid var(--line);border-radius:8px;background:var(--panel);box-shadow:var(--shadow)}.stat-card{padding:15px}.stage-card span,.stat-card span{display:block;color:var(--muted);font-size:13px;font-weight:700}.stage-card strong,.stat-card strong{display:block;margin-top:8px;font-size:28px;line-height:1}.stage-card{position:relative;display:grid;min-height:150px;align-content:space-between;border:1px solid var(--line);border-radius:8px;background:#fffefa;box-shadow:var(--shadow);padding:15px}.stage-card:after{content:"";position:absolute;right:-12px;top:50%;width:12px;height:1px;background:var(--line)}.stage-card:last-child:after{display:none}.capture-preview,.metric-row p,.stage-card p{margin:0}.metric-row,.stage-meta{display:flex;align-items:center;justify-content:space-between;gap:10px}.metric-row{padding:9px 0;border-bottom:1px solid var(--line)}.metric-row:last-child{border-bottom:0}.panel{padding:18px}.alert{margin-bottom:16px;border:1px solid var(--gold-soft);border-radius:8px;background:#fff7e4;color:#624411;padding:12px 14px;font-weight:700}.panel-header{display:flex;align-items:center;justify-content:space-between;gap:14px;margin-bottom:14px}.panel-title{margin:0;font-size:18px}.table-wrap{overflow:auto}table{width:100%;border-collapse:collapse}td,th{padding:12px 14px;border-bottom:1px solid var(--line);text-align:left;vertical-align:top}th{background:var(--panel-strong);color:#41504e;font-size:12px;letter-spacing:0;text-transform:uppercase}tr:last-child td{border-bottom:0}.filter-tabs,.form-grid,.inline-form,.row-actions{display:flex;flex-wrap:wrap;gap:8px}.filter-tabs{margin-bottom:16px}.filter-tab{display:inline-flex;align-items:center;min-height:34px;border:1px solid var(--line);border-radius:8px;background:#fffefa;color:var(--ink);padding:0 12px;font-weight:800}.filter-tab.active{border-color:var(--accent);background:var(--green-soft);color:var(--accent-strong)}.quality-list{display:flex;flex-wrap:wrap;gap:5px;margin-top:6px}.quality-list .badge{min-height:21px;font-size:11px}.capture-preview{max-width:680px;color:#3f4c49;line-height:1.45}.provenance{display:grid;gap:6px;margin:10px 0 0;color:var(--muted);font-size:13px}.code-cell{max-width:380px;overflow-wrap:anywhere}.form-grid{display:grid;grid-template-columns:repeat(4,minmax(180px,1fr));align-items:end}.form-grid.wide{grid-template-columns:repeat(2,minmax(220px,1fr))}label{display:grid;gap:6px;color:#34413f;font-size:13px;font-weight:700}input,select,textarea{width:100%;min-height:38px;border:1px solid #cfc8bb;border-radius:8px;background:#fffefa;color:var(--ink);padding:8px 10px}textarea{min-height:96px;resize:vertical}.primary-button{padding:0 14px;background:var(--accent);color:white}.primary-button:focus-visible,.primary-button:hover{background:var(--accent-strong)}.danger-button,.secondary-button{min-height:34px;padding:0 12px;background:#fffefa;color:var(--ink);border-color:var(--line)}.danger-button{color:var(--red)}.badge{display:inline-flex;align-items:center;min-height:24px;border-radius:999px;padding:0 9px;background:var(--blue-soft);color:var(--blue);font-size:12px;font-weight:800;white-space:nowrap}.badge.good{background:var(--green-soft);color:var(--accent-strong)}.badge.warn{background:var(--gold-soft);color:var(--gold)}.badge.bad{background:var(--red-soft);color:var(--red)}.badge.muted{background:#ece8df;color:#586461}.login-page{display:grid;min-height:100vh;place-items:center;padding:24px}.login-panel{width:min(440px,100%);border:1px solid var(--line);border-radius:8px;background:var(--panel);box-shadow:var(--shadow);padding:28px}.login-panel h1{margin:0 0 8px}.login-panel form{display:grid;gap:14px;margin-top:22px}.error-message{padding:10px 12px;border:1px solid var(--red-soft);border-radius:8px;background:#fff1ee;color:var(--red);font-weight:700}.empty-state{padding:24px;color:var(--muted)}@media (max-width:1100px){.app-shell{grid-template-columns:1fr}.sidebar{position:static}.nav-list{grid-template-columns:repeat(3,minmax(0,1fr))}.form-grid,.form-grid.wide,.grid.three,.grid.two,.pipeline-grid,.stats-grid{grid-template-columns:1fr}.stage-card:after{display:none}}@media (max-width:640px){.main-panel{padding:18px}.page-header{display:grid}.nav-list{grid-template-columns:1fr}}.pipeline-nav{display:grid;gap:22px}.nav-group{display:grid;gap:6px}.nav-group-label{margin:0 0 4px;padding:0 8px;font-size:11px;font-weight:800;letter-spacing:.12em;text-transform:uppercase;color:#8da39d}.pipeline-nav .nav-item{display:grid;grid-template-columns:22px 1fr auto;align-items:center;gap:10px;min-height:42px;padding:0 10px}.pipeline-nav .nav-item.system{grid-template-columns:18px 1fr auto}.pipeline-nav .nav-item.active{background:rgba(255,255,255,.1);border-color:rgba(255,255,255,.18)}.stage-chip{display:inline-flex;align-items:center;justify-content:center;width:22px;height:22px;border-radius:6px;background:rgba(255,255,255,.14);color:#fff;font-size:11px;font-weight:800;line-height:1}.stage-chip[data-stage="1"]{background:var(--stage-1)}.stage-chip[data-stage="2"]{background:var(--stage-2)}.stage-chip[data-stage="3"]{background:var(--stage-3);color:#2b1d04}.stage-chip[data-stage="4"]{background:var(--stage-4)}.stage-chip[data-stage="5"]{background:var(--stage-5)}.nav-pill{display:inline-flex;align-items:center;min-height:20px;padding:0 7px;border-radius:999px;background:rgba(255,255,255,.12);color:#f1ece0;font-size:11px;font-weight:800;white-space:nowrap}.nav-pill.warn{background:rgba(245,234,208,.22);color:#f5ead0}.nav-pill.bad{background:rgba(247,222,217,.25);color:#f7ded9}.nav-pill.muted{background:rgba(255,255,255,.06);color:#b9c7c2}.stage-header{display:grid;gap:16px;margin-bottom:22px;padding:20px 22px;border-left:1px solid var(--line);border:1px solid var(--line);border-left-width:4px;border-radius:10px;background:var(--surface-raised);box-shadow:var(--shadow)}.stage-header[data-stage="1"]{border-left-color:var(--stage-1)}.stage-header[data-stage="2"]{border-left-color:var(--stage-2)}.stage-header[data-stage="3"]{border-left-color:var(--stage-3)}.stage-header[data-stage="4"]{border-left-color:var(--stage-4)}.stage-header[data-stage="5"]{border-left-color:var(--stage-5)}.stage-header.system{border-left-color:#b8aea0}.stage-header-top{display:flex;align-items:flex-start;justify-content:space-between;gap:20px}.stage-eyebrow{display:inline-flex;align-items:center;gap:8px;margin:0 0 6px;font-size:12px;font-weight:800;letter-spacing:.08em;text-transform:uppercase;color:var(--muted)}.stage-eyebrow .stage-chip{width:24px;height:24px;font-size:12px}.stage-title{margin:0;font-size:28px;line-height:1.15;color:var(--ink-strong)}.stage-subtitle{max-width:760px;margin:8px 0 0;color:var(--muted);line-height:1.5}.stage-flow{display:flex;flex-wrap:wrap;align-items:center;gap:10px;margin:0;padding-top:12px;border-top:1px dashed var(--line);color:var(--muted);font-size:13px}.stage-flow strong{color:var(--ink);font-weight:700}.stage-flow .flow-arrow{display:inline-flex;align-items:center;color:#b8aea0}.stage-kpis{display:grid;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:10px}.kpi-tile{display:grid;gap:6px;padding:14px 16px;border:1px solid var(--line);border-radius:10px;background:var(--surface-raised)}.kpi-tile.good{border-color:#b6dcc9;background:#f1faf5}.kpi-tile.warn{border-color:#ecd9a8;background:#fbf5e3}.kpi-tile.bad{border-color:#ecc7c0;background:#fbf0ec}.kpi-label{color:var(--muted);font-size:12px;font-weight:800;letter-spacing:.04em;text-transform:uppercase}.kpi-value{font-size:26px;font-weight:800;line-height:1;color:var(--ink-strong)}.kpi-hint{color:var(--muted);font-size:12px}.pipeline-canvas{position:relative;display:grid;grid-template-columns:repeat(5,minmax(0,1fr));gap:12px;margin-bottom:22px;padding:20px 18px;border:1px solid var(--line);border-radius:12px;background:var(--surface-raised);box-shadow:var(--shadow)}.canvas-stage{position:relative;display:grid;gap:10px;padding:14px 14px 16px;border:1px solid var(--line);border-top:4px solid var(--line);border-radius:10px;background:#fff;text-align:left;color:inherit;transition:transform .12s ease,box-shadow .12s ease}.canvas-stage:hover{transform:translateY(-1px);box-shadow:0 8px 20px rgba(30,37,36,.08)}.canvas-stage[data-stage="1"]{border-top-color:var(--stage-1)}.canvas-stage[data-stage="2"]{border-top-color:var(--stage-2)}.canvas-stage[data-stage="3"]{border-top-color:var(--stage-3)}.canvas-stage[data-stage="4"]{border-top-color:var(--stage-4)}.canvas-stage[data-stage="5"]{border-top-color:var(--stage-5)}.canvas-stage-head{display:flex;align-items:center;gap:8px;font-size:12px;font-weight:800;letter-spacing:.06em;text-transform:uppercase;color:var(--muted)}.canvas-stage-name{margin:0;font-size:16px;font-weight:800;color:var(--ink-strong);text-transform:none;letter-spacing:0}.canvas-stage-value{display:flex;align-items:baseline;gap:6px;margin:0}.canvas-stage-value strong{font-size:30px;line-height:1;color:var(--ink-strong)}.canvas-stage-value span{color:var(--muted);font-size:12px}.canvas-stage-detail{margin:0;color:var(--muted);font-size:12.5px;line-height:1.45}.canvas-arrows{position:absolute;inset:0;pointer-events:none}.bottleneck-pill,.flow-pill{display:inline-flex;align-items:center;gap:4px;align-self:start;min-height:20px;padding:0 8px;border-radius:999px;font-size:11px;font-weight:800;letter-spacing:.04em;text-transform:uppercase}.bottleneck-pill{background:var(--red-soft);color:var(--red)}.flow-pill{background:var(--green-soft);color:var(--accent-strong)}.flow-pill.idle{background:#ece8df;color:#586461}.queue{display:grid;gap:8px}.queue-row{display:grid;grid-template-columns:auto 1fr auto;gap:14px;align-items:center;padding:12px 14px;border:1px solid var(--line);border-radius:10px;background:var(--surface-raised);transition:border-color .12s ease,box-shadow .12s ease}.queue-row:hover{border-color:#c7bfae;box-shadow:0 6px 16px rgba(30,37,36,.05)}.queue-row-rail{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:4px;min-width:56px;padding:6px 8px;border-radius:8px;background:var(--surface-sunken);color:var(--ink-strong)}.queue-row-rail strong{font-size:15px;line-height:1}.queue-row-rail span{font-size:11px;color:var(--muted);letter-spacing:.04em;text-transform:uppercase}.queue-row-body{min-width:0;display:grid;gap:4px}.queue-row-title{margin:0;font-size:15px;font-weight:700;color:var(--ink-strong);overflow:hidden;text-overflow:ellipsis;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical}.queue-row-meta{display:flex;flex-wrap:wrap;gap:6px 10px;color:var(--muted);font-size:12.5px}.queue-row-meta strong{color:var(--ink);font-weight:700}.queue-row-actions{gap:6px;justify-content:flex-end}.queue-row-actions,.tabs{display:flex;flex-wrap:wrap}.tabs{gap:4px;margin-bottom:16px;padding:4px;border:1px solid var(--line);border-radius:10px;background:var(--surface-sunken);width:max-content;max-width:100%}.tabs-tab{display:inline-flex;align-items:center;gap:6px;min-height:32px;padding:0 12px;border:1px solid transparent;border-radius:7px;background:transparent;color:var(--ink);font-weight:700;font-size:13px;cursor:pointer}.tabs-tab:hover{background:rgba(255,255,255,.6)}.tabs-tab[aria-selected=true]{background:#fff;border-color:var(--line);color:var(--ink-strong);box-shadow:0 1px 2px rgba(30,37,36,.06)}.tabs-tab .tab-count{display:inline-flex;align-items:center;min-height:18px;padding:0 6px;border-radius:999px;background:var(--surface-sunken);color:var(--muted);font-size:11px}.tabs-tab[aria-selected=true] .tab-count{background:var(--green-soft);color:var(--accent-strong)}.filter-bar{display:flex;flex-wrap:wrap;gap:8px;align-items:center;margin-bottom:16px}.filter-bar input[type=search],.filter-bar select{min-height:34px;padding:6px 10px;border-radius:8px;border:1px solid var(--line);background:var(--surface-raised);font-size:13px}.filter-bar input[type=search]{min-width:240px}.drawer-backdrop{position:fixed;inset:0;background:rgba(18,26,25,.42);backdrop-filter:blur(2px);z-index:40;animation:drawer-fade-in .12s ease both}.drawer-panel{position:fixed;top:0;right:0;bottom:0;width:min(560px,100%);background:var(--surface-raised);border-left:1px solid var(--line);box-shadow:-16px 0 40px rgba(18,26,25,.12);z-index:41;display:flex;flex-direction:column;animation:drawer-slide-in .18s cubic-bezier(.2,.8,.2,1) both}.drawer-head{display:flex;align-items:flex-start;justify-content:space-between;gap:16px;padding:18px 22px 14px;border-bottom:1px solid var(--line)}.drawer-head h2{margin:0;font-size:18px;color:var(--ink-strong)}.drawer-head p{margin:4px 0 0;color:var(--muted);font-size:13px}.drawer-close{display:inline-flex;align-items:center;justify-content:center;width:32px;height:32px;border-radius:8px;border:1px solid var(--line);background:var(--surface-raised);color:var(--ink)}.drawer-body{flex:1;overflow-y:auto;padding:18px 22px 24px;display:grid;gap:14px}.drawer-footer{display:flex;flex-wrap:wrap;gap:8px;justify-content:flex-end;padding:14px 22px 18px;border-top:1px solid var(--line);background:var(--surface-sunken)}@keyframes drawer-fade-in{0%{opacity:0}to{opacity:1}}@keyframes drawer-slide-in{0%{transform:translateX(24px);opacity:0}to{transform:translateX(0);opacity:1}}@media (max-width:640px){.drawer-panel{width:100%;border-left:none}}.stage-section{display:grid;gap:12px;margin-bottom:18px}.stage-section-head{display:flex;align-items:center;justify-content:space-between;gap:12px}.stage-section-head h2{margin:0;font-size:16px;color:var(--ink-strong)}.stage-section-head .muted{font-size:13px}.row-inline{display:inline-flex;align-items:center;gap:6px}.divider-dot{display:inline-block;width:3px;height:3px;border-radius:50%;background:#b8aea0}@media (max-width:1100px){.pipeline-canvas{grid-template-columns:1fr}.stage-header-top{flex-direction:column;align-items:flex-start}.queue-row{grid-template-columns:1fr}.queue-row-actions{justify-content:flex-start}}