.qoe-summary[data-v-f0364e56]{display:grid;grid-template-columns:repeat(5,minmax(0,1fr));gap:8px}.qoe-summary div[data-v-f0364e56]{border:1px solid var(--border);border-radius:6px;padding:8px 10px;background:#f9f7f2}.qoe-summary span[data-v-f0364e56],.qoe-summary strong[data-v-f0364e56]{display:block}.qoe-summary span[data-v-f0364e56]{color:var(--muted);font-size:12px}.qoe-summary strong[data-v-f0364e56]{margin-top:2px;font-size:15px}.download-progress[data-v-f0364e56]{display:grid;gap:12px}.download-progress__bar[data-v-f0364e56]{width:100%;height:14px;overflow:hidden;border:1px solid var(--border);border-radius:6px;background:#e6e2dc}.download-progress__fill[data-v-f0364e56]{height:100%;background:#1f77b4;transition:width .18s ease}.download-progress__stats[data-v-f0364e56]{display:grid;grid-template-columns:repeat(5,minmax(0,1fr));gap:8px}.download-progress__stats div[data-v-f0364e56]{border:1px solid var(--border);border-radius:6px;padding:8px 10px;background:#f9f7f2}.download-progress__stats span[data-v-f0364e56],.download-progress__stats strong[data-v-f0364e56]{display:block}.download-progress__stats span[data-v-f0364e56]{color:var(--muted);font-size:12px}.download-progress__stats strong[data-v-f0364e56]{margin-top:2px;font-size:15px}@media (max-width: 720px){.qoe-summary[data-v-f0364e56],.download-progress__stats[data-v-f0364e56]{grid-template-columns:repeat(2,minmax(0,1fr))}}:root{font-family:IBM Plex Mono,monospace;color:#1f1f1f;background:#f6f4ef}*{box-sizing:border-box}body{margin:0;min-width:320px}button,input,select,textarea{font:inherit}#app{padding:20px}.page{display:flex;flex-direction:column;gap:16px}.page__title{margin:0;font-size:24px}.grid{display:grid;gap:16px}.grid--two{grid-template-columns:repeat(auto-fit,minmax(320px,1fr))}.panel{border:1px solid #d8d2c7;border-radius:8px;background:#fffdf8;padding:12px}.panel__title{margin:0 0 10px;font-size:14px;text-transform:uppercase;letter-spacing:.08em}.panel__hint{margin:0;font-size:12px;color:#4a4a4a}.panel__hint--error{color:#a13232}.panel-header{display:flex;align-items:center;justify-content:space-between;gap:12px}.panel-header .panel__title{margin-bottom:0}.stack{display:flex;flex-direction:column;gap:12px}.placeholder{min-height:120px;border:1px dashed #c6b8a6;border-radius:8px;padding:12px;background:#fff;color:#4a4a4a}.toolbar{display:flex;flex-wrap:wrap;gap:8px}.button{padding:8px 10px;border-radius:6px;border:1px solid #c6b8a6;background:#c9ada7;color:#fff;cursor:pointer;text-decoration:none}.button--secondary{background:#4a4a4a}.button--compact{padding:5px 8px;font-size:12px}.button:disabled{opacity:.5;cursor:default}.form-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:12px}.field{display:flex;flex-direction:column;gap:4px;padding:8px 10px;border:1px solid #e2dfd7;border-radius:8px;background:#fff}.field label{font-size:13px;font-weight:600;text-transform:uppercase;letter-spacing:.08em}.field small{font-size:12px;color:#4a4a4a}.queue-list{display:flex;flex-direction:column;gap:8px}.queue-item{border:1px solid #e2dfd7;border-radius:8px;background:#fff;padding:8px}.queue-item--running{border-color:#c87a1b;background:#fff5e8}.queue-item--done{border-color:#6f9b70}.queue-item--error,.queue-item--cancelled{border-color:#b14e4e}.queue-item__header{display:flex;justify-content:space-between;align-items:flex-start;gap:12px}.queue-meta{margin-top:8px;display:flex;flex-direction:column;gap:4px;font-size:12px;white-space:pre-wrap}.run-output{min-height:220px;max-height:320px;overflow:auto;white-space:pre-wrap;background:#1f1f1f;color:#eee;padding:12px;border-radius:8px;margin:0}.chart-wrap{position:relative;width:100%;border:1px solid #e2dfd7;border-radius:8px;background:#fff;overflow:hidden}.chart-wrap--line{height:320px}.chart-wrap--pie{width:min(100%,540px);height:320px;margin-inline:auto}.chart-wrap canvas{width:100%!important;height:100%!important}.heatmap-wrap{overflow-x:auto;border:1px solid #e2dfd7;border-radius:8px;background:#fff;padding:8px}.heatmap-legend{display:flex;flex-wrap:wrap;gap:8px 12px}.legend-item{display:inline-flex;align-items:center;gap:6px;font-size:12px}.legend-swatch{display:inline-block;width:18px;height:12px;border:1px solid #c6b8a6}.legend-swatch--accent{border-top:3px solid #2f4858;border-bottom:3px solid #2f4858}.legend-swatch--band{background:linear-gradient(to bottom,#f5f2ea 0,#f5f2ea 35%,var(--legend-band-color, #7eb77f) 35%,var(--legend-band-color, #7eb77f) 65%,#f5f2ea 65%,#f5f2ea 100%)}.button--danger{background:#8e3b3b}
