html,
body {
    margin: 0;    
    margin: 0;
    height: 100dvh;
    background-color: var(--custom_gray);
}

:root {
    /* #623173 #cccce4 #d1ab9e #ebdcd5*/
    /*colors*/
    --custom_black: #000000;
    --custom_darkGray: #282828;
    --custom_gray: #cccce4;
    --custom_white: #efefef;
    --custom_yellow: #F5DF4D;
    --custom_violet: #623173;
    --custom_darkViolet: #381c41;
    --custom_red: #e41421;
    --White: #fff;
    --Red: #990000;
    --Redgrey: #993333;

    color-scheme: light only;
}

.noselect {
    -webkit-user-select: none;
    -khtml-user-select: none;
    -moz-user-select: none;
    -o-user-select: none;
    user-select: none;
}

a:link {
    color: var(--custom_blue);
    text-decoration: none;
}

a:link:visited {
    color: var(--custom_blue);
    text-decoration: none;
}

a:link:hover {
    color: var(--custom_blue);
    text-decoration: underline;
}

a:link:active {
    color: var(--custom_blue);
    text-decoration: none;
}

@font-face {
    font-family: ApfelGrotezk;
    font-weight: normal;
    src: url(../fonts/ApfelGortezk-clt/ApfelGrotezk-Regular.woff2);
}

@font-face {
    font-family: ApfelGrotezk-bold;
    font-weight: bold;
    src: url(../fonts/ApfelGortezk-clt/ApfelGrotezk-Fett.woff2);
}

p,
span,
i,
footer,
figure,
figcaption,
li {
    font-family: 'ApfelGrotezk';
    margin: 0;
    padding: 0;
    text-align: left;
    font-size: calc(1dvw + 10px);
}

h1{
    font-family: 'ApfelGrotezk-bold';
    margin: 0;
    padding: 0;
    text-align: left;
    font-size: calc(1.5dvw + 15px);
}

h2,
h3,
h4,
h5,
h6,
b,
a {
    font-family: 'ApfelGrotezk';
    margin: 0;
    padding: 0;
    text-align: left;
    font-size: calc(1.1dvw + 11px);
}

.disappear {
    visibility: hidden;
    display: none;
    opacity: 0;
    -webkit-transition: visibility 0s, opacity 0.4s linear;
    /* Safari */
    transition: visibility 0s, opacity 0.4s linear;
    
}

.hide {
    display: none !important;
    visibility: hidden;
    opacity: 0;
    -webkit-transition: visibility 0s, opacity 0.4s linear;
    /* Safari */
    transition: visibility 0s, opacity 0.4s linear;
    z-index: -1;
}

@media only screen and (max-width: 888px) {
    .hideonmobile {
        display: none !important;
    }

    iframe {
        max-width: 100%;
    }
}


/* =============================================================================
================================================================================
                                Container
================================================================================
==============================================================================*/

.container{
    display: flex;
    flex-direction: row-reverse;
    background-color: var(--custom_gray);
    min-height: 100%;
}

@media only screen and (max-width: 888px) {
    .container{
        display: flex;
        flex-direction: column;
    }
}



/* =============================================================================
================================================================================
                               RIGHT GENERAL
================================================================================
==============================================================================*/

#main-right{
    width: 400px;
    display: flex;
    flex-direction: column;
    position: relative;
    right: 0;
    max-height: 100dvh;
    padding: 20px;
    box-sizing: border-box;
}

#navBar{
    display: flex;
    justify-content: space-between;
    align-items: center;
    background: var(--custom_yellow);
    text-align: right;
    padding: 10px;
}

#navBar a{
    padding: 10px 5px;
    font-size: calc(0.8dvw + 8px);
}
#navBar a:hover{
    cursor: pointer;
    color: var(--custom_violet);
}

#navBar a.langSelected{ 
    text-decoration: underline;
    color: var(--custom_violet);
}

@media only screen and (max-width: 888px) {
    #main-right{
        width: 100dvw;
        position: sticky;
        top: 0;
        padding: 0;
        max-height: 50dvh;
    }
    #navBar{
        margin: 0;
        border: 0;
        border-bottom: 1px solid;
        width: 100%;
        box-sizing: border-box;
    }
    #navBar a {
        font-size: calc(1.2dvw + 12px);
    }
}
/* =============================================================================

                                    FAQ

==============================================================================*/



#faq {
    margin-top: 20px;
    overflow: auto;
    display: flex;
    flex-direction: column;
}

