@media (max-width: 370px) {
  .app-screen {
    gap: 10px;
    padding: calc(8px + var(--safe-top)) 8px calc(10px + var(--safe-bottom));
  }

  .app-top {
    gap: 10px;
  }

  .app-header {
    gap: 8px;
  }

  .header-brand__line {
    font-size: 13px;
    letter-spacing: 0.06em;
  }

  .header-actions {
    gap: 6px;
  }

  .location-chip {
    gap: 10px;
    padding: 10px 12px;
    border-radius: 20px;
  }

  .location-chip__icon-wrap {
    width: 38px;
    height: 38px;
    border-radius: 14px;
  }

  .location-chip__city {
    font-size: 14px;
  }

  .location-chip__delivery {
    font-size: 11px;
  }

  .section-card {
    padding: 12px;
  }

  .product-grid,
  .skeleton-grid,
  .discover-grid {
    gap: 8px;
  }

  .product-body,
  .skeleton-body {
    padding: 11px;
    gap: 8px;
  }

  .product-title {
    min-height: 36px;
    font-size: 12.5px;
  }

  .product-price {
    font-size: 18px;
  }

  .product-compare-price,
  .delivery-badge--inline,
  .product-popularity {
    font-size: 10px;
  }

  .action-button {
    min-height: 34px;
    padding: 0 10px;
    font-size: 11px;
  }

  .icon-button {
    width: 42px;
    min-width: 42px;
    height: 42px;
    border-radius: 14px;
  }

  .search-shell {
    min-height: 54px;
    padding: 0 14px;
  }

  .cart-item {
    grid-template-columns: 80px minmax(0, 1fr);
    gap: 10px;
  }

  .cart-item__footer {
    align-items: flex-start;
    flex-direction: column;
  }

  .bottom-nav {
    gap: 4px;
    padding: 7px 6px;
    border-radius: 22px;
  }

  .nav-item {
    min-height: 58px;
    gap: 4px;
    padding: 8px 4px 7px;
    border-radius: 16px;
  }

  .nav-item svg {
    width: 20px;
    height: 20px;
  }

  .nav-item span {
    font-size: 10px;
  }

  .nav-item.is-active::after {
    width: 20px;
    bottom: 5px;
  }
}

@media (min-width: 768px) {
  .app-frame {
    padding: 10px;
  }

  .app-shell {
    height: 100%;
  }

  .header-brand__line {
    font-size: 1.55rem;
  }

  .bottom-nav {
    padding: 10px;
    gap: 8px;
  }

  .nav-item {
    min-height: 68px;
  }

  .nav-item span {
    font-size: 12px;
  }
}
