/**
 * Адаптивные стили для умного поиска mod_smartfinder
 * Подключается после smart-search.css
 */

/* Фикс для iOS: предотвращаем зум при фокусе на input (минимум 16px) */
@supports (-webkit-touch-callout: none) {
  .mod-smartfinder-input-wrap .form-control {
    font-size: 16px;
  }
  
  .mod-smartfinder-input-wrap {
    position: relative;
  }
}

/* 
 * Scroll margin для input — учитывается scrollIntoView() 
 * CSS Custom Property позволяет JS установить реальную высоту header
 */
.mod-smartfinder-input-wrap .form-control {
  scroll-margin-top: var(--smartfinder-header-height, 120px);
}

/* 
 * scroll-padding на html для scrollIntoView с block: 'nearest'
 * Будет установлено через JS при определении высоты header
 */
html.smartfinder-ios-keyboard-open {
  scroll-padding-top: var(--smartfinder-header-height, 120px);
}

/* --- Планшеты (≤768px) --- */
@media (max-width: 768px) {
  .mod-smartfinder-search {
    padding: 12px 0;
  }

  .mod-smartfinder-search-icon {
    width: 44px;
    min-width: 44px;
    height: 44px;
  }

  .mod-smartfinder-search-icon .icon-search,
  .mod-smartfinder-search-icon .mod-smartfinder-search-icon-svg {
    font-size: 18px;
  }

  .mod-smartfinder-search-icon .mod-smartfinder-search-icon-svg {
    width: 18px;
    height: 18px;
  }

  .mod-smartfinder-input-wrap .form-control {
    font-size: 16px;
    min-height: 42px;
    padding: 8px 10px;
    max-width: 100%;
  }

  .mod-smartfinder-search-btn {
    min-height: 42px;
    min-width: 44px;
    padding: 0 12px;
    font-size: 14px;
    flex-shrink: 0;
  }

  .mod-finder-smart-results {
    max-height: min(80vh, 400px);
    -webkit-overflow-scrolling: touch;
    font-size: 15px;
  }

  .mod-finder-result-item {
    padding: 10px 16px;
    min-height: 48px;
  }

  .mod-finder-result-title {
    font-size: 16px;
    line-height: 1.4;
  }

  .mod-finder-result-intro {
    display: none;
  }

  .mod-finder-result-category {
    font-size: 13px;
  }

  .mod-finder-section-title {
    padding: 8px 16px;
    font-size: 12px;
  }

  .mod-finder-show-all {
    padding: 10px 16px;
  }

  .mod-finder-show-all a {
    font-size: 15px;
    padding: 8px 0;
    min-height: 44px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
  }

  .mod-finder-popular-item {
    padding: 10px 16px;
    min-height: 44px;
  }

  .mod-finder-popular-text {
    font-size: 15px;
  }

  .mod-finder-result-title {
    flex-wrap: nowrap;
    gap: 8px;
  }

  .mod-finder-result-price {
    font-size: 12px;
    flex-shrink: 0;
    flex-direction: row;
    align-items: baseline;
    gap: 6px;
    white-space: nowrap;
  }

  .mod-finder-result-specialties {
    margin-left: 6px;
    gap: 3px 4px;
  }

  .mod-finder-result-specialty {
    font-size: 10px;
    padding: 1px 5px;
  }
}

/* --- Телефоны (≤576px) --- */
@media (max-width: 576px) {
  .mod-smartfinder-search {
    padding: 10px 0;
  }

  .mod-smartfinder-search-icon {
    width: 40px;
    min-width: 40px;
    height: 40px;
  }

  .mod-smartfinder-search-icon .icon-search,
  .mod-smartfinder-search-icon .mod-smartfinder-search-icon-svg {
    font-size: 16px;
  }

  .mod-smartfinder-search-icon .mod-smartfinder-search-icon-svg {
    width: 16px;
    height: 16px;
  }

  /* iOS зум при фокусе, если font-size < 16px — не снижаем */
  .mod-smartfinder-input-wrap .form-control {
    font-size: 16px;
    line-height: 1;
    min-height: 40px;
    padding: 8px 10px;
    max-width: 100%;
  }

  .mod-smartfinder-search-btn {
    min-height: 40px;
    min-width: 40px;
    font-size: 13px;
    padding: 0 10px;
    flex-shrink: 0;
  }

  .mod-finder-smart-results {
    max-height: min(75vh, 380px);
    left: 0;
    right: 0;
    border-radius: 0 0 6px 6px;
  }

  .mod-finder-result-item {
    margin: 2px 12px;
    padding: 8px 12px;
    min-height: 44px;
  }

  .mod-finder-section-title {
    padding: 8px 12px;
    font-size: 12px;
  }

  .mod-finder-popular-item,
  .mod-finder-show-all {
    padding: 10px 12px;
  }

  .mod-finder-show-all a {
    min-height: 40px;
    padding: 6px 0;
  }

  .mod-finder-result-specialties {
    margin-left: 4px;
    gap: 2px 4px;
  }

  .mod-finder-result-specialty {
    font-size: 10px;
    padding: 1px 4px;
  }
}

/* --- Узкие телефоны (≤480px) --- */
@media (max-width: 480px) {
  .mod-smartfinder-search {
    padding: 8px 0;
  }

  .mod-smartfinder-search-icon {
    width: 38px;
    min-width: 38px;
    height: 38px;
  }

  .mod-smartfinder-search-icon .icon-search,
  .mod-smartfinder-search-icon .mod-smartfinder-search-icon-svg {
    font-size: 15px;
  }

  .mod-smartfinder-search-icon .mod-smartfinder-search-icon-svg {
    width: 15px;
    height: 15px;
  }

  /* iOS зум при фокусе — минимум 16px */
  .mod-smartfinder-input-wrap .form-control {
    line-height: 1;
    min-height: 38px;
    font-size: 16px;
    padding: 6px 8px;
    max-width: 100%;
  }

  .mod-smartfinder-search-btn {
    min-height: 38px;
    min-width: 38px;
    font-size: 12px;
    padding: 0 8px;
  }

  .mod-finder-result-title {
    font-size: 12px;
    flex-wrap: wrap;
    gap: 6px;
  }

  .mod-finder-result-title-text {
    display: block;
    -webkit-line-clamp: unset;
    -webkit-box-orient: unset;
    overflow: visible;
  }

  .mod-finder-result-price {
    flex-shrink: 0;
    font-size: 11px;
    margin-left: auto;
  }

  .mod-finder-result-specialties {
    flex-shrink: 0;
    margin-left: 4px;
  }
}
