/* ================================
   VibeQuests Library Page Styles
   Step 2A: searchable catalogue + canonical Life Area folders
   Load after css/shared.css on vibequests.html
================================ */

.quest-page-note { max-width: 760px; margin-top: 22px; color: var(--muted); font-weight: 700; }
.quest-intro-grid { display: grid; grid-template-columns: repeat(3, minmax(0, 1fr)); gap: 18px; margin-top: 28px; }
.quest-intro-card, .quest-card, .quest-search-panel, .catalogue-note-card { position: relative; overflow: hidden; border: 1px solid rgba(255,255,255,.13); background: radial-gradient(circle at 12% 8%, rgba(82,255,224,.13), transparent 16rem), radial-gradient(circle at 86% 20%, rgba(185,150,255,.12), transparent 18rem), linear-gradient(180deg, rgba(255,255,255,.105), rgba(255,255,255,.048)); box-shadow: 0 18px 48px rgba(0,0,0,.20); }
.quest-intro-card { min-height: 220px; padding: 24px; border-radius: 28px; }
.quest-intro-card > span { display: grid; place-items: center; width: 48px; height: 48px; margin-bottom: 18px; border-radius: 18px; background: rgba(82,255,224,.12); border: 1px solid rgba(82,255,224,.22); font-size: 1.35rem; }
.quest-search-panel { margin-top: 28px; padding: clamp(20px, 3vw, 30px); border-radius: 30px; }
.quest-search-row { display: grid; grid-template-columns: minmax(0, 1fr) auto; gap: 12px; align-items: center; }
.quest-search-box { position: relative; }
.quest-search-box input { width: 100%; min-height: 56px; padding: 0 18px 0 48px; border-radius: 999px; border: 1px solid rgba(255,255,255,.16); background: rgba(2,8,31,.52); color: var(--text); font: inherit; font-weight: 800; outline: none; box-shadow: inset 0 0 0 1px rgba(82,255,224,.04); }
.quest-search-box input::placeholder { color: rgba(210,222,255,.55); }
.quest-search-box input:focus { border-color: rgba(82,255,224,.45); box-shadow: 0 0 0 4px rgba(82,255,224,.10); }
.quest-search-box .search-icon { position: absolute; left: 18px; top: 50%; transform: translateY(-50%); color: var(--teal); font-size: 1.05rem; }
.quest-clear-btn { min-height: 50px; padding: 0 18px; border-radius: 999px; border: 1px solid rgba(255,255,255,.14); background: rgba(255,255,255,.075); color: var(--soft); font-weight: 950; cursor: pointer; }
.quest-filter-block { margin-top: 20px; }
.quest-filter-block strong { display: block; margin-bottom: 10px; font-size: .84rem; letter-spacing: .08em; text-transform: uppercase; color: var(--muted); }
.quest-filter-chips, .quick-signal-chips { display: flex; flex-wrap: wrap; gap: 9px; }
.filter-chip, .quick-chip { border: 1px solid rgba(255,255,255,.14); background: rgba(255,255,255,.075); color: var(--soft); border-radius: 999px; padding: 9px 12px; font-size: .86rem; font-weight: 900; cursor: pointer; transition: transform .18s ease, border-color .18s ease, background .18s ease, color .18s ease; }
.filter-chip:hover, .quick-chip:hover { transform: translateY(-2px); border-color: rgba(82,255,224,.35); color: var(--teal); }
.filter-chip.is-active { color: #07122d; border-color: rgba(82,255,224,.5); background: linear-gradient(135deg, var(--teal), var(--cyan) 55%, #d9c7ff); }
.quest-library-meta { margin-top: 18px; display: flex; align-items: center; justify-content: space-between; gap: 16px; flex-wrap: wrap; color: var(--muted); font-weight: 800; }
.quest-library-meta-text { display: grid; gap: 4px; }
.quest-library-meta-text small { color: rgba(210,222,255,.68); font-weight: 750; line-height: 1.45; }
.quest-view-actions { display: flex; gap: 9px; flex-wrap: wrap; }
.quest-view-btn { min-height: 40px; padding: 0 14px; border-radius: 999px; border: 1px solid rgba(255,255,255,.14); background: rgba(255,255,255,.075); color: var(--soft); font-weight: 950; cursor: pointer; transition: transform .18s ease, border-color .18s ease, background .18s ease, color .18s ease; }
.quest-view-btn:hover { transform: translateY(-2px); border-color: rgba(82,255,224,.35); color: var(--teal); }
.quest-view-btn.is-active { color: #07122d; border-color: rgba(82,255,224,.5); background: linear-gradient(135deg, var(--teal), var(--cyan) 55%, #d9c7ff); }
.quest-library-grid { display: grid; grid-template-columns: repeat(3, minmax(0, 1fr)); gap: 18px; margin-top: 24px; }
.quest-card { display: flex; flex-direction: column; min-height: 410px; padding: 24px; border-radius: 30px; transition: transform .18s ease, border-color .18s ease, background .18s ease; }
.quest-card:hover { transform: translateY(-4px); border-color: rgba(82,255,224,.36); background: radial-gradient(circle at 12% 8%, rgba(82,255,224,.18), transparent 16rem), radial-gradient(circle at 86% 20%, rgba(185,150,255,.16), transparent 18rem), linear-gradient(180deg, rgba(255,255,255,.13), rgba(255,255,255,.06)); }
.quest-card-top { display: flex; align-items: flex-start; justify-content: space-between; gap: 14px; margin-bottom: 14px; }
.quest-icon { display: grid; place-items: center; width: 48px; height: 48px; flex: 0 0 auto; border-radius: 18px; background: rgba(82,255,224,.12); border: 1px solid rgba(82,255,224,.22); font-size: 1.35rem; }
.quest-status { padding: 6px 10px; border-radius: 999px; color: #07122d; background: linear-gradient(135deg, var(--teal), var(--cyan) 55%, #d9c7ff); font-size: .72rem; font-weight: 950; letter-spacing: .06em; text-transform: uppercase; }
.quest-status[data-status="planned"] { color: var(--soft); background: rgba(255,255,255,.08); border: 1px solid rgba(255,255,255,.13); }
.quest-card h3 { margin: 4px 0 10px; font-size: clamp(1.45rem, 2vw, 1.9rem); }
.quest-card p { margin: 0; }
.quest-mini-meta { display:flex; flex-wrap: wrap; gap:8px; margin: 14px 0 0; color: var(--muted); font-size:.82rem; font-weight:850; }
.quest-mini-meta span { padding: 5px 8px; border-radius: 999px; background: rgba(0,0,0,.14); border: 1px solid rgba(255,255,255,.08); }
.quest-focus { display: flex; flex-wrap: wrap; gap: 7px; margin: 16px 0 0; }
.quest-focus span { padding: 6px 9px; border-radius: 999px; border: 1px solid rgba(255,255,255,.13); background: rgba(255,255,255,.07); color: var(--soft); font-size: .78rem; font-weight: 850; }
.quest-card-footer { margin-top: auto; padding-top: 22px; display: flex; align-items: center; justify-content: space-between; gap: 14px; }
.quest-count { color: var(--muted); font-size: .86rem; font-weight: 800; }
.quest-link { display: inline-flex; align-items: center; justify-content: center; min-height: 42px; padding: 0 15px; border-radius: 999px; background: rgba(82,255,224,.10); border: 1px solid rgba(82,255,224,.25); color: var(--teal); font-weight: 950; white-space: nowrap; }
.no-results { display:none; margin-top: 24px; padding: 28px; border-radius: 28px; border: 1px dashed rgba(255,255,255,.22); color: var(--soft); background: rgba(255,255,255,.055); }
.no-results.is-visible { display:block; }
@media (max-width: 1080px) { .quest-library-grid, .quest-intro-grid { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 720px) { .quest-search-row { grid-template-columns: 1fr; } .quest-clear-btn { width:100%; } }
@media (max-width: 640px) { .quest-library-grid, .quest-intro-grid { grid-template-columns: 1fr; } .quest-card { min-height: auto; } .quest-card-footer { flex-direction: column; align-items: stretch; } .quest-link { width: 100%; } }
