I wanted to use @media (hover: hover)
but I could not get it to work. I have three images in a row that display a text overlay when they are hovered over with a mouse. Currently, whenever I add @media (hover: hover)
and switch to a mobile view, the images remain unaltered. I either want to get @media (hover: hover)
working or try something else entirely. This is my first time designing a website and using stack overflow, so I am a little out of my depth. I did not see any questions already posted that were similar enough to my problem to help me achieve my goal. My CSS is below.
.card-container
{
margin-top: 10%;
}
.card-container h1
{
font-family: merriweather;
}
.card
{
position: relative;
overflow: hidden;
}
.card:before
{
position: absolute;
content: '';
width: 80%;
height: 220%;
background: rgba(217, 153, 35, 0.7);
top: -50%;
left: -100%;
z-index: 1;
transform: rotate(25deg);
transform-origin: center top 0;
transition: .5s;
}
.card:hover:before
{
left: 10%;
}
.card img
{
width: 100%;
height: auto;
}
.card-text
{
width: 100%;
padding: 0 20px;
position: absolute;
top: -100%;
color: #ffff;
left: 0;
z-index: 2;
transition: 1.1s;
}
.card-text h3
{
font-family: merriweather;
font-weight: 900;
}
.card-text h5
{
font-family: lora;
}
.card:hover .card-text
{
top: 80px;
}
In mobile, you need a combination of hover and active to hover element.
So, you need to declare in your css like.
.card:hover, .card:active{
//your hover effect.
}
You just need to use combine CSS selector properties in responsive media queries.
i.e.- .class:hover, .class:active, .class: focus
please refer this link for live demo to understand in details. https://jsfiddle.net/yudizsolutions/nc2fh7kp/
ol,
ul {
list-style: none;
}
li {
display: inline-block;
padding: 20px 0 20px;
vertical-align: middle;
}
a:hover,
a:focus,
a:active {
color: #999;
text-decoration: none;
}
a {
text-decoration: none;
transition: color 0.1s, background-color 0.1s;
position: relative;
display: block;
padding: 16px 0;
margin: 0 12px;
letter-spacing: 1px;
font-size: 12px;
line-height: 16px;
font-weight: 900;
text-transform: uppercase;
transition: color 0.1s, background-color 0.1s, padding 0.2s ease-in;
color: #000;
}
a::before {
content: '';
display: block;
position: absolute;
bottom: 3px;
left: 0;
height: 3px;
width: 100%;
background-color: #000;
transform-origin: right top;
transform: scale(0, 1);
transition: color 0.1s, transform 0.2s ease-out;
}
a:active::before {
background-color: #000;
}
a:hover::before,
a:focus::before {
transform-origin: left top;
transform: scale(1, 1);
}
<nav>
<ul>
<li class="item"><a href="#">link 1</a></li>
<li class="item"><a href="#">link 2</a></li>
<li class="item"><a href="#">link 3</a></li>
<li class="item"><a href="#">link 4</a></li>
<li class="item"><a href="#">link 5</a></li>
</ul>
</nav>
If you love us? You can donate to us via Paypal or buy me a coffee so we can maintain and grow! Thank you!
Donate Us With