:root{
    --annotationFont: "Fuzzy Bubbles", sans-serif;
}

.questionText .questionNumber.correct{
    background-color: var(--colorGoodBackground);
}

.questionText .questionNumber.incorrect{
    background-color: var(--colorWrongBackground) !important;
}

.percentageScore{
    text-align: center;
    font-size:3rem;
    font-weight: bold;
    position: absolute;
    top:60%;
    left: 50%;
    transform: translate(-50%, -50%);
}

.explanation{
    font-family: var(--annotationFont);
}

.annotation{
    font-family: var(--annotationFont);
    font-size:0.85rem;
    display: inline-block;
    margin-left:1.5rem;
    color: var(--colorWrong);
}

.annotation.header{
    font-size:1rem;
    margin:2rem 0;
    text-align: left;
    display: block;
}

.qwt5 .annotation{
    margin-left:0;
}

.annotation.checkmark{
    position: absolute;
    left: 0.3rem;
    top: 55%;
    font-size: 1rem;
    font-weight: bold;
    transform: rotate(-10deg) translateY(-50%);
}

.qwt6 .annotation.checkmark{
    left:-1rem;
}

.qwt7 .annotation.checkmark{
    left:1rem;
}

.annotation.correct{
    color: var(--colorGood);
}

.testBox.summary .annotationSummary{
    font-size:1rem;
    font-family: var(--annotationFont);
    margin:2rem 1rem 1rem 1rem;
    text-align: right;
}

.testBox.summary .annotationSummary.wrong{
    color: var(--colorWrong);
}

.testBox.summary .annotationSummary.good{
    color: var(--colorGood);
}

.testBox.summary.answerCheckbox.incorrect{
    opacity:1;
    border-color: var(--colorWrong);
}
.testBox.summary .answerCheckbox.correct
{
    opacity:1 !important;
    color: var(--colorGood) !important;
    background-color: var(--colorGoodBackground) !important;
}

.comboBox{
    background-color: transparent;
    border:1px dotted var(--m5InputTextColor);
}

.tfSwitch{
    display: inline-block;
    padding:0.5rem 1rem;
    margin-right:1rem;
    border: 1px solid var(--m5InputBorderColor);
    width:6rem;
    border-radius: 0.25rem;
    text-align: center;
}

.pairs .pairElement{
    background-color: var(--m5InputBackground) !important;
}

.pairs.correct{
    border-color: var(--colorGoodBorder) !important;
    background-color: var(--colorGoodBackground) !important;
}
.pairs .pairElement{
    background-color: transparent !important;
}

.tfSwitch.incorrect{
    border-color: var(--colorWrong);
}

.strikethrough{
    text-decoration: line-through;
    color: var(--colorWrong);
}

.answerCheckbox{
    border:none !important;
    display: flex !important;
    background-color: transparent !important;
    border-bottom: 1px solid var(--m5BordersLite) !important;
    border-radius: 0 !important;
    margin:0 !important;
    position: relative !important;
}

.answerCheckbox:first-of-type{
    border-radius: 0.25rem 0.25rem 0 0;
}

.answerCheckbox:last-of-type{
    border-radius: 0 0 0.25rem 0.25rem;
    border-bottom: none;
}

.questionField{
    padding:0.5rem 2.5rem 0.5rem 1.5rem;
}

