/* Repair sources indicator (wrench icon) shown next to item names in
   damage-calculation forms. Hovering or focusing reveals a popover with
   linked repair/paint material and work rows. */

.repair-sources-indicator {
    display: inline-flex;
    align-items: center;
    flex-shrink: 0;
}

.repair-sources-indicator .bi-wrench {
    font-size: 1rem;
    line-height: 1;
}

.repair-sources-indicator .bi-wrench:focus-visible {
    outline: 2px solid var(--brass-400);
    outline-offset: 2px;
    border-radius: var(--radius-sm);
}

.repair-sources-popover {
    --bs-popover-bg: var(--card-bg-color);
    --bs-popover-border-color: rgba(212, 160, 23, 0.56);
    --bs-popover-border-width: 2px;
    --bs-popover-body-color: var(--text-color);
    --bs-popover-max-width: min(44rem, calc(100vw - 2rem));
    min-width: min(36rem, calc(100vw - 2rem));
    box-shadow:
        0 0 0 1px rgba(232, 235, 239, 0.08),
        0 14px 32px rgba(0, 0, 0, 0.58);
}

.repair-sources-popover .popover-body {
    max-height: calc(100vh - 6rem);
    overflow-x: auto;
    overflow-y: auto;
    padding: 0.85rem 1rem;
}

.repair-sources-popover .popover-arrow::before {
    border-top-color: var(--bs-popover-border-color);
}

.repair-sources-popover .popover-arrow::after {
    border-top-color: var(--bs-popover-bg);
}

.repair-sources-popover-body {
    color: var(--text-color);
    font-size: 0.875rem;
}

.repair-sources-popover-body table {
    color: var(--text-color);
    margin-bottom: 0.5rem;
    min-width: 34rem;
    table-layout: auto;
    width: 100%;
}

.repair-sources-popover-body caption {
    color: var(--brass-400);
    font-family: var(--font-mono);
    font-size: 0.75rem;
    letter-spacing: 0.06em;
    text-transform: uppercase;
}

.repair-sources-popover-body th,
.repair-sources-popover-body td {
    color: var(--text-color);
    padding: 0.3rem 0.65rem;
    vertical-align: middle;
}

.repair-sources-popover-body th:first-child,
.repair-sources-popover-body td:first-child {
    min-width: 12rem;
}

.repair-sources-popover-body .text-end {
    white-space: nowrap;
}

.repair-sources-popover-body thead th {
    border-bottom: 1px solid var(--border-color);
    font-family: var(--font-mono);
    font-size: 0.7rem;
    letter-spacing: 0.04em;
    text-transform: uppercase;
}

.repair-sources-popover-body tfoot th {
    border-top: 1px solid var(--border-color);
    font-weight: 600;
}

.repair-sources-grand-totals {
    color: var(--text-color);
    font-size: 0.875rem;
    margin-top: 0.25rem;
}

[data-theme="light"] .repair-sources-popover {
    --bs-popover-bg: #ffffff;
    --bs-popover-border-color: #9aa3af;
    --bs-popover-body-color: #111827;
    box-shadow:
        0 0 0 1px rgba(17, 24, 39, 0.08),
        0 14px 30px rgba(17, 24, 39, 0.18);
}

@media (max-width: 640px) {
    .repair-sources-popover {
        min-width: calc(100vw - 1.5rem);
    }
}
