/* Broker comparison — uses site Bootstrap tokens only */

.broker-compare-toolbar {
    gap: 0.75rem;
}

.broker-compare-chips {
    gap: 0.5rem;
}

.broker-compare-chip {
    cursor: pointer;
    border: 1px solid var(--bs-border-color);
    background: var(--bs-body-bg);
    color: var(--bs-body-color);
    font-size: 0.875rem;
    padding: 0.35rem 0.75rem;
    border-radius: var(--bs-border-radius-pill);
    transition: background 0.15s ease, border-color 0.15s ease, color 0.15s ease;
}

.broker-compare-chip:hover {
    border-color: var(--bs-primary);
    color: var(--bs-primary);
}

.broker-compare-chip.active {
    background: var(--bs-primary);
    border-color: var(--bs-primary);
    color: var(--bs-white);
}

.broker-compare-highlight {
    cursor: pointer;
    font-size: 0.8125rem;
}

.broker-compare-table-wrap {
    overflow: auto;
    max-height: min(72vh, 720px);
    -webkit-overflow-scrolling: touch;
}

#dynamicTable thead th {
    background: var(--bs-body-bg) !important;
    position: sticky;
    top: 0;
    z-index: 3;
    box-shadow: 0 1px 0 var(--bs-border-color);
}

#dynamicTable thead th.sortable {
    cursor: pointer;
    user-select: none;
}

#dynamicTable tbody tr {
    height: 70px;
}

#dynamicTable tbody tr > td {
    vertical-align: middle !important;
    padding-top: 18px !important;
    padding-bottom: 18px !important;
}

#dynamicTable thead th[data-col]:not([data-col="regulator"]),
#dynamicTable tbody td[data-field]:not([data-field="regulator"]) {
    text-align: center;
}

#dynamicTable tbody td[data-field="broker"] .broker-name-btn {
    display: inline-block;
}

#dynamicTable tbody tr.row-selected {
    background-color: rgba(var(--bs-primary-rgb), 0.08);
}

#dynamicTable tbody tr.row-hidden {
    display: none;
}

#dynamicTable th.col-hidden,
#dynamicTable td.col-hidden {
    display: none;
}

.broker-fee-bar {
    height: 1.25rem;
    border-radius: var(--bs-border-radius);
    background: var(--bs-primary);
    min-width: 2px;
    transition: width 0.25s ease;
}

.broker-fee-bar-label {
    font-size: 0.75rem;
    color: var(--bs-secondary-color);
    min-width: 5.5rem;
}

.broker-compare-panel {
    border: 1px solid var(--bs-border-color-translucent);
}

.broker-compare-metric-diff {
    font-size: 0.75rem;
    color: var(--bs-primary);
}

.broker-compare-bar {
    position: fixed;
    bottom: 0;
    left: 0;
    right: 0;
    z-index: 1040;
    transform: translateY(100%);
    transition: transform 0.25s ease;
    border-top: 1px solid var(--bs-border-color);
}

.broker-compare-bar.is-visible {
    transform: translateY(0);
}

body:has(.broker-compare-bar.is-visible) {
    padding-bottom: 4.5rem;
}

.broker-detail-drawer .offcanvas-body {
    font-size: inherit;
}

.broker-compare-slot {
    min-height: 4.5rem;
    border: 1px dashed var(--bs-border-color);
    border-radius: var(--bs-border-radius-lg);
}

.broker-compare-slot.filled {
    border-style: solid;
    background: var(--bs-body-tertiary);
}

@media (max-width: 575.98px) {
    .broker-compare-toolbar .form-control {
        font-size: 1rem;
    }
}
