/* UI extras: filters visibility, sticky, scroll-to-top, mini-sidebar */

.filters-card { display: none; }
.filters-visible {
  display: block !important;
  opacity: 1;
  transform: translateY(0);
}

/* Higher specificity rule for the filters card to ensure visibility */
#filters-card.filters-visible {
  display: block !important;
}

.filters-sticky {
  position: sticky;
  top: 0;
  z-index: 1020;
  background: var(--filters-bg, #fff);
}

.filters-compact input,
.filters-compact select,
.filters-compact .form-control {
  padding: 0.25rem 0.5rem;
  font-size: 0.875rem;
}

.scroll-to-top-btn {
  position: fixed;
  right: 1rem;
  bottom: 1.25rem;
  width: 44px;
  height: 44px;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  background: rgba(0,0,0,0.6);
  color: white;
  opacity: 0;
  visibility: hidden;
  transition: opacity .2s, transform .2s;
}
.scroll-to-top-btn.visible {
  opacity: 1;
  visibility: visible;
  transform: translateY(0);
}

.mini-sidebar {
  position: fixed;
  left: 1rem;
  top: 50%;
  transform: translateY(-50%);
  background: rgba(255,255,255,0.95);
  border-radius: 8px;
  box-shadow: 0 6px 18px rgba(0,0,0,0.08);
  padding: 0.5rem;
  opacity: 0;
  visibility: hidden;
  transition: opacity .2s, transform .2s;
  z-index: 1050;
}
.mini-sidebar.visible {
  opacity: 1;
  visibility: visible;
}

.filter-drawer {
  position: fixed;
  right: 0;
  top: 0;
  height: 100vh;
  width: 360px;
  max-width: 100%;
  background: var(--filters-bg, #fff);
  box-shadow: -8px 0 24px rgba(0,0,0,0.12);
  transform: translateX(100%);
  transition: transform .28s ease;
  z-index: 1100;
  display: flex;
  flex-direction: column;
}
.filter-drawer.visible { transform: translateX(0); }
.filter-drawer .filter-drawer-body { padding: 1rem; overflow:auto; }
.filter-drawer .filter-drawer-footer { border-top: 1px solid rgba(0,0,0,0.04); }

/* body lock when drawer open */
.drawer-open { overflow: hidden; }

/* Autocomplete / overlay z-index helper */
.ui-overlay-high { z-index: 1200 !important; }