#faqQuestions{
    margin-bottom: 20px;
}

#faqQuestions a{
    font-size: calc(0.8dvw + 8px);
    user-select: none;
}

#faqQuestions a:hover{
    cursor: pointer;;
    text-decoration: underline;
    color: var(--custom_violet);
}

#faqQuestions a.questionAsked{
    color: var(--custom_violet);
}

#faqReponse.showReponseDiv {
    background: var(--White);
    padding: 10px;
    margin-top: 10px;
    overflow: auto;
}

#faqReponse h2{
    text-align: center;
    padding: 10px;
}

/* Class spécifiques à une question*/

#faqReponse.quiARepondu{
    display: flex;
    flex-direction: column;
    align-items: center;
}

#faqReponse p.q-quiARepondu-oui::after{
    content: " : oui/ja";
    color: var(--custom_yellow);
}

#faqReponse p.q-quiARepondu-non::after{
    content: " : non/nein";
    color: red;
}

@media only screen and (max-width: 888px) {
    #faq{
        padding: 10px 10px 10px;
        background-color: var(--custom_gray);
        border-bottom: 1px solid;
        margin: 0;
    }
    #faqQuestions a{
        font-size: calc(1.1dvw + 11px);
    }
    #faqReponse.showReponseDiv {
        max-height: 60dvh;
    }

}


/* =============================================================================

                             resultatContainer

==============================================================================*/

#resultatsContainer{
    position: relative;
    display: flex;
    flex-direction: column;
    align-items: center;
    height: fit-content;
    padding: 10px;
    margin-top: 10px;
    background: var(--custom_white);
    overflow: auto;
}
#resultatsComparaison #divSearchBar{
    display: flex;
    align-items: center;
    margin: 20px 0 10px;
}
#resultatsComparaison #divSearchBar label{
    font-family: 'ApfelGrotezk';
    font-size: calc(10px + 0.8dvw);
    margin-right: 10px;
}
#resultatsComparaison #searchBar{
    flex-grow: 3;
    border: 0;
    height: 30px;
    font-size: calc(10px + 0.8dvw);
}
#resultatsComparaison #searchBar:focus-visible {
    border: 4px solid var(--custom_yellow);
    outline: 0;
}
#resultatsComparaison>p:first-of-type{
    margin-bottom: 10px;
    font-size: calc(1.1dvw + 12px);
}
#resultatsComparaison p:nth-child(2) {
    font-size: calc(1.1dvw + 8px);
    color: #878787;
}

#resultatsContainer #btnGetResultats{
    padding: 20px 15px;
    width: -webkit-fill-available;
    font-family: 'ApfelGrotezk-bold';
    background: var(--custom_yellow);
    color: var(--custom_darkViolet);
    border: 0;
    font-size: 30px;
    text-align: center;
}

#resultatsContainer a:hover{
    cursor: pointer;
}

#resultatsContainer #resultatsComparaison{
    width: 100%;
}

#resultatsComparaison p.formulaireIncomplet {
    text-align: center;
    color: #dc0000;
}

#resultatsContainer #resultatsComparaison div.comparaisonPoliticien{
    width: 100%;
    margin-bottom: 8px;
}
#resultatsContainer #resultatsComparaison div.comparaisonPoliticien>p:hover{
    color: var(--custom_violet);
    text-decoration: underline;
    cursor: pointer;
}

#resultatsContainer #resultatsComparaison div.comparaisonPoliticien>p{
    padding: 5px;
    font-family: 'ApfelGrotezk';
    text-align: right;
    color: var(--custom_black);
}
#resultatsContainer #resultatsComparaison div.comparaisonPoliticien>p small{
    font-size: calc(0.6dvw + 8px);
    margin-right: 8px;
    margin-left: 5px;
}

#resultatsContainer #resultatsComparaison div.comparaisonPoliticien>p:has(+ div.aCompare)::before{
    content: "-";
    padding-left: 3px;
}
#resultatsContainer #resultatsComparaison div.comparaisonPoliticien>p::before{
    content: "+";
    padding-left: 0;
    float: left;
}
#resultatsContainer #resultatsComparaison div.comparaisonPoliticien>div.descriptionPoliticienne{
    padding: 5px;
}

