The orientation CSS @media media feature can be used to apply styles based on the orientation of the viewport (or the page box, for paged media).

Note: This feature does not correspond to device orientation. Opening the soft keyboard on many devices in portrait orientation will cause the viewport to become wider than it is tall, thereby causing the browser to use landscape styles instead of portrait.


The orientation feature is specified as a keyword value chosen from the list below.

Keyword values

The device is in a portrait orientation, i.e.,  the height is greater than or equal to the width.
The device is in a landscape orientation, i.e., the width is greater than the height.



<div>Box 1</div>
<div>Box 2</div>
<div>Box 3</div>


body {
  display: flex;

div {
  background: yellow;

@media screen and (orientation: landscape) {
  body {
    flex-direction: row;

@media screen and (orientation: portrait) {
  body {
    flex-direction: column;



Specification Status Comment
Media Queries Level 4
The definition of 'orientation' in that specification.
Candidate Recommendation No change.
Media Queries
The definition of 'orientation' in that specification.
Recommendation Initial definition.

Browser compatibility

We're converting our compatibility data into a machine-readable JSON format. This compatibility table still uses the old format, because we haven't yet converted the data it contains. Find out how you can help!

Feature Chrome Firefox (Gecko) Internet Explorer Opera Safari
Basic support ? ? ? ? ?
Feature Android Firefox Mobile (Gecko) IE Mobile Opera Mobile Safari Mobile
Basic support ? ? ? ? ?


Document Tags and Contributors

Contributors to this page: mfluehr, chrisdavidmills, auramgold, mrenty, kscarfone, cvrebert
Last updated by: mfluehr,