@charset "utf-8";
@import url(https://fonts.googleapis.com/css?family=Rubik:400,400i,700,900);

* {
    padding: 0;
    margin: 0;
    box-sizing: border-box;
    outline: 0;
    border: none
}

:focus {
    outline: 0
}

body {
    font-size: 62.5%;
    font-family: Rubik, sans-serif;
    font-weight: 400;
    padding: 0;
    margin: 0;
    background-color: #000;
    color: #fff
}

aside, div, footer, header, main, nav, section {
    display: block;
    overflow: hidden
}

.id-main {
    clear: both;
    background-color: #fff
}

.id-content header {
    background-color: #702f8a
}

.id-content > div > :first-child {
    margin-top: 0 !important
}

.id-content > div > :last-child {
    margin-bottom: 0 !important
}

body.home .id-content header {
    min-height: 400px;
    padding-bottom: 100%;
    background-image: url(assets/images/bg-man.jpg);
    background-repeat: no-repeat;
    background-position: bottom left;
    background-size: contain
}

@media all and (min-width: 720px) {
    .id-content > div {
        max-width: 960px
    }

    body.home .id-content header {
        padding-bottom: 0;
        background-position: bottom right
    }
}

@font-face {
    font-family: FontAwesome;
    src: url(https://cdnjs.cloudflare.com/ajax/libs/font-awesome/4.7.0/fonts/fontawesome-webfont.eot?v=4.7.0);
    src: url(https://cdnjs.cloudflare.com/ajax/libs/font-awesome/4.7.0/fonts/fontawesome-webfont.eot?#iefix&v=4.7.0) format('embedded-opentype'), url(https://cdnjs.cloudflare.com/ajax/libs/font-awesome/4.7.0/fonts/fontawesome-webfont.woff2?v=4.7.0) format('woff2'), url(https://cdnjs.cloudflare.com/ajax/libs/font-awesome/4.7.0/fonts/fontawesome-webfont.woff?v=4.7.0) format('woff'), url(https://cdnjs.cloudflare.com/ajax/libs/font-awesome/4.7.0/fonts/fontawesome-webfont.ttf?v=4.7.0) format('truetype'), url(https://cdnjs.cloudflare.com/ajax/libs/font-awesome/4.7.0/fonts/fontawesome-webfont.svg?v=4.7.0#fontawesomeregular) format('svg');
    font-weight: 400;
    font-style: normal
}

h1, h2, h3, h4, h5, h6 {
    color: #000;
    font-family: Rubik, sans-serif;
    font-weight: 900;
    text-transform: uppercase;
    line-height: 1em
}

h1 {
    font-size: 4em;
    margin-bottom: .25em
}

h2 {
    font-size: 3em;
    margin-bottom: .33333em
}

h3 {
    font-size: 2.4em;
    margin-bottom: .417em
}

h4, h5, h6 {
    font-size: 2em;
    margin-bottom: .5em
}

p {
    color: #000;
    font-family: Rubik, sans-serif;
    font-weight: 400;
    font-size: 1.6em;
    line-height: 1.5em;
    margin-bottom: 1.25em
}

p + h2 {
    margin-top: 1.333em
}

p + h3 {
    margin-top: 1.667em
}

p + h4, p + h5, p + h6 {
    margin-top: 2em
}

p a {
    color: #fff
}

strong {
    font-weight: 900
}

.id-content header {
    padding: 4em 2em
}

.id-content header h1 {
    color: #fff;
    margin: 0
}

.id-content > div {
    padding: 4em 2em
}

@media all and (min-width: 720px) {
    .id-content > div {
        padding: 4em
    }

    .id-content header {
        padding: 4em
    }

    .id-content header h1 {
        font-size: 6em
    }

    body.home .id-content header h1 {
        width: 60%
    }
}

.resize {
    overflow-x: hidden;
    overflow-y: auto
}

.id-sharingmessage {
    display: none
}

.id-intro {
    height: 100vh;
    width: 100%;
    background-color: #702f8a;
    background-image: url(assets/images/bg-humanist.svg);
    background-repeat: no-repeat;
    background-size: cover;
    background-position: top right;
    position: relative
}

.innercontent {
    position: relative;
    z-index: 1
}

.cover {
    display: block;
    overflow: hidden;
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    background-color: #702f8a;
    opacity: .8;
    transition: opacity .5s ease-out
}

.id-finalscore .cover {
    background-color: #fc0
}

.id-logo {
    height: 80px;
    width: calc(100% - 8em);
    background-image: url(assets/images/logo-humanists.svg);
    background-position: center;
    background-repeat: no-repeat;
    background-size: contain;
    margin: 4em;
    text-indent: 100%;
    white-space: nowrap;
}

.id-intro h1 {
    max-width: 600px;
    margin-left: 1em;
    margin-right: 1em;
    color: #fff
}

.id-intro p {
    max-width: 600px;
    margin-left: 2.5em;
    margin-right: 2.5em;
    color: #fff
}

.id-restartquiz, .id-seefinalscore, .id-startquiz {
    color: #702f8a;
    font-family: Rubik, sans-serif;
    font-weight: 900;
    text-transform: uppercase;
    line-height: 2.5em;
    font-size: 1.6em;
    padding: .625em;
    display: block;
    overflow: hidden;
    cursor: pointer;
    cursor: hand;
    white-space: nowrap;
    background-color: #fff
}

.id-restartquiz, .id-startquiz {
    margin-left: 2.5em;
    margin-top: 2.5em;
    margin-bottom: 2.5em
}

.id-seefinalscore {
    margin-top: 2.5em
}

.id-restartquiz span, .id-seefinalscore span, .id-startquiz span {
    display: block;
    border-top: 2px solid #702f8a;
    border-bottom: 2px solid #702f8a
}

@media all and (min-width: 720px) {
    .id-logo {
        width: 240px;
        height: 80px
    }

    .cover {
        opacity: 0
    }
}

.id-questions {
    display: none;
    height: 100vh;
    width: 100%
}

.id-questions li, .id-questions ol {
    display: block;
    overflow: hidden;
    list-style: none;
    padding: 0;
    margin: 0
}

.id-questions > ol, .id-questions > ol > li {
    height: 85vh;
    width: 100%
}

.answers li {
    cursor: pointer;
    cursor: hand;
    user-select: none;
    position: relative
}

.answers li span {
    pointer-events: none;
    user-select: none
}

.answers li::after {
    content: '';
    display: block;
    width: 1em;
    height: 1em;
    border: .25em solid #fff;
    position: absolute;
    top: 1em;
    right: 1em;
    border-radius: 50%;
    transition: background-color .5s ease-out
}

.answers li.selected::after {
    background-color: #fff
}

.id-submitanswer {
    height: 15vh;
    line-height: 15vh;
    font-size: 1.6em;
    background-color: #fff;
    color: #702f8a;
    text-align: center;
    width: 100%;
    font-weight: 900;
    text-transform: uppercase;
    font-family: Rubik, sans-serif;
    cursor: pointer;
    cursor: hand
}

.id-submitanswer span {
    display: inline-block;
    border-top: 2px solid #702f8a;
    border-bottom: 2px solid #702f8a;
    line-height: 2.5em
}

.counter {
    display: block;
    position: absolute;
    font-weight: 900;
    font-size: 2em;
    background-color: #fff;
    color: #000;
    height: 1.5em;
    width: 1.5em;
    line-height: 1.5em;
    text-align: center;
    top: .5em;
    left: .5em
}

.id-questions .question {
    height: 25vh;
    line-height: 25vh;
    padding: 2em;
    text-align: center;
    display: flex;
    justify-content: center;
    flex-direction: column
}

.id-questions .question h3 {
    color: #fff;
    text-align: center;
    display: block;
    line-height: 1em;
    opacity: 0;
    transform: scale(1.2);
    margin: 0;
    user-select: none
}

.id-questions .question h3::after {
    font-family: FontAwesome;
    font-weight: 400;
    display: inline-block;
    margin-left: .25em;
    content: '\f00c';
    opacity: 0;
    transition: opacity .5s ease-out
}

.id-questions .answered .question h3::after {
    opacity: 1
}

.id-questions .question h3.bringin {
    animation: bringin 1s 1;
    animation-fill-mode: forwards
}

.id-questions .question h3.broughtin {
    opacity: 1;
    transform: scale(1)
}

@keyframes bringin {
    0% {
        opacity: 0;
        transform: scale(1.2)
    }
    100% {
        opacity: 1;
        transform: scale(1)
    }
}

.id-questions .answers {
    height: 60vh;
    display: flex;
    flex-direction: column
}

.id-questions li.answered {
    cursor: pointer;
    cursor: hand
}

.id-questions .answers li {
    width: 100%;
    display: flex;
    flex: 1 0 auto;
    flex-direction: column;
    justify-content: center;
    padding: 0 2em;
    text-align: center;
    transform: rotateY(90deg);
    transition: opacity .5s ease-out
}

.id-questions .answers li.flip {
    transform-style: preserve-3d;
    animation: flip 1s 1;
    animation-fill-mode: forwards
}

.id-questions .answers li.flipcomplete {
    transform: rotateY(0) !important
}

@keyframes flip {
    0% {
        transform: rotateY(90deg)
    }
    100% {
        transform: rotateY(0)
    }
}

.id-questions .answers li.faded {
    opacity: .4
}

.id-questions .answers li span {
    font-family: Rubik, sans-serif;
    font-size: 1.5em;
    line-height: 1em;
    font-weight: 700;
    display: block;
    max-width: 600px;
    margin: 0 auto
}

.id-questions .answers li:nth-child(4n+1) {
    background-color: #4c4184;
    color: #fc3
}

.id-questions .answers li:nth-child(4n+2) {
    background-color: #00c7b1;
    color: #702f8a
}

.id-questions .answers li:nth-child(4n+3) {
    background-color: #fc3;
    color: #702f8a
}

.id-questions .answers li:nth-child(4n+4) {
    background-color: #e87722;
    color: #4c4184
}

@media all and (min-width: 720px) {
    .answers li::after {
        width: 2em;
        height: 2em;
        border: .5em solid #fff
    }

    .id-questions .answers li span {
        font-size: 2em
    }

    .counter {
        font-size: 4em
    }

    .id-questions .answers {
        flex-direction: row;
        flex-wrap: wrap
    }

    .id-questions .answers li {
        width: 33.33333%
    }

    .id-questions .answers2 .answers li, .id-questions .answers4 .answers li {
        width: 50%
    }
}

.id-backtoscore {
    position: fixed;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    cursor: pointer;
    cursor: hand;
    display: none
}

.id-score {
    height: 100vh;
    width: 100%;
    position: fixed;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    z-index: 200;
    display: none
}

.id-score.show {
    display: block
}

.id-score.show > div {
    display: flex;
    animation: backfade 1s 1;
    animation-fill-mode: forwards;
    flex-direction: column;
    justify-content: center;
    transition: background-color .5s ease-out;
    padding: 0 4em;
    height: 100vh;
    width: 100%
}

@keyframes backfade {
    0% {
        background-color: rgba(0, 0, 0, 0)
    }
    100% {
        background-color: rgba(0, 0, 0, .8)
    }
}

.id-score li, .id-score ol {
    display: block;
    overflow: hidden;
    list-style: none;
    padding: 0;
    margin: 0
}

.id-score ol {
    width: 100%;
    display: flex;
    flex-direction: row;
    flex-wrap: wrap
}

.id-score li {
    flex: 1 0 auto;
    transform: rotateY(90deg);
    width: calc(33.33333% - 1em);
    margin-left: 1em;
    margin-top: 1em
}

.id-score li:nth-child(3n+1) {
    margin-left: 0
}

.id-score li:nth-child(-n+3) {
    margin-top: 0
}

.id-score li.flip {
    transform-style: preserve-3d;
    animation: flip 1s 1;
    animation-fill-mode: forwards
}

.id-score li.flipcomplete {
    transform: rotateY(0) !important
}

.id-score ol button {
    font-family: Rubik, sans-serif;
    font-weight: 900;
    text-transform: uppercase;
    text-align: center;
    user-select: none;
    width: 100%;
    display: block;
    overflow: hidden;
    line-height: 2em;
    padding: 0 .5em;
    font-size: 2em;
    background-color: #fff;
    color: #702f8a;
    white-space: nowrap
}

.id-score ol button span {
    opacity: .2;
    pointer-events: none
}

.id-score ol .amber button span, .id-score ol .green button span, .id-score ol .next button span, .id-score ol .red button span {
    opacity: 1
}

.id-score ol .amber button, .id-score ol .green button, .id-score ol .next button, .id-score ol .red button {
    cursor: pointer;
    cursor: hand
}

.id-score ol button span::after {
    font-family: FontAwesome;
    font-weight: 400;
    display: inline-block;
    margin-left: .25em;
    font-size: .8em;
    line-height: 1.25em
}

.id-score .amber button span::after, .id-score .green button span::after, .id-score .red button span::after {
    content: '\f00c'
}

.id-score .next button span::after {
    content: '\f054'
}

@media all and (min-width: 960px) {
    .id-score ol {
        flex-wrap: nowrap
    }

    .id-score li {
        width: auto;
        margin-top: 0
    }

    .id-score li:nth-child(3n+1) {
        margin-left: 1em
    }

    .id-score li:first-child {
        margin-left: 0
    }

    .id-score.show, .id-score.show > div {
        height: 15vh !important;
        position: absolute;
        bottom: 0;
        left: 0;
        right: 0;
        top: auto
    }

    .id-score.final .id-seefinalscore {
        height: 15vh;
        width: 250px;
        bottom: 0;
        right: 0;
        position: absolute
    }

    .id-score.final ol {
        width: calc(100% - 250px)
    }
}

.id-finalscore {
    height: 100vh;
    width: 100%;
    background-color: #fc0;
    background-image: url(assets/images/bg-humanist-final.svg);
    background-repeat: no-repeat;
    background-size: cover;
    background-position: top right;
    position: relative
}

.id-finalscore h1 {
    color: #4c4184;
    margin: 0 .5em;
    font-size: 8em
}

.id-finalscore p a {
    color: #000
}

.id-share, .id-share li {
    display: block;
    overflow: hidden;
    list-style: none;
    padding: 0;
    margin: 0
}

.id-share {
    clear: both;
    max-width: 600px;
    margin: 0 4em
}

.id-share li {
    float: left;
    width: 50%
}

.id-pointdisplay {
    margin: 0 2.5em 1.25em;
    padding: .625em 1.25em;
    font-weight: 700;
    border: 2px solid #4c4184;
    color: #4c4184;
    border-radius: .313em;
    max-width: 600px;
    float: left
}

.id-share .facebook, .id-share .twitter {
    color: #fff;
    font-weight: 900;
    text-transform: uppercase;
    text-align: center;
    width: 100%;
    display: block;
    overflow: hidden;
    font-size: 1.6em;
    line-height: 1.6em;
    padding: .5em 1em;
    font-family: Rubik, sans-serif;
    cursor: pointer;
    cursor: hand;
    white-space: nowrap
}

@media all and (min-width: 640px) {
    .id-share .facebook, .id-share .twitter {
        font-size: 2em;
        line-height: 2em
    }
}

.id-share .facebook {
    background-color: #3c5a98
}

.id-share .twitter {
    background-color: #47c7fa
}

.id-share .facebook::before, .id-share .twitter::before {
    content: '\f09a';
    display: inline-block;
    font-weight: 400;
    font-family: FontAwesome;
    margin-right: .25em
}

.id-share .twitter::before {
    content: '\f099'
}

.id-resultdisplay {
    clear: both;
    margin: 0 4em;
    max-width: 600px
}