@media only screen and (max-width: 888px) {
    #resultatsContainer{
        margin: 0;
        border: 0;
        border-bottom: 1px solid;
        padding: 10px;
    }
    #resultatsContainer #btnGetResultats{
        margin-bottom: 0;
    }
    #resultatsComparaison>p:first-of-type{
        font-size: calc(1.3dvw + 14px);
    }
    #resultatsContainer #resultatsComparaison div.comparaisonPoliticien>p{
        font-size: calc(1.2dvw + 12px);
    }
    #resultatsContainer #resultatsComparaison div.comparaisonPoliticien>div>p{
        font-size: calc(1.2dvw + 12px);
    }
}

/* =============================================================================
================================================================================
                             introContainer
================================================================================
==============================================================================*/

#introContainer{
    box-sizing: border-box;
    display: flex;
    padding: 50px 10dvw;
    background: var(--custom_violet);
    border: 20px solid var(--custom_gray);
    z-index: 1;
    color: var(--White);
    height: 100dvh;
    overflow-x: auto;
    width: -webkit-fill-available;
}

#introLangues{
    position: absolute;
    top: 40px;
    right: 40px;
}
 
#introContainer #introLangues a {
    padding: 5px;
    user-select: none;
    color: var(--custom_white);
    text-decoration: none;
}
#introContainer #introLangues a:hover, 
#introContainer #introLangues a.langSelected{
    text-decoration: underline;
    cursor: pointer;
    color: var(--custom_yellow);
}

#introContainer .intro h1{
    font-size: calc(2dvw + 20px);
    margin-bottom: 2dvh;
    text-align: center;
}
#introContainer .intro h2{    
    margin-bottom: 15px;
    font-size: calc(1.1dvw + 11px);
    font-family: 'ApfelGrotezk-bold';
    text-align: center; 
}
#introContainer .intro h2.toggleText{    
    user-select: none;
}
#introContainer .intro .toggleText h2:hover{   
    cursor: pointer;
}
#introContainer .intro p,
#introContainer .intro a{
    margin-bottom: 13px;
    font-size: calc(0.8dvw + 10px);
}
#introContainer .intro>p:first-of-type{
    text-align: center;
}
#introContainer .intro>p:first-of-type img{
    max-width: 20dvw;
    max-height: 15dvh;
}
#introContainer .intro>p:last-of-type{
    text-align: center;
    margin-top: 50px;
    padding-bottom: 50px;
}

#introContainer a{
    color: var(--custom_yellow);
}

#introContainer #texteIntro .toggleText h2:has(+ div)::after{
    content: " -";
}

#introContainer #texteIntro .toggleText h2:has(+ div.hide)::after{
    content: " +";
}

#introContainer a.next{   
    text-align: center;
    padding: 15px;
    background: #ffffff;
    color: #623173;
    font-family: 'ApfelGrotezk-bold';
    font-size: calc(1.8dvw + 10px);
}
#introContainer a.next:hover{
    cursor: pointer;
}

@media only screen and (max-width: 888px) {
    #introContainer{
        width: 100dvw;
        padding: 60px 20px;
        border: 10px solid var(--custom_gray);
    }

    #introContainer h1{    
        font-size: calc(1dvh + 25px);
        margin-bottom: 2dvh;
    }
    
    #introContainer p{
        font-size: calc(0.8dvh + 10px);
        margin-bottom: 10px;
    
    }

    #introContainer a.next{
        font-size: calc(1.1dvh + 11px);
    }

    #introLangues{
        top: 10px;
        left: 10px;
        padding: 10px;
        background: var(--custom_violet);
        width: calc(100dvw - 40px);
        display: flex;
        justify-content: flex-end;
    }

}

/* =============================================================================
================================================================================
                             questionsContainer
================================================================================
==============================================================================*/

#questionsContainer{
    width: calc(100dvw - 400px);
    height: auto;
    display: flex;
    flex-direction: column;
    background: var(--custom_gray);
}

#questionsContainer .questionData h1{
    font-size: calc(2dvw + 20px);
    margin-right: auto;
}

#questionsContainer .questionData h2{
    padding: 20px 0;
    font-size: calc(1.5dvw + 15px);
}

#questionsContainer .questionData .descriptionQuestion{
    padding: 20px;
    background: var(--custom_darkViolet);
    color: var(--White);
    font-size: calc(0.8dvw + 10px);
}
#questionsContainer .questionData>div:first-child{
    display: flex;
    align-items: center;
}
#questionsContainer .questionData>div:first-child a{
    text-decoration: none;
    font-weight: bolder;
    font-size: calc(1.5dvw + 15px);
    margin-left: 25px;
}
#questionsContainer .questionData>div:first-child a:hover{
    cursor: pointer;
}

