:root {
    --ezCatDarkColor: var(--ezClockerSilver);
    --ezCatLightColor: var(--ezClockerOffWhite);
}

.cat {
    position: relative;
    z-index: -1;
    top: -20vh;
    left: 42vw;
    height: 170px;
    width: 192.1px;
}

.ear {
    position: absolute;
    top: -20%;
    height: 60%;
    width: 35%;
    background: var(--ezCatDarkColor);
}

.ear::before,
.ear::after {
    content: '';
    position: absolute;
    bottom: 24%;
    height: 10%;
    width: 5%;
    border-radius: 50%;
    background: var(--ezCatLightColor);
}

.ear::after {
    transform-origin: 50% 100%;
}

.ear--left {
    left: 0%;
    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: -0%;
    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: var(--ezCatDarkColor);
    border-radius: 50%;
}

.eye {
    position: absolute;
    top: 35%;
    height: 30%;
    width: 31%;
    background: var(--ezCatLightColor);
    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: var(--ezCatDarkColor);
    animation: blink 4s infinite ease-in;
}

@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: var(--ezCatLightColor);
    border-radius: 50%;
}

.eye--left {
    left: 15px;
}

.eye--left::before {
    right: -5%;
}

.eye--right {
    right: 15px;
}

.eye--right::before {
    left: -5%;
}

.eye-pupil {
    position: absolute;
    top: 25%;
    height: 50%;
    width: 20%;
    background: var(--ezCatDarkColor);
    border-radius: 50%;
    animation: look-around 4s infinite;
}

@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: var(--ezCatLightColor);
}

.muzzle {
    position: absolute;
    top: 60%;
    left: 50%;
    height: 6%;
    width: 10%;
    background: var(--ezCatLightColor);
    transform: translateX(-50%);
    border-radius: 50% 50% 50% 50% / 30% 30% 70% 70%;
}