/* ============================================
   MOBILE FILTERS & MODALS
   Стили для фильтров и модальных окон
   ============================================ */

/* === Selection Styles === */

/* Spinner on filter arrow while loading */
.filter-arrow-loading {
  display: inline-block !important;
  width: 14px !important;
  height: 14px !important;
  border: 2px solid rgba(127, 145, 164, 0.3);
  border-top-color: #7f91a4;
  border-radius: 50%;
  animation: filterArrowSpin 0.6s linear infinite;
}
.filter-arrow-loading svg,
.filter-arrow-loading path {
  display: none !important;
}
@keyframes filterArrowSpin {
  from { transform: rotate(0deg); }
  to { transform: rotate(360deg); }
}

.brand-item {
  padding: 12px 10px;
  margin: 0;
  border-radius: 8px;
}

.list-active {
  background-color: #fffbeb !important;
  border: none !important;
  border-radius: 8px !important;
  font-weight: 500 !important;
  color: #0f172a !important;
}

/* Brand name text color */
.brand-name-text {
  color: #7f91a4;
}

[data-theme="dark"] .list-active,
html.dark .list-active {
  background-color: #17212B !important;
  border: none !important;
  box-shadow: none !important;
  color: #ffffff !important;
}

html.dark .list-active .brand-name-text {
  color: #ffffff !important;
}

html.dark .list-active .dd-count-mobile {
  background: #283341 !important;
  color: #cbd5e1 !important;
  border: none !important;
  box-shadow: none !important;
}

/* Count badges (desktop style) */
.dd-count-mobile {
  color: #7f91a4;
  font-size: 10px;
  font-weight: 700;
  background: #283341;
  padding: 2px 6px;
  border-radius: 4px;
  font-family: var(--font-family);
  border: none;
  box-shadow: none;
  flex-shrink: 0;
  display: inline-flex;
  align-items: center;
  justify-content: center;
}

.chip-active {
  background-color: var(--color-primary) !important;
  color: #000000 !important;
  border-color: var(--color-primary) !important;
  font-weight: var(--font-weight-extrabold) !important;
}

.selection-edge {
  background-color: var(--color-primary) !important;
  color: #000000 !important;
  border-color: var(--color-primary) !important;
  font-weight: var(--font-weight-extrabold) !important;
  transform: scale(1.05);
}

.selection-middle {
  background-color: #fef3c7 !important;
  color: #000000 !important;
  border-color: #fcd34d !important;
}

[data-theme="dark"] .selection-middle,
html.dark .selection-middle {
  background-color: rgba(255, 185, 0, 0.2) !important;
  color: #fbbf24 !important;
}

.multi-active {
  background-color: #fffbeb !important;
  border: 1px solid var(--color-primary) !important;
  color: #000000 !important;
  font-weight: var(--font-weight-bold) !important;
}

[data-theme="dark"] .multi-active,
html.dark .multi-active {
  background-color: rgba(255, 185, 0, 0.15) !important;
  border-color: var(--color-primary) !important;
  color: #ffffff !important;
}

/* === Full Screen Filter Modal === */
#full-screen-filter {
  transition: transform 0.4s cubic-bezier(0.32, 0.72, 0, 1);
}

/* === Toggle Switch === */
.toggle-checkbox:checked {
  right: 0;
  border-color: #172554;
}

/* === Modal Max Heights === */
.modal-nested-card {
  max-height: 85vh;
}

.modal-sort-card {
  max-height: 90vh;
}

.toggle-checkbox:checked + .toggle-label {
  background-color: #172554;
}

/* === Drum/Wheel Year Picker === */
.drum-picker-container {
  display: flex;
  align-items: stretch;
  gap: 0;
  justify-content: center;
  padding: 0 20px;
}

.drum-picker-column {
  flex: 0 0 125px;
  display: flex;
  flex-direction: column;
  align-items: center;
}

.drum-picker-wrapper {
  position: relative;
  width: 100%;
  height: 150px; /* 3 items * 50px */
  overflow: hidden;
}

.drum-picker-scroll {
  position: relative;
  z-index: 2;
  width: 100%;
  height: 100%;
  overflow-y: auto;
  -webkit-overflow-scrolling: touch;
  scrollbar-width: none;
}

.drum-picker-scroll::-webkit-scrollbar {
  display: none;
}

.drum-picker-item {
  height: 50px;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 18px;
  font-weight: 400;
  color: rgba(127, 145, 164, 0.3);
  transition: color 0.15s, font-weight 0.15s;
  cursor: pointer;
  user-select: none;
  -webkit-user-select: none;
  flex-shrink: 0;
}

.drum-picker-item.drum-active {
  color: #ffffff;
  font-weight: 700;
  font-size: 22px;
}

.drum-picker-item.drum-near {
  color: rgba(127, 145, 164, 0.4);
  font-size: 17px;
}

/* Center highlight band — always filled */
.drum-picker-highlight {
  position: absolute;
  top: 50%;
  left: 0;
  right: 0;
  height: 50px;
  transform: translateY(-50%);
  background: #283341;
  border: none;
  border-radius: 12px;
  pointer-events: none;
  z-index: 1;
}

/* Gradient masks for fade effect */
.drum-picker-mask-top,
.drum-picker-mask-bottom {
  position: absolute;
  left: 0;
  right: 0;
  height: 50px;
  pointer-events: none;
  z-index: 3;
}

.drum-picker-mask-top {
  top: 0;
  background: linear-gradient(to bottom, #242F3D 0%, transparent 100%);
}

.drum-picker-mask-bottom {
  bottom: 0;
  background: linear-gradient(to top, #242F3D 0%, transparent 100%);
}

/* Spacers for scroll padding — top spacer = center offset so first items start BELOW center */
.drum-picker-spacer-top {
  height: 100px; /* wrapper=150, center=75, first item center=125 — dist=50 > threshold 35 */
  flex-shrink: 0;
}

.drum-picker-spacer-bottom {
  height: 50px;
  flex-shrink: 0;
}

/* Separator between columns */
.drum-picker-separator {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 40px;
  flex-shrink: 0;
  color: #7f91a4;
  font-size: 20px;
  font-weight: 500;
}

/* === Filter interaction styles === */

html.dark #filter-box {
    background: #242F3D !important;
    border-radius: 12px !important;
    box-shadow: 0 1px 4px 0px rgba(0, 0, 0, 0.12), 0 0px 1px rgba(0, 0, 0, 0.08);
}

.filter-cell {
    box-shadow: 0 1px 4px 0px rgba(0, 0, 0, 0.12), 0 0px 1px rgba(0, 0, 0, 0.08);
    transition: transform 0.12s cubic-bezier(.2,.6,.35,1), box-shadow 0.15s ease;
}
.filter-cell:active {
    transform: scale(0.98);
    box-shadow: 0 0 2px rgba(0, 0, 0, 0.1);
}

.show-btn {
    transition: transform 0.12s cubic-bezier(.2,.6,.35,1), box-shadow 0.15s ease;
    box-shadow: 0 1px 4px 0px rgba(0, 0, 0, 0.12);
}
.show-btn:active {
    transform: scale(0.98);
    box-shadow: 0 0 2px rgba(0, 0, 0, 0.1);
}

#full-screen-filter button {
    transition: transform 0.12s cubic-bezier(.2,.6,.35,1);
}
#full-screen-filter button:active {
    transform: scale(0.97);
}

.filter-arrow {
    transition: transform 0.3s ease;
}
.filter-arrow.is-open {
    transform: rotate(90deg);
}

.filter-cell img:first-child {
    display: none;
}

.filter-arrow {
    filter: none !important;
}