/*

.pageContainer.summary{
    grid-template-columns: 20rem 1fr;
}


.summaryStatistics{
    display: grid;
    grid-template-columns: 20rem 1fr 1fr;
    gap: 4rem;
    background-color: var(--m5BoxBackgroundColor);
    border-radius: 0.5rem;
    padding:2rem;
}

H4{
    font-size:1.2rem;
}

.percentageScore{
    text-align: center;
    font-size:3rem;
    font-weight: bold;
    position: absolute;
    top:60%;
    left: 50%;
    transform: translate(-50%, -50%);
}

.columnResults{
    order:0;
}

.columnGraphs{
    margin:0;
}

.columnGraphs .box{
    margin:0;
}

.columnResults{
    margin:0 1.5rem;
}

.columnButtons{
    margin:0 0 0 1.5rem;
}

.columnButtons .buttons .button.main{
    padding:1rem;
}

.columnGraphs .sidebarSkyscraper{
    margin:2rem auto;
}

.graphContainer{
    margin:0 auto;
    box-sizing: border-box;
}

.summaryController{
    display: flex;
}

.summaryController .button{
    font-size:0.9rem;
    text-align: center;
    margin:0 0 0.5rem 0;
    border-radius: 0;
    flex:1 1;
    transition: all 400ms;
}

.summaryController .button:first-of-type{
    border-radius: 0.25rem 0 0 0.25rem;
}

.summaryController .button:last-of-type{
    border-radius: 0 0.25rem 0.25rem 0;
}

.summaryExtras A{
    font-weight: bold;
    background-color: var(--themeMainMed);
    padding:0.05rem 0.5rem;
    border-radius: 0.25rem;
    color: var(--themeColorText);
    text-decoration: none;
    transition: all 400ms;
}

.summaryExtras A:hover{
    color: var(--themeColorTextInvert);
    background-color: var(--themeMain);
}


.summaryExtras .row{
    margin:0.5rem 0;
    padding:0.5rem 0;
    border-bottom:none;
    line-height:1.6rem;
}

.summaryExtras .row .column{
    flex:1 1;
    margin-right:1rem;
}

.summaryExtras .row .column.label{
    flex:0.5 0.5;
}

.summaryExtras .row .column:last-of-type{
    text-align: right;
}

.challengePlace{
    flex: none;
    max-width: 2rem;
    min-width: 2rem;
    margin-right: 2rem;

}

.challengePlaceIndicator{
    margin: 0 auto;
    font-size: 0.8rem;
    line-height: 2.4rem;
    font-weight: bold;
    text-align: center;
    width: 2.5rem;
    height: 2.5rem;
    box-sizing: border-box;
    border-radius: 0.25rem;
    background-color: var(--themeMain);
    color: #FFF;
}

.challengePlayer{
    font-size:1.1rem;
    padding:1rem;
    margin:0 1rem;
}

.challengeScore{
    font-size: 2rem;
    color:var(--themeMainMed);
    text-align: center;
}

.summaryAnswerFeedbackBlock{
    flex: 1 1;
}

.summaryAnswerFeedbackBlock A{
    font-size:0.9rem;
    padding:0.25rem 0.5rem;
    background-color: var(--themeMainLiteMax);
    border-radius: 0.25rem;
    cursor:pointer;
}

.summaryAnswerBlock{
    display: inline-block;
    padding:0.5rem 1rem;
    border-radius: 0.25rem;
    margin:0 0.5rem 0.5rem 0;
    background-color: var(--themeColorModeBackground);
}

.summaryAnswerBlock I{
    margin-right:0.5rem;
}

.summaryAnswerBlock.correct{
    background-color: var(--themeMainLite);
}
.summaryAnswerBlock.incorrect{

}

.summarySmall{
    font-size:0.9rem;
    background-color: var(--themeColorModeUiQuizElementBackground);
    border:1px solid var(--themeColorModeBordersLite);
    padding:1rem;
    margin:2rem 0;
    border-radius:0.5rem;
}

.box .row{
    display: grid;
    grid-template-columns: 10rem 1fr 1.5fr;
    border:1px solid var(--themeColorModeBordersLite);
    font-size:0.9rem;
    transition: all 400ms;
    padding:0 !important;
    margin:2rem 0;
    border-radius: 0.25rem;
}

.box .row.header .cell{
    border-color: var(--themeMainLiteMax);
}

.box .row.locked{
    background-color: var(--themeMainLiteMax);
}

.box .row.header{
    font-weight: bold;
    background-color: var(--m5BoxBackgroundColor);
    border-radius:0.5rem 0.5rem 0 0;
}

.box .row .cell{
    border-right:1px solid var(--themeColorModeBordersLite);
    padding:1rem 0.5rem;
    box-sizing: border-box;
}

.box .row .cell.type6{
    line-height: 1.8rem;
}

.box .row .cell.paddingless{
    padding: 0;
}

.box .row.correct .cell{
    border-right-color: var(--themeMainLiteMax);
}

.answerBox .check{
    display: block;
    padding:0.25rem;

    margin-bottom: 0.25rem;
}

.box .row .cell .check H5{
    margin:0;
}

.box .row .cell .check:last-of-type{
    margin-bottom: unset;
}

.cell.question{
    font-weight:bold;
}

.cell.grade{
    text-align: center;
}

.cell .orderNumber{
    display: inline-block;
    width:1.5rem;
    height:1.5rem;
    line-height: 1.5rem;
    text-align: center;
    background-color: var(--themeMainLite);
    color:var(--themeMain);
    font-weight: bold;
    border-radius: 0.25rem;
    margin-right:0.5rem;
}

.cell .image{
    margin:1rem auto;
    max-width: 12rem;
}

.cell .image IMG{
    border-radius: 0.25rem;
}

.cell .comboBox{
    background-color: var(--themeMainLite);
    padding:0.25rem 0.5rem;
    border-radius: 0.25rem;
}

.cell .indicator{
    font-size:0.7rem;
    padding:0.25rem 0.5rem;
    border: 1px solid var(--colorWrong);
    color:var(--colorWrong);
    border-radius: 0.25rem;
}

.cell .indicator.correct{
    border-color: var(--colorGood);
    color: var(--colorGood);
}

TABLE.pairContainer{
    table-layout: fixed;
    text-align: center;
    border:none;
    border-radius: 0.25rem;
    margin:0;
    width: 100%;
    height:100%;
    border-spacing: 0;
    border-collapse: collapse;
}

TABLE.pairContainer THEAD{
    background-color: var(--themeColorModeBackground) !important;
    border-top:none !important;
}

TABLE.pairContainer THEAD TD{
    font-size:0.7rem;
    font-weight: bold;
}

.pairContainer TD{
    border-right:1px solid var(--m5InputBorderColor);
    border-bottom:1px solid var(--m5InputBorderColor);
    padding:0.5rem;
    min-width: 25%;
    max-width: 75%;
    font-size:0.9rem;
    text-align: left;
}

.pairContainer TD.status{
    width:15%;
}

.pairContainer TD.status.incorrect{

    color:#FFF;
}

.pairContainer TR.correct{

}
.pairContainer TR.incorrect.checked TD.answer .userAnswer{
    text-decoration: line-through;
    color: var(--colorWrong);
}

.pairContainer TR.correct TD.answer{


}

.pairContainer TR:last-of-type TD{
    border-bottom:none;
}

.userAnswer .text{
    color: var(--m5InputTextColor) !important;
}

.annotation{
    font-family: "Grape Nuts", cursive;
    font-size:1.2rem;
    display: inline-block;
    margin-left:1.5rem;
    color: var(--colorWrong);
}

.annotation.correct{
    color: var(--colorGood);
}

.annotationSummary{
    font-size:1.5rem;
    font-family: "Grape Nuts", cursive;
    margin:1rem;
    text-align: right;
}

.annotationSummary.wrong{
    color: var(--colorWrong);
}

.annotationSummary.good{
    color: var(--colorGood);
}


.box .row .cell:last-child{
    border-right:none;
}

.ccCorrect{
    color:var(--themeMain);
}

.switchLabel{
    width:100px;
    font-weight: bold;
    font-size:0.8rem;
    text-align: center;
    padding:0.25rem 1rem;
}

.switchLabel:first-of-type{
    margin-left:3rem;
}

.tFRow .switchContainer{
    display: flex;
}


@media screen and (max-width: 640px) {

    .summaryStatistics{
        display: block;
    }

    .box{
        padding: 0;
    }

    .box .row{
        grid-template-columns: 8rem auto;
        border-bottom:none;
    }

    .box .row .cell.grade,
    .box .row .cell.question
    {
        border:none;
    }

    .box .row > :nth-child(3) {
        grid-column: 1 / -1;
        text-align: left;
        border-bottom: 3px solid var(--themeColorModeBordersLite);
    }

    .box .row.header{
        display: none;
    }

    .percentageScore{
        font-size:3rem;
        top:65%;
    }

    .graphContainer {
        max-width: initial;
    }

    .summaryExtras{
        font-size:0.9rem;
        margin-bottom:0;
    }

    .summaryController{
        flex-direction: column;
    }

    .summaryController .button{
        margin:0;
        border-top:none;
        padding:0.25rem;
    }

    .summaryController .button:first-of-type{
        border-radius: 0.25rem 0.25rem 0 0;
        border-top:1px solid #DDD;
    }

    .summaryController .button:last-of-type{
        border-radius: 0 0 0.25rem 0.25rem;
    }

    .testBox .body H5{
        font-size:0.6rem;
    }

    .summaryAnswerBlock{
        font-size:0.8rem;
    }

    .summaryAnswerFeedbackBlock{
        padding:0;
        text-align: center;
    }

    .summaryAnswerFeedbackBlock .answerCheckboxContainer{
        align-items: center;
    }

    .tFRow{
        display: block;
    }

    .tFRow .sentence{
        width:100%;
        margin-bottom:1rem;
    }

    .tFRow .switchContainer{
        flex-direction: column;
    }

    .tFRow .switch{
        margin:0.5rem auto !important;
        flex:1 1;
    }

    .columnButtons{
        margin:0.5rem 0;
    }

    .columnResults{
        order:1;
        margin:0.5rem 0;
        padding:0;
    }

    .columnGraphs{
        order:0;
        margin:0.5rem 0;
    }

    .challengeTableColumn{
        order:1;
    }

    .challengeStartColumn{
        order:0;
    }

    .challengePlace{
        margin-right: 1rem;
    }
}*/