/* Style niespeceyficzne dla serwisów - ogólne ustawienia quizów - "framework" (jest responsywny) */

.quiz{
    color: #333;
    font-size: 20px;
    padding-left: 15px;
    margin: 30px 0 0;
}

.quiz span,
.quiz p,
.quiz h2,
.quiz h3{
    line-height: 100%;
    margin: 0;
    padding: 0;
    font-size: 1em;
}

.quiz:not(.item){    
    -webkit-box-shadow: 2px 0 5px 3px #D3D3D3;
    box-shadow: 2px 0 5px 3px #D3D3D3;
    padding: 10px;
    margin-bottom: 15px;
    -webkit-box-sizing: border-box;
    box-sizing: border-box;
}

.quiz h2{
    font-weight: bold;
    margin: 15px 0;
    padding: 10px;
    font-size: 24px;
    background-color: #D3D3D3;
    text-align: left;
    line-height: 150%;
}

.quiz .question{
    font-weight: bold;
    margin: 15px 0;
}

.quiz .question p{
    margin-top: 20px;
    font-size: 22px;
    line-height: 32px;
}

.quiz .progress {
    margin: 15px 0;
    font-weight: bold;
}

.quiz .progress .circle{
    margin-left: 10px;
}

.quiz .big_img,
.quiz .circle,
.quiz .podsumowanie > p,
.quiz .quiz-opis .good.checked,
.quiz .questions > li > span {
    font-weight: bold;
}

.quiz .big_img p{
    font-size: 22px;
}

.quiz .answers > .item{
    margin: 20px 0;
    margin-left: 10px;
    color: #FFF;
    border-radius: 20px;
    position: relative;
    width: 90%;
    box-sizing: border-box;
    cursor: pointer;
    font-weight: bold;
    font-size: 0;
}

.quiz .answers .selected{
    border-radius: 20px;
}

.quiz .answers > .item:hover,
.quiz .answers .selected{
    background-color: #FFF;
}

.quiz .answers > .item .number,
.quiz .answers > .item .text-btn{
    display: inline-block;
    vertical-align: middle;
}

.quiz .answers > .item .text-btn{
    width: calc(80% - 40px);
    margin-left: 40px;
}

.quiz .text-btn > span{
    line-height: 150%;
    font-size: 20px;
}

.quiz .answers > .item .number{
    width: 20%;
    text-align: right;
    position: relative;
    min-height: 44px;
}

.quiz .answers > .item .number::before {
    content: "";
    width: 24px;
    height: 24px;
    display: inline-block;
    vertical-align: top;
    border-radius: 50%;
    box-sizing: border-box;
    margin: 0 10px;
    position: absolute;
    left: 0;
    top: calc(50% - 12px);
    background-color: #FFF;
}

.quiz .answers > .item .number::after{
    content: "";
    width: 10px;
    height: 10px;
    display: inline-block;
    vertical-align: top;
    border-radius: 50%;
    box-sizing: border-box;
    margin: 0 10px;
    background-color: #FFF;
    position: absolute;
    left: 7px;
    top: calc(50% - 5px);
}

.quiz .answers > .item .number span,
.quiz .answers > .selected .number span{
    display: inline-block;
    font-weight: bold;
    background-color: #FFF;
    border-radius: 50%;
    width: 35px;
    height: 35px;
    line-height: 35px;
    text-align: center;
    font-size: 20px;
    margin: 4.5px 0 4.5px 40px;
}

.quiz .answers > .item:hover .number span,
.quiz .item .selected .number span{
    color: #FFF;
    float: none;
}

.quiz .answers{
    margin: 10px 0;
}

.quiz .answers li{
    margin: 15px 0 15px 10px;
    padding: 10px;
    border-radius: 15px;
}

.quiz .podsumowanie > p > span{
    font-weight: normal;
    margin-left: 20px;
}

.quiz .podsumowanie > p{
    font-size: 20px;
    line-height: 28px;
    padding: 10px 0;
}

.quiz .quiz-opis{
    padding: 20px 0;
}

.quiz .quiz-opis > p{
    font-size: 20px;
    line-height: 28px;
    font-weight: bold;
    margin-top: 0;
    padding: 10px;
}

.quiz .quiz-opis .checked{
    color: #FFF;
    position: relative;
    padding-left: 50px;
}

.quiz .quiz-opis .checked::before {
    content: "";
    width: 24px;
    height: 24px;
    display: inline-block;
    vertical-align: top;
    border-radius: 50%;
    box-sizing: border-box;
    margin: 0 10px;
    position: absolute;
    left: 0;
    top: calc(50% - 12px);
    background-color: #FFF;
}

.quiz .quiz-opis .checked::after{
    content: "";
    width: 10px;
    height: 10px;
    display: inline-block;
    vertical-align: top;
    border-radius: 50%;
    box-sizing: border-box;
    margin: 0 10px;
    position: absolute;
    left: 7px;
    top: calc(50% - 5px);
}

.quiz .quiz-opis .good{
    color: #FFF;
    font-weight: bold;
    padding-left: 50px;
}

.quiz .quiz-opis .good.checked::after{
    content: "";
    width: 10px;
    height: 10px;
    display: inline-block;
    vertical-align: top;
    border-radius: 50%;
    box-sizing: border-box;
    margin: 0 10px;
    position: absolute;
    left: 7px;
    top: calc(50% - 5px);
}

.quiz .quiz-opis .questions{
    margin-top: 20px;
}

.quiz .questions p{
    margin-top: 20px;
    font-size: 22px;
    line-height: 32px;
    color: #333;
}

/*  style specyficzne dla serwisu - SE  */

.quiz:not(.item){
    border-left: 10px solid #E00616;
}

.quiz .question{
    /* Reset - question występuje w innych stylach, bez tego wartości są przypisywane z innego arkusza. */
    position: unset;
    z-index: unset;
    width: unset;
    padding: unset;
    border: unset;
    text-align: left;
    left: unset;
    top: unset;
}

.quiz .answers > .item{
    background-color: #E00616;
    border: 2px solid #E00616;
}

.quiz .answers > .item .number span{
    color: #E00616;
}

.quiz .answers > .item:hover,
.quiz .item .selected{
    color: #E00616;
}

.quiz .answers > .item:hover .number::before,
.quiz .item .selected .number::before{
    border: 2px solid #E00616;
    background-color: #FFF;
}

/* Poniższe 2 reguły dotyczą ekranu podsumowania poprawnych i błędnych odpowiedzi */

    .quiz .quiz-opis .checked,
    .quiz .quiz-opis .checked::after{
        background-color: #F00;
    }

    .quiz .quiz-opis .good,
    .quiz .quiz-opis .good.checked::after{
        background-color: #006400;
    }


.quiz .answers > .item:active .number::after,
.quiz .item .selected .number::after{
    background-color: #E00616;
}

.quiz .progress {
    color: #E00616;
}

.quiz .quiz-opis > p{
    border: 2px solid #E00616;
}

.quiz .answers > .item .number{
    float: none;
}

.quiz .answers > .item:hover .number span,
.quiz .item .selected .number span{
    background-color: #E00616;
}

.quiz .questions > li{
    border-bottom: 2px solid #E00616;
}

/* To poniżej służy pozostawieniu koloru na selected */

.quiz .item .selected .number span{
    color: #FFF;
}