body {
    color: #fff;
    font-family: arial, sans-serif;
    height: 100%;
}

.name {
    font-size: 4em;
    text-align: center;
}

.links {
    display: flex;
    justify-content: space-evenly;
    align-items: center;
}

.links svg {
    border-radius: 2em;
    overflow: hidden;
    height: 10em;
    width: 10em;
    transition: all 0.2s linear;
}

.linkedin {
    fill: #fff;
    border: 0.5em solid #161616;
}

.linkedin:hover {
    fill: #161616;
    background-color: #fff;
    border: 0.5em solid #fff;
}

.email {
    fill: #fff;
    stroke: #fff;
}

.email .email-v {
    stroke: #161616;
}

.email:hover {
    fill: #161616;
}

.email:hover .email-v {
    stroke: #fff;
}

.cat-container {
    width: 100%;
    text-align: center;
    padding-top: 12em;
}

.cat {
    position: relative;
    display: inline-block;
    height: 20em;
    width: calc(20em * 1.13);
}

.ear {
    position: absolute;
    top: -30%;
    height: 60%;
    width: 25%;
    background: #fff;
}

.ear::before,
.ear::after {
    content: '';
    position: absolute;
    bottom: 24%;
    height: 10%;
    width: 5%;
    border-radius: 50%;
    background: #161616;
}

.ear::after {
    transform-origin: 50% 100%;
}

.ear-left {
    left: -7%;
    border-radius: 70% 30% 0% 0%/100% 100% 0% 0%;
    transform: rotate(-15deg);
}

.ear-left::before,
.ear-left::after {
    right: 10%;
}

.ear-left::after {
    transform: rotate(-45deg);
}

.ear-right {
    right: -7%;
    border-radius: 30% 70% 0% 0%/100% 100% 0% 0%;
    transform: rotate(15deg);
}

.ear-right::before,
.ear-right::after {
    left: 10%;
}

.ear-right::after {
    transform: rotate(45deg);
}

.face {
    position: absolute;
    height: 100%;
    width: 100%;
    background: #161616;
    border-radius: 50%;
}

.eye {
    position: absolute;
    top: 35%;
    height: 30%;
    width: 31%;
    background: #fff;
    border-radius: 50% 50% 50% 50%/60% 60% 40% 40%;
}

.eye::after {
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    height: 0;
    width: 100%;
    border-radius: 0 0 50% 50%/0 0 40% 40%;
    background: #161616;
    -webkit-animation: blink 4s infinite ease-in;
    animation: blink 4s infinite ease-in;
}

@-webkit-keyframes blink {
    0% {
        height: 0;
    }

    90% {
        height: 0;
    }

    92.5% {
        height: 100%;
    }

    95% {
        height: 0;
    }

    97.5% {
        height: 100%;
    }

    100% {
        height: 0;
    }
}

@keyframes blink {
    0% {
        height: 0;
    }

    90% {
        height: 0;
    }

    92.5% {
        height: 100%;
    }

    95% {
        height: 0;
    }

    97.5% {
        height: 100%;
    }

    100% {
        height: 0;
    }
}

.eye::before {
    content: '';
    position: absolute;
    top: 60%;
    height: 10%;
    width: 15%;
    background: #fff;
    border-radius: 50%;
}

.eye-left {
    left: 0;
}

.eye-left::before {
    right: -5%;
}

.eye-right {
    right: 0;
}

.eye-right::before {
    left: -5%;
}

.eye-pupil {
    position: absolute;
    top: 25%;
    height: 50%;
    width: 20%;
    background: #161616;
    border-radius: 50%;
    -webkit-animation: look-around 4s infinite;
    animation: look-around 4s infinite;
}

@-webkit-keyframes look-around {
    0% {
        transform: translate(0);
    }

    5% {
        transform: translate(50%, -25%);
    }

    10% {
        transform: translate(50%, -25%);
    }

    15% {
        transform: translate(-100%, -25%);
    }

    20% {
        transform: translate(-100%, -25%);
    }

    25% {
        transform: translate(0, 0);
    }

    100% {
        transform: translate(0, 0);
    }
}

@keyframes look-around {
    0% {
        transform: translate(0);
    }

    5% {
        transform: translate(50%, -25%);
    }

    10% {
        transform: translate(50%, -25%);
    }

    15% {
        transform: translate(-100%, -25%);
    }

    20% {
        transform: translate(-100%, -25%);
    }

    25% {
        transform: translate(0, 0);
    }

    100% {
        transform: translate(0, 0);
    }
}

.eye-left .eye-pupil {
    right: 30%;
}

.eye-right .eye-pupil {
    left: 30%;
}

.eye-pupil::after {
    content: '';
    position: absolute;
    top: 30%;
    right: -5%;
    height: 20%;
    width: 35%;
    border-radius: 50%;
    background: #fff;
}

.muzzle {
    position: absolute;
    top: 60%;
    left: 50%;
    height: 6%;
    width: 10%;
    background: #fff;
    transform: translateX(-50%);
    border-radius: 50% 50% 50% 50%/30% 30% 70% 70%;
}

/* General page styling */
html {
    height: 100%;
    display: flex;
    align-items: center;
    justify-content: center;
    background: #161616;
}