/* Find the Bit — themed (light/dark) styles for the landing and show pages. */
:root {
  --bg:#0f0f0f; --fg:#f1f1f1; --muted:#888; --muted2:#666; --muted3:#999;
  --accent:#3ea6ff; --card:#1b1b1b; --card2:#181818; --border:#2a2a2a; --border2:#3f3f3f;
  --hit:#272727; --art1:#1f2a33; --art2:#2b3a45;
}
[data-theme="light"] {
  --bg:#ffffff; --fg:#181818; --muted:#5b5b63; --muted2:#8a8a93; --muted3:#5b5b63;
  --accent:#0b6bd6; --card:#f7f7f9; --card2:#f0f0f3; --border:#e4e4e8; --border2:#d3d3da;
  --hit:#f2f2f5; --art1:#dbe7f2; --art2:#c4d6e8;
}

* { box-sizing: border-box; }

body {
  font-family: -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, Oxygen, Ubuntu, sans-serif;
  max-width: 860px;
  margin: 0 auto;
  padding: 2rem;
  background: var(--bg);
  color: var(--fg);
}

a { color: var(--accent); }

.site-header { margin-bottom: 1.5rem; }
.site-title { font-weight: 600; font-size: 1.9rem; margin: 0; }
.site-title .accent { color: var(--accent); }
.site-tagline { color: var(--muted); margin: 0.4rem 0 0; font-size: 0.95rem; }
.back-link { display: inline-block; margin-bottom: 1rem; text-decoration: none; font-size: 0.9rem; }
.back-link:hover { text-decoration: underline; }

/* --- Header controls (layout + theme toggles) --- */
.ftb-controls { display:flex; gap:.6rem; align-items:center; justify-content:flex-end; }
.seg { display:inline-flex; border:1px solid var(--border2); border-radius:8px; overflow:hidden; }
.seg button { background:var(--card); color:var(--muted); border:none; padding:.35rem .6rem; font:inherit; font-size:.8rem; cursor:pointer; }
.seg button.active { background:var(--accent); color:#fff; }
.theme-toggle { background:var(--card); border:1px solid var(--border2); color:var(--muted); border-radius:8px; padding:.35rem .55rem; cursor:pointer; font-size:.9rem; line-height:1; }

/* --- Landing: show cards --- */
.show-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(min(100%, 240px), 1fr));
  gap: 1rem;
  margin-top: 1.5rem;
}
.show-card {
  display: flex;
  flex-direction: column;
  background: var(--card);
  border: 1px solid var(--border);
  border-radius: 12px;
  overflow: hidden;
  text-decoration: none;
  color: inherit;
  transition: border-color 0.15s, transform 0.15s;
}
.show-card:hover { border-color: var(--accent); transform: translateY(-2px); }
.show-card-art {
  aspect-ratio: 16 / 9;
  background: linear-gradient(135deg, var(--art1), var(--art2));
  background-size: cover;
  background-position: center;
}
.show-card-body { padding: 0.9rem 1rem 1.1rem; }
.show-card-title { font-weight: 600; color: var(--fg); margin-bottom: 0.3rem; }
.show-card-desc { color: var(--muted3); font-size: 0.85rem; line-height: 1.45; }
.show-card-meta { color:var(--muted2); font-size:.72rem; margin-top:.5rem; }

/* --- Landing: list layout --- */
.show-grid.list { grid-template-columns:1fr; }
.show-grid.list .show-card { flex-direction:row; }
.show-grid.list .show-card-art { width:140px; aspect-ratio:auto; flex:none; }
.show-grid.list .show-card-body { flex:1; display:flex; flex-direction:column; justify-content:center; }

/* --- Show page: search --- */
.show-head { display: flex; align-items: center; gap: 1rem; margin-bottom: 1.25rem; }
.show-head-art {
  width: 64px; height: 64px; border-radius: 10px; flex: none;
  background: linear-gradient(135deg, var(--art1), var(--art2));
  background-size: cover; background-position: center;
}
.show-head-text h1 { margin: 0; font-size: 1.5rem; font-weight: 600; }
.show-head-text p { margin: 0.25rem 0 0; color: var(--muted); font-size: 0.9rem; }

