.chord-prog {
    display: flex;
    flex-direction: column;
    gap: 1.5rem;
}

.cp-controls {
    display: flex;
    flex-wrap: wrap;
    align-items: flex-end;
    gap: 1rem;
    padding: 1.25rem;
    background: var(--surface);
    border: 1px solid var(--border);
    border-radius: 12px;
    box-shadow: var(--shadow);
}

.cp-field {
    display: flex;
    flex-direction: column;
    gap: 0.35rem;
}

.cp-field > span {
    font-size: 0.85rem;
    font-weight: 600;
    color: var(--muted);
}

.cp-field .field {
    width: 6rem;
}

.cp-gen {
    display: inline-flex;
    align-items: center;
    gap: 0.45rem;
    margin-left: auto;
}

.cp-gen .icon {
    width: 1em;
    height: 1em;
    fill: currentColor;
}

.cp-result {
    display: flex;
    flex-direction: column;
    gap: 1rem;
}

.cp-name {
    margin: 0;
    font-size: 1.05rem;
    font-weight: 600;
    color: var(--muted);
}

.cp-chords {
    display: flex;
    flex-wrap: wrap;
    gap: 0.75rem;
}

.cp-chord {
    flex: 1 1 6rem;
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 0.35rem;
    padding: 1.1rem 0.75rem;
    background: var(--surface);
    border: 1px solid var(--border);
    border-radius: 12px;
    box-shadow: var(--shadow);
}

.cp-roman {
    font-size: 0.95rem;
    font-weight: 600;
    color: var(--muted);
    font-variant-numeric: tabular-nums;
}

.cp-symbol {
    font-size: 1.8rem;
    font-weight: 700;
    color: var(--accent-strong);
    line-height: 1;
}
