@import url(https://fonts.googleapis.com/css?family=Open+Sans:400,300);
* {
    box-sizing: border-box;
}

body {
    background-color: #322514;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    height: 100vh;
    overflow: hidden;
    margin: 0;
}

.container {
    border-radius: 10px;
    text-align: left;
    max-width: 100%;
    width: 70%;
}

.joke {
    font-size: 24px;
    letter-spacing: 1px;
    line-height: 40px;
    max-width: 720px;
    font-family: Open sans;
    color: #fbcbc9;
}

#author {
    margin-top: 20px;
    margin-bottom: 30px;
}

.btn {
    background-color: #e75874;
    color: #fff;
    border: 0;
    border-radius: 10px;
    box-shadow: 0 5px 15px rgba(0, 0, 0, 0.1), 0 6px 6px rgba(0, 0, 0, 0.1);
    padding: 10px 30px;
    font-size: 16px;
    cursor: pointer;
    font-family: Open sans;
}

.btn:active {
    transform: scale(0.98);
}

.btn:focus {
    outline: 0;
}

.loader {
    display: inline-block;
    position: relative;
    width: 80px;
    height: 80px;
    visibility: hidden;
}

.loader.display {
    visibility: visible;
}

.loader div {
    animation: loader 1.2s cubic-bezier(0.5, 0, 0.5, 1) infinite;
    transform-origin: 40px 40px;
}

.loader div:after {
    content: " ";
    display: block;
    position: absolute;
    width: 7px;
    height: 7px;
    border-radius: 50%;
    background: #fff;
    margin: -4px 0 0 -4px;
}

.loader div:nth-child(1) {
    animation-delay: -0.036s;
}

.loader div:nth-child(1):after {
    top: 63px;
    left: 63px;
}

.loader div:nth-child(2) {
    animation-delay: -0.072s;
}

.loader div:nth-child(2):after {
    top: 68px;
    left: 56px;
}

.loader div:nth-child(3) {
    animation-delay: -0.108s;
}

.loader div:nth-child(3):after {
    top: 71px;
    left: 48px;
}

.loader div:nth-child(4) {
    animation-delay: -0.144s;
}

.loader div:nth-child(4):after {
    top: 72px;
    left: 40px;
}

.loader div:nth-child(5) {
    animation-delay: -0.18s;
}

.loader div:nth-child(5):after {
    top: 71px;
    left: 32px;
}

.loader div:nth-child(6) {
    animation-delay: -0.216s;
}

.loader div:nth-child(6):after {
    top: 68px;
    left: 24px;
}

.loader div:nth-child(7) {
    animation-delay: -0.252s;
}

.loader div:nth-child(7):after {
    top: 63px;
    left: 17px;
}

.loader div:nth-child(8) {
    animation-delay: -0.288s;
}

.loader div:nth-child(8):after {
    top: 56px;
    left: 12px;
}

@keyframes loader {
    0% {
        transform: rotate(0deg);
    }
    100% {
        transform: rotate(360deg);
    }
}