/**
 * ASPARA — общие улучшения адаптивности (телефон, планшет, десктоп).
 * Подключайте после локальных стилей страницы.
 */

html {
  -webkit-text-size-adjust: 100%;
  text-size-adjust: 100%;
}

html,
body {
  overflow-x: hidden;
  max-width: 100vw;
}

img,
video,
svg {
  max-width: 100%;
  height: auto;
}

/* Удобные зоны нажатия на touch-устройствах */
@media (hover: none) and (pointer: coarse) {
  .btn-aspara,
  .btn-login,
  .btn-header,
  .btn-add,
  .nav-btn,
  .nav-item,
  .qty-btn,
  button,
  a.btn-aspara {
    min-height: 44px;
  }
}

/* Планшет */
@media (max-width: 968px) {
  .checkout-container {
    grid-template-columns: 1fr !important;
    gap: 24px !important;
    margin: 24px auto !important;
    padding: 0 16px !important;
  }

  .page-container {
    margin: 40px auto !important;
    padding: 0 16px !important;
  }

  .info-header h1 {
    font-size: 2.2rem !important;
  }

  .content-block {
    padding: 28px 22px !important;
  }

  header {
    padding-left: 16px !important;
    padding-right: 16px !important;
  }

  .nav-links {
    gap: 16px !important;
  }
}

/* Телефон */
@media (max-width: 600px) {
  .glass-card,
  .admin-form,
  .login-container {
    padding: 24px 18px !important;
  }

  .form-grid {
    grid-template-columns: 1fr !important;
  }

  .payment-methods {
    grid-template-columns: 1fr !important;
  }

  .hero-logo {
    font-size: 2.5rem !important;
    letter-spacing: 12px !important;
  }

  .success-content {
    padding: 32px 20px !important;
  }

  /* Таблицы админки — горизонтальный скролл */
  .products-table {
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
  }

  .products-table table {
    min-width: 640px;
  }

  .admin-nav {
    overflow-x: auto;
    flex-wrap: nowrap !important;
    -webkit-overflow-scrolling: touch;
  }

  .nav-tab {
    flex-shrink: 0;
  }

  /* Корзина: кнопки на всю ширину */
  .cart-controls {
    width: 100% !important;
    margin-left: 0 !important;
    justify-content: space-between !important;
    flex-wrap: wrap;
    padding-top: 12px;
    border-top: 1px solid var(--border, #333);
  }

  /* Нижняя навигация + safe area (iPhone) */
  .bottom-nav {
    padding-bottom: calc(12px + env(safe-area-inset-bottom, 0px)) !important;
    bottom: calc(12px + env(safe-area-inset-bottom, 0px)) !important;
  }

  body {
    padding-bottom: calc(100px + env(safe-area-inset-bottom, 0px)) !important;
  }
}

/* Очень узкие экраны */
@media (max-width: 380px) {
  .hero-logo {
    font-size: 2rem !important;
    letter-spacing: 8px !important;
  }

  .btn-aspara {
    padding-left: 20px !important;
    padding-right: 20px !important;
    font-size: 0.85rem !important;
  }
}
