.link {
    position: relative;
    display: block;
    /* padding: 1em 3em 1em 1em; */
    padding-left: 3.4em;
    /* font-size: 30px; */
    font-weight: bold;
    text-decoration: none;
    color: #e74c3c;
    /* box-shadow: inset 0 0 0 0.2em #e74c3c; */
    height: 100%;
}
.link:after,
.link:before {
    content: "";
    display: block;
    position: absolute;
    -webkit-transition: all 0.5s ease-in-out;
    transition: all 0.5s ease-in-out;
}
.link:before {
    top: 50%;
    right: 1em;
    width: 1em;
    height: 1em;
    -webkit-transform-origin: 50% 50%;
    transform-origin: 50% 50%;
    -webkit-transform: translate(0, -0.5em) rotate(45deg);
    transform: translate(0, -0.5em) rotate(45deg);
    box-shadow: inset -0.2em 0.2em 0 0 #fff;
    border-radius: 0 0.15em 0 0;
}
.link:after {
    top: 50%;
    right: 1em;
    width: 1.8em;
    height: 0.2em;
    -webkit-transform: translate(0, -0.1em);
    transform: translate(0, -0.1em);
    background-color: #fff;
}
.link:hover:before {
    -webkit-transform: translate(0.5em, -0.5em) rotate(45deg);
    transform: translate(0.5em, -0.5em) rotate(45deg);
}
.link:hover:after {
    -webkit-transform: translate(0.5em, -0.1em);
    transform: translate(0.5em, -0.1em);
}