/* ============================================
   ECOFACTOR - Controls Molecules
   Based on Figma Design System
   ============================================ */

/* ============================================
   CHECKBOX WITH TEXT (Filter Item)
   ============================================ */

.filter-checkbox {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 12px 16px;
  background-color: var(--color-white);
  border: 1px solid var(--color-gray-40);
  border-radius: 12px;
  cursor: pointer;
  transition: all var(--transition-fast);
  min-width: 200px;
}

.filter-checkbox:hover {
  border-color: var(--color-gray-30);
  background-color: var(--color-gray-95);
}

.filter-checkbox--checked {
}

.filter-checkbox__control {
  width: 21px;
  height: 21px;
  border: 1px solid var(--color-gray-30);
  border-radius: 4px;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: all var(--transition-fast);
  flex-shrink: 0;
  background-color: transparent;
}

.filter-checkbox--checked .filter-checkbox__control {
  background-color: var(--color-green-60);
  border-color: var(--color-green-60);
}

.filter-checkbox__control svg {
  width: 14px;
  height: 14px;
  opacity: 0;
}

.filter-checkbox--checked .filter-checkbox__control svg {
  opacity: 1;
}

.filter-checkbox__text {
  font-family: var(--font-primary);
  font-size: 14px;
  color: var(--color-gray-20);
  flex: 1;
}

/* ============================================
   RADIO WITH TEXT (Delivery Option)
   ============================================ */

.radio-field {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 8px 0;
  cursor: pointer;
  transition: all var(--transition-fast);
}

.radio-field:hover .radio-field__control {
  border-color: var(--color-green-50);
}

.radio-field__control {
  width: 24px;
  height: 24px;
  border: 2px solid var(--color-gray-30);
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: all var(--transition-fast);
  flex-shrink: 0;
}

.radio-field__control::after {
  content: '';
  width: 14px;
  height: 14px;
  border-radius: 50%;
  background-color: var(--color-green-60);
  transform: scale(0);
  transition: transform var(--transition-fast);
}

.radio-field--checked .radio-field__control::after {
  transform: scale(1);
}

.radio-field__text {
  font-family: var(--font-primary);
  font-size: 14px;
  color: var(--color-gray-20);
}

/* Radio on dark background */
.radio-field--dark {
  color: var(--color-white);
}

.radio-field--dark .radio-field__control {
  border-color: var(--color-gray-70);
}

.radio-field--dark .radio-field__text {
  color: var(--color-white);
}

/* ============================================
   FILTER ACCORDION
   ============================================ */

.filter-accordion {
  background-color: var(--color-white);
  border: 1px solid var(--color-gray-40);
  border-radius: 12px;
  overflow: hidden;
}

.filter-accordion__header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 16px 20px;
  background-color: transparent;
  border: none;
  cursor: pointer;
  width: 100%;
  transition: background-color var(--transition-fast);
}

.filter-accordion__header:hover {
  background-color: var(--color-gray-95);
}

.filter-accordion__title {
  font-family: var(--font-primary);
  font-size: 16px;
  font-weight: var(--font-medium);
  color: var(--color-gray-20);
}

.filter-accordion__icon {
  width: 24px;
  height: 24px;
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--color-gray-30);
  transition: transform var(--transition-fast);
}

.filter-accordion__icon svg {
  width: 12px;
  height: 12px;
}

.filter-accordion--open .filter-accordion__icon {
  transform: rotate(45deg);
}

.filter-accordion__content {
  max-height: 0;
  overflow: hidden;
  transition: max-height var(--transition-base);
}

.filter-accordion--open .filter-accordion__content {
  max-height: 500px;
}

.filter-accordion__body {
  padding: 0 20px 16px;
  display: flex;
  flex-direction: column;
  gap: 8px;
}

/* Dark theme accordion */
.filter-accordion--dark {
  background-color: var(--color-gray-20);
  border-color: var(--color-gray-30);
}

.filter-accordion--dark .filter-accordion__header:hover {
  background-color: var(--color-gray-30);
}

.filter-accordion--dark .filter-accordion__title {
  color: var(--color-white);
}

.filter-accordion--dark .filter-accordion__icon {
  color: var(--color-gray-70);
}

/* ============================================
   SELECT ALL / RESET BUTTONS
   ============================================ */

.select-actions {
  display: flex;
  align-items: center;
  gap: 16px;
  padding: 12px 0;
}

.select-action {
  display: flex;
  align-items: center;
  gap: 8px;
  font-family: var(--font-primary);
  font-size: 14px;
  color: var(--color-gray-30);
  background: transparent;
  border: none;
  cursor: pointer;
  padding: 4px 0;
  transition: color var(--transition-fast);
}

.select-action:hover {
  color: var(--color-gray-20);
}

