Я не знаю, искали ли вы это, но вот быстрый пример:
/* entire container, keeps perspective */
.flip-container {
perspective: 1500px;
margin: 0 auto;
margin-top:100px;
}
/* flip the pane when hovered */
.flip-container:hover .flipper, .flip-container.hover .flipper {
transform: rotateY(180deg);
}
.flip-container, .front, .back {
width: 320px;
height: 480px;
}
/* flip speed goes here */
.flipper {
transition: 0.6s;
transform-style: preserve-3d;
transform-origin: 100%;
position: relative;
}
/* hide back of pane during swap */
.front, .back {
backface-visibility: hidden;
position: absolute;
top: 0;
left: 0;
}
/* front pane, placed above back */
.front {
background-color:red;
z-index: 2;
/* for firefox 31 */
transform: rotateY(0deg);
}
/* back, initially hidden pane */
.back {
background-color:green;
transform: rotateY(180deg);
}
<div class="flip-container" ontouchstart="this.classList.toggle('hover');">
<div class="flipper">
<div class="front">
<p>FRONT</p>
</div>
<div class="back">
<p>BACK</p>
</div>
</div>
</div>
Ключом к достижению эффекта 3d является perspective: 1500px;
Этот пример основан на этой удивительной статье , которая объясняет свойство