Hello Guys! In this blog, I'm going to explain to you how to make a glassmorphism profile card using CSS. This will be a step-by-step guide including HTML and CSS. Let's get started 🚀.
Get FULL SOURCE Code and more Amazing Web Development projects on Coding Torque
We can convert any simple design into a Glassmorphism design. For this, we need to change a little bit of code. First we use background color semi-transparent such as rgba(255,255,255,0.1.5).
Then, we need to use backdrop-filter: blur (10px) to blur the background a bit. In the end, we need to use a border to enhance its beauty.
Let's cover HTML Part
We use HTML to make the skeleton of a website. HTML is a markup language.
Now let's import the fonts using Google Fonts API. Below is the code for Poppins
Font. Paste the below code in <head>
tag.
<link rel="preconnect" href="https://fonts.googleapis.com">
<link rel="preconnect" href="https://fonts.gstatic.com" crossorigin>
<link href="https://fonts.googleapis.com/css2?family=Poppins&display=swap" rel="stylesheet">
Now let's design the container in our <body>
tag. In the below HTML code, we have created a container that contains the two divs with classname 'circle' for the circle shapes to show the glassmorphic effect. Next, we have card div that contain profile image, heading tag for name, paragraph tag for designation, view profile button, ratings(metrics).
<div class="container">
<div class="circle"></div>
<div class="circle"></div>
<div class="card">
<div class="profile-img">
<img src="../imgs/prof-pic.jpg" alt="profile">
</div>
<h4 class="name">Code Scientist</h4>
<p class="designation">Full Stack Developer</p>
<button class="glass-btn">View Profile</button>
<div class="ratings">
<p>
<span>80%</span>
<span>Rating</span>
</p>
<p class="partition"></p>
<p>
<span>90%</span>
<span>Activity</span>
</p>
</div>
</div>
</div>
Here is the final HTML code
<!doctype html>
<html lang="en">
<head>
<!-- Required meta tags -->
<meta charset="utf-8">
<meta name="viewport" content="width=device-width, initial-scale=1">
<!-- Google Fonts -->
<link rel="preconnect" href="https://fonts.googleapis.com">
<link rel="preconnect" href="https://fonts.gstatic.com" crossorigin>
<link href="https://fonts.googleapis.com/css2?family=Poppins&display=swap" rel="stylesheet">
<title>Profile Card (Glassmorphic) using CSS - @code.scientist x @codingtorque</title>
</head>
<body>
<div class="container">
<div class="circle"></div>
<div class="circle"></div>
<div class="card">
<div class="profile-img">
<img src="../imgs/prof-pic.jpg" alt="profile">
</div>
<h4 class="name">Code Scientist</h4>
<p class="designation">Full Stack Developer</p>
<button class="glass-btn">View Profile</button>
<div class="ratings">
<p>
<span>80%</span>
<span>Rating</span>
</p>
<p class="partition"></p>
<p>
<span>90%</span>
<span>Activity</span>
</p>
</div>
</div>
</div>
</body>
</html>
Output Till Now
Let's understand CSS part
In the below CSS code.
- We declare a * selectors for the font Poppins that we have imported in our head tag.
- Next we declare a body selector which consists of styles for dark mode and aligns all elements in the body to the center.
- Next we created a circle using equal height & width and used
border-radius: 50%
to curve all edges. Then we created the gradient background for our circles. - Next, we have a card that contains
backdrop-filter: blur(10px)
, background: semi-transparent, and border property to create an amazing glassmorphism effect. Then we have flex properties to align item center and width properties.
* {
margin: 0;
padding: 0;
font-family: 'Poppins', sans-serif;
}
body {
background: black;
color: white;
display: flex;
align-items: center;
justify-content: center;
padding-top: 15rem;
}
.container {
position: relative;
}
/* 3 */
.circle {
width: 6rem;
height: 6rem;
background: linear-gradient(45deg, #fc00ff, #00dbde);
border-radius: 50%;
z-index: -1;
position: absolute;
top: -40px;
right: -30px;
}
.circle:nth-child(2) {
top: 112px;
left: -65px;
background: linear-gradient(45deg, #2980B9, #6DD5FA, #ffffff);
}
/* 4 */
.card {
backdrop-filter: blur(16px) saturate(180%);
background-color: rgba(17, 25, 40, 0);
border-radius: 8px;
border: 1px solid rgba(255, 255, 255, 0.125);
display: flex;
flex-direction: column;
align-items: center;
width: 15rem;
padding-top: 20px;
}
.profile-img {
height: 100px;
width: 100px;
background: white;
display: flex;
align-items: center;
justify-content: center;
border-radius: 50%;
backdrop-filter: blur(16px) saturate(180%);
background-color: rgb(255 255 255 / 11%);
border: 1px solid rgba(255, 255, 255, 0.125);
}
.profile-img img {
height: 80px;
width: 80px;
border-radius: 50%;
}
.name {
text-transform: uppercase;
letter-spacing: 1px;
margin-top: 10px;
}
.designation {
text-transform: uppercase;
color: gainsboro;
font-size: 12px;
letter-spacing: 1px;
}
.glass-btn {
backdrop-filter: blur(16px) saturate(180%);
background-color: rgb(255 255 255 / 11%);
border: 1px solid rgba(255, 255, 255, 0.125);
margin: 20px 0;
padding: 8px 20px;
cursor: pointer;
color: white;
}
.ratings {
backdrop-filter: blur(16px) saturate(180%);
background-color: rgb(255 255 255 / 11%);
border: 1px solid rgba(255, 255, 255, 0.125);
font-size: 12px;
width: 100%;
display: flex;
justify-content: space-evenly;
padding: 9px 0;
}
.ratings p {
display: flex;
flex-direction: column;
align-items: center;
justify-content: center;
}
.partition {
width: 2px;
background-color: white;
margin: 0 15px;
}
Top comments (0)