/* ═══════════════════════════════════════════════════════════════════
   TNG Brick Wall Finder v1.1.0
   Parchment aesthetic — matched to TNG Heritage Map plugin
   Font: Georgia serif · Warm sepia/gold palette · Foxing grain
   ═══════════════════════════════════════════════════════════════════ */

/* ── Parchment background texture via CSS ────────────────────── */
.tng-bw-wrap {
    font-family: "Georgia", "Cambria", "Times New Roman", serif;
    color: #2c2416;
    background:
        repeating-linear-gradient(
            0deg,
            transparent,
            transparent 3px,
            rgba(139,90,43,.018) 3px,
            rgba(139,90,43,.018) 4px
        ),
        radial-gradient(ellipse at 40% 30%, #fdfaf4 0%, #f5eed8 50%, #ede3c8 100%);
    background-color: #faf8f4;
    border: 1px solid #d9cfc0;
    border-radius: 8px;
    padding: 1.75rem 1.5rem;
    max-width: 100%;
    line-height: 1.55;
    box-shadow: 0 2px 12px rgba(28,18,10,.10);
    position: relative;
}
/* Foxing speckle overlay */
.tng-bw-wrap::before {
    content: '';
    position: absolute;
    inset: 0;
    border-radius: 8px;
    pointer-events: none;
    background-image:
        radial-gradient(circle 1.5px at 12% 18%, rgba(107,76,30,.06) 50%, transparent 50%),
        radial-gradient(circle 2px   at 87% 42%, rgba(107,76,30,.05) 50%, transparent 50%),
        radial-gradient(circle 1px   at 45% 72%, rgba(107,76,30,.04) 50%, transparent 50%),
        radial-gradient(circle 1.8px at 68% 14%, rgba(107,76,30,.05) 50%, transparent 50%),
        radial-gradient(circle 1.2px at 28% 88%, rgba(107,76,30,.04) 50%, transparent 50%),
        radial-gradient(circle 2px   at 92% 78%, rgba(107,76,30,.06) 50%, transparent 50%),
        radial-gradient(circle 1px   at 55% 35%, rgba(107,76,30,.03) 50%, transparent 50%);
    z-index: 0;
}
.tng-bw-wrap > * { position: relative; z-index: 1; }

/* ── Color tokens (Heritage Map aligned) ─────────────────────── */
:root {
    --bw-parchment:    #faf8f4;
    --bw-surface:      #fdfcf8;
    --bw-border:       #d9cfc0;
    --bw-border-dark:  #c5b89a;
    --bw-ink:          #2c2416;
    --bw-ink-muted:    #7a6a58;
    --bw-ink-light:    #a09480;
    --bw-sepia:        #6b4c1e;
    --bw-gold:         #b8860b;
    --bw-gold-light:   #d4a820;
    --bw-gold-pale:    #f5ecd4;
    --bw-accent:       #3d5a80;
    --bw-teal:         #1d7a73;
    --bw-teal-bg:      #edf7f6;
    --bw-crimson:      #c0392b;
    --bw-crimson-bg:   #fdf0ee;
    --bw-amber:        #8a6d1b;
    --bw-amber-bg:     #fdf8eb;
    --bw-green:        #3a6f4a;
    --bw-green-bg:     #eef6f0;
    --bw-radius:       6px;
    --bw-shadow:       0 1px 4px rgba(28,18,10,.08);
    --bw-shadow-lg:    0 4px 14px rgba(28,18,10,.12);
    --bw-transition:   .2s ease;
}

/* ── Header ───────────────────────────────────────────────────── */
.tng-bw-header {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    flex-wrap: wrap;
    gap: .75rem;
    margin-bottom: 1.25rem;
    padding-bottom: 1rem;
    border-bottom: 2px solid var(--bw-gold);
}
.tng-bw-title {
    font-family: "Georgia", serif;
    font-size: 1.4rem;
    font-weight: 700;
    color: var(--bw-sepia);
    margin: 0;
    letter-spacing: .01em;
}
.tng-bw-subtitle {
    display: block;
    font-size: .82rem;
    color: var(--bw-ink-muted);
    margin-top: .2rem;
    font-style: italic;
}
.tng-bw-btn {
    display: inline-flex;
    align-items: center;
    gap: .4rem;
    padding: .45rem .85rem;
    font-family: "Georgia", serif;
    font-size: .76rem;
    font-weight: 600;
    letter-spacing: .03em;
    border: 1px solid var(--bw-border-dark);
    border-radius: var(--bw-radius);
    background: var(--bw-surface);
    color: var(--bw-ink);
    cursor: pointer;
    transition: all var(--bw-transition);
}
.tng-bw-btn:hover {
    background: var(--bw-gold-pale);
    border-color: var(--bw-gold);
    color: var(--bw-sepia);
}

/* ── Help callout bar ─────────────────────────────────────────── */
.tng-bw-help-bar {
    display: flex;
    align-items: center;
    gap: .65rem;
    margin-bottom: 1.25rem;
    padding: .75rem 1rem;
    background: linear-gradient(135deg, #edf7f6 0%, #f5ecd4 100%);
    border: 1px solid rgba(29,122,115,.2);
    border-left: 3px solid var(--bw-teal);
    border-radius: var(--bw-radius);
    font-size: .84rem;
    color: var(--bw-ink);
    line-height: 1.5;
}
.tng-bw-help-bar svg { flex-shrink: 0; color: var(--bw-teal); }
.tng-bw-help-bar strong { color: var(--bw-sepia); }
.tng-bw-help-bar em { font-style: italic; color: var(--bw-teal); font-weight: 600; }

/* ── Filters ──────────────────────────────────────────────────── */
.tng-bw-filters {
    display: flex;
    align-items: center;
    flex-wrap: wrap;
    gap: 1rem;
    margin-bottom: 1.25rem;
}
.tng-bw-search-wrap {
    position: relative;
    flex: 1;
    min-width: 200px;
}
.tng-bw-search-icon {
    position: absolute;
    left: .7rem;
    top: 50%;
    transform: translateY(-50%);
    color: var(--bw-ink-light);
    pointer-events: none;
}
.tng-bw-search {
    width: 100%;
    padding: .5rem .7rem .5rem 2rem;
    font-family: "Georgia", serif;
    font-size: .84rem;
    border: 1px solid var(--bw-border-dark);
    border-radius: var(--bw-radius);
    background: var(--bw-surface);
    color: var(--bw-ink);
    transition: border-color var(--bw-transition), box-shadow var(--bw-transition);
}
.tng-bw-search:focus {
    outline: none;
    border-color: var(--bw-gold);
    box-shadow: 0 0 0 2px rgba(184,134,11,.12);
}
.tng-bw-search::placeholder { color: var(--bw-ink-light); font-style: italic; }

.tng-bw-filter-group { display: flex; align-items: center; gap: .45rem; }
.tng-bw-filter-label {
    font-family: -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;
    font-size: .7rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: .07em;
    color: var(--bw-ink-muted);
    white-space: nowrap;
}

/* Chips */
.tng-bw-chips { display: flex; gap: .3rem; flex-wrap: wrap; }
.tng-bw-chip {
    padding: .3rem .65rem;
    font-family: "Georgia", serif;
    font-size: .7rem;
    font-weight: 600;
    border: 1px solid var(--bw-border);
    border-radius: 20px;
    background: var(--bw-surface);
    color: var(--bw-ink-muted);
    cursor: pointer;
    transition: all var(--bw-transition);
    white-space: nowrap;
}
.tng-bw-chip:hover { border-color: var(--bw-gold); color: var(--bw-sepia); }
.tng-bw-chip.active {
    background: var(--bw-sepia);
    border-color: var(--bw-sepia);
    color: #faf8f4;
}

/* Select */
.tng-bw-select {
    padding: .4rem .65rem;
    font-family: "Georgia", serif;
    font-size: .8rem;
    border: 1px solid var(--bw-border-dark);
    border-radius: var(--bw-radius);
    background: var(--bw-surface);
    color: var(--bw-ink);
    cursor: pointer;
    max-width: 180px;
}
.tng-bw-select:focus { outline: none; border-color: var(--bw-gold); }

/* ── Summary Cards ────────────────────────────────────────────── */
.tng-bw-summary {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(155px, 1fr));
    gap: .75rem;
    margin-bottom: 1.25rem;
}
.tng-bw-card {
    display: flex;
    align-items: center;
    gap: .7rem;
    padding: .8rem .9rem;
    background: var(--bw-surface);
    border: 1px solid var(--bw-border);
    border-radius: var(--bw-radius);
    box-shadow: var(--bw-shadow);
    cursor: pointer;
    transition: all var(--bw-transition);
}
.tng-bw-card:hover {
    box-shadow: var(--bw-shadow-lg);
    transform: translateY(-1px);
    border-color: var(--bw-gold);
}
.tng-bw-card-icon {
    width: 36px; height: 36px;
    border-radius: 8px;
    display: flex;
    align-items: center;
    justify-content: center;
    flex-shrink: 0;
}
.tng-bw-card-father  { background: #e8f0f7;             color: var(--bw-accent);  }
.tng-bw-card-mother  { background: var(--bw-crimson-bg); color: var(--bw-crimson); }
.tng-bw-card-date    { background: var(--bw-amber-bg);   color: var(--bw-amber);   }
.tng-bw-card-place   { background: var(--bw-teal-bg);    color: var(--bw-teal);    }

.tng-bw-card-data { display: flex; flex-direction: column; }
.tng-bw-card-num {
    font-family: "Georgia", serif;
    font-size: 1.2rem;
    font-weight: 700;
    line-height: 1.15;
    color: var(--bw-ink);
}
.tng-bw-card-label {
    font-family: -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;
    font-size: .68rem;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: .04em;
    color: var(--bw-ink-muted);
}

/* ── Table ────────────────────────────────────────────────────── */
.tng-bw-table-wrap {
    overflow: auto;
    border: 1px solid var(--bw-border);
    border-radius: var(--bw-radius);
    background: var(--bw-surface);
    box-shadow: var(--bw-shadow);
}
.tng-bw-table { width: 100%; border-collapse: collapse; font-size: .84rem; }
.tng-bw-table thead { position: sticky; top: 0; z-index: 2; }
.tng-bw-table th {
    background: #f3ede0;
    padding: .6rem .8rem;
    text-align: left;
    font-family: -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;
    font-size: .66rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: .07em;
    color: var(--bw-ink-muted);
    border-bottom: 2px solid var(--bw-border);
    white-space: nowrap;
    user-select: none;
}
.tng-bw-sortable { cursor: pointer; }
.tng-bw-sortable:hover { color: var(--bw-sepia); }
.tng-bw-sort-arrow { font-size: .6rem; margin-left: .2rem; }
.tng-bw-sort-arrow::after { content: '▸'; display: inline-block; transform: rotate(90deg); opacity: .3; }
.tng-bw-sortable.asc  .tng-bw-sort-arrow::after { content: '▲'; opacity: .8; color: var(--bw-gold); }
.tng-bw-sortable.desc .tng-bw-sort-arrow::after { content: '▼'; opacity: .8; color: var(--bw-gold); }

.tng-bw-table td {
    padding: .5rem .8rem;
    border-bottom: 1px solid #ece5d8;
    vertical-align: middle;
    color: var(--bw-ink);
}
.tng-bw-table tbody tr:last-child td { border-bottom: none; }
.tng-bw-table tbody tr:hover { background: #f9f5ec; }

/* Severity dots */
.tng-bw-severity { display: flex; gap: 3px; }
.tng-bw-sev-dot { width: 9px; height: 9px; border-radius: 50%; background: #e4ddd4; }
.tng-bw-sev-dot.filled-1 { background: var(--bw-amber); }
.tng-bw-sev-dot.filled-2 { background: #c47a1a; }
.tng-bw-sev-dot.filled-3 { background: #b84a2a; }
.tng-bw-sev-dot.filled-4 { background: var(--bw-crimson); }

/* Missing tags */
.tng-bw-tags { display: flex; flex-wrap: wrap; gap: .25rem; }
.tng-bw-tag {
    display: inline-block;
    font-family: -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;
    font-size: .6rem;
    font-weight: 700;
    padding: .15em .5em;
    border-radius: 3px;
    text-transform: uppercase;
    letter-spacing: .04em;
    white-space: nowrap;
}
.tng-bw-tag-father    { background: #e8f0f7;             color: var(--bw-accent);  border: 1px solid rgba(61,90,128,.18); }
.tng-bw-tag-mother    { background: var(--bw-crimson-bg); color: var(--bw-crimson); border: 1px solid rgba(192,57,43,.18); }
.tng-bw-tag-birthdate { background: var(--bw-amber-bg);   color: var(--bw-amber);  border: 1px solid rgba(138,109,27,.18); }
.tng-bw-tag-birthplace{ background: var(--bw-teal-bg);    color: var(--bw-teal);   border: 1px solid rgba(29,122,115,.18); }

/* Person ID chip */
.tng-bw-pid {
    display: inline-block;
    font-family: 'SFMono-Regular', 'Consolas', 'Liberation Mono', monospace;
    font-size: .63rem;
    padding: .1em .4em;
    background: #efe8da;
    border: 1px solid var(--bw-border);
    border-radius: 3px;
    color: var(--bw-ink-muted);
    letter-spacing: .03em;
    margin-right: .3rem;
    vertical-align: middle;
}
.tng-bw-name { font-family: "Georgia", serif; font-weight: 600; }
.tng-bw-name-last { text-transform: uppercase; letter-spacing: .02em; }

/* ── Actions column ───────────────────────────────────────────── */
.tng-bw-actions { display: flex; flex-direction: column; gap: .35rem; }
.tng-bw-link {
    display: inline-flex;
    align-items: center;
    gap: .25rem;
    font-family: -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;
    font-size: .73rem;
    font-weight: 600;
    color: var(--bw-accent);
    text-decoration: none;
    transition: color var(--bw-transition);
    white-space: nowrap;
}
.tng-bw-link:hover { color: #2a4060; text-decoration: underline; }

.tng-bw-link-help {
    display: inline-flex;
    align-items: center;
    gap: .3rem;
    font-family: -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;
    font-size: .71rem;
    font-weight: 600;
    color: var(--bw-teal);
    text-decoration: none;
    transition: color var(--bw-transition);
    white-space: nowrap;
}
.tng-bw-link-help:hover { color: #14605a; text-decoration: underline; }
.tng-bw-link-help svg { flex-shrink: 0; }

/* Empty cell */
.tng-bw-empty { color: var(--bw-ink-light); font-style: italic; font-size: .78rem; }

/* Loading */
.tng-bw-loading {
    text-align: center;
    padding: 2.5rem 1rem !important;
    color: var(--bw-ink-muted);
    font-size: .88rem;
    font-style: italic;
}
.tng-bw-spinner {
    display: inline-block;
    width: 18px; height: 18px;
    border: 2px solid var(--bw-border);
    border-top-color: var(--bw-gold);
    border-radius: 50%;
    animation: tng-bw-spin .7s linear infinite;
    margin-right: .5rem;
    vertical-align: middle;
}
@keyframes tng-bw-spin { to { transform: rotate(360deg); } }

/* No results */
.tng-bw-noresults {
    text-align: center;
    padding: 2rem 1rem !important;
    color: var(--bw-ink-muted);
    font-style: italic;
}
.tng-bw-noresults-icon { font-size: 2rem; margin-bottom: .5rem; opacity: .4; }

/* ── Pagination ───────────────────────────────────────────────── */
.tng-bw-pagination {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: .35rem;
    margin-top: 1rem;
    flex-wrap: wrap;
}
.tng-bw-page-btn {
    min-width: 30px; height: 30px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    font-family: "Georgia", serif;
    font-size: .76rem;
    font-weight: 600;
    border: 1px solid var(--bw-border);
    border-radius: var(--bw-radius);
    background: var(--bw-surface);
    color: var(--bw-ink-muted);
    cursor: pointer;
    transition: all var(--bw-transition);
    padding: 0 .35rem;
}
.tng-bw-page-btn:hover:not(.disabled) {
    border-color: var(--bw-gold);
    color: var(--bw-sepia);
    background: var(--bw-gold-pale);
}
.tng-bw-page-btn.active {
    background: var(--bw-sepia);
    border-color: var(--bw-sepia);
    color: #faf8f4;
}
.tng-bw-page-btn.disabled { opacity: .35; cursor: default; }
.tng-bw-page-info {
    font-size: .73rem;
    color: var(--bw-ink-muted);
    margin: 0 .5rem;
    font-style: italic;
}

/* ── Responsive ───────────────────────────────────────────────── */
@media (max-width: 768px) {
    .tng-bw-wrap { padding: 1rem; }
    .tng-bw-header { flex-direction: column; }
    .tng-bw-filters { flex-direction: column; align-items: stretch; }
    .tng-bw-filter-group { flex-wrap: wrap; }
    .tng-bw-summary { grid-template-columns: repeat(2, 1fr); }
    .tng-bw-table { font-size: .78rem; }
    .tng-bw-table th, .tng-bw-table td { padding: .4rem .5rem; }
    .tng-bw-help-bar { flex-direction: column; text-align: center; }
}
