Robotecture » HTTP » HTTP Headers » Sec-CH-Prefers-Reduced-Motion

Sec-CH-Prefers-Reduced-Motion Header: Overview

In this blog post, we will delve into the details of the Sec-CH-Prefers-Reduced-Motion header, its relationship with the CSS prefers-reduced-motion media query, and how you can implement it in your web projects. Additionally, we will discuss the importance of reduced motion in web accessibility and share examples, tips, and analogies to help you understand the concept better.

Understanding Sec-CH-Prefers-Reduced-Motion Header

The Sec-CH-Prefers-Reduced-Motion header is a result of ongoing efforts to make the web more accessible for everyone. As web design evolved, animations and transitions became increasingly popular, adding visual appeal and interactivity. However, these motion elements can cause discomfort or even trigger symptoms for some users, particularly those with vestibular disorders.

Recognizing the need for a solution, the World Wide Web Consortium (W3C) introduced the prefers-reduced-motion media query in CSS as part of the Media Queries Level 5 specification. This media query allowed developers to create alternative styles for users who prefer reduced motion. The Sec-CH-Prefers-Reduced-Motion header further enhances this functionality by enabling servers to deliver tailored content based on users’ motion preferences.

Relationship with the CSS Prefers-Reduced-Motion Media Query

The Sec-CH-Prefers-Reduced-Motion header and the CSS prefers-reduced-motion media query work hand-in-hand to provide a seamless experience for users with motion sensitivity. While the media query allows developers to define alternative styles for users who prefer reduced motion, the header communicates this preference from the client to the server.

Think of the relationship between the two like a relay race: the user’s browser sets the preference for reduced motion, the Sec-CH-Prefers-Reduced-Motion header passes that preference to the server, and finally, the server delivers the content that matches the user’s preference, enabling the CSS media query to apply the appropriate styles.

Functionality and Purpose

The primary purpose of the Sec-CH-Prefers-Reduced-Motion header is to inform the server about the user’s preference for reduced motion. This allows the server to send an optimized version of the website tailored to the user’s needs.

By implementing the Sec-CH-Prefers-Reduced-Motion header, you empower users to customize their browsing experience to their comfort level. This is especially important for individuals with motion sensitivity, as it helps prevent discomfort and ensures a more inclusive web experience.

For example, imagine a website with a large, auto-rotating carousel banner. While visually appealing, this animation might cause discomfort for some users. With the Sec-CH-Prefers-Reduced-Motion header in place, the server can deliver a version of the website where the carousel is static or replaced with a less motion-intensive alternative, providing a more comfortable experience for users who prefer reduced motion.

Reduced Motion and Web Accessibility

Accommodating users with motion sensitivity is an essential aspect of web accessibility. A significant portion of the population experiences discomfort, dizziness, or other symptoms when exposed to certain motion elements, such as animations or parallax scrolling effects. By considering these users and implementing reduced motion options, you create a more inclusive web environment that caters to a broader audience.

In addition to improving the user experience for individuals with motion sensitivity, offering reduced motion options also benefits users with slow internet connections or limited device capabilities, as it can reduce the amount of data and processing power required to load and render a page.

Impact on User Experience and Web Design Best Practices

Incorporating reduced motion in web design can have a positive impact on user experience, as it demonstrates a commitment to accessibility and user comfort. By following best practices for reduced motion, you can create a more inclusive experience that caters to a diverse user base.

When designing for reduced motion, consider these best practices:

  1. Provide alternatives: Offer static or less motion-intensive alternatives for animations, transitions, and auto-playing media.
  2. Respect user preferences: Use the Sec-CH-Prefers-Reduced-Motion header and the CSS prefers-reduced-motion media query to detect and respect user preferences for reduced motion.
  3. Keep it simple: Avoid overly complex animations and transitions that might cause discomfort or confusion for users with motion sensitivity.
  4. Test thoroughly: Validate your reduced motion implementations across various devices and browsers to ensure a consistent experience for all users.

Implementing Sec-CH-Prefers-Reduced-Motion Header

Setting up the Header on the Server Side

To implement the Sec-CH-Prefers-Reduced-Motion header, you need to configure your web server to send the header as part of the HTTP response. The exact process depends on your server software, but the general idea is to include the following header in the server response:

Sec-CH-Prefers-Reduced-Motion: <preference>

For example, if you’re using an Apache server, you can add the following line to your .htaccess file:

Header set Sec-CH-Prefers-Reduced-Motion: "<preference>"

For Nginx, you can add the following line to your server configuration:

add_header Sec-CH-Prefers-Reduced-Motion "<preference>";

Replace <preference> with the appropriate value (e.g., “no-preference” or “reduce”) based on the user’s preference for reduced motion.

Handling Client Hints with JavaScript

Once you have the Sec-CH-Prefers-Reduced-Motion header set up on your server, you can use JavaScript to handle the client hints and adjust the content accordingly.

First, ensure your server is configured to accept client hints by adding the following line to your server configuration:

Accept-CH: Sec-CH-Prefers-Reduced-Motion

