text-emphasis-position
        
        
          
                Baseline
                
                  Widely available
                
                 *
              
        
        
        
          
                
              
                
              
                
              
        
        
      
      This feature is well established and works across many devices and browser versions. It’s been available across browsers since March 2022.
* Some parts of this feature may have varying levels of support.
The text-emphasis-position CSS property sets where emphasis marks are drawn. Similar to the text rendered by the <ruby> HTML element, if there isn't enough room for emphasis marks, the line height is increased.
Try it
text-emphasis-position: auto;
text-emphasis-position: over right;
text-emphasis-position: under right;
text-emphasis-position: auto;
writing-mode: vertical-rl;
text-emphasis-position: over left;
writing-mode: vertical-rl;
text-emphasis-position: over right;
writing-mode: vertical-rl;
<section id="default-example">
  <p>
    I'd far rather be
    <span class="transition-all" id="example-element">happy than right</span>
    any day.
  </p>
</section>
p {
  font: 1.5em sans-serif;
}
#example-element {
  text-emphasis: filled double-circle #ffb703;
}
Syntax
/* Initial value */
text-emphasis-position: auto;
/* Keyword values */
text-emphasis-position: over;
text-emphasis-position: under;
text-emphasis-position: over right;
text-emphasis-position: over left;
text-emphasis-position: under right;
text-emphasis-position: under left;
text-emphasis-position: left over;
text-emphasis-position: right over;
text-emphasis-position: right under;
text-emphasis-position: left under;
/* Global values */
text-emphasis-position: inherit;
text-emphasis-position: initial;
text-emphasis-position: revert;
text-emphasis-position: revert-layer;
text-emphasis-position: unset;
Values
The property accepts one or two values:
- If only one value is provided, it can be auto,over, orunder. When onlyoverorunderis used,rightis assumed as the default position.
- If two values are provided, they must include one of overorunderand one ofrightorleft. Their order does not matter.
The values include:
- auto
- 
Draws marks over the text in horizontal writing mode and to the right of the text in vertical writing mode. 
- over
- 
Draws marks over the text in horizontal writing mode. 
- under
- 
Draws marks under the text in horizontal writing mode. 
- right
- 
Draws marks to the right of the text in vertical writing mode. 
- left
- 
Draws marks to the left of the text in vertical writing mode. 
Description
The preferred position of emphasis marks depends on the language. In Japanese for example, the preferred position is over right. In Chinese, on the other hand, the preferred position is under right. The informative table below summarizes the preferred emphasis mark positions for Chinese, Mongolian and Japanese:
| Language | Preferred position | Illustration | ||
|---|---|---|---|---|
| Horizontal | Vertical | |||
| Japanese | over | right |   |   | 
| Korean | ||||
| Mongolian | ||||
| Chinese | under | right |   | |
Note:
The text-emphasis-position cannot be set, and therefore are not reset either, using the text-emphasis shorthand property.
Formal definition
| Initial value | auto | 
|---|---|
| Applies to | all elements | 
| Inherited | yes | 
| Computed value | as specified | 
| Animation type | discrete | 
Formal syntax
text-emphasis-position =
[ over | under ] &&
[ right | left ]?
Examples
>Adding emphasis mark positions
Use the drop down menu to change the position of the emphasis marks. This will change the class on the <section> element, which in turn, will update the position of the emphasis marks on the text.
HTML
<section id="setting" class="auto">
  <p class="horizontal" lang="zh">你好世界</p>
  <!-- Hello World in Chinese -->
  <p class="vertical" lang="ja">世界、こんにちは。</p>
  <!-- Hello World in Japanese -->
</section>
CSS
section p {
  text-emphasis: filled circle tomato;
  text-emphasis-position: auto;
}
.over-right p,
.preferred p [lang="ja"] {
  text-emphasis-position: over right;
}
.over-left p {
  text-emphasis-position: over left;
}
.under-right p,
.preferred p [lang="zh"] {
  text-emphasis-position: under right;
}
.under-left p {
  text-emphasis-position: under left;
}
.preferred p [lang="ja"] {
}
Result
Use the "Emphasis position" drop down to choose the location of the emphasis marks. The preferred option in the drop down uses the preferred positions, as explained in the Description section.
Preferring ruby over emphasis marks
Some editors prefer to hide emphasis marks when they conflict with ruby. In HTML, this can be done with the following style rule:
ruby {
  text-emphasis: none;
}
Preferring emphasis marks over ruby
Some other editors prefer to hide ruby when they conflict with emphasis marks. In HTML, this can be done with the following pattern:
em {
  text-emphasis: dot; /* Set text-emphasis for <em> elements */
}
em rt {
  display: none; /* Hide ruby inside <em> elements */
}
Specifications
| Specification | 
|---|
| CSS Text Decoration Module Level 3> # text-emphasis-position-property> | 
Browser compatibility
Loading…
See also
- text-underline-position
- text-emphasis-style
- text-emphasis-color
- text-emphasisshorthand property
- writing-mode