/* Quiet usage meter chip + device-local recent searches (Phase 4a). */
.meter-row { display:inline-flex; align-items:center; gap:.5rem; margin-top:.4rem; }
.meter-chip { display:inline-block; margin-top:.4rem; padding:.15rem .5rem; font-size:.72rem;
  color:var(--muted2,#888); border:1px solid var(--border,#2a2a2a); border-radius:999px; }
.meter-chip[hidden] { display:none; }
.meter-row .meter-chip { margin-top:0; }
.meter-chip.warn { border-color:var(--accent,#3ea6ff); color:var(--accent,#3ea6ff); }

/* Magic-link accounts: account menu, soft prompt, sign-in modal (Phase 4b). */
.acct-btn { background:var(--card,#1b1b1b); color:var(--muted,#888); border:1px solid var(--border2,#3f3f3f);
  border-radius:999px; padding:.15rem .6rem; font:inherit; font-size:.72rem; cursor:pointer; }
.acct-btn:hover { border-color:var(--accent,#3ea6ff); color:var(--accent,#3ea6ff); }
.signin-prompt { margin-top:.4rem; font-size:.78rem; color:var(--muted,#888); display:flex; gap:.4rem;
  align-items:center; flex-wrap:wrap; }
.link-btn { background:none; border:none; padding:0; font:inherit; font-size:.78rem; color:var(--accent,#3ea6ff);
  cursor:pointer; text-decoration:underline; }
.ftb-overlay { position:fixed; inset:0; background:rgba(0,0,0,.6); display:flex; align-items:center;
  justify-content:center; z-index:50; padding:1rem; }
.ftb-card { position:relative; background:var(--card,#1b1b1b); color:var(--fg,#f1f1f1); padding:1.5rem;
  border:1px solid var(--border2,#3f3f3f); border-radius:12px; max-width:24rem; width:100%; }
.ftb-card h2 { margin:0 0 .5rem; }
.ftb-card p { margin:.25rem 0; color:var(--muted,#888); font-size:.9rem; }
.ftb-card input { width:100%; padding:.5rem; margin:.6rem 0; border-radius:6px;
  border:1px solid var(--border2,#3f3f3f); background:var(--bg,#0f0f0f); color:var(--fg,#f1f1f1); font:inherit; }
.ftb-card button[type=submit] { background:var(--accent,#3ea6ff); color:#fff; border:none; border-radius:6px;
  padding:.45rem .8rem; font:inherit; cursor:pointer; }
.ftb-card button[type=submit]:disabled { opacity:.6; cursor:default; }
.ftb-close { position:absolute; top:.6rem; right:.8rem; background:none; border:none; color:var(--muted,#888);
  font-size:1.4rem; line-height:1; cursor:pointer; }
.muted { color:var(--muted2,#888); font-size:.8rem; }
/* Phase 4c — upgrade / Pro emphasis + soft cap banner. */
.acct-btn-pro { color:var(--accent,#3ea6ff); border-color:var(--accent,#3ea6ff); }
.acct-btn-pro:hover { background:var(--accent,#3ea6ff); color:#fff; }
.upgrade-options { display:flex; gap:.5rem; margin:.8rem 0; flex-wrap:wrap; }
.upgrade-options .acct-btn { font-size:.85rem; padding:.45rem .9rem; }
.upgrade-options .acct-btn:disabled { opacity:.6; cursor:default; }
.soft-banner { position:fixed; left:0; right:0; bottom:0; padding:.6rem 1rem; text-align:center;
  display:flex; gap:.6rem; align-items:center; justify-content:center; flex-wrap:wrap;
  background:var(--card,#1b1b1b); border-top:1px solid var(--border,#2a2a2a); color:var(--fg,#f1f1f1); z-index:40; }
.recent-searches { margin:.4rem 0 0; padding:.4rem; border:1px solid var(--border,#2a2a2a);
  border-radius:8px; background:var(--card,#1b1b1b); }
.recent-label { font-size:.7rem; color:var(--muted2,#888); margin:0 0 .3rem .2rem; }
.recent-item { display:inline-block; margin:.15rem; padding:.25rem .6rem; font:inherit; font-size:.8rem;
  background:var(--hit,#272727); color:var(--fg,#f1f1f1); border:none; border-radius:6px; cursor:pointer; }

.controls-row { display: flex; gap: 0.75rem; align-items: center; flex-wrap: wrap; }
#searchbox { flex: 1; min-width: 220px; }

.ais-SearchBox, .ais-SearchBox-form, .ais-SearchBox-input { background-image: none !important; }
.ais-SearchBox-input {
  background: var(--hit); border: 1px solid var(--border2); color: var(--fg);
  padding: 0.75rem 1rem !important; font-size: 1rem; border-radius: 8px; width: 100%;
}
.ais-SearchBox-input:focus { outline: none; border-color: var(--accent); }
.ais-SearchBox-input::placeholder { color: var(--muted2); opacity: 1; }
.ais-SearchBox-input:focus::placeholder { color: transparent; }
.ais-SearchBox-submit, .ais-SearchBox-reset, .ais-SearchBox-submitIcon,
.ais-SearchBox-resetIcon, .ais-SearchBox-loadingIndicator,
.ais-SearchBox::before, .ais-SearchBox::after, .ais-SearchBox-form::before,
.ais-SearchBox-form::after, .ais-SearchBox svg,
.ais-Hits-item::before, .ais-Hits-item::after { display: none !important; }

.ais-MenuSelect-select {
  background: var(--hit); border: 1px solid var(--border2); color: var(--fg);
  padding: 0.65rem 0.75rem; border-radius: 8px; font-size: 0.9rem;
}
#series-filter { display: none; }
#series-filter.visible { display: block; }

.ais-Hits-list { border: none !important; box-shadow: none !important; }
.ais-Hits-item {
  border: none !important; box-shadow: none !important; background: transparent !important;
  padding: 0 !important; margin: 0 !important;
}
#hits { margin-top: 1.5rem; }

.hit-item {
  display: block; background: var(--hit); border-radius: 8px; padding: 1rem;
  margin-bottom: 1rem; text-decoration: none; color: inherit;
}
.hit-item:hover { background: var(--border2); }
.hit-title { font-weight: 500; margin-bottom: 0.5rem; color: var(--accent); }
.hit-series { color: #6f8; font-size: 0.72rem; text-transform: uppercase; letter-spacing: 0.04em; margin-bottom: 0.35rem; }
.hit-text { color: var(--muted3); font-size: 0.9rem; line-height: 1.5; }
.hit-timestamp { font-size: 0.8rem; color: var(--muted2); margin-top: 0.5rem; }
.ais-Highlight-highlighted {
  background: #3ea6ff33; color: var(--accent); padding: 0 2px; border-radius: 2px;
}

.ais-Stats { color: var(--muted2); font-size: 0.85rem; margin: 1rem 0; }
.ais-Pagination { margin-top: 2rem; }
.ais-Pagination-list { display: flex; gap: 0.5rem; justify-content: center; list-style: none; padding: 0; }
.ais-Pagination-link {
  background: var(--hit); color: var(--fg); padding: 0.5rem 0.75rem; border-radius: 4px; text-decoration: none;
}
.ais-Pagination-link:hover { background: var(--border2); }
.ais-Pagination-item--selected .ais-Pagination-link { background: var(--accent); color: var(--bg); }

.empty-state { text-align: center; color: var(--muted2); padding: 3rem; }

.meta-footer {
  margin-top: 3rem; padding-top: 1.5rem; border-top: 1px solid var(--hit);
  color: var(--muted2); font-size: 0.8rem; text-align: center;
}
.made-by { text-align: center; color: var(--muted2); font-size: 0.8rem; margin-top: 0.4rem; }
.made-by a { color: var(--accent); text-decoration: none; }
.made-by a:hover { text-decoration: underline; }

.support { text-align: center; margin-top: 1.2rem; }
.bmc-button {
  display: inline-block; background: #ffdd00; color: #0d0c22; font-weight: 600;
  font-size: 0.85rem; padding: 0.45rem 0.9rem; border-radius: 8px; text-decoration: none;
}
.bmc-button:hover { filter: brightness(0.95); }

/* --- Chat modal --- */
.chat-fab {
  position: fixed; right: 1.5rem; bottom: 1.5rem; background: var(--accent); color: var(--bg);
  border: none; border-radius: 999px; padding: 0.75rem 1.25rem; font-size: 0.95rem;
  font-weight: 600; cursor: pointer; box-shadow: 0 4px 16px rgba(0, 0, 0, 0.4); z-index: 50;
}
.chat-fab:hover { background: #5cb6ff; }
.chat-overlay {
  position: fixed; inset: 0; background: rgba(0, 0, 0, 0.6); display: none;
  align-items: center; justify-content: center; z-index: 100; padding: 1rem;
}
.chat-overlay.open { display: flex; }
.chat-modal {
  background: var(--card2); border: 1px solid var(--border2); border-radius: 12px; width: 100%;
  max-width: 600px; height: min(70vh, 640px); display: flex; flex-direction: column; overflow: hidden;
}
.chat-header {
  display: flex; align-items: center; justify-content: space-between;
  padding: 1rem 1.25rem; border-bottom: 1px solid var(--hit); font-weight: 600;
}
.chat-close { background: none; border: none; color: var(--muted3); font-size: 1.4rem; line-height: 1; cursor: pointer; }
.chat-close:hover { color: var(--fg); }
.chat-messages { flex: 1; overflow-y: auto; padding: 1rem 1.25rem; display: flex; flex-direction: column; gap: 0.75rem; }
.chat-empty { color: var(--muted2); font-size: 0.9rem; text-align: center; margin: auto 0; line-height: 1.5; }
.chat-msg {
  max-width: 85%; padding: 0.6rem 0.85rem; border-radius: 10px; font-size: 0.92rem;
  line-height: 1.5; white-space: pre-wrap; word-wrap: break-word;
}
.chat-msg.user { align-self: flex-end; background: var(--accent); color: var(--bg); }
.chat-msg.bot { align-self: flex-start; background: var(--hit); color: var(--fg); }
.chat-citations { align-self: flex-start; max-width: 85%; display: flex; flex-wrap: wrap; gap: 0.4rem; margin-top: -0.25rem; }
.chat-cite {
  background: var(--art1); color: var(--accent); border: 1px solid var(--border2); border-radius: 999px;
  padding: 0.2rem 0.6rem; font-size: 0.75rem; text-decoration: none;
}
.chat-cite:hover { background: var(--art2); }
.chat-input-row { display: flex; gap: 0.5rem; padding: 0.85rem 1rem; border-top: 1px solid var(--hit); }
.chat-input-row textarea {
  flex: 1; resize: none; background: var(--hit); border: 1px solid var(--border2); color: var(--fg);
  border-radius: 8px; padding: 0.6rem 0.75rem; font-size: 0.92rem; font-family: inherit; max-height: 120px;
}
.chat-input-row textarea:focus { outline: none; border-color: var(--accent); }
.chat-send {
  background: var(--accent); color: var(--bg); border: none; border-radius: 8px;
  padding: 0 1rem; font-weight: 600; cursor: pointer;
}
.chat-send:disabled { opacity: 0.5; cursor: default; }

/* --- Shared clip card (search results + chat citations) --- */
.clip-card {
  background: var(--hit);
  border: 1px solid var(--border);
  border-radius: 10px;
  overflow: hidden;
  margin-bottom: 1rem;
}
.clip-card-main { display: flex; gap: 0.85rem; padding: 0.85rem; cursor: pointer; }
.clip-card:hover .clip-card-main { background: var(--border); }

.clip-thumb {
  position: relative; flex: none; width: 160px; aspect-ratio: 16 / 9;
  border-radius: 6px; overflow: hidden;
  background: linear-gradient(135deg, var(--art1), var(--art2));
}
.clip-thumb-img { width: 100%; height: 100%; object-fit: cover; display: block; }
.clip-thumb-badge {
  position: absolute; right: 4px; bottom: 4px;
  background: rgba(0, 0, 0, 0.8); color: #fff; font-size: 0.72rem;
  padding: 1px 5px; border-radius: 3px;
}
.clip-thumb-play {
  position: absolute; inset: 0; display: flex; align-items: center; justify-content: center;
  color: #fff; font-size: 1.6rem; opacity: 0.85; pointer-events: none;
  text-shadow: 0 1px 4px rgba(0, 0, 0, 0.6);
}

.clip-card-body { flex: 1; min-width: 0; display: flex; flex-direction: column; }
.clip-title { font-weight: 500; color: var(--accent); text-decoration: none; margin-bottom: 0.35rem; }
.clip-title:hover { text-decoration: underline; }
.clip-snippet { color: var(--muted3); font-size: 0.9rem; line-height: 1.5; }
.clip-footer { display: flex; align-items: center; gap: 0.75rem; margin-top: 0.5rem; }
.clip-time { font-size: 0.8rem; color: var(--muted2); }
.clip-external { font-size: 0.8rem; color: var(--muted); text-decoration: none; }
.clip-external:hover { color: var(--accent); text-decoration: underline; }

.clip-player { width: 100%; aspect-ratio: 16 / 9; background: #000; }
.clip-player[hidden] { display: none; }
.clip-iframe { width: 100%; height: 100%; border: 0; display: block; }

/* Compact variant inside the chat modal */
.chat-citations { flex-direction: column; }
.chat-citations .clip-card { width: 100%; margin-bottom: 0; }
.chat-citations .clip-card--compact .clip-thumb { width: 96px; }
.chat-citations .clip-card--compact .clip-snippet { display: none; }
.chat-citations .clip-card--compact .clip-player { max-height: min(46vh, 360px); }

@media (max-width: 560px) {
  .clip-card-main { flex-direction: column; }
  .clip-thumb { width: 100%; }
  .chat-citations .clip-card--compact .clip-thumb { width: 100%; }
}

/* --- Suggest-a-show entry card (appended to the show grid) --- */
.suggest-card {
  display: flex; align-items: center; justify-content: center; text-align: center;
  border: 2px dashed var(--border2); border-radius: 12px; color: var(--muted);
  min-height: 120px; cursor: pointer; background: transparent; font: inherit;
  font-size: 0.95rem; transition: border-color 0.15s, color 0.15s;
}
.suggest-card:hover { color: var(--fg); border-color: var(--accent); }

/* --- Community wishlist --- */
.wishlist { margin: 3rem 0 1rem; }
.wishlist h2 { font-size: 1.3rem; margin: 0 0 0.4rem; }
.suggest-toggle {
  background: var(--card); color: var(--fg); border: 1px solid var(--border2);
  border-radius: 8px; padding: 0.5rem 0.9rem; font: inherit; font-size: 0.9rem;
  cursor: pointer; margin: 0.6rem 0 0.4rem;
}
.suggest-toggle:hover { border-color: var(--accent); }
.wishlist-form { display: flex; flex-direction: column; gap: 0.6rem; margin: 1rem 0 2rem; }
.wishlist-form[hidden] { display: none; }
.wishlist-form input, .wishlist-form textarea {
  background: var(--card); color: var(--fg); border: 1px solid var(--border2);
  border-radius: 8px; padding: 0.6rem 0.7rem; font: inherit;
}
.wishlist-form input:focus, .wishlist-form textarea:focus {
  outline: none; border-color: var(--accent);
}
.wishlist-form button {
  background: var(--accent); color: #fff; border: none; border-radius: 8px;
  padding: 0.6rem 1rem; font: inherit; cursor: pointer; align-self: flex-start;
}
.wishlist-form button:disabled { opacity: 0.6; cursor: default; }
.wishlist-msg { font-size: 0.85rem; min-height: 1.1em; }
.wishlist-msg.err { color: #e06; }
.wishlist-msg.ok { color: var(--accent); }
.wishlist-list { display: flex; flex-direction: column; gap: 0.5rem; list-style: none; padding: 0; margin: 0; }
.wishlist-item {
  display: flex; align-items: center; gap: 0.8rem; background: var(--card);
  border: 1px solid var(--border); border-radius: 10px; padding: 0.7rem 0.9rem;
}
.wishlist-item.wishlist-empty { color: var(--muted); justify-content: center; }
.wishlist-item-body { flex: 1; min-width: 0; }
.wishlist-item-name { font-weight: 600; color: var(--fg); }
.wishlist-item-note { color: var(--muted2); font-size: 0.82rem; margin: 0.1rem 0; }
.wishlist-item a { color: var(--accent); font-size: 0.8rem; }
.upvote {
  display: flex; flex-direction: column; align-items: center; gap: 0.1rem;
  background: var(--card2); border: 1px solid var(--border2); border-radius: 8px;
  color: var(--muted); padding: 0.35rem 0.55rem; cursor: pointer; font: inherit;
  min-width: 3rem;
}
.upvote.voted { background: var(--accent); color: #fff; border-color: var(--accent); }
.upvote-score { font-weight: 700; font-size: 0.95rem; }
.upvote-label { font-size: 0.62rem; text-transform: uppercase; letter-spacing: 0.04em; }
