body.benchmark-app {
    font-family: 'Inter', system-ui, sans-serif;
    background: var(--comp-bg, #f0f3f8);
    color: var(--comp-text, #1a2233);
    min-height: 100dvh;
}

.benchmark-main {
    max-width: 1200px;
    margin: 0 auto;
    padding: 16px 16px 40px;
}

.benchmark-hero {
    margin-bottom: 14px;
}

.benchmark-hero__badge {
    font-size: 12px;
    font-weight: 700;
    color: var(--comp-accent, #6d5ef7);
    margin: 0 0 6px;
}

.benchmark-hero__title {
    margin: 0 0 8px;
    font-size: clamp(1.35rem, 3vw, 1.75rem);
    font-weight: 800;
}

.benchmark-hero__lead {
    margin: 0;
    font-size: 14px;
    line-height: 1.6;
    color: var(--comp-muted, #6b7a90);
    max-width: 52rem;
}

#benchmarkQueueBanner {
    margin-bottom: 14px;
}

.benchmark-media-row {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 14px;
    margin-bottom: 14px;
}

.benchmark-media-row .comp-cam-frame,
.benchmark-media-row .comp-sim-view {
    min-height: clamp(200px, 32vw, 340px);
}

.benchmark-workspace {
    display: grid;
    grid-template-columns: minmax(0, 1fr) minmax(0, 1.1fr);
    gap: 14px;
    margin-bottom: 14px;
}

.benchmark-path-card .path-input--area {
    width: 100%;
    margin-bottom: 8px;
}

.benchmark-path-actions {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
    margin-top: 10px;
}

.benchmark-path-actions .btn-primary {
    flex: 1 1 160px;
}

.benchmark-batch-picker {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 10px;
    margin-bottom: 12px;
}

.benchmark-batch-picker__label {
    font-size: 13px;
    font-weight: 600;
    color: #334155;
}

.benchmark-batch-select {
    min-width: 220px;
    padding: 8px 10px;
    border: 1px solid var(--comp-border, #e4e9f2);
    border-radius: 8px;
    font-size: 13px;
    font-family: inherit;
    background: #fff;
}

.benchmark-batch-meta {
    font-size: 12px;
    color: #64748b;
}

.benchmark-csv-upload {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 10px;
    margin-bottom: 12px;
}

.benchmark-file-label {
    cursor: pointer;
    margin: 0;
}

.benchmark-file-name {
    font-size: 13px;
    color: var(--comp-muted, #6b7a90);
}

.benchmark-csv-actions {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
    margin-bottom: 10px;
}

#benchmarkExportBtn.benchmark-export--ready {
    border-color: var(--comp-accent, #6d5ef7);
    color: var(--comp-accent, #6d5ef7);
    font-weight: 600;
}

.benchmark-export-hint {
    margin: 0 0 10px;
    font-size: 13px;
    color: #0f766e;
    font-weight: 500;
}

.benchmark-progress {
    margin: 0 0 10px;
    font-size: 13px;
    font-weight: 600;
    color: var(--comp-accent, #6d5ef7);
}

.benchmark-table-wrap {
    overflow-x: auto;
    border: 1px solid var(--comp-border, #e4e9f2);
    border-radius: 10px;
}

.benchmark-table {
    width: 100%;
    border-collapse: collapse;
    font-size: 13px;
}

.benchmark-table th,
.benchmark-table td {
    padding: 8px 10px;
    text-align: left;
    border-bottom: 1px solid var(--comp-border, #e4e9f2);
    vertical-align: top;
}

.benchmark-table th {
    background: #f8fafc;
    font-weight: 600;
    font-size: 12px;
}

.benchmark-table tbody tr {
    cursor: pointer;
}

.benchmark-table tbody tr:hover {
    background: #f8fafc;
}

.benchmark-table tbody tr.is-running {
    background: var(--comp-accent-soft, #f0edff);
}

.benchmark-table tbody tr.is-ok td:nth-child(4) {
    color: var(--comp-green, #22a06b);
    font-weight: 700;
}

.benchmark-table tbody tr.is-err td:nth-child(3) {
    color: #b91c1c;
}

.benchmark-table-empty {
    text-align: center;
    color: var(--comp-muted, #6b7a90);
    padding: 20px !important;
}

.benchmark-path-cell {
    font-family: ui-monospace, monospace;
    font-size: 12px;
    word-break: break-all;
    max-width: 220px;
}

.benchmark-log-card {
    margin-bottom: 0;
}

.benchmark-log {
    max-height: 160px;
    overflow-y: auto;
    font-size: 12px;
    line-height: 1.45;
    padding: 10px 12px;
    background: #f8fafc;
    border-radius: 8px;
    border: 1px solid var(--comp-border, #e4e9f2);
}

.benchmark-log.empty-state {
    color: var(--comp-muted, #6b7a90);
}

.benchmark-log .log-entry {
    padding: 2px 0;
}

.benchmark-log .log-time {
    color: #64748b;
    margin-right: 6px;
}

body.benchmark-app.viewer-session .benchmark-media-row {
    display: grid;
}

@media (max-width: 900px) {
    .benchmark-media-row,
    .benchmark-workspace {
        grid-template-columns: 1fr;
    }
}
