/* ================================================================
   Plotly chart wrapper
   ================================================================ */
.plotly-wrap {
  width: 100%;
  min-height: 420px;
  border-radius: var(--radius);
  overflow: hidden;
}

/* ================================================================
   Venn diagram wrapper (venn.js SVG)
   ================================================================ */
.venn-mode-btn {
  font-size: .78rem;
  padding: .3rem .8rem;
  border-radius: 20px;
  border: 1px solid var(--border);
  background: var(--bg3);
  color: var(--text-muted);
  cursor: pointer;
  transition: background .15s, color .15s, border-color .15s;
}
.venn-mode-btn:hover {
  background: rgba(255,255,255,.08);
  color: #e2e2f0;
}
.venn-mode-btn.active {
  border-color: var(--accent);
  color: var(--accent);
  background: rgba(139,92,246,.12);
}

#venn-wrap {
  width: 100%;
  max-width: 700px;
  margin: 0 auto;
}

#venn-wrap text {
  fill: #e2e2f0 !important;
  font-family: 'Segoe UI', system-ui, sans-serif;
}

/* Cache dot on favorite chips */
.cache-dot { vertical-align: middle; }

/* ================================================================
   Global Filter Panel
   ================================================================ */
.global-filter-panel {
  background: var(--card-bg);
  border: 1px solid var(--border);
  border-radius: 10px;
  margin-bottom: .8rem;
  overflow: visible;
}

.gfp-toggle-btn {
  display: flex;
  align-items: center;
  gap: .5rem;
  width: 100%;
  background: none;
  border: none;
  color: var(--text);
  font-size: .9rem;
  font-weight: 600;
  padding: .65rem 1rem;
  cursor: pointer;
  text-align: left;
  border-radius: 10px;
  transition: background .15s;
}
.gfp-toggle-btn:hover { background: var(--hover-bg, rgba(255,255,255,.06)); }

.gfp-active-badge {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 1.2rem;
  height: 1.2rem;
  padding: 0 .35rem;
  border-radius: 999px;
  background: var(--accent, #5b8dee);
  color: #fff;
  font-size: .7rem;
  font-weight: 700;
  line-height: 1;
}

.gfp-arrow {
  margin-left: auto;
  transition: transform .2s;
  font-size: .75rem;
  color: var(--text-muted);
}
.global-filter-panel.open .gfp-arrow { transform: rotate(90deg); }

.gfp-body {
  padding: .5rem 1rem .8rem;
  border-top: 1px solid var(--border);
  display: flex;
  flex-direction: column;
  gap: .55rem;
}

.gfp-row {
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  gap: .45rem;
}

.gfp-label {
  min-width: 5rem;
  font-size: .8rem;
  font-weight: 600;
  color: var(--text-muted);
  text-transform: uppercase;
  letter-spacing: .04em;
}

.gfp-input {
  background: var(--input-bg, rgba(255,255,255,.07));
  border: 1px solid var(--border);
  border-radius: 6px;
  color: var(--text);
  font-size: .85rem;
  padding: .3rem .55rem;
  outline: none;
  transition: border-color .15s;
}
.gfp-input:focus { border-color: var(--accent, #5b8dee); }

.gfp-select {
  background: var(--input-bg, rgba(255,255,255,.07));
  border: 1px solid var(--border);
  border-radius: 6px;
  color: var(--text);
  font-size: .85rem;
  padding: .3rem .45rem;
  cursor: pointer;
  outline: none;
}

.gfp-year-input  { width: 5.5rem; }
.gfp-score-input { width: 4.5rem; }
.gfp-separator   { color: var(--text-muted); font-size: .85rem; }

.gfp-range-wrap {
  display: inline-flex;
  align-items: center;
  gap: .35rem;
  color: var(--text-muted);
}

.gfp-genre-area {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: .35rem;
}
.gfp-genre-tags {
  display: flex;
  flex-wrap: wrap;
  gap: .3rem;
}
.gfp-genre-tag {
  display: inline-flex;
  align-items: center;
  gap: .25rem;
  font-size: .78rem;
  font-weight: 600;
  padding: .2rem .5rem .2rem .6rem;
  border-radius: 999px;
  cursor: pointer;
  user-select: none;
  border: 1px solid transparent;
  transition: opacity .15s;
}
.gfp-genre-tag.mode-include {
  background: rgba(72,187,120,.18);
  color: #48bb78;
  border-color: rgba(72,187,120,.4);
}
.gfp-genre-tag.mode-exclude {
  background: rgba(245,101,101,.18);
  color: #f56565;
  border-color: rgba(245,101,101,.4);
}
.gfp-tag-rm {
  background: none;
  border: none;
  color: inherit;
  cursor: pointer;
  padding: 0;
  font-size: .85rem;
  line-height: 1;
  opacity: .7;
}
.gfp-tag-rm:hover { opacity: 1; }

.gfp-suggestions {
  position: absolute;
  top: calc(100% + 2px);
  left: 0;
  z-index: 200;
  background: var(--card-bg, #1a1f2e);
  border: 1px solid var(--border);
  border-radius: 7px;
  min-width: 160px;
  max-height: 200px;
  overflow-y: auto;
  list-style: none;
  margin: 0;
  padding: .25rem 0;
  box-shadow: 0 6px 20px rgba(0,0,0,.3);
}
.gfp-suggestions li {
  padding: .35rem .75rem;
  font-size: .83rem;
  cursor: pointer;
  color: var(--text);
}
.gfp-suggestions li:hover { background: var(--hover-bg, rgba(255,255,255,.06)); }

.gfp-chip-group {
  display: flex;
  flex-wrap: wrap;
  gap: .3rem;
}
.gfp-chip {
  background: var(--input-bg, rgba(255,255,255,.07));
  border: 1px solid var(--border);
  border-radius: 999px;
  color: var(--text-muted);
  font-size: .78rem;
  padding: .2rem .65rem;
  cursor: pointer;
  transition: background .15s, color .15s, border-color .15s;
  user-select: none;
}
.gfp-chip.active {
  background: rgba(91,141,238,.22);
  color: var(--accent, #5b8dee);
  border-color: rgba(91,141,238,.5);
  font-weight: 600;
}

.gfp-footer {
  display: flex;
  justify-content: flex-end;
  padding-top: .2rem;
  border-top: 1px solid var(--border);
  margin-top: .2rem;
}

/* ================================================================
   Mobile – results / global-filter panel
   ================================================================ */
@media (max-width: 640px) {
  /* Global filter panel inner padding tighter */
  .gfp-body {
    padding: .4rem .75rem .65rem;
    gap: .4rem;
  }

  /* Make the label a full-width top line, inputs expand below */
  .gfp-row {
    flex-wrap: wrap;
    row-gap: .25rem;
  }
  .gfp-label {
    flex-basis: 100%;
    min-width: unset;
    margin-bottom: 0;
  }

  /* Title input spans full row */
  #gfp-title {
    flex: 1 1 100%;
  }

  /* Year inputs: keep inline but a bit narrower */
  .gfp-year-input  { width: 4.8rem; }
  .gfp-score-input { width: 3.8rem; }

  /* Genre area wraps naturally */
  .gfp-genre-area {
    width: 100%;
  }

  /* Venn fills full width */
  #venn-wrap {
    max-width: 100%;
  }

  /* Charts don't need huge minimum height */
  .plotly-wrap {
    min-height: 300px;
  }

  /* Venn mode button smaller */
  .venn-mode-btn {
    font-size: .72rem;
    padding: .25rem .6rem;
  }
}
