:root{--bg-main: #0b1220;--bg-panel: #131c2e;--bg-panel-2: #1c2742;--border: #2a3759;--text-main: #f1f5f9;--text-mute: #94a3b8;--text-dim: #64748b;--accent: #a78bfa;--accent-2: #34d399;--accent-warn: #fbbf24;--accent-danger: #f87171}*{box-sizing:border-box}html,body,#root{margin:0;padding:0}body{background:var(--bg-main);color:var(--text-main);font-family:Inter,system-ui,sans-serif;font-size:14px}button,select,input{font-family:inherit}.app{max-width:1400px;margin:0 auto;padding:0 20px 60px}header{padding:28px 0;border-bottom:1px solid var(--border);margin-bottom:24px}header h1{margin:0 0 4px;font-size:28px;font-weight:800;background:linear-gradient(90deg,var(--accent),var(--accent-2));-webkit-background-clip:text;background-clip:text;color:transparent}header .tagline{color:var(--text-mute);font-size:13px}.tabs{display:flex;gap:4px;margin-top:16px;border-bottom:1px solid var(--border);margin-bottom:-1px}.tab{background:transparent;border:1px solid var(--border);border-bottom:none;color:var(--text-mute);padding:8px 18px;border-radius:6px 6px 0 0;font-size:13px;cursor:pointer;font-family:inherit;position:relative;bottom:-1px}.tab:hover{color:var(--accent)}.tab.active{background:var(--bg-panel);color:var(--accent);font-weight:700;border-bottom:1px solid var(--bg-panel)}section{margin-bottom:28px}h2{font-size:16px;font-weight:700;margin:0 0 12px}.scenarios-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(360px,1fr));gap:12px}.sc-card{background:var(--bg-panel);border:1px solid var(--border);border-radius:8px;padding:14px 16px}.sc-card .sc-head{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:6px}.sc-card h3{margin:0;font-size:14px}.sc-card .sc-id{font-size:10px;color:var(--text-dim);font-family:monospace}.sc-card p{font-size:12px;color:var(--text-mute);margin:0 0 10px;line-height:1.6}.sc-card .sc-tags{display:flex;gap:4px;flex-wrap:wrap;margin-bottom:10px}.sc-card .tag{background:var(--bg-panel-2);color:var(--text-mute);font-size:10px;padding:2px 7px;border-radius:8px}.sc-card .sc-meta{font-size:10px;color:var(--text-dim);font-family:monospace;margin-bottom:8px}.sc-card .sc-result{background:var(--bg-panel-2);border-radius:4px;padding:8px 10px;font-size:11px;margin-bottom:8px}.sc-card .sc-result.pass{border-left:3px solid var(--accent-2)}.sc-card .sc-result.fail{border-left:3px solid var(--accent-danger)}.sc-card .sc-actions{display:flex;gap:6px}.btn{background:var(--bg-panel-2);color:var(--text-main);border:1px solid var(--border);padding:6px 12px;border-radius:4px;font-size:12px;cursor:pointer}.btn:hover{border-color:var(--accent);color:var(--accent)}.btn.primary{background:var(--accent);border-color:var(--accent);color:var(--bg-main);font-weight:700}.btn.primary:hover{background:#c4b5fd}.btn:disabled{opacity:.5;cursor:not-allowed}.batch-bar{background:var(--bg-panel);border:1px solid var(--border);border-radius:8px;padding:14px 18px;margin-bottom:18px;display:flex;align-items:center;gap:14px}.batch-bar .summary{display:flex;gap:16px;font-size:13px;color:var(--text-mute)}.batch-bar .summary strong{color:var(--accent-2);font-family:monospace}.metric-row{display:flex;justify-content:space-between;font-family:monospace;font-size:11px;margin-bottom:2px}.metric-row .label{color:var(--text-mute)}.metric-row .val{color:var(--text-main)}.metric-row .val.danger{color:var(--accent-danger)}.metric-row .val.warn{color:var(--accent-warn)}.criteria{margin-top:6px}.criterion{font-size:10px;font-family:monospace;display:flex;gap:4px}.criterion.pass{color:var(--accent-2)}.criterion.fail{color:var(--accent-danger)}footer{margin-top:40px;padding:16px 0;border-top:1px solid var(--border);text-align:center;color:var(--text-dim);font-size:11px}.editor-page{display:grid;grid-template-columns:280px 1fr;gap:20px}.editor-side .panel{background:var(--bg-panel);border:1px solid var(--border);border-radius:10px;padding:14px;margin-bottom:16px}.editor-side .panel h3{margin:0 0 10px;font-size:14px;color:var(--accent)}.editor-side .hint{font-size:11px;color:var(--text-dim);margin-top:6px;line-height:1.4}.editor-side .sub-label{font-size:11px;color:var(--text-mute);margin:10px 0 4px;text-transform:uppercase;letter-spacing:.05em}.ai-prompt{width:100%;background:var(--bg-main);color:var(--text-main);border:1px solid var(--border);border-radius:6px;padding:8px;font-size:12px;resize:vertical;margin-bottom:8px}.scenario-list{list-style:none;margin:0;padding:0}.scenario-list li{display:flex;justify-content:space-between;align-items:center;padding:4px 0;border-bottom:1px solid var(--border)}.scenario-list .link{background:none;border:none;color:var(--text-main);font-size:12px;cursor:pointer;padding:2px 0;text-align:left;font-family:monospace}.scenario-list .link:hover{color:var(--accent-2)}.scenario-list .del{background:none;border:none;color:var(--text-dim);cursor:pointer;font-size:12px}.scenario-list .del:hover{color:var(--accent-danger)}.editor-main{display:flex;flex-direction:column}.editor-toolbar{display:flex;gap:8px;align-items:center;margin-bottom:10px;flex-wrap:wrap}.editor-toolbar .info{color:var(--text-dim);font-size:12px;margin-left:4px}.editor-toolbar .status{font-size:12px;padding:4px 10px;border-radius:4px;margin-left:auto}.editor-toolbar .status.ok{background:#34d39926;color:var(--accent-2)}.editor-toolbar .status.fail{background:#f8717126;color:var(--accent-danger)}.editor-wrap{display:flex;background:var(--bg-main);border:1px solid var(--border);border-radius:8px;overflow:hidden;height:460px}.line-numbers{width:40px;padding:10px 6px 10px 0;margin:0;background:var(--bg-panel-2);color:var(--text-dim);font-family:JetBrains Mono,Menlo,monospace;font-size:12px;line-height:1.5;text-align:right;white-space:pre;overflow:hidden}.yaml-editor{flex:1;background:var(--bg-main);color:var(--text-main);border:none;outline:none;padding:10px 12px;font-family:JetBrains Mono,Menlo,monospace;font-size:12px;line-height:1.5;resize:none;white-space:pre}.run-summary{margin-top:14px;padding:12px 14px;border-radius:8px;border:1px solid var(--border);background:var(--bg-panel)}.run-summary.pass{border-color:var(--accent-2)}.run-summary.fail{border-color:var(--accent-danger)}.run-summary .run-head{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px}.run-summary .badge{font-weight:700;font-size:11px;padding:2px 10px;border-radius:10px}.run-summary.pass .badge{background:#34d39926;color:var(--accent-2)}.run-summary.fail .badge{background:#f8717126;color:var(--accent-danger)}.metric-grid{display:grid;grid-template-columns:repeat(6,1fr);gap:8px;font-size:12px}.metric-grid>div{display:flex;flex-direction:column}.metric-grid .lab{color:var(--text-dim);font-size:10px}.run-summary .hint{font-size:11px;color:var(--accent);margin-top:8px}.badge-custom{font-size:9px;padding:1px 6px;border-radius:8px;background:#a78bfa2e;color:var(--accent);margin-left:4px;vertical-align:middle}.replay-page{display:flex;flex-direction:column;gap:10px}.replay-toolbar{display:flex;gap:10px;align-items:center;flex-wrap:wrap;background:var(--bg-panel);padding:10px 14px;border-radius:8px;border:1px solid var(--border)}.replay-toolbar label{display:flex;gap:6px;align-items:center;font-size:12px;color:var(--text-mute)}.replay-toolbar .check{cursor:pointer}.time-slider{width:100%}.replay-canvas{width:100%;height:520px;background:var(--bg-main);border:1px solid var(--border);border-radius:8px;display:block}.replay-meta{display:flex;gap:16px;flex-wrap:wrap;background:var(--bg-panel);padding:10px 14px;border-radius:8px;border:1px solid var(--border);font-size:12px}.replay-meta .ok{color:var(--accent-2);font-weight:700}.replay-meta .bad{color:var(--accent-danger);font-weight:700}.empty-replay{background:var(--bg-panel);border:1px dashed var(--border);border-radius:12px;padding:60px 30px;text-align:center;color:var(--text-mute)}.empty-replay p:first-child{font-size:24px;margin:0 0 8px;color:var(--accent)}
