/**
 * Mobile/tablet styles (max-width: 1023px)
 * Оптимизации производительности: упрощение анимаций.
 */

@media (max-width: 1023px) {
  .sort-icon-part-filled,
  .sort-icon-part-filled * {
    fill: currentColor !important;
    stroke: none !important;
  }

  .placeholder-svg {
    transform: scale(1.2);
    transform-origin: center;
  }
  .placeholder-dbset-svg {
    transform: scale(3);
    transform-origin: center;
  }

  .safe-area-bottom {
    padding-bottom: env(safe-area-inset-bottom, 0);
  }

  /* Отступ снизу под остров нижней панели (кнопки 44px + отступы ~14px×2) */
  .pb-safe {
    padding-bottom: calc(72px + env(safe-area-inset-bottom, 0));
  }

  .app-main-catalog {
    min-width: 0;
    -webkit-overflow-scrolling: touch;
    overflow-anchor: none;
  }

  /* Карточки и грид должны сжиматься под ширину экрана */
  .app-main-catalog .card-outer,
  .app-main-catalog > div[class*="grid"] > * {
    min-width: 0;
  }

  /* Количество карточек подстраивается под ширину, минимальный размер 120px.
     Отступ снизу у сетки — чтобы последние карточки не перекрывались нижней панелью. */
  .app-main-catalog .catalog-grid-sets,
  .app-main-catalog .catalog-grid-minifigs,
  .app-main-catalog .catalog-grid-parts,
  .modal-content .catalog-grid-sets,
  .modal-content .catalog-grid-minifigs,
  .modal-content .catalog-grid-parts {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(160px, 1fr));
    gap: 0.75rem;
    min-width: 0;
    padding-bottom: calc(72px + env(safe-area-inset-bottom, 0));
  }
  .modal-content .catalog-grid-sets > *,
  .modal-content .catalog-grid-minifigs > *,
  .modal-content .catalog-grid-parts > * {
    min-width: 0;
  }

  /* В модалке детали и минфигурки — одинаковый грид (минимум 3 в строке) */
  .modal-content .catalog-grid-parts:not(.catalog-additions-fluid),
  .modal-content .catalog-grid-minifigs:not(.catalog-additions-fluid) {
    grid-template-columns: repeat(auto-fill, minmax(100px, 1fr));
  }

  /* Модалка новинок: без лишнего отступа снизу под нижнюю панель каталога */
  .modal-content .catalog-grid-sets.catalog-additions-fluid,
  .modal-content .catalog-grid-minifigs.catalog-additions-fluid,
  .modal-content .catalog-grid-parts.catalog-additions-fluid {
    padding-bottom: 1rem !important;
  }

  .app-main-catalog .card-info-container .truncate,
  .app-main-catalog .card-info-container .card-title,
  .modal-content .card-info-container .truncate,
  .modal-content .card-info-container .card-title {
    max-width: 100%;
  }

  #root > div,
  #root > div > div.flex-1 {
    min-height: 100dvh;
  }

  .app-main:not(.app-main-catalog) {
    padding-bottom: max(6rem, calc(64px + env(safe-area-inset-bottom, 0)));
  }

  /* Нижняя панель — контрастный остров, сильные скругления */
  .bottom-bar {
    background: var(--color-bg-bottom-bar, rgb(30 41 59)) !important;
    border: 1px solid var(--color-border-bottom-bar, rgba(71, 85, 105, 0.8));
    box-shadow: var(--shadow-bottom-bar, 0 8px 32px rgba(0, 0, 0, 0.5), 0 0 0 1px rgba(100, 116, 139, 0.3));
  }
  /* Вариант со стеклом — цвет #1e293b с прозрачностью и размытием как у навбара */
  .bottom-bar.bottom-bar-glass {
    background-color: rgba(30, 41, 59, 0.95) !important;
    border-color: rgba(71, 85, 105, 0.8);
    backdrop-filter: blur(30px);
    -webkit-backdrop-filter: blur(30px);
  }

  /* Modal: full screen on mobile */
  .modal-content {
    border-radius: 20px 20px 0 0 !important;
    max-height: 95dvh !important;
    margin-top: auto !important;
  }
  /* Модалки набора/минифига и детали — одинаковая минимальная высота */
  [data-set-modal] .modal-content,
  [data-part-modal] .modal-content {
    min-height: 95dvh;
  }

  /* Высота модалки подстраивается под контент, не превышая экран */
  .account-modal-avatar-layout {
    height: fit-content !important;
    min-height: 0;
    max-height: 95dvh !important;
  }

  /* Горизонтальный скролл, 2 ряда, аватарки в 1.5 раза больше; блок прижат к низу */
  #avatar-modal-grid.avatar-options-scroll {
    margin-top: auto;
    height: auto;
    min-height: calc(2 * 6.375rem + 12px);
    overflow-x: auto;
    overflow-y: hidden;
    overscroll-behavior-x: contain;
  }

  #avatar-modal-grid .avatar-options-grid.avatar-options-grid-horizontal {
    display: grid;
    grid-template-rows: repeat(2, 6.375rem);
    grid-auto-flow: column;
    grid-auto-columns: 6.375rem;
    gap: 12px;
    padding: 8px 12px;
    border-bottom-right-radius: 0;
    justify-items: center;
    align-content: start;
    width: max-content;
  }

  #avatar-modal-grid .avatar-options-grid.avatar-options-grid-horizontal > [data-action="account-select-avatar-save"] {
    width: 6.375rem;
    height: 6.375rem;
    min-height: 0 !important;
  }

  /* Один ряд аватарок при нехватке высоты (класс выставляется из JS) */
  .account-modal-avatar-layout.avatar-grid-single-row #avatar-modal-grid.avatar-options-scroll {
    min-height: calc(1 * 6.375rem + 12px);
  }
  .account-modal-avatar-layout.avatar-grid-single-row .avatar-options-grid.avatar-options-grid-horizontal {
    grid-template-rows: repeat(1, 6.375rem);
  }

  /* Упрощённая карточка при нажатии — меньше тени */
  .card-hover:active {
    box-shadow: var(--shadow-card-active, 0 0 0 1px rgba(59, 130, 246, 0.2));
  }
  .card-outer:active {
    box-shadow: 0 4px 8px rgba(0, 0, 0, 0.15);
  }

  .card-select-pin {
    border: 1px solid rgba(148, 163, 184, 0.45);
    background: rgba(15, 23, 42, 0.72);
    color: rgba(203, 213, 225, 0.95);
    backdrop-filter: blur(6px);
    transition: all 0.2s ease;
  }
  .card-select-pin.is-selected {
    border-color: rgba(59, 130, 246, 0.85);
    background: rgba(37, 99, 235, 0.85);
    color: #ffffff;
    box-shadow: 0 0 0 2px rgba(59, 130, 246, 0.25);
  }
  .card-outer.is-card-selected {
    box-shadow: 0 0 0 2px rgba(59, 130, 246, 0.65), 0 14px 24px rgba(15, 23, 42, 0.28);
  }

  /* Better touch targets */
  button, a, [role="button"] {
    min-height: 40px;
  }

  button.card-select-pin,
  .card-select-pin {
    width: 28px !important;
    height: 28px !important;
    min-width: 28px !important;
    min-height: 28px !important;
    max-width: 28px !important;
    max-height: 28px !important;
    border-radius: 9999px !important;
    padding: 0 !important;
  }

  /* Пины в шапке модалок — компактная высота, без увеличения под touch */
  .modal-pin,
  .modal-pin[role="button"] {
    min-height: 0 !important;
    height: 20px !important;
  }

  /* Модалка детали: панель цветов — компактнее на узких экранах */
  [data-part-modal] .part-modal-colors-grid {
    grid-template-columns: repeat(auto-fill, minmax(3.5rem, 1fr));
  }

  /* Двойной range-слайдер фильтров: фирменный тёмный стиль и корректный drag обеих ручек */
  .dual-range .dual-range-input {
    -webkit-appearance: none;
    appearance: none;
    background: transparent;
    pointer-events: none;
    cursor: default;
  }
  .dual-range .dual-range-input::-webkit-slider-runnable-track {
    height: 6px;
    background: transparent;
    border: 0;
  }
  /* Ручка: большая невидимая зона хвата (прозрачный край), видимый круг как раньше */
  .dual-range .dual-range-input::-webkit-slider-thumb {
    -webkit-appearance: none;
    appearance: none;
    width: 32px;
    height: 32px;
    margin-top: -13px;
    border-radius: 9999px;
    border: none;
    background: radial-gradient(
      circle at 50% 50%,
      rgb(59, 130, 246) 0 6px,
      rgba(30, 41, 59, 0.95) 6px 7.5px,
      transparent 7.5px
    );
    box-shadow: none;
    filter: drop-shadow(0 0 2px rgba(59, 130, 246, 0.35));
    pointer-events: auto;
    cursor: pointer;
  }
  .dual-range .dual-range-input::-moz-range-track {
    height: 6px;
    background: transparent;
    border: 0;
  }
  .dual-range .dual-range-input::-moz-range-thumb {
    width: 32px;
    height: 32px;
    border-radius: 9999px;
    border: none;
    background: radial-gradient(
      circle at 50% 50%,
      rgb(59, 130, 246) 0 6px,
      rgba(30, 41, 59, 0.95) 6px 7.5px,
      transparent 7.5px
    );
    box-shadow: none;
    filter: drop-shadow(0 0 2px rgba(59, 130, 246, 0.35));
    pointer-events: auto;
    cursor: pointer;
  }
  .dual-range .dual-range-track-wrap {
    /* половина ширины ::-webkit-slider-thumb (32px) — совпадает с траекторией центра ручки */
    --range-pad: 16px;
    --range-from: 0;
    --range-to: 1;
  }
  /* Шире трек + inputs: отрицательный margin внутри padding родителя — ручки остаются на линии шкалы */
  .dual-range .dual-range-track-wrap.dual-range-track-bleed-sheet {
    margin-left: -0.5rem;
    margin-right: -0.5rem;
    width: calc(100% + 1rem);
  }
  .dual-range .dual-range-track-wrap.dual-range-track-bleed-sidebar {
    margin-left: -0.75rem;
    margin-right: -0.75rem;
    width: calc(100% + 1.5rem);
  }
  .dual-range .dual-range-track-wrap::before,
  .dual-range .dual-range-track-wrap::after {
    content: "";
    position: absolute;
    top: 50%;
    transform: translateY(-50%);
    height: 6px;
    border-radius: 9999px;
    pointer-events: none;
  }
  /* Трек по той же ширине, по которой двигается центр ручки — края совпадают с min/max */
  .dual-range .dual-range-track-wrap::before {
    left: var(--range-pad);
    right: var(--range-pad);
    background: rgba(55, 65, 81, 0.9);
    box-shadow: inset 0 0 0 1px rgba(100, 116, 139, 0.25);
  }
  .dual-range .dual-range-track-wrap::after {
    left: calc(var(--range-pad) + var(--range-from) * (100% - 2 * var(--range-pad)));
    right: calc(100% - var(--range-pad) - var(--range-to) * (100% - 2 * var(--range-pad)));
    background: rgb(59, 130, 246);
  }
  .dual-range .dual-range-track-wrap-manual::before,
  .dual-range .dual-range-track-wrap-manual::after {
    display: none;
  }
  .dual-range .dual-range-input-min { z-index: 3; }
  .dual-range .dual-range-input-max { z-index: 4; }
}
