/**
 * BillboardMax — Shared venue-card styles.
 *
 * Visual ruleset for the `<template id="finder-card-template">` markup that
 * lives in /partials/venue_card.php and is consumed today by:
 *
 *   - /finder/              (assets/js/finder.js — search results list)
 *   - /plan/view/           (assets/js/plan-view-venue-detail.js — detail
 *                            drawer launched from the venues rail)
 *
 * Selectors stay namespaced under `.finder-card*` so the partial's class
 * names and finder.js's selectors keep working without modification. New
 * consumers (e.g. the plan-view detail drawer) wrap the cloned card in a
 * neutral overlay (`.bbm-venue-detail-*`) so the card itself is visually
 * identical between the two surfaces.
 *
 * CSS variables (`--bm-amber`, `--bm-line`, etc.) come from app.css, which
 * is loaded ahead of this file on every page that uses the cards.
 */

/* ---- Cards (compact for the narrow column) ----------------------------- */

.finder-card {
    background: #fff;
    border: 1px solid var(--bm-line);
    border-radius: 0.65rem;
    padding: 0.7rem 0.8rem 0.75rem;
    box-shadow: 0 1px 2px rgba(11, 26, 43, 0.04);
    transition: border-color 0.15s ease, box-shadow 0.15s ease, transform 0.15s ease;
    display: grid;
    gap: 0.4rem;
}
.finder-card:hover {
    border-color: rgba(255, 176, 32, 0.55);
    box-shadow: 0 4px 14px rgba(11, 26, 43, 0.08);
}
.finder-card.is-selected {
    border-color: var(--bm-amber);
    background: linear-gradient(180deg, #fff8e8 0%, #fff 60%);
    box-shadow: 0 4px 14px rgba(255, 176, 32, 0.18);
}

.finder-card-head {
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: 0.5rem;
    font-size: 0.78rem;
    color: var(--bm-muted);
    font-weight: 600;
}

.finder-card-distance {
    display: inline-flex;
    align-items: center;
    gap: 0.35rem;
    color: var(--bm-ink-3);
    flex-wrap: wrap;
}
.finder-card-distance::before {
    content: '\F3E7';
    font-family: 'bootstrap-icons';
    color: var(--bm-amber-2);
    font-size: 0.95rem;
    line-height: 1;
}

/* ZIP pill sits between the pin icon (::before) and the mile-range value.
 * Compact, monospace-friendly look so it reads as an identifier without
 * competing with the address below. */
.finder-card-zip-top {
    display: inline-block;
    padding: 0.08rem 0.4rem;
    border-radius: 0.35rem;
    background: var(--bm-cloud, #f1f3f5);
    color: var(--bm-ink, #0b1a2b);
    font-size: 0.72rem;
    font-weight: 700;
    letter-spacing: 0.03em;
    line-height: 1.3;
}
.finder-card-zip-top:empty { display: none; }

.finder-card-distance-val {
    color: var(--bm-ink-3);
    font-weight: 600;
}
.finder-card-distance-val:not(:empty)::before {
    content: '·';
    margin-right: 0.35rem;
    color: var(--bm-muted, #6b7280);
    opacity: 0.6;
}

.finder-card-size {
    background: var(--bm-cloud);
    color: var(--bm-ink);
    border: 1px solid var(--bm-line);
    font-weight: 600;
    font-size: 0.7rem;
    padding: 0.15rem 0.4rem;
}

.finder-card-address {
    font-size: 0.94rem;
    margin: 0;
    font-weight: 700;
    color: var(--bm-ink);
    line-height: 1.25;
    word-break: break-word;
}

.finder-card-meta {
    margin: 0;
    color: var(--bm-muted);
    font-size: 0.82rem;
    line-height: 1.3;
}

.finder-card-toggle {
    justify-self: stretch;  /* full-width button in the narrow column */
    border-radius: 0.45rem;
    font-weight: 600;
    font-size: 0.85rem;
    padding: 0.35rem 0.5rem;
    transition: all 0.15s ease;
}
.finder-card.is-selected .finder-card-toggle {
    background: var(--bm-amber);
    color: #1a1206;
    border-color: #f89804;
}
.finder-card.is-selected .finder-card-toggle:hover {
    background: var(--bm-amber-2);
    color: #1a1206;
    border-color: #d97500;
}

.finder-card-disabled-note {
    margin: 0;
    color: var(--bm-muted);
    font-size: 0.78rem;
}
.finder-card.is-disabled .finder-card-toggle { display: none; }

/* ---- Root-agency target_id drawer -------------------------------------- *
 *
 * An arrow-down toggle that expands a list of click-to-copy target_ids
 * sitting between the UID line and the Add-to-plan button. Hidden until
 * the JS populates it (only happens when FINDER_BOOT.isAgencyRoot === true).
 * Visual goal: feels like a "more details" affordance, not a primary CTA. */
.finder-card-expander {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 0.2rem;
    margin: 0 auto 0.35rem;
    width: 28px;
    height: 22px;
    padding: 0;
    border: 1px solid var(--bm-line);
    border-radius: 0.45rem;
    background: var(--bm-cloud, #f1f3f5);
    color: var(--bm-ink);
    font-size: 0.8rem;
    line-height: 1;
    cursor: pointer;
    transition: transform 0.18s ease, background-color 0.15s ease, border-color 0.15s ease;
}
.finder-card-expander:hover {
    background: #fff;
    border-color: var(--bm-amber);
    color: var(--bm-amber-strong, #c66100);
}
.finder-card-expander[aria-expanded="true"] {
    transform: rotate(180deg);
    background: #fff;
    border-color: var(--bm-amber);
    color: var(--bm-amber-strong, #c66100);
}
.finder-card-expander i { line-height: 1; }

.finder-card-targets {
    list-style: none;
    margin: 0 0 0.5rem;
    padding: 0.35rem;
    background: rgba(11, 26, 43, 0.04);
    border: 1px solid var(--bm-line);
    border-radius: 0.5rem;
    display: grid;
    gap: 0.25rem;
}

.finder-card-target-row {
    margin: 0;
}

.finder-card-target-copy {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 0.35rem;
    width: 100%;
    padding: 0.3rem 0.5rem;
    background: #fff;
    border: 1px solid var(--bm-line);
    border-radius: 0.4rem;
    color: var(--bm-ink);
    font-family: var(--bs-font-monospace, ui-monospace, SFMono-Regular, Menlo, monospace);
    font-size: 0.78rem;
    text-align: left;
    cursor: pointer;
    transition: border-color 0.12s ease, background-color 0.12s ease;
}
.finder-card-target-copy:hover {
    border-color: var(--bm-amber);
    background: #fffbf2;
}
.finder-card-target-copy.is-copied {
    border-color: #1f9d55;
    background: #ecfdf5;
    color: #166534;
}
.finder-card-target-copy .finder-card-target-id {
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
    flex: 1 1 auto;
    min-width: 0;
}
.finder-card-target-copy .finder-card-target-icon {
    flex: 0 0 auto;
    opacity: 0.7;
    font-size: 0.85rem;
}
.finder-card-target-copy.is-copied .finder-card-target-icon { opacity: 1; }

/* Multi-face billboards (grouping mirrors plan-view's mergeVenuesSameCoordinates) —
 * one card per physical structure with all faces toggled as a unit. Subtle
 * left-rail accent + tighter address line so "N-face billboard" reads as a
 * grouped card rather than a single listing. */
.finder-card.is-multi {
    padding-left: calc(0.75rem - 3px);
}
.finder-card.is-multi .finder-card-address {
    color: var(--bm-amber-strong, #c66100);
    font-weight: 700;
}
.finder-card.is-multi .finder-card-meta {
    font-style: normal;
}

/* ---- Card: UID chip line (first 9 chars per face) ---------------------- */
.finder-card-uids {
    margin: 0.05rem 0 0.4rem;
    font-family: var(--bs-font-monospace, ui-monospace, SFMono-Regular, Menlo, monospace);
    font-size: 0.72rem;
    letter-spacing: 0.02em;
    color: var(--bm-muted);
    word-break: break-all;
}
.finder-card.is-selected .finder-card-uids { color: var(--bm-ink); }


/* ---- Plan-view rail integration ---------------------------------------- *
 *
 * When the shared finder-card markup is reused inside the plan-view venue
 * rail it picks up an extra `.plan-view-venue-card` class so existing
 * handlers (selection highlight, scroll-into-view, map pin linkage) keep
 * working. The plan-view stylesheet, however, sets its own grid + max-height
 * on `.plan-view-venue-card` for the legacy thumb-based card. These rules
 * re-assert the finder-card layout when both classes coexist so the card
 * renders identically to /finder/. */
.plan-view-venue-card.finder-card {
    display: grid;
    grid-template-columns: 1fr;
    grid-template-rows: auto;
    column-gap: 0;
    row-gap: 0.4rem;
    align-items: stretch;
    padding: 0.7rem 0.8rem 0.75rem;
    max-height: none !important;
    background: #fff;
    border-radius: 0.65rem;
    flex: 0 0 auto;
}

/* Selection styling for the shared card on plan-view — keeps the amber
 * accent from the legacy card so the existing "highlighted pin pairs with
 * highlighted card" behavior still reads visually. */
.plan-view-venue-card.finder-card.is-selected {
    border-color: var(--bm-amber);
    background: linear-gradient(180deg, #fff8e8 0%, #fff 60%);
    box-shadow:
        0 0 0 1px rgba(245, 158, 11, 0.25),
        0 8px 22px -10px rgba(245, 158, 11, 0.35);
}
