
        /* Animation.css */

.lake {
    text-align: center;
    display: inline-block;
    overflow: hidden;
    position: relative;
    text-decoration: none;
}

.lake:before {
    display: block;
    background-color: rgb(0, 0, 0);
    content: "";
    height: 100%;
    opacity: 0;
    position: absolute;
    width: 100%;
    z-index: 2;
}
    
.lake:after {
    color: white;
    content: attr(alt);
    display: block;
    font-size: 16px;
    opacity: 0;
    padding: 0 4%;
    position: absolute;
    text-transform: none;
    top: 50%;
    -webkit-transform-origin: 50% 0%;
    transform-origin: 50% 0%;
    -webkit-transform: scale(0) translateY(-50%);
    transform: scale(0) translateY(-50%);
    width: 100%;
    z-index: 3;
}
    
.lake img {
    border: none;
    display: block;
    z-index: 1;
}
    
.lake:after {
    -webkit-transition: all 350ms ease-in-out;
    transition: all 350ms ease-in-out;
}
    
.lake:hover:before {
    opacity: 0.6;
}
    
.lake:hover:after {
    opacity: 1;
    -webkit-transform: scale(1) translateY(-50%);
    transform: scale(1) translateY(-50%);
}