#questionsContainer .questionData .descriptionQuestion p, 
#questionsContainer .questionData .descriptionQuestion ul, 
#questionsContainer .questionData .descriptionQuestion ol{
    padding-bottom: 10px;
}

#questionsDivs{
    flex-grow: 2;
    margin: 20px 0 0 20px;
}

#questionsContainer label{
    font-size: 10px;
}

#questionsContainer .question{
    display: flex;
    flex-direction: column;
    box-sizing: border-box;
    background: var(--custom_violet);
    color: white;
    padding: 20px;
    margin: 0;
    height: 100%;
    margin-bottom: 20px;
}

#questionsContainer .question .radiosQuestions{
    margin-top: 20px;
    display: flex;
}

#questionsContainer .question .radiosQuestions label:not(:last-of-type){
    cursor: pointer;
    background-color: var(--White);
    color: black;
    margin: 4px;
    padding: 8px;
    transition: all .2s ease-out;
    font-size: calc(1dvw + 10px);
    font-family: 'ApfelGrotezk';
    user-select: none;
}
#questionsContainer .question .radiosQuestions label:not(:last-of-type):hover{
    background-color: var(--custom_yellow);
}
#questionsContainer .questionData a{
    color: var(--custom_yellow);
    text-decoration: underline;
    font-size: calc(0.8dvw + 10px);
}

#questionsContainer .question .radiosQuestions input[type="radio"]{
    visibility: hidden;
    display: none;
    height: 0;
    width: 0;
}

#questionsContainer .question .radiosQuestions input[type="radio"]:checked + label:not(:last-of-type){
    background-color: var(--custom_yellow);
    font-family: 'ApfelGrotezk-bold';
} 
#questionsContainer .question .radiosQuestions label:last-of-type{
    width: 100%;
    font-family: 'ApfelGrotezk';
    text-align: right;
    font-size: calc(0.8dvw + 8px);
}
#questionsContainer .question .radiosQuestions label:last-of-type:hover{
    cursor: pointer;
    text-decoration: underline;
}
#questionsContainer .question .radiosQuestions input[type="radio"]:checked + label:last-of-type{
    text-decoration: underline;
    font-family: 'ApfelGrotezk-bold';
    color: var(--custom_yellow);
}

#questionsContainer .question .radiosQuestions{
    margin-top: auto;
    display: flex;
    flex-wrap: wrap;
    padding-top: 30px;
}
#questionsContainer .reponseDefinitives{
    margin-top: auto;
    padding: 10px;
    color: var(--custom_black);
    background: var(--custom_white);
}
#questionsContainer .reponseDefinitives>p, 
#questionsContainer .reponseDefinitives b{
    color: var(--custom_black);
    font-size: calc(1dvw + 14px);
    background-color: var(--custom_yellow);
    padding: 5px;
    margin-top: 5px;
}
#questionsContainer .reponseDefinitives>p.reponseUser,
 #questionsContainer .reponseDefinitives>p.reponseUser b {
    background: var(--custom_white);
    margin: 0;
}

@media only screen and (max-width: 888px) {
    #questionsContainer{
        width: 100dvw;
    }
    #questionsContainer .question{
        margin: 10px;
        min-height: 55dvh;
    }
    #questionsContainer .question:first-of-type{
        margin-top: 10px;
    }
    #questionsContainer .questionData{
        margin-bottom: 10px;
    }
    #questionsContainer .questionData h1{
        font-size: calc(2dvw + 20px);
    }
    #questionsContainer .questionData>h2{
        font-size: calc(1.6dvw + 16px);
        padding: 10px 0;
    }
    #questionsContainer .questionData p{
        font-size: calc(1.2dvw + 12px);
    }
    #questionsContainer .questionData a {
        font-size: calc(1.2dvw + 12px);
    }
    #questionsContainer .question .radiosQuestions{
        margin-top: auto;
        justify-content: center;
    }
    #questionsContainer .question .radiosQuestions label:first-of-type{
        margin-left: 0;
    }
    #questionsContainer .question .radiosQuestions label:last-of-type{
        font-size: calc(1.1dvw + 11px);
        margin-top: 20px;
    }
    #questionsContainer .question .radiosQuestions label:not(:last-of-type){
        font-size: calc(1.2dvw + 10px)
    }
    #questionsDivs{
        margin: 0;
    }
    #questionsContainer .questionData .descriptionQuestion{
        padding: 10px 20px;
    }
    
    .container.modeResultats #questionsContainer .question{
        min-height: auto;
    }
    .container.modeResultats #questionsContainer .question{
        min-height: auto;
        padding: 10px;
    }
    .container.modeResultats #questionsContainer .questionData>h2{
        font-size: calc(1dvw + 13px);
        font-weight: lighter;
        line-height: 1;
    }
    .container.modeResultats #questionsContainer .reponseDefinitives p, 
    .container.modeResultats #questionsContainer .reponseDefinitives b{
        font-size: calc(1.2dvw + 12px);
        padding: 2px;
    }
    
}


