/**
 * mobile-fixes.css — глобальные исправления горизонтального скролла и обрезов
 * Применяется ко всем страницам новых категорий и SEO-лендингам.
 */

* { box-sizing: border-box !important; }

html, body {
  margin: 0;
  padding: 0;
  max-width: 100vw;
  overflow-x: hidden;
}

/* Login-боксы — адаптируем под узкие экраны */
@media (max-width: 600px) {
  body { padding: 12px !important; align-items: flex-start !important; padding-top: 60px !important; }
  .box {
    max-width: 100% !important;
    width: 100% !important;
    padding: 22px 16px !important;
    margin: 0 !important;
  }
  .box h1 {
    font-size: 1.1rem !important;
    word-break: break-word;
    line-height: 1.3;
  }
  .box .sub { font-size: .82rem !important; }
}

/* Register-формы — формы во всю ширину */
@media (max-width: 768px) {
  .form-wrapper {
    padding: 0 14px !important;
    max-width: 100vw !important;
  }
  .form-wrapper h1,
  h1[style*="1.8rem"] {
    font-size: 1.3rem !important;
    word-break: break-word;
    line-height: 1.25 !important;
  }
  .form-wrapper p {
    font-size: .9rem;
  }

  .form-group label {
    word-wrap: break-word;
    font-size: .82rem !important;
  }

  /* Все блоки внутри register - не должны вылезать */
  .medical-block, .pet-block, .home-block, .ed-block, .fit-block, .ev-block {
    padding: 14px !important;
  }

  /* Многоколоночные grid превращаются в 1 колонку */
  .doc-row, .spec-row, .trainer-row, .hand-row, .t-row {
    grid-template-columns: 1fr !important;
    gap: 8px !important;
  }
  .doc-row > button, .spec-row > button,
  .trainer-row > button, .hand-row > button, .t-row > button {
    justify-self: flex-end;
    width: 40px;
  }

  /* Form inputs — крупнее на мобиле, без iOS zoom */
  input, select, textarea {
    font-size: 16px !important;
    padding: 11px 12px !important;
  }

  /* Submit-button — full width */
  .submit-btn {
    width: 100% !important;
    padding: 14px !important;
    font-size: 1rem !important;
  }
}

/* SEO-лендинги — header проблема */
header.container-header,
header > .container {
  padding: 0 16px !important;
}

/* Длинные заголовки на лендингах */
@media (max-width: 480px) {
  h1 {
    font-size: 1.5rem !important;
    word-break: break-word;
    hyphens: auto;
  }
  .hero h1, .hero p {
    padding: 0 8px;
  }
}

/* Уберём horizontal overflow в category-tabs (если используется flex) */
.category-tabs,
.mobile-cat-row {
  scrollbar-width: thin;
}
.category-tabs::-webkit-scrollbar,
.mobile-cat-row::-webkit-scrollbar {
  height: 4px;
}
