Imagine you’re reading a captivating novel, and the first letter of each chapter is elaborately designed, drawing your attention immediately. In web design, the ::first-letter
pseudo-element in CSS works similarly. It allows you to style the first letter of a block-level element, making it stand out and giving your text a touch of elegance.

with hands-on learning.
get the skills and confidence to land your next move.
What is the ::first-letter Pseudo-element?
The ::first-letter
pseudo-element is used to style the first letter of the first line of a block-level element. This can be particularly useful for creating drop caps or other typographic effects that enhance the visual appeal of your text content.
Here’s how it looks:
element::first-letter {
property: value;
}
Why Use the ::first-letter Pseudo-element?
- Enhanced Readability: The
::first-letter
pseudo-element helps draw attention to the beginning of a paragraph or section, making it easier for readers to follow the text.
- Aesthetic Appeal: It allows you to add decorative elements to your text, creating a visually appealing design that enhances the overall look and feel of your webpage.
- Simplified Code: Using the
::first-letter
pseudo-element can reduce the need for additional HTML elements, keeping your markup clean and maintainable.
Practical Examples
Let’s explore some practical examples to see how the ::first-letter
pseudo-element can be used effectively.
Example 1: Creating a Drop Cap
You can use the ::first-letter
pseudo-element to create a drop cap effect at the beginning of a paragraph.
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<title>Drop Cap</title>
<style>
p::first-letter {
font-size: 3em;
font-weight: bold;
float: left;
margin-right: 10px;
color: darkblue;
}
</style>
</head>
<body>
<p>
Once upon a time, in a land far, far away, there was a magical kingdom where dreams came true.
</p>
</body>
</html>
In this example, the p::first-letter
selector increases the font size of the first letter, makes it bold, floats it to the left, and adds some margin, creating a classic drop cap effect.
Example 2: Styling the First Letter with a Different Font
You can style the first letter of a paragraph with a different font to make it stand out.
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<title>First Letter Font</title>
<style>
p::first-letter {
font-family: 'Courier New', Courier, monospace;
font-size: 2em;
color: red;
}
</style>
</head>
<body>
<p>
The quick brown fox jumps over the lazy dog.
</p>
</body>
</html>
Here, the p::first-letter
selector changes the font family and color of the first letter, making it visually distinct from the rest of the text.
Example 3: Adding Background Color to the First Letter
You can add a background color to the first letter of a paragraph to highlight it.
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<title>First Letter Background</title>
<style>
p::first-letter {
background-color: yellow;
padding: 5px;
border-radius: 3px;
}
</style>
</head>
<body>
<p>
In the beginning, there was light.
</p>
</body>
</html>
In this example, the p::first-letter
selector adds a yellow background color, padding, and rounded corners to the first letter, making it stand out.
Example 4: Styling the First Letter of Blockquote
You can use the ::first-letter
pseudo-element to style the first letter of a blockquote.
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<title>Blockquote First Letter</title>
<style>
blockquote::first-letter {
font-size: 2.5em;
color: green;
font-style: italic;
}
</style>
</head>
<body>
<blockquote>
To be, or not to be, that is the question.
</blockquote>
</body>
</html>
Here, the blockquote::first-letter
selector styles the first letter of the blockquote with a larger font size, green color, and italic style, emphasizing the beginning of the quote.
Conclusion
The ::first-letter
pseudo-element is a versatile and powerful tool in CSS, allowing you to style the first letter of a block-level element. Whether you’re creating a drop cap, changing the font, or adding background color, the ::first-letter
pseudo-element helps you enhance your web design with dynamic and engaging typography. So, the next time you want to add a special touch to the beginning of your text, remember the ::first-letter
pseudo-element — your key to creative and effective styling.