<div class="container">
<ul class="cards">
<li class="card cards__item">
<div class="card__frame">
<div class="card__picture">
<img src="https://image.flaticon.com/icons/svg/1496/1496034.svg" alt="" width="120">
</div>
<h2 class="card__title">Design</h2>
</div>
<div class="card__overlay"></div>
<div class="card__content">
<h2>Design</h2>
<p>Lorem, ipsum dolor sit amet consectetur adipisicing elit. Neque ipsum veritatis id quia cupiditate sed architecto aliquam nostrum unde nam minima voluptas dicta, beatae sint reprehenderit sit ducimus officiis ratione?</p>
</div>
</li>
<li class="card cards__item">
<div class="card__frame">
<div class="card__picture">
<img src="https://image.flaticon.com/icons/svg/1336/1336494.svg" alt="" width="120">
</div>
<h2 class="card__title">Code</h2>
</div>
<div class="card__overlay"></div>
<div class="card__content">
<h2>Code</h2>
<p>Dignissimos ipsam culpa vitae vel hic harum omnis doloremque debitis laudantium neque quos iure voluptates quidem ratione esse modi, rerum illum facere eius accusantium dolorem incidunt beatae officiis voluptatem? Nostrum.</p>
</div>
</li>
<li class="card cards__item">
<div class="card__frame">
<div class="card__picture">
<img src="https://image.flaticon.com/icons/svg/478/478543.svg" alt="" width="120">
</div>
<h2 class="card__title">Launch</h2>
</div>
<div class="card__overlay"></div>
<div class="card__content">
<h2>Launch</h2>
<p>Asperiores, harum dignissimos at neque quaerat, excepturi, ipsa in consectetur blanditiis tempore error! Libero fuga possimus qui saepe temporibus praesentium, ut ratione facere rem distinctio, beatae omnis officiis illum animi.</p>
</div>
</li>
</ul>
</div>
body {
display: flex;
align-items: center;
justify-content: center;
min-height: 100vh;
font-family: 'Poppins', sans-serif;
color: #ffffff;
background-color: #333333;
}
.container {
flex-grow: 1;
max-width: 960px;
margin-left: auto;
margin-right: auto;
padding-left: 20px;
padding-right: 20px;
}
.cards {
display: grid;
grid-template-columns: repeat(3, 1fr);
grid-gap: 32px;
margin: 0;
padding: 0;
list-style: none;
}
.cards__item {
height: 400px;
}
.card {
position: relative;
display: flex;
align-items: center;
justify-content: center;
background-color: #000000;
&::before {
content: "";
position: absolute;
top: 0;
left: 0;
z-index: 20;
width: 50%;
height: 100%;
background-color: rgba(#ffffff, 0.1);
pointer-events: none;
}
&:nth-child(1) {
background-image: linear-gradient(45deg, #3503ad, #f7308c);
}
&:nth-child(2) {
background-image: linear-gradient(45deg, #ccff00, #09afff);
}
&:nth-child(3) {
background-image: linear-gradient(45deg, #e91e63, #ffeb3b);
}
}
.card__frame {
position: absolute;
top: 0;
left: 0;
right: 0;
bottom: 0;
display: flex;
flex-direction: column;
align-items: center;
justify-content: center;
text-align: center;
}
.card__picture {
margin-bottom: 12px;
filter: invert(1);
img {
display: block;
max-width: 100%;
height: auto;
}
}
.card__title {
margin: 0;
font-weight: 700;
letter-spacing: 0.08em;
text-transform: uppercase;
}
.card__overlay {
position: absolute;
bottom: 20px;
right: 20px;
display: flex;
align-items: center;
justify-content: center;
width: 52px;
height: 52px;
background-color: #ffffff;
border-radius: 50%;
box-shadow: 0 2px 4px rgba(#000000, 0.2);
transition: 0.5s;
cursor: pointer;
&::before {
content: "Read";
font-size: 12px;
text-transform: uppercase;
font-weight: 500;
letter-spacing: 0.02em;
}
&:hover,
&:focus {
bottom: 0;
right: 0;
width: 100%;
height: 100%;
box-shadow: none;
border-radius: 0;
opacity: 0.9;
&::before {
content: none;
}
}
.card:nth-child(1) & {
background-image: linear-gradient(45deg, #3503ad, #f7308c);
}
.card:nth-child(2) & {
background-image: linear-gradient(45deg, #ccff00, #09afff);
}
.card:nth-child(3) & {
background-image: linear-gradient(45deg, #e91e63, #ffeb3b);
}
}
.card__content {
z-index: 1;
padding: 20px;
line-height: 1.4;
opacity: 0;
visibility: hidden;
box-sizing: border-box;
pointer-events: none;
transition: 0s;
.card__overlay:hover ~ & {
opacity: 1;
visibility: visible;
transition: 0.2s 0.3s;
}
h2 {
margin: 0;
margin-bottom: 16px;
}
}
View Compiled
This Pen doesn't use any external CSS resources.
This Pen doesn't use any external JavaScript resources.