/* =========================================================
   Shared Filter UI — used by ALL pill-based filters
   (case filter, product filter, and any future filter).
   Namespace: .brk-filter*  +  card states .brk-filter-hide / -show.

   Each concrete filter keeps its own root hook class for JS
   (e.g. .brk-cf / .brk-pf) and data-* map, but renders this
   shared chrome so every filter looks identical.
   ========================================================= */

.brk-filter {
    --brk-filter-radius: 2px;
    --brk-filter-accent: var(--brk-yellow, var(--primary, #FFC600));
    --brk-filter-ink: var(--text-dark, #0A0A0A);
    --brk-filter-muted: var(--text-dark-muted, #555);
    --brk-filter-line: var(--neutral-trans-20, rgba(0, 0, 0, 0.12));
    --brk-filter-surface: var(--surface, #fff);

    font-family: "Geist", -apple-system, BlinkMacSystemFont, sans-serif;
    color: var(--brk-filter-ink);
    width: 100%;
    margin-bottom: var(--space-m, 1.5rem);
}

/* Fill full content width even inside a narrow (ACSS content-width) block. */
.brxe-block:has(.brk-filter),
.brxe-shortcode:has(.brk-filter) {
    max-width: none !important;
    width: 100% !important;
}

/* ── Bar (toggle + results count) ───────────────────────── */
.brk-filter__bar {
    display: flex;
    align-items: center;
    gap: var(--space-m, 1.5rem);
    flex-wrap: wrap;
    padding-bottom: var(--space-s, 1rem);
    border-bottom: 1px solid var(--brk-filter-line);
}

/* ── Toggle — mirrors the theme .btn--outline + .btn--pill buttons:
   transparent body, dark border, dark text, light-grey icon block on
   the right holding the count circle. ─────────────────────────────── */
.brk-filter__toggle {
    display: inline-flex;
    align-items: stretch;
    overflow: hidden;
    padding: 0 0 0 1.5rem;
    background: var(--base);
    border: 0;
    border-radius: var(--brk-filter-radius);
    color: #fff;
    font-family: "Saira Semi Condensed", "Geist", sans-serif;
    font-size: var(--text-s, 0.875rem);
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.04em;
    cursor: pointer;
    transition: box-shadow 0.2s ease, background-color 0.2s ease, color 0.2s ease;
}

.brk-filter__toggle-text {
    display: inline-flex;
    align-items: center;
    gap: 0.5rem;
    padding-block: 0.9rem;
}

.brk-filter__toggle-text > svg {
    flex-shrink: 0;
}

/* Right-hand block (where the icon usually sits on .btn--pill) */
.brk-filter__icon {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    align-self: stretch;
    margin-left: var(--btn-medium-inline, 1.25rem);
    padding: 0 0.9em;
    background: var(--base);
    border-left: 2px solid var(--brk-filter-ink);
    transition: box-shadow 0.2s ease;
}

.brk-filter__toggle:hover,
.brk-filter__toggle[aria-expanded="true"] {
    box-shadow: 0 4px 24px rgba(0, 0, 0, 0.12);
}

/* Yellow count circle inside the right block */
.brk-filter__count {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-width: 2em;
    height: 2em;
    padding: 0 0.55em;
    background: var(--brk-filter-accent);
    color: var(--brk-filter-ink);
    border-radius: 999px;
    font-size: 0.95rem;
    font-weight: 700;
    line-height: 1;
}

.brk-filter__results {
    margin: 0;
    font-family: "Saira Semi Condensed", "Geist", sans-serif;
    font-size: var(--text-s, 0.875rem);
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.04em;
    color: var(--brk-filter-muted);
}

.brk-filter__results-count {
    color: var(--brk-filter-ink);
}

/* ── Facets (collapsible) ───────────────────────────────── */
.brk-filter__facets {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: var(--space-m, 1.5rem) var(--space-l, 2rem);
    max-height: 0;
    overflow: hidden;
    transition: max-height 0.35s ease, padding 0.35s ease, margin-top 0.35s ease;
    padding-top: 0;
    margin-top: 0;
}

.brk-filter__facets > .brk-filter__clear {
    grid-column: 1 / -1;
}

@media (max-width: 900px) {
    .brk-filter__facets {
        grid-template-columns: 1fr;
    }
}

/* Events filter: only When (2 pills) + Year + Country (many pills). A fixed
   3-col grid leaves the When/Year columns short and Country tall/lopsided.
   Put When | Year on the top row and let Country span full width below —
   fewer rows, less white space. Scoped to .brk-ev so case/product are untouched. */
@media (min-width: 901px) {
    .brk-ev .brk-filter__facets {
        grid-template-columns: 1fr 1fr;
    }
    .brk-ev .brk-filter__facet:nth-of-type(3) {
        grid-column: 1 / -1;
    }
}

.brk-filter__toggle[aria-expanded="true"] ~ .brk-filter__facets,
.brk-filter__bar:has(.brk-filter__toggle[aria-expanded="true"]) + .brk-filter__facets {
    max-height: 1200px;
    padding-top: var(--space-m, 1.5rem);
    margin-top: 0;
}

.brk-filter__facet {
    border: 0;
    padding: 0;
    margin: 0;
    min-width: 0;
}

.brk-filter__facet-title {
    padding: 0;
    margin: 0 0 0.75rem 0;
    font-family: "Saira Semi Condensed", "Geist", sans-serif;
    font-size: var(--text-s, 0.875rem);
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.04em;
    color: var(--brk-filter-muted);
}

/* ── Pills ──────────────────────────────────────────────── */
.brk-filter__pills {
    display: flex;
    flex-wrap: wrap;
    gap: 0.5rem;
}

.brk-filter__pill {
    display: inline-flex;
    align-items: center;
    min-height: 40px;
    padding: 0.4rem 2rem;
    background: transparent;
    border: 1px solid var(--brk-filter-line);
    border-radius: 999px;
    color: var(--brk-filter-ink);
    font-family: "Geist", -apple-system, sans-serif;
    font-size: var(--text-xs, 0.75rem);
    font-weight: 600;
    line-height: 1.2;
    cursor: pointer;
    transition: background-color 0.15s ease, border-color 0.15s ease, color 0.15s ease;
}

.brk-filter__pill:hover {
    border-color: var(--brk-filter-ink);
}

.brk-filter__pill.is-active {
    background: var(--brk-filter-accent);
    border-color: var(--brk-filter-accent);
    color: var(--brk-filter-ink);
    font-weight: 700;
}

.brk-filter__pill:focus-visible {
    outline: 2px solid var(--brk-filter-accent);
    outline-offset: 2px;
}

.brk-filter__clear {
    align-self: flex-start;
    background: transparent;
    border: 0;
    padding: 0.25rem 0;
    color: var(--brk-filter-muted);
    font-size: var(--text-s, 0.875rem);
    text-decoration: underline;
    text-underline-offset: 4px;
    cursor: pointer;
    transition: color 0.15s ease;
}

.brk-filter__clear:hover {
    color: var(--brk-filter-ink);
}

/* ── Empty state ────────────────────────────────────────── */
.brk-filter__empty {
    margin: var(--space-m, 1.5rem) 0;
    padding: var(--space-l, 2rem);
    text-align: center;
    background: var(--brk-filter-line);
    border-radius: var(--brk-filter-radius);
    color: var(--brk-filter-muted);
    font-size: var(--text-s, 0.875rem);
}

.brk-filter__empty-reset {
    margin-left: 0.5rem;
    background: transparent;
    border: 0;
    color: var(--brk-filter-ink);
    text-decoration: underline;
    text-underline-offset: 4px;
    cursor: pointer;
    font-size: inherit;
    font-weight: 700;
}

/* ── Card states (applied on the Bricks loop cards) ─────── */
.brk-filter-hide {
    display: none !important;
}

@keyframes brkFilterFadeIn {
    from { opacity: 0; transform: translateY(6px); }
    to   { opacity: 1; transform: none; }
}

.brk-filter-show {
    animation: brkFilterFadeIn 0.25s ease both;
}

@media (prefers-reduced-motion: reduce) {
    .brk-filter__facets,
    .brk-filter-show {
        animation: none;
        transition: none;
    }
}
