/* ═══════════════════════════════════════════════════════════════════════════
   Playground page — ML Browser Benchmark
   ═══════════════════════════════════════════════════════════════════════════ */

/* ── Playground layout ────────────────────────────────────────────────────── */
.playground-layout {
    display: grid;
    grid-template-columns: 340px 1fr;
    gap: var(--space-6);
    align-items: start;
}
@media (max-width: 768px) {
    .playground-layout {
        grid-template-columns: 1fr;
    }
}
.block-panel {
    background: var(--color-surface);
    border: 1px solid var(--color-border);
    border-radius: var(--radius-md);
    padding: var(--space-5);
    box-shadow: var(--shadow-sm);
}
.playground-main {
    display: flex;
    flex-direction: column;
    gap: var(--space-4);
}
.run-controls {
    display: flex;
    align-items: center;
    gap: var(--space-3);
    flex-wrap: wrap;
    background: var(--color-surface);
    padding: var(--space-4);
    border-radius: var(--radius-md);
    border: 1px solid var(--color-border);
}

/* ── Block canvas ─────────────────────────────────────────────────────────── */
.pipeline {
    display: flex;
    align-items: stretch;
    gap: 0;
    flex-wrap: wrap;
    margin-bottom: var(--space-4);
    background: var(--color-surface);
    border: 1px solid var(--color-border);
    border-radius: var(--radius-md);
    padding: var(--space-3);
    box-shadow: var(--shadow-sm);
}
.pipeline-arrow {
    display: flex;
    align-items: center;
    color: var(--color-muted);
    font-size: 1.1rem;
    padding: 0 var(--space-2);
    flex-shrink: 0;
}
.block-card {
    flex: 1;
    background: var(--color-surface-2);
    border: 2px solid var(--color-border);
    border-radius: var(--radius-sm);
    padding: var(--space-3) var(--space-3);
    cursor: pointer;
    min-width: 72px;
    text-align: center;
    transition:
        border-color 0.15s,
        background 0.15s,
        box-shadow 0.15s;
    position: relative;
}
.block-card:hover {
    border-color: var(--color-primary);
    box-shadow: var(--shadow-md);
    background: var(--color-surface);
}
.block-card.active-block {
    border-color: var(--color-primary);
    background: var(--color-surface);
    box-shadow: var(--shadow-md);
}
.block-icon {
    font-size: 1.5rem;
    line-height: 1;
    margin-bottom: var(--space-1);
}
.block-label {
    font-size: 0.68rem;
    font-weight: 700;
    color: var(--color-muted);
    text-transform: uppercase;
    letter-spacing: 0.06em;
    margin-bottom: 2px;
}
.block-value {
    font-size: 0.78rem;
    color: var(--color-muted);
    margin-top: 2px;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
    max-width: 100%;
}
.block-value.configured {
    color: var(--color-success);
    font-weight: 600;
}
.block-config-panel {
    padding: var(--space-4) 0;
    border-top: 1px solid var(--color-border);
    margin-top: var(--space-3);
}
.block-config-panel h4 {
    font-size: var(--text-sm);
    margin-bottom: var(--space-1);
}
.block-config-panel > .muted {
    font-size: var(--text-sm);
    margin-bottom: var(--space-3);
}
.block-select {
    width: 100%;
    padding: var(--space-2) var(--space-3);
    border: 1px solid var(--color-border);
    border-radius: var(--radius-sm);
    background: var(--color-surface);
    color: var(--color-text);
    font-size: var(--text-sm);
    margin-top: var(--space-2);
}

/* ── Option-card grid (runtime / backend / model selection) ───────────────── */
.option-grid {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: var(--space-2);
    margin-top: var(--space-2);
}
.option-card {
    background: var(--color-surface);
    border: 2px solid var(--color-border);
    border-radius: var(--radius-md);
    padding: var(--space-3) var(--space-3);
    display: flex;
    flex-direction: column;
    gap: 3px;
    transition:
        border-color 0.15s,
        background 0.15s,
        box-shadow 0.15s;
    user-select: none;
}
.option-card:hover:not(.option-disabled) {
    border-color: var(--color-primary);
    background: var(--layer-shell);
    box-shadow: var(--shadow-sm);
}
.option-card.selected {
    border-color: var(--color-primary);
    background: var(--layer-shell);
    box-shadow: var(--shadow-sm);
}
.option-card.option-disabled {
    opacity: 0.45;
    cursor: not-allowed !important;
    background: var(--color-surface-2);
    border-color: var(--color-border);
    border-style: dashed;
}
.option-card-name {
    font-size: var(--text-sm);
    font-weight: 600;
    color: var(--color-text);
    line-height: 1.3;
}
.option-card.selected .option-card-name {
    color: var(--color-primary);
}
.option-card-hw {
    display: flex;
    gap: var(--space-1);
    flex-wrap: wrap;
    margin-top: 1px;
}
.option-card-reason {
    font-size: 0.72rem;
    color: var(--color-error);
    margin-top: 2px;
    line-height: 1.3;
}

/* ── Runtime cards span full width ────────────────────────────────────────── */
.option-card--runtime {
    grid-column: span 1;
}
.option-grid:has(.option-card--runtime) {
    grid-template-columns: repeat(2, 1fr);
}

/* ── Runtime compat mini-table ────────────────────────────────────────────── */
.runtime-compat-list {
    list-style: none;
    display: flex;
    flex-direction: column;
    gap: 3px;
    margin-top: var(--space-2);
    padding: 0;
    border-top: 1px solid var(--color-border);
    padding-top: var(--space-2);
}
.runtime-compat-item {
    display: flex;
    align-items: center;
    gap: var(--space-1);
    font-size: 0.72rem;
    line-height: 1.4;
}
.compat-icon {
    font-size: 0.7rem;
    font-weight: 800;
    width: 14px;
    flex-shrink: 0;
    text-align: center;
}
.compat-ok .compat-icon {
    color: var(--color-success);
}
.compat-no .compat-icon {
    color: var(--color-error);
}
.compat-backend-name {
    flex: 1;
    color: var(--color-text);
    font-weight: 500;
}
.compat-no .compat-backend-name {
    color: var(--color-muted);
    text-decoration: line-through;
    text-decoration-color: var(--color-error);
}
.compat-hw-row {
    display: inline-flex;
    gap: 2px;
    flex-shrink: 0;
}

/* ── Backend panel hint ───────────────────────────────────────────────────── */
.option-grid-hint {
    font-size: var(--text-sm);
    color: var(--color-muted);
    padding: var(--space-4);
    background: var(--color-surface-2);
    border-radius: var(--radius-md);
    border: 1px dashed var(--color-border);
    text-align: center;
    margin-top: var(--space-2);
}

/* ── Log panel ────────────────────────────────────────────────────────────── */
.log-panel {
    background: var(--color-surface-2);
    border: 1px solid var(--color-border);
    border-radius: var(--radius-sm);
    padding: var(--space-3) var(--space-4);
    font-family: var(--font-mono);
    font-size: 0.8rem;
    max-height: 200px;
    overflow-y: auto;
    color: var(--color-muted);
    line-height: 1.7;
}