/* =============================================================================

                             progression questions

==============================================================================*/

#progressionQuestionsGeneral{
    margin: 20px 0 20px 20px;
    padding: 20px;
    background-color: var(--custom_white);
}

#progressionQuestionsGeneral h2{
    margin-bottom: 10px;
    font-size: calc(0.9dvw + 9px);
    font-family: 'ApfelGrotezk-bold';
}

#progressionQuestions{
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
}

#progressionQuestions>div {
    width: calc(2.2dvw + 21px);
    padding: 2px;
    margin: 1px;
    box-sizing: border-box;
    background: white;
}
#progressionQuestions>div:hover{
    cursor: pointer;
}
#progressionQuestions>div.repondu{
    background-color: #F5DF4D;
}
#progressionQuestions>div.questionAffichee {
    background: black;
    color: white;
}

#progressionQuestions>div.questionAffichee.repondu {
    color: var(--custom_yellow);
}
#progressionQuestions>div>p{
    user-select: none;
    font-size: calc(0.9dvw + 9px);
}

#navQuestions{
    display: flex;
    justify-content: space-between;
    margin-top: 10px;
}

#navQuestions a{
    text-decoration: underline;
    color: var(--custom_violet);
    user-select: none;
    font-size: calc(0.9dvw + 9px);
}

#navQuestions a:hover{
    cursor: pointer;
}

@media only screen and (max-width: 888px) {

    #progressionQuestionsGeneral{
        margin: 10px;
    }

}




/* =============================================================================

                             MODE RESULTATS

==============================================================================*/



#globalContainer div.hideDescription p,
#globalContainer div.hideDescription h1,
#globalContainer div.hideDescription h2,
#globalContainer div.hideDescription ol,
#globalContainer div.hideDescription ul{
    display: none;
}

#globalContainer div.descriptionQuestion:hover{
    cursor: pointer;
}

#globalContainer div.descriptionQuestion::before{
    content: "- Infos";
    font-size: calc(1dvw + 10px);
    font-family: 'ApfelGrotezk-bold';
}

#globalContainer div.descriptionQuestion.hideDescription::before{
    content: "+ Infos";
    font-size: calc(1dvw + 10px);
    font-family: 'ApfelGrotezk-bold';
}


@media only screen and (min-width: 888px) {
    #globalContainer.modeResultats #questionsContainer .questionData h1{
        font-size: calc(1.5dvw + 15px);
    }
    #globalContainer.modeResultats #questionsContainer .questionData h2{
        font-size: calc(1.1dvw + 13px);
        padding: 10px 0 20px;
    }
    #globalContainer.modeResultats #questionsContainer .questionData .descriptionQuestion{
        padding: 1dvw;
    }
    #globalContainer.modeResultats #main-right{
        -webkit-transition: all 0.5s cubic-bezier(0.3, 0.24, 0.48, 0.93);
        transition: all 0.5s cubic-bezier(0.3, 0.24, 0.48, 0.93);
        width: 50dvw;
    }
    #globalContainer.modeResultats #questionsContainer{
        -webkit-transition: all 0.5s cubic-bezier(0.3, 0.24, 0.48, 0.93);
        transition: all 0.5s cubic-bezier(0.3, 0.24, 0.48, 0.93);
        width: 50dvw;
    }
}


/* =============================================================================

                              FOOTEURS

==============================================================================*/

div.footer{
    width: 100%;
    background: var(--custom_violet);
    color: var(--custom_white);
}

div.footer p {
    padding: 10px;
    text-align: center;
    font-size: calc(0.8dvw + 10px);
}

div.footer a {
    text-decoration: underline;
    font-size: calc(0.8dvw + 10px);
    color: var(--custom_yellow);
}

div.footer a:hover{
    cursor: pointer;
}