/* ===================================================
   CUSTOM DROPDOWN FILTERS - Rosa tema design
   =================================================== */

/* Färgvariabler - Rosa tema */
:root {
  --filter-rose-50: #fef2f2;
  --filter-rose-100: #fce7f3;
  --filter-rose-200: #fda4af;
  --filter-rose-300: #fda4af;
  --filter-rose-500: #f43f5e;
  --filter-rose-600: #e11d48;
  --filter-rose-700: #be123c;
  --filter-rose-800: #9f1239;
  --filter-stone-300: #d6d3d1;
  --filter-stone-500: #78716c;
  --filter-gray-50: #f9fafb;
  --filter-gray-200: #e5e7eb;
  --filter-gray-400: #9ca3af;
  --filter-gray-700: #374151;
  --filter-gray-800: #1f2937;
}

/* Container */
.jfilters {
  width: 100%;
  max-width: 100%;
  padding: 0;
  box-sizing: border-box;
}

.jfilters * {
  box-sizing: border-box;
}

/* Filter row - flex layout */
.jfilters__row {
  display: flex;
  flex-wrap: wrap;
  align-items: flex-start;
  gap: 8px;
  margin-bottom: 16px;
}

.jfilters--sidebar {
  margin-bottom: 16px;
  padding: 0 0 10px;
}

.jfilters--sidebar .jfilters__row {
  flex-direction: column;
  gap: 10px;
  margin-bottom: 10px;
}

.jfilters--sidebar .jfilters__field {
  width: 100%;
}

.jfilters--sidebar .jfilters__dropdown-menu {
  z-index: 30;
}

.jfilters__actions {
  display: flex;
  gap: 8px;
  width: 100%;
}

.jfilters__actions .jfilters__save,
.jfilters__actions .jfilters__clear {
  flex: 1;
}

/* Individual filter field container */
.jfilters__field {
  position: relative;
  width: 100%;
  flex-shrink: 0;
}

/* Dropdown button */
.jfilters__dropdown-btn {
  display: inline-flex;
  justify-content: space-between;
  align-items: center;
  width: 100%;
  background: white;
  border-radius: 4px;
  padding: 6px 8px;
  font-size: 14px;
  line-height: 1.4;
  color: var(--filter-stone-500);
  background-color: var(--filter-gray-50);
  border: 1px solid var(--filter-stone-300);
  cursor: pointer;
  appearance: none;
  outline: none;
  transition: all 0.15s ease;
}

.jfilters__dropdown-btn:focus {
  outline: none;
  border-color: var(--filter-rose-500);
  box-shadow: 0 0 0 2px var(--filter-rose-100);
}

.jfilters__dropdown-btn:hover {
  border-color: var(--filter-stone-300);
}

/* Button text (truncate long text) */
.jfilters__dropdown-label {
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
  margin: 0 6px;
  flex-grow: 1;
  text-align: left;
}

/* Chevron icon */
.jfilters__dropdown-icon {
  width: 16px;
  height: 16px;
  flex-shrink: 0;
  color: currentColor;
}

/* Dropdown menu (hidden by default) */
.jfilters__dropdown-menu {
  position: absolute;
  z-index: 10;
  min-width: 100%;
  width: max-content;
  max-width: 350px;
  margin-top: 4px;
  border-radius: 4px;
  background: white;
  box-shadow: 0 0 0 2px var(--filter-rose-100);
  border: 1px solid var(--filter-rose-500);
  display: none;
}

.jfilters__dropdown-menu.is-open {
  display: block;
}

/* Search input container */
.jfilters__search-wrapper {
  position: relative;
}

.jfilters__search-input {
  display: block;
  width: 100%;
  padding: 6px 32px 6px 12px;
  font-size: 14px;
  color: var(--filter-gray-800);
  border: none;
  border-bottom: 1px solid var(--filter-gray-200);
  border-radius: 4px 4px 0 0;
  outline: none;
}

.jfilters__search-input:focus {
  outline: none;
}

/* Clear search button */
.jfilters__search-clear {
  position: absolute;
  top: 0;
  right: 8px;
  bottom: 0;
  display: none;
  align-items: center;
  padding: 0 8px;
  background: none;
  border: none;
  cursor: pointer;
  color: var(--filter-gray-400);
}

.jfilters__search-clear:hover {
  color: var(--filter-rose-600);
}

.jfilters__search-clear.is-visible {
  display: flex;
}

.jfilters__search-clear svg {
  width: 16px;
  height: 16px;
}

/* Dropdown items list - vertical scroll if needed */
.jfilters__dropdown-list {
  max-height: 300px;
  overflow-y: auto;
  overflow-x: hidden;
  border-radius: 0 0 4px 4px;
}

/* Custom scrollbar */
.jfilters__dropdown-list::-webkit-scrollbar {
  width: 6px;
}

.jfilters__dropdown-list::-webkit-scrollbar-track {
  background: var(--filter-rose-50);
}

.jfilters__dropdown-list::-webkit-scrollbar-thumb {
  background: var(--filter-rose-300);
  border-radius: 3px;
}

/* Dropdown item */
.jfilters__dropdown-item {
  display: block;
  padding: 8px 12px;
  font-size: 14px;
  color: var(--filter-gray-700);
  cursor: pointer;
  background: white;
  border: none;
  width: 100%;
  text-align: left;
  transition: background-color 0.15s ease;
}

.jfilters__dropdown-item:hover {
  background-color: var(--filter-rose-100);
  color: var(--filter-rose-600);
}

.jfilters__dropdown-item.is-selected {
  background-color: var(--filter-rose-100);
}

/* Checkbox inside item */
.jfilters__item-content {
  display: flex;
  align-items: flex-start;
  gap: 8px;
}

.jfilters__checkbox {
  width: 14px;
  height: 14px;
  border: 1px solid var(--filter-gray-400);
  border-radius: 3px;
  flex-shrink: 0;
  cursor: pointer;
  margin-top: 1px;
}

.jfilters__item-label {
  flex-grow: 1;
  font-size: 14px;
  line-height: 1.4;
  white-space: nowrap;
}

/* Meta section - only contains tags, no border */
.jfilters__meta {
  display: none;
}

/* Clear all filters button - inline with filters */
.jfilters__clear {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  color: #b42318;
  text-decoration: none;
  font-size: 14px;
  line-height: 1.4;
  font-weight: 500;
  padding: 6px 14px;
  min-height: 34px;
  border-radius: 4px;
  border: 1px solid #fda29b;
  background-color: #fef3f2;
  transition: all 0.15s ease;
  white-space: nowrap;
  height: fit-content;
}

.jfilters__save {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  color: #166534;
  text-decoration: none;
  font-size: 14px;
  line-height: 1.4;
  font-weight: 500;
  padding: 6px 14px;
  min-height: 34px;
  border-radius: 4px;
  border: 1px solid #86efac;
  background-color: #dcfce7;
  transition: all 0.15s ease;
  white-space: nowrap;
  height: fit-content;
  cursor: pointer;
}

.jfilters__save:hover {
  background-color: #bbf7d0;
  border-color: #4ade80;
}

.jfilters__clear:hover {
  background-color: #fee4e2;
  border-color: #f97066;
}

/* Hidden inputs for form submission */
.jfilters__hidden {
  display: none;
}

/* Responsive: desktop - fixed widths */
@media (min-width: 768px) {
  .jfilters__field {
    width: 118px;
  }
}

/* Mobile: stack vertically */
@media (max-width: 767px) {
  .jfilters__field {
    width: 100%;
  }
  
  .jfilters__dropdown-btn {
    width: 100%;
  }

  .jfilters--sidebar .jfilters__dropdown-menu--wide {
    min-width: 100%;
    max-width: calc(100vw - 32px);
  }

  .jfilters--sidebar .location-filter,
  .jfilters--sidebar .occupation-filter {
    max-width: 100%;
  }
}

@media (max-width: 1024px) {
  .jfilters--sidebar .jfilters__dropdown-menu--wide {
    min-width: 320px;
    max-width: min(92vw, 560px);
  }
}