.select-action__icon {
  width: 16px;
  height: 16px;
}

/* ============================================
   SHOW MORE / LESS
   ============================================ */

.show-more {
  display: flex;
  align-items: center;
  gap: 8px;
  font-family: var(--font-primary);
  font-size: 14px;
  color: var(--color-gray-30);
  background: transparent;
  border: none;
  cursor: pointer;
  padding: 12px 0;
  transition: color var(--transition-fast);
}

.show-more:hover {
  color: var(--color-gray-20);
}

.show-more__icon {
  width: 16px;
  height: 16px;
  display: flex;
  align-items: center;
  justify-content: center;
}

.show-more__icon svg {
  width: 12px;
  height: 12px;
}

/* ============================================
   SEARCH INPUT
   ============================================ */

.search-input {
  position: relative;
  width: 100%;
}

.search-input__field {
  width: 100%;
  height: 50px;
  padding: 0 48px 0 16px;
  font-family: var(--font-primary);
  font-size: 14px;
  color: var(--color-gray-20);
  background-color: var(--color-white);
  border: 1px solid var(--color-gray-40);
  border-radius: 12px;
  transition: all var(--transition-fast);
}

.search-input__field::placeholder {
  color: var(--color-gray-70);
}

.search-input__field:hover {
  border-color: var(--color-gray-30);
}

.search-input__field:focus {
  outline: none;
  border-color: var(--color-green-50);
  box-shadow: 0 0 0 3px rgba(61, 208, 120, 0.1);
}

.search-input__icon {
  position: absolute;
  right: 16px;
  top: 50%;
  transform: translateY(-50%);
  width: 20px;
  height: 20px;
  color: var(--color-gray-70);
  pointer-events: none;
}

.search-input__clear {
  position: absolute;
  right: 16px;
  top: 50%;
  transform: translateY(-50%);
  width: 20px;
  height: 20px;
  display: flex;
  align-items: center;
  justify-content: center;
  background: transparent;
  border: none;
  cursor: pointer;
  color: var(--color-gray-30);
  padding: 0;
}

.search-input__clear:hover {
  color: var(--color-gray-20);
}

/* Search with active state (text entered) */
.search-input--active .search-input__field {
  padding-right: 80px;
}

/* ============================================
   PRICE RANGE SLIDER
   ============================================ */

.price-slider {
  display: flex;
  flex-direction: column;
  gap: 16px;
  padding: 16px 0;
}

.price-slider__track {
  position: relative;
  height: 4px;
  background-color: var(--color-gray-40);
  border-radius: 2px;
}

.price-slider__range {
  position: absolute;
  height: 100%;
  background-color: var(--color-gray-20);
  border-radius: 2px;
}

.price-slider__thumb {
  position: absolute;
  top: 50%;
  transform: translate(-50%, -50%);
  width: 12px;
  height: 12px;
  background-color: var(--color-gray-20);
  border-radius: 50%;
  cursor: grab;
  transition: transform var(--transition-fast);
}

.price-slider__thumb:hover {
  transform: translate(-50%, -50%) scale(1.2);
}

.price-slider__thumb:active {
  cursor: grabbing;
}

.price-slider__inputs {
  display: flex;
  align-items: center;
  gap: 12px;
}

.price-slider__input {
  width: 100px;
  height: 46px;
  padding: 0 16px;
  font-family: var(--font-primary);
  font-size: 14px;
  color: var(--color-gray-20);
  background-color: var(--color-white);
  border: 1px solid var(--color-gray-40);
  border-radius: 8px;
  text-align: center;
}

.price-slider__input:focus {
  outline: none;
  border-color: var(--color-green-50);
}

.price-slider__separator {
  font-family: var(--font-primary);
  font-size: 14px;
  color: var(--color-gray-30);
}

/* ============================================
   DROPDOWN SELECT
   ============================================ */

.dropdown {
  position: relative;
  min-width: 200px;
}

