:root {
  --bg: #050d1f; --panel: #0b1c36; --panel-soft: #08152b;
  --line: #2f4d78; --text: #edf3ff; --muted: #a9bddb;
  --gold: #f0d28f; --gold-border: rgba(230,195,106,.28);
}
* { box-sizing: border-box; }
body { margin: 0; font-family: 'Inter', sans-serif; background: #050d1f url('../textura.png') center/cover fixed; color: var(--text); }

.page-shell { width: min(1200px, calc(100% - 32px)); margin: 16px auto 60px; }
.breadcrumbs { display: flex; gap: 10px; align-items: center; color: var(--muted); font-size: 15px; margin-bottom: 14px; }
.breadcrumbs a { color: #f0dba8; text-decoration: none; }
.breadcrumbs a:hover { text-decoration: underline; }

.hero { border: 1px solid var(--gold-border); border-radius: 12px; background: linear-gradient(130deg,rgba(9,24,50,.95),rgba(8,18,35,.88)); padding: 22px 28px; margin-bottom: 20px; }
.eyebrow { margin: 0; color: #f2daa2; text-transform: uppercase; font-size: 12px; letter-spacing: 2px; font-weight: 700; }
.hero h1 { margin: 5px 0 7px; font-family: 'Cinzel', serif; font-size: clamp(24px, 3vw, 38px); }
.copy { margin: 0; color: #c8d8f0; font-size: 15px; }

/* ── Search bar ── */
.search-wrap { margin-bottom: 24px; }
.search-bar { display: flex; align-items: center; gap: 0; background: #0c1f3d; border: 1px solid var(--line); border-radius: 12px; padding: 0 14px; margin-bottom: 12px; transition: border-color .15s; }
.search-bar:focus-within { border-color: var(--gold); }
.search-icon { color: var(--muted); font-size: 16px; flex-shrink: 0; }
#search-input { flex: 1; background: transparent; border: none; outline: none; color: var(--text); font-size: 18px; padding: 14px 12px; font-family: 'Inter', sans-serif; }
#search-input::placeholder { color: #4a6080; }
.search-clear { display: flex; align-items: center; justify-content: center; background: transparent; border: none; color: var(--muted); cursor: pointer; padding: 6px; border-radius: 6px; font-size: 14px; }
.search-clear:hover { color: var(--text); }
.search-filters { display: flex; gap: 8px; flex-wrap: wrap; }
.filter-btn { padding: 6px 12px; border: 1px solid var(--line); border-radius: 20px; background: #0c203d; color: var(--muted); cursor: pointer; font-size: 12px; font-weight: 600; transition: all .12s; display: flex; align-items: center; gap: 6px; }
.filter-btn:hover { border-color: rgba(230,195,106,.4); color: #e0d0b0; }
.filter-btn.active { border-color: var(--gold); color: var(--gold); background: rgba(240,210,143,.08); }
.filter-count { min-width: 20px; padding: 1px 6px; border-radius: 999px; background: rgba(255,255,255,.08); color: #d6e5ff; font-size: 10px; line-height: 1.5; text-align: center; }
.filter-btn.active .filter-count { background: rgba(240,210,143,.18); color: #ffe7aa; }

/* ── Stats ── */
.search-stats { color: var(--muted); font-size: 13px; margin-bottom: 16px; }

/* ── Placeholders ── */
.placeholder-msg, .no-results { display: flex; flex-direction: column; align-items: center; justify-content: center; gap: 14px; padding: 60px 20px; color: var(--muted); text-align: center; }
.placeholder-msg i, .no-results i { font-size: 40px; opacity: .3; }
.placeholder-msg p, .no-results p { margin: 0; font-size: 15px; }
.placeholder-hint { max-width: 620px; color: #8fa6c8; font-size: 13px !important; line-height: 1.5; }
.no-results-hint { font-size: 13px !important; opacity: .7; }

/* ── Result groups ── */
.result-group { margin-bottom: 36px; }
.group-header { display: flex; align-items: center; gap: 10px; margin-bottom: 12px; border-bottom: 1px solid rgba(47,77,120,.5); padding-bottom: 8px; }
.group-icon { font-size: 16px; }
.group-title { margin: 0; font-family: 'Cinzel', serif; font-size: 16px; color: var(--gold); flex: 1; }
.group-count { background: rgba(47,77,120,.5); color: var(--muted); font-size: 11px; font-weight: 700; padding: 2px 8px; border-radius: 10px; }
.group-link { font-size: 12px; color: var(--muted); text-decoration: none; display: flex; align-items: center; gap: 5px; transition: color .12s; }
.group-link:hover { color: var(--gold); }

/* ── Result grid ── */
.result-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(240px, 1fr)); gap: 10px; }
.result-card { display: grid; grid-template-columns: 58px minmax(0,1fr); align-items: center; gap: 10px; min-height: 92px; background: linear-gradient(180deg,#0d2040,#091629); border: 1px solid var(--line); border-radius: 10px; padding: 10px; text-decoration: none; transition: border-color .12s, transform .1s; }
.result-card:hover { border-color: rgba(230,195,106,.5); transform: translateY(-2px); }
.card-img-wrap { width: 58px; height: 58px; display: flex; align-items: center; justify-content: center; background: linear-gradient(145deg, rgba(255,255,255,.92), rgba(196,215,235,.92)); border: 1px solid rgba(255,255,255,.22); box-shadow: inset 0 0 0 1px rgba(0,0,0,.08); border-radius: 8px; overflow: hidden; flex-shrink: 0; color: var(--result-color, #f0d28f); font-size: 24px; }
.card-img-wrap.no-img { background: #0c203d; }
.card-img-wrap.no-img::after { content: '?'; font-size: 20px; color: #3a5070; }
.card-img-wrap img { width: 100%; height: 100%; object-fit: contain; }
.card-info { display: flex; flex-direction: column; align-items: flex-start; gap: 3px; min-width: 0; width: 100%; }
.card-source { font-size: 10px; font-weight: 800; text-transform: uppercase; letter-spacing: .06em; }
.card-name { font-size: 13px; font-weight: 800; color: var(--text); text-align: left; line-height: 1.25; display: -webkit-box; -webkit-box-orient: vertical; -webkit-line-clamp: 2; overflow: hidden; }
.card-sub { font-size: 11px; color: var(--muted); text-align: left; line-height: 1.35; display: -webkit-box; -webkit-box-orient: vertical; -webkit-line-clamp: 2; overflow: hidden; }
.card-context { margin-top: 2px; color: #c8d8f0; font-size: 11px; line-height: 1.35; opacity: .88; display: -webkit-box; -webkit-box-orient: vertical; -webkit-line-clamp: 2; overflow: hidden; }
mark { background: rgba(240,210,143,.3); color: var(--gold); border-radius: 2px; padding: 0 1px; }
.more-hint { margin: 8px 0 0; font-size: 12px; color: var(--muted); display: flex; align-items: center; gap: 6px; }

@media (max-width: 640px) {
  #search-input { font-size: 15px; padding: 12px 8px; }
  .result-grid { grid-template-columns: 1fr; }
  .result-card { grid-template-columns: 52px minmax(0,1fr); min-height: 82px; }
  .card-img-wrap { width: 52px; height: 52px; }
}