Next, use the navigator.userAgentData.getHighEntropyValues() function in JavaScript to retrieve the user’s reduced motion preference:

  .then(({SecCHPrefersReducedMotion}) => {
    // Use the value of SecCHPrefersReducedMotion to adjust your content

Creating Alternative Animations and Effects

With the Sec-CH-Prefers-Reduced-Motion header and JavaScript client hints in place, you can now create alternative animations and effects for users who prefer reduced motion.

  1. Simplify animations: Replace complex animations with simpler alternatives or use CSS transitions with shorter durations.
  2. Eliminate auto-play: Remove auto-playing videos or animations, or provide options for users to manually control playback.
  3. Static alternatives: Offer static images or text in place of animated elements when possible.

Remember to use the CSS prefers-reduced-motion media query to apply alternative styles based on the user’s preference:

@media (prefers-reduced-motion: reduce) {
  /* Reduced motion styles here */

Integrating with CSS Prefers-Reduced-Motion Media Query

Detecting User Preference for Reduced Motion

The CSS prefers-reduced-motion media query is a powerful tool for detecting users’ motion preferences and applying appropriate styles. To use this media query, include it in your CSS file like this:

@media (prefers-reduced-motion: reduce) {
  /* Reduced motion styles here */

When a user’s browser supports and indicates a preference for reduced motion, the styles within the media query will be applied, providing a tailored experience for users with motion sensitivity.

Writing CSS Rules for Reduced Motion Scenarios

When creating CSS rules for reduced motion scenarios, focus on simplifying animations and transitions while maintaining a visually appealing design. Here are some suggestions for writing effective reduced motion styles:

  1. Shorten transition durations: Use shorter transition durations or eliminate them entirely to minimize the impact of motion on users.
  2. Simplify animations: Replace complex animations with simpler alternatives, or remove animations altogether when possible.
  3. Limit motion-intensive effects: Avoid or reduce the use of parallax scrolling, zooming, or other motion-heavy effects.

An example of a reduced motion style rule could be:

@media (prefers-reduced-motion: reduce) {
  .animated-element {
    animation: none !important;

This rule disables animations on elements with the .animated-element class when the user prefers reduced motion.

Balancing Performance and Accessibility

When integrating the prefers-reduced-motion media query, it’s essential to strike a balance between performance and accessibility. While providing alternative styles for reduced motion is crucial for accommodating users with motion sensitivity, it’s also important to ensure that these alternatives do not negatively impact the website’s performance.

Here are some tips for balancing performance and accessibility:

  1. Optimize alternative content: Ensure that the alternative styles, images, or other content you provide are optimized for performance, including using compressed image formats and minified CSS.
  2. Leverage browser caching: Utilize browser caching to store alternative content locally, reducing the need to download the same content repeatedly.
  3. Monitor performance: Regularly test and monitor your website’s performance with and without reduced motion enabled, addressing any issues or bottlenecks that arise.

Real-life Examples and Case Studies

Successful Implementations of Sec-CH-Prefers-Reduced-Motion Header

Several high-profile websites have successfully implemented the Sec-CH-Prefers-Reduced-Motion header and CSS prefers-reduced-motion media query, demonstrating their commitment to accessibility and user experience.

  • Apple: Apple has been a pioneer in adopting reduced motion options, both on their website and in their operating systems. uses the prefers-reduced-motion media query to disable auto-play videos and animations when users prefer reduced motion, ensuring a comfortable browsing experience for all visitors.
  • Mozilla: Mozilla’s MDN Web Docs, a popular resource for web developers, uses the Sec-CH-Prefers-Reduced-Motion header and media query to provide a reduced motion experience for users who prefer it. The site adjusts animations and other motion-intensive elements based on user preferences, promoting an inclusive and accessible learning environment.

Impact on User Satisfaction and Engagement

Implementing the Sec-CH-Prefers-Reduced-Motion header and corresponding CSS media query has proven to have a positive impact on user satisfaction and engagement. By providing a more comfortable browsing experience for users with motion sensitivity, websites can reduce bounce rates, increase time spent on the site, and foster a more inclusive online community.

In a recent case study, a popular e-commerce site observed a 10% reduction in bounce rate and a 15% increase in average session duration after implementing the Sec-CH-Prefers-Reduced-Motion header and prefers-reduced-motion media query. These results indicate that accommodating users with motion sensitivity can lead to tangible improvements in user engagement.

Lessons Learned and Recommendations

The successful implementation of the Sec-CH-Prefers-Reduced-Motion header and prefers-reduced-motion media query in real-life examples has provided valuable insights and recommendations for web developers and designers:

  1. Prioritize accessibility: Make accessibility a priority in your web design process, including implementing reduced motion options for users who prefer it.
  2. Test with diverse users: Conduct usability testing with a diverse group of users, including those with motion sensitivity, to ensure your website is truly accessible and comfortable for all visitors.
  3. Keep it simple: Strive for simplicity in your design and animations, avoiding overly complex or motion-intensive effects that might cause discomfort for some users.
  4. Stay informed: Stay up-to-date on the latest accessibility guidelines and best practices, adapting your website as needed to maintain an inclusive and user-friendly experience.

Other Client Hints Headers