.dropdown__trigger {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 8px;
  width: 100%;
  padding: 8px 16px;
  font-family: var(--font-primary);
  font-size: var(--body-size);
  font-weight: var(--font-regular);
  line-height: 1.5;
  color: var(--color-gray-20, #3a3a3a);
  background-color: var(--color-white);
  border: 2px solid var(--color-gray-95, #f1f3f5);
  border-radius: 10px;
  cursor: pointer;
  transition: all var(--transition-fast);
  height: 46px;
}

.dropdown__trigger:hover {
  background-color: var(--color-gray-95, #f1f3f5);
  border-color: var(--color-gray-95, #f1f3f5);
}

.dropdown--open .dropdown__trigger {
  background-color: var(--color-gray-95, #f1f3f5);
  border-color: var(--color-gray-95, #f1f3f5);
  border-radius: 12px 12px 0 0;
  border-bottom-color: transparent;
}

.dropdown__icon {
  width: 12px;
  height: 12px;
  color: var(--color-gray-20, #3a3a3a);
  transition: transform var(--transition-fast);
  flex-shrink: 0;
  display: flex;
  align-items: center;
  justify-content: center;
}

.dropdown__icon svg {
  width: 8px;
  height: 12px;
  transform: rotate(-90deg);
  transition: transform var(--transition-fast);
}

.dropdown--open .dropdown__icon svg {
  transform: rotate(90deg);
}

.dropdown__menu {
  position: absolute;
  top: 100%;
  left: 0;
  right: 0;
  background-color: var(--color-white);
  border: 1px solid var(--color-gray-95, #f1f3f5);
  border-top: none;
  border-radius: 0 0 8px 8px;
  max-height: 0;
  overflow: hidden;
  transition: max-height var(--transition-fast);
  z-index: var(--z-dropdown);
  box-shadow: 0px 4px 9px 0px rgba(241, 243, 245, 0.9);
}

.dropdown--open .dropdown__menu {
  max-height: 300px;
  overflow-y: auto;
}

.dropdown__item {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 8px 16px;
  height: 46px;
  font-family: var(--font-primary);
  font-size: var(--body-size);
  font-weight: var(--font-regular);
  line-height: 1.5;
  color: var(--color-gray-30, #525252);
  cursor: pointer;
  transition: background-color var(--transition-fast), color var(--transition-fast);
}

.dropdown__item:hover {
  background-color: var(--color-gray-95, #f1f3f5);
}

.dropdown__item--selected {
  color: var(--color-gray-10, #1f1f1f);
}

.dropdown__item:last-child {
  border-radius: 0 0 8px 8px;
}

/* ============================================
   INPUT CHIP (Filter tag in dropdown)
   ============================================ */

.input-chip {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 8px 16px;
  background-color: var(--color-white);
  border: 1px solid var(--color-gray-40);
  border-radius: 8px;
  font-family: var(--font-primary);
  font-size: 14px;
  color: var(--color-gray-20);
  cursor: pointer;
  transition: all var(--transition-fast);
}

.input-chip:hover {
  background-color: var(--color-gray-95);
}

.input-chip--selected {
  border-color: var(--color-green-50);
  background-color: rgba(61, 208, 120, 0.1);
}

.input-chip__icon {
  width: 12px;
  height: 12px;
  display: flex;
  align-items: center;
  justify-content: center;
}

/* ============================================
   BULLET (Large pagination dots)
   ============================================ */

.bullets {
  display: flex;
  align-items: center;
  gap: 12px;
}

.bullet {
  width: 12px;
  height: 12px;
  border-radius: 50%;
  background-color: var(--color-gray-70);
  cursor: pointer;
  transition: all var(--transition-fast);
  border: none;
  padding: 0;
}

.bullet:hover {
  background-color: var(--color-gray-30);
}

.bullet--active,
.bullet[aria-current="true"] {
  background-color: var(--color-gray-20);
}

/* ============================================
   NUMBER INPUT FIELD
   ============================================ */

.number-field {
  width: 100px;
  height: 46px;
  padding: 0 16px;
  font-family: var(--font-primary);
  font-size: 14px;
  font-weight: var(--font-medium);
  color: var(--color-gray-20);
  background-color: var(--color-white);
  border: 1px solid var(--color-gray-40);
  border-radius: 8px;
  text-align: center;
  transition: all var(--transition-fast);
}

.number-field:hover {
  border-color: var(--color-gray-30);
}

.number-field:focus {
  outline: none;
  border-color: var(--color-green-50);
  box-shadow: 0 0 0 3px rgba(61, 208, 120, 0.1);
}

.number-field::placeholder {
  color: var(--color-gray-70);
}

/* ============================================
   PRICE FILTER COLLAPSIBLE
   ============================================ */

.price-filter {
  background-color: var(--color-white);
  border: 1px solid var(--color-gray-40);
  border-radius: 12px;
}

.price-filter__header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 16px 20px;
  cursor: pointer;
}

.price-filter__title {
  font-family: var(--font-primary);
  font-size: 16px;
  font-weight: var(--font-medium);
  color: var(--color-gray-20);
}

.price-filter__icon {
  width: 24px;
  height: 24px;
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--color-gray-30);
  transition: transform var(--transition-fast);
}

.price-filter--open .price-filter__icon {
  transform: rotate(45deg);
}

.price-filter__content {
  max-height: 0;
  overflow: hidden;
  transition: max-height var(--transition-base);
}

.price-filter--open .price-filter__content {
  max-height: 200px;
}

.price-filter__body {
  padding: 0 20px 20px;
}








