:root{--bg-base: #0b0f19;--bg-glass: rgba(30, 41, 59, .64);--bg-glass-hover: rgba(51, 65, 85, .72);--bg-input: rgba(0, 0, 0, .25);--bg-surface: rgba(255, 255, 255, .03);--border-glass: rgba(148, 163, 184, .18);--primary: #6366f1;--primary-glow: rgba(99, 102, 241, .35);--danger: #ef4444;--success: #10b981;--text-main: #f8fafc;--text-muted: #94a3b8;--radius-sm: 6px;--radius-md: 12px;--radius-lg: 20px;--radius-pill: 9999px;--shadow-card: 0 4px 30px rgba(0, 0, 0, .2);--shadow-float: 0 20px 40px rgba(0, 0, 0, .35);--focus-ring: 0 0 0 2px #0b0f19, 0 0 0 4px var(--primary);font-family:Inter,Segoe UI,sans-serif;font-size:14px;color:var(--text-main);background:radial-gradient(circle at 15% 20%,rgba(49,46,129,.22),transparent 36%),radial-gradient(circle at 85% 30%,rgba(5,150,105,.18),transparent 36%),var(--bg-base)}*{box-sizing:border-box}body{margin:0;color:var(--text-main);background:transparent;min-height:100vh}a{color:#bfdbfe}.layout{display:grid;grid-template-columns:220px 1fr;min-height:100vh}.skip-link{position:absolute;left:12px;top:-40px;z-index:2001;padding:8px 12px;border-radius:8px;background:#111827;color:#f8fafc;text-decoration:none;border:1px solid var(--border-glass)}.skip-link:focus{top:8px}.sidebar{background:var(--bg-glass);border-right:1px solid var(--border-glass);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);color:var(--text-main);padding:14px 14px 16px;display:flex;flex-direction:column;gap:8px}.brand-wrap{margin-bottom:6px}.sidebar nav{display:flex;flex-direction:column;gap:8px;margin-top:8px}.nav-link{text-decoration:none;color:#dbeafe;padding:7px 9px;border-radius:10px;border:1px solid transparent;display:flex;align-items:center;gap:8px;font-size:13px}.nav-icon{display:inline-flex;width:24px;height:24px;align-items:center;justify-content:center;border-radius:999px;border:1px solid var(--border-glass);background:#0f172a8c;font-size:10px;font-weight:700;letter-spacing:.02em}.nav-link:hover{background:#ffffff0a;border-color:var(--border-glass)}.nav-link.active{background:#6366f133;border-color:#6366f180;color:#e0e7ff}.brand{font-weight:700;font-size:16px;letter-spacing:-.02em}.meta{color:var(--text-muted);font-size:11px}.content{padding:14px 16px 18px;overflow-x:hidden}.topbar{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:8px 10px;margin-bottom:12px;border:1px solid var(--border-glass);background:#0f172a80;padding:8px 10px;border-radius:var(--radius-md);position:sticky;top:8px;z-index:8}.mobile-bottom-nav{display:none}.mobile-nav-link{text-decoration:none;color:#cbd5e1;padding:8px 10px;border-radius:10px;border:1px solid transparent;font-size:12px;text-align:center;display:grid;gap:2px}.mobile-nav-icon{display:inline-flex;align-items:center;justify-content:center;margin:0 auto;width:20px;height:20px;border-radius:999px;border:1px solid var(--border-glass);font-size:9px;font-weight:700}.mobile-nav-text{font-size:11px;line-height:1.1}.mobile-nav-link.active{background:#6366f140;border-color:#6366f18c;color:#e0e7ff}.topbar-left{display:flex;gap:10px;align-items:baseline}.topbar-right{display:flex;gap:8px;align-items:center}.topbar-actions{gap:8px}.crumb{font-weight:600;letter-spacing:-.01em}.header-subnav{width:100%;display:flex;flex-wrap:wrap;gap:8px;padding-top:4px;border-top:1px solid rgba(148,163,184,.15)}.header-subnav-link{text-decoration:none;display:inline-flex;align-items:center;padding:5px 10px;border-radius:999px;border:1px solid var(--border-glass);font-size:12px;color:#dbeafe;background:#ffffff05}.header-subnav-link:hover{background:#6366f12e;border-color:#6366f173}.header-subnav-link.active{background:#6366f140;border-color:#6366f199;color:#e0e7ff}.header-quick-controls{width:100%;display:flex;flex-wrap:wrap;gap:8px}.header-quick-btn{margin-bottom:0;padding:5px 10px;border-radius:999px;border:1px solid var(--border-glass);background:#ffffff05;font-size:12px;color:#dbeafe}.header-quick-btn.active{background:#6366f140;border-color:#6366f199;color:#e0e7ff}.card{background:var(--bg-glass);backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px);border:1px solid var(--border-glass);border-radius:var(--radius-md);box-shadow:var(--shadow-card);padding:16px;margin-bottom:16px}.compact-card{padding:12px;margin-top:10px}.grid2{display:grid;grid-template-columns:1fr 1fr;gap:16px}.kpi-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:16px;margin-bottom:16px}.kpi-label{font-size:12px;color:var(--text-muted);margin-bottom:8px}.kpi-value{font-size:24px;font-weight:700;color:var(--text-main)}.kpi-sub{font-size:12px;color:var(--text-muted);margin-top:8px}.row{display:flex;gap:10px;margin-top:12px;flex-wrap:wrap;align-items:center}.panel-head{display:flex;justify-content:space-between;align-items:center;gap:10px;margin-top:0}.panel-head h3,.panel-head h4{margin:0}.form-grid2{display:grid;gap:4px}.form-feedback{margin-top:6px}.center{min-height:100vh;display:grid;place-items:center}label{display:block;margin-bottom:4px;font-size:12px;color:#cbd5e1}input,button,select,textarea{padding:10px;margin-bottom:10px;border:1px solid var(--border-glass);border-radius:10px;font:inherit}input:not([type=checkbox]):not([type=radio]),select,textarea{width:100%;background:var(--bg-input);color:var(--text-main)}input[type=checkbox],input[type=radio]{width:auto;margin:0;padding:0;background:transparent;accent-color:var(--primary)}input::placeholder,textarea::placeholder{color:var(--text-muted)}.input-error{border-color:#ef444499!important;box-shadow:0 0 0 4px #ef44441f}input:focus,select:focus,textarea:focus,button:focus-visible,a:focus-visible{outline:none;box-shadow:var(--focus-ring)}button{background:#ffffff14;color:var(--text-main);cursor:pointer}button:hover:not(:disabled){border-color:#ffffff59;transform:translateY(-1px)}button.primary-btn{background:var(--primary);border-color:var(--primary);box-shadow:0 8px 22px -10px var(--primary-glow)}button.secondary-btn{background:#ffffff0a;color:#e2e8f0;border-color:var(--border-glass)}button.danger-btn{margin-top:auto;background:#ef444429;border-color:#ef44444d;color:#fecaca}button:disabled{opacity:.55;cursor:not-allowed;transform:none}.table-wrap{overflow:auto;border:1px solid var(--border-glass);border-radius:10px;background:#0f172a73}table{width:100%;border-collapse:collapse;table-layout:auto}.history-table{margin:0}.history-runs-table{table-layout:fixed}.history-runs-table th:nth-child(1),.history-runs-table td:nth-child(1){width:74px}.history-runs-table th:nth-child(2),.history-runs-table td:nth-child(2){width:auto}.history-runs-table th:nth-child(3),.history-runs-table td:nth-child(3),.history-runs-table th:nth-child(4),.history-runs-table td:nth-child(4){width:58px}.history-runs-table th:nth-child(5),.history-runs-table td:nth-child(5){width:84px}.history-runs-table th:nth-child(6),.history-runs-table td:nth-child(6){width:64px}.history-runs-table th:nth-child(7),.history-runs-table td:nth-child(7){width:90px}.truncate-cell{overflow:hidden;white-space:nowrap;text-overflow:ellipsis;max-width:100%}.history-table thead th{position:sticky;top:0;z-index:2;background:#0f172ad9}.table-wrap .skeleton-line{margin:6px 0}.skeleton-table{display:grid;gap:6px}.compact-table th,.compact-table td{padding:7px 8px;font-size:13px}td,th{border-bottom:1px solid var(--border-glass);padding:8px;text-align:left;vertical-align:top}tfoot td{background:#6366f114}tr:hover td{background:#ffffff05}.row-active td{background:#6366f11f}.status-pill{display:inline-flex;align-items:center;padding:2px 8px;border-radius:var(--radius-pill);border:1px solid var(--border-glass);background:#ffffff0d;font-size:12px;font-weight:600;color:#e2e8f0}.status-pill.status-done{background:#10b98133;border-color:#10b98173;color:#d1fae5}.status-pill.status-running{background:#3b82f633;border-color:#3b82f673;color:#dbeafe}.status-pill.status-failed{background:#ef444433;border-color:#ef444473;color:#fee2e2}.status-pill.status-queued{background:#f59e0b33;border-color:#f59e0b73;color:#fef3c7}.status-pill.status-active{background:#10b98133;border-color:#10b98173;color:#d1fae5}.status-pill.status-suspended,.status-pill.status-cancelled{background:#ef444433;border-color:#ef444473;color:#fee2e2}.row-clickable{cursor:pointer}.mini-progress-wrap{min-width:110px}.mini-progress-label{font-size:11px;color:var(--text-muted);display:block;margin-bottom:4px}.mini-progress-track{width:100%;height:6px;border-radius:999px;background:#94a3b840;overflow:hidden}.mini-progress-fill{height:100%;border-radius:999px;background:linear-gradient(90deg,#6366f1,#10b981);transition:width .3s ease}pre{white-space:pre-wrap;word-break:break-word}.error{color:#fca5a5}.success{color:#86efac}.warn{color:#fde68a}.muted{color:var(--text-muted)}.alert-card{border-width:1px}.alert-title{margin-top:0;margin-bottom:6px}.alert-text{margin-bottom:0}.alert-warning{border-color:#f59e0b80;background:#f59e0b26}.alert-error{border-color:#ef44448c;background:#ef444426}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}.empty-inline{display:flex;align-items:center;justify-content:space-between;gap:10px}.empty-panel{display:grid;gap:6px;padding:12px;border:1px dashed var(--border-glass);border-radius:10px;background:#0f172a73}.inline-link-btn{display:inline-flex;align-items:center;text-decoration:none;border:1px solid rgba(99,102,241,.6);background:#6366f133;color:#e0e7ff;padding:6px 10px;border-radius:10px}h1,h2,h3,h4{margin-top:0;letter-spacing:-.01em}h1{font-size:2rem;margin-bottom:10px}h3{font-size:1.25rem}.history-meta{display:grid;gap:6px;padding:10px 12px;border:1px solid var(--border-glass);border-radius:10px;background:#0f172a59;margin-bottom:10px}.history-meta>div{overflow-wrap:anywhere}.history-page{min-width:0}.history-layout{grid-template-columns:minmax(340px,37%) minmax(0,63%);align-items:stretch;min-width:0}.history-layout-modal{grid-template-columns:minmax(0,1fr)}.history-layout-focused{grid-template-columns:minmax(250px,24%) minmax(0,76%)}.history-layout>.card{min-width:0;margin-bottom:0}.history-list-card,.history-detail-card{display:flex;flex-direction:column;min-width:0;min-height:clamp(520px,calc(100vh - 190px),980px)}.history-head-row{margin-top:0;margin-bottom:6px;justify-content:space-between}.history-head-row h3{margin:0}.history-list-card .table-wrap,.history-detail-card .table-wrap{max-width:100%}.history-list-card .table-wrap{flex:1;min-height:280px}.history-detail-card{overflow:auto}.run-modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#020617a6;backdrop-filter:blur(2px);-webkit-backdrop-filter:blur(2px);z-index:119}.history-detail-modal{display:none}.history-detail-modal.open{position:fixed;display:grid;grid-template-rows:auto minmax(0,1fr);top:2vh;left:max(12px,2vw);right:max(12px,2vw);bottom:2vh;transform:none;width:auto;max-height:none;z-index:120;margin:0;overflow:hidden;box-shadow:var(--shadow-float)}.history-detail-body{min-height:0;overflow:auto;padding-right:2px;font-size:13px}.history-detail-modal .history-meta{margin-bottom:6px;gap:6px;padding:8px 10px}.history-detail-modal .card{margin-top:6px}.history-detail-modal .table-wrap{max-height:min(36vh,360px)}.history-detail-modal .sticky-actions-row{margin-top:4px;margin-bottom:6px}.run-analytics-panel>summary{cursor:pointer;font-weight:700;margin-bottom:6px}.run-analytics-panel[open]>summary{margin-bottom:8px}.run-files-table{table-layout:fixed}.run-files-table th:nth-child(1),.run-files-table td:nth-child(1){width:72px}.run-files-table th:nth-child(2),.run-files-table td:nth-child(2){width:120px}.run-files-table th:nth-child(4),.run-files-table td:nth-child(4){width:100px}.run-files-table th:nth-child(5),.run-files-table td:nth-child(5){width:86px}.history-detail-card>.detail-tabs{position:sticky;top:0;z-index:3;padding-top:4px;background:linear-gradient(180deg,#1e293bf2,#1e293bc7);border-bottom:1px solid var(--border-glass)}.detail-tabs{display:flex;gap:8px;margin-bottom:10px;flex-wrap:wrap}.detail-tabs button{margin-bottom:0}.detail-tabs button.active{background:#6366f147;border-color:#6366f1a6}.kpi-inline{display:grid;grid-template-columns:repeat(3,minmax(140px,1fr));gap:10px;margin-bottom:8px}.history-kpi-inline{grid-template-columns:repeat(4,minmax(120px,1fr))}.kpi-pill{border:1px solid rgba(99,102,241,.35);background:#6366f11f;border-radius:10px;padding:8px 10px;display:flex;justify-content:space-between;align-items:baseline}.kpi-pill span{font-size:12px;color:#cbd5e1}.kpi-pill strong{font-size:18px;color:#e0e7ff}.plan-toolbar{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:10px;align-items:center;margin:8px 0;padding:8px;border:1px solid var(--border-glass);border-radius:10px;background:#0f172a5c}.history-runs-toolbar{position:sticky;top:0;z-index:5;padding:0;border-radius:0;background:transparent;border:none}.history-plan-toolbar{grid-template-columns:repeat(auto-fit,minmax(210px,1fr))}.quick-status-row{display:flex;flex-wrap:wrap;gap:8px;margin:6px 0 10px}.chip-btn{margin-bottom:0;padding:6px 10px;border-radius:var(--radius-pill);background:#ffffff08}.chip-btn.active{border-color:#6366f1b3;background:#6366f140}.sticky-actions-row{position:sticky;top:0;z-index:4;padding:8px;border-radius:10px;border:1px solid var(--border-glass);background:#0f172aad;margin-bottom:10px}.plan-toolbar input,.plan-toolbar select,.plan-toolbar button{margin-bottom:0;min-height:40px;padding-top:8px;padding-bottom:8px}.workers-toolbar .row select,.workers-toolbar .row button{margin-bottom:0}.plan-table-wrap{max-height:420px}.sortable-col{cursor:pointer;-webkit-user-select:none;user-select:none}.sortable-col:hover{background:#94a3b840!important}.plan-pagination{display:flex;gap:10px;align-items:center;justify-content:flex-end;margin-top:8px}.column-toggle-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:8px 12px;margin-top:10px}.skeleton-line{height:12px;border-radius:8px;margin:8px 0;background:linear-gradient(90deg,#94a3b826,#94a3b847,#94a3b826);background-size:200% 100%;animation:skeleton-shimmer 1.4s ease infinite}@keyframes skeleton-shimmer{0%{background-position:0 0}to{background-position:-200% 0}}.auth-shell{padding:24px}.auth-grid{width:min(980px,100%);display:grid;grid-template-columns:1.1fr .9fr;gap:16px}.auth-card{background:var(--bg-glass);border:1px solid var(--border-glass);border-radius:14px;padding:20px;box-shadow:var(--shadow-float)}.auth-card h1,.auth-card h2{margin-top:0}.auth-card form{display:grid;gap:4px}.info-box{border:1px dashed var(--border-glass);background:#0f172a66;border-radius:8px;padding:12px;color:var(--text-muted)}.progress-track{width:100%;height:10px;border-radius:999px;background:#94a3b840;overflow:hidden;margin-top:10px}.progress-fill{height:100%;border-radius:999px;background:linear-gradient(90deg,#6366f1,#10b981);transition:width .35s ease}.toast-stack{position:fixed;right:20px;bottom:20px;display:flex;flex-direction:column;gap:10px;z-index:2000}.toast{min-width:260px;max-width:440px;border-radius:10px;padding:12px 14px;border:1px solid transparent;box-shadow:0 10px 25px #0f172a73;background:#0f172ad9;color:#f1f5f9}.toast-info{border-color:#7dd3fc}.toast-success{border-color:#86efac}.toast-error{border-color:#fca5a5}.wysiwyg-editor{min-height:240px;border:1px solid var(--border-glass);border-radius:8px;padding:12px;background:#0f172a99;margin-bottom:10px}.preset-preview{border:1px dashed var(--border-glass);border-radius:8px;padding:12px;background:#0f172a66}details.section-block{border:1px solid var(--border-glass);border-radius:10px;padding:10px 12px;margin-bottom:10px;background:#0f172a66}details.section-block[open]{background:#0f172a8c}details.section-block summary{cursor:pointer;font-weight:600;color:var(--text-main)}.compact-hint{font-size:12px;color:var(--text-muted);margin-top:4px}@media (max-width: 980px){.layout{grid-template-columns:1fr}.sidebar{position:sticky;top:0;z-index:20;border-right:none;border-bottom:1px solid var(--border-glass);padding:10px 12px;gap:0}.sidebar .sidebar-meta,.sidebar nav,.sidebar .danger-btn{display:none}.sidebar .brand-wrap{margin:0}.sidebar .brand{font-size:15px}.sidebar .meta{font-size:10px}.content{padding:10px 10px 88px}.grid2,.kpi-grid,.kpi-inline,.auth-grid,.plan-toolbar,.history-layout,.history-layout-focused{grid-template-columns:1fr}.history-list-card,.history-detail-card{min-height:auto}.history-runs-toolbar,.sticky-actions-row,.history-detail-card>.detail-tabs{position:static}.plan-pagination{justify-content:flex-start}.column-toggle-grid{grid-template-columns:1fr}.topbar{flex-direction:column;align-items:flex-start;gap:6px;position:static;top:auto}.mobile-bottom-nav{position:fixed;bottom:10px;left:10px;right:10px;z-index:40;display:grid;grid-template-columns:repeat(5,minmax(0,1fr));gap:6px;padding:8px;border-radius:14px;border:1px solid var(--border-glass);background:#0f172ad9;backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px)}}@media (max-width: 1500px){.history-layout,.history-layout-focused{grid-template-columns:1fr}.history-list-card,.history-detail-card{min-height:auto}.history-detail-modal.open{top:10px;right:10px;bottom:10px;left:10px}.run-files-table th:nth-child(4),.run-files-table td:nth-child(4){display:none}}@media (max-width: 1700px) and (min-width: 1501px){.history-layout{grid-template-columns:minmax(320px,39%) minmax(0,61%)}.history-plan-toolbar{grid-template-columns:repeat(auto-fit,minmax(190px,1fr))}}@media (prefers-reduced-motion: reduce){*{transition:none!important;animation:none!important}}body.pref-reduced-motion *{transition:none!important;animation:none!important}body.pref-compact-tables td,body.pref-compact-tables th{padding-top:5px;padding-bottom:5px;font-size:12px}
