

/* STYLE ANCIEN FORMULAIRE */

h3.titre-progression{
    color: #8DC63F;
    font-family: "Oswald", sans-serif;
    font-weight: bold;
    text-transform: uppercase;
    text-align: center;
}

#barre-progression .texte_etape{
    position: absolute;
    top: 15px;
    font-weight: bold;
    opacity: 0;
    display: none;
    transition: all 0.25s;
}

#barre-progression #texte_etape_1{
    opacity: 1;
    display: block;
}

.pourcentage_barre{
    position: relative;
    width: 100%;
    height: 1rem;
    font-weight: bold;
}

.pourcentage_barre .pourcentage_gauche{
    position: absolute;
    left: 0;
}

.pourcentage_barre .pourcentage_droite{
    position: absolute;
    right: 0;
}

#barre-progression{
    position: relative;
    bottom: 30px;
    height: 60px;
    width: 100%;
    border: 3px solid #0050A4;
    overflow: hidden;
    margin-top: 45px;
}

#barre-progression #pourcentage{
    background: #8DC63F;
    height: 60px;
    width: 0;
    transition: all 1s;
    display: inline-block;
}

#barre-progression #pourcentage_etape_actuelle{
    position: relative;
    height: 60px;
    background: rgba(141, 198, 63,0.5);
    transition: all 1s;
    display: inline-block;
}

#barre-progression #pourcentage_etape_actuelle p{
    position: absolute;
    right: 30px;
}

#barre-progression #pourcentage_etape_actuelle span{
    position: absolute;
    right: 15px;
    color: #333;
    font-weight: bold;
}
/*
.headingStep{
    display: none;
}

#headingStep1{
    display: block;
}
*/
/*
.form-etape .collapse:not(.show){
    display: block;
}
*/
.section-formulaire{
    position: relative;
    background: #8DC63F;
    padding: 45px 0 15px 0;
    min-height: 625px;
}

.numero-etape{
    position: absolute;
    right: 0;
    font-size: 1.2rem;
    font-weight: bold;
}

.section-formulaire .background-formulaire{
    background-repeat: no-repeat;
    background-position: bottom right;
    background-size: 40% auto;
}

.section-formulaire .container{
    position: relative;
    transition: all 0.5s;
    opacity: 1;
}

.section-formulaire label, .section-formulaire p{
    font-weight: bold;
}

.row-form-document label{
    font-weight: bold;
    font-size: 1.1rem;
}

/* FRONT FORMULAIRE RADIO */
.section-formulaire label.control-label, .section-formulaire input[type="text"],
.section-formulaire input[type="tel"], .section-formulaire input[type="email"], .section-formulaire input[type="number"],
.section-formulaire input[type="date"]{
    /* width: 100%; */
}
.section-formulaire input[type="text"], .section-formulaire input[type="tel"], 
.section-formulaire input[type="email"], .section-formulaire input[type="number"],
.section-formulaire input[type="date"]{
    height: 35px;
    padding: 0 15px;
    color: #212529;
    border: 1px solid #ABADB3;
}

.section-formulaire textarea{
    width: 100%;
    padding: 15px 30px;
    color: #212529;
    border: 1px solid #ABADB3;
}

.section-formulaire select, .customSelect select{
    opacity: 0;
    position: absolute;
    z-index: 999;
    cursor: pointer;
    margin: 0;
    padding: 0;
    width: calc(100% - 30px);
    height: 35px;
}

/* BOOTSTRAP-SELECT ADAPTATION */

.section-formulaire .bootstrap-select .dropdown-toggle::after, .customSelect .dropdown-toggle::after {
    border-top: .4em solid;
    border-right: .4em solid transparent;
    border-left: .4em solid transparent;
    color: #8DC63F;
    font-size: 1.3rem;
}

.section-formulaire .bootstrap-select.dropup .dropdown-toggle::after, .customSelect.dropup .dropdown-toggle::after {
    border-top: 0;
    border-right: .4em solid transparent;
    border-bottom: .4em solid;
    border-left: .4em solid transparent;
}

.section-formulaire .bootstrap-select:hover .dropdown-toggle::after, .section-formulaire .bootstrap-select:active .dropdown-toggle::after, 
.section-formulaire .bootstrap-select .dropdown-toggle:focus::after, .bootstrap-select > select.mobile-device:focus + .dropdown-toggle::after,
.customSelect:hover .dropdown-toggle::after, .customSelect:active .dropdown-toggle::after, 
.customSelect .dropdown-toggle:focus::after, .customSelect > select.mobile-device:focus + .dropdown-toggle::after {
    display: inline-block !important;
    margin-left: -.75em !important;
    vertical-align: 5px !important;
}

.section-formulaire .bootstrap-select, .customSelect {
    width: 100% !important;
}

.section-formulaire .bootstrap-select .btn, .customSelect .btn, .customSelect .btn:hover, .customSelect .btn:focus, .customSelect .btn:active{
    border: 1px solid #ABADB3;
    border-radius: 0;
    height: 35px;
    font-size: 1rem;
    font-family: "Roboto", sans-serif !important;
    font-weight: normal;
    text-transform: none;
    outline: none !important;
    color: #212529;
}

/* -------------------------- */

.section-formulaire .adresse{
    margin: 5rem 0 3rem 0;
    font-weight: bold;
    font-size: 1.2rem;
}

.section-formulaire .m-row{
    margin-left: -15px;
    margin-right: -15px;
}

.section-formulaire .btn-transparent{
    margin-left: 15px;
    width: 200px;
}

.section-formulaire .message-erreur, .form-rge .message-erreur{
    font-weight: bold;
    color: red;
    display: none;
}

#erreur_code_postal *:not(strong){
    font-weight: normal;
}

#erreur_code_postal strong *{
    font-weight: bold;
}

.section-formulaire .message-erreur *:not(a){
    color: red;
}

.section-formulaire .message-information, .form-rge .message-information{
    font-weight: bold;
}

.section-formulaire #message_proprietaire{
    display: none;
}

.section-formulaire #bloc_dte_date, .section-formulaire #bloc_adresse_residence, .section-formulaire #bloc_commune_residence, .section-formulaire #bloc_code_postal_residence, 
.section-formulaire #bloc_proprietaire-autre, .section-formulaire #bloc_rfr_total_3_ans, .section-formulaire #bloc_rfr_total_6_ans, 
.section-formulaire #bloc_nb_personne_foyer_3_ans, .section-formulaire #bloc_nb_personne_foyer_6_ans{
    display: none;
}


/* REWORK */

.section-formulaire .btn-transparent{
    margin-right: 15px;
    width: 200px;
}

.section-formulaire #step-1{
    display: block;
    opacity: 1;
}

.section-formulaire label.control-label{
    text-align: right;
    padding: 5px;
}

.step-image{
    height: 150px;
    border: 2px solid #8DC63F;
    border-radius: 200px;
    width: 150px;
    background: #fff;
    overflow: hidden;
    position: relative;
    z-index: 9;
    display: flex;  
    align-items: center;
}

.step-image img{
    max-width: 75%;
    max-height: 75%;
    margin: auto;
}

.step-title{
    position: static;
    padding-left: 0;
}

.step-title h5{
    display: inline-block;
    font-weight: bold;
    font-size: 1.8rem;
    padding: 5px 30px;
    border: 2px solid #8DC63F;
    color: #8DC63F;
    position: absolute;
    top: 33.3%;
    left: 140px;
    width: 83.3%;
}

.sans-image .step-title h5{
    width: calc(100% - (16.666667% - 140px));
    left: 0;
    top: 50px;
}

.step-title i{
    float: right;
    padding-top: 2px;
    transition: all 0.25s;
}

.step-title.active h5{
    background: #8DC63F;
    color: #fff;
}

.step-title.active h5 span, .step-title.active h5 i{
    color: #fff;
}

.customSelect{
    border: 1px solid #ABADB3;
}

.section-formulaire .padding-form{
    padding: 30px 45px 30px 150px;
}

.section-formulaire .sans-image.padding-form{
    padding: 150px 45px 30px 150px;
}

.section-formulaire .col-image{
    padding: 0;
}

.section-formulaire .btn-group .btn-secondary{
    padding: 7px 15px;
    background-color: #ddd;
    color: #212529 !important;
    font-size: 1.2rem;
    font-weight: normal;
    text-transform: none;
}

.section-formulaire .btn-group .btn-secondary.focus, .section-formulaire .btn-group .btn-secondary:focus{
    box-shadow: none;
} 

.section-formulaire .btn-group .btn-secondary.active,.section-formulaire .btn-group .btn-secondary:hover, 
.section-formulaire .btn-group .btn-secondary:focus, .section-formulaire .btn-group .btn-secondary:active{
    background-color: #8DC63F !important;
    border-color: #8DC63F !important;
    color: #fff !important;
}

.section-formulaire .btn-group .btn-secondary:nth-child(2){
    border-top-right-radius: 0.25rem !important;
    border-bottom-right-radius: 0.25rem !important;
}

/* COPROPRIETE */

.copropriete .step-image, .copropriete .step-title h5{
    border: 2px solid #0050A4;
}

.copropriete .step-title.active h5{
    background: #0050A4;
}

.section-formulaire.copropriete  .btn-group .btn-secondary.active, .section-formulaire.copropriete .btn-group .btn-secondary:hover, 
.section-formulaire.copropriete .btn-group .btn-secondary:focus, .section-formulaire.copropriete .btn-group .btn-secondary:active{
    background-color: #0050A4 !important;
    border-color: #0050A4 !important;
}

.section-formulaire.copropriete .bootstrap-select .dropdown-toggle::after, .copropriete h3.titre-progression,
.copropriete .customSelect .dropdown-toggle::after {
    color: #0050A4;
}

.copropriete #barre-progression {
    border: 3px solid #212529;
    color: #fff;
}

.copropriete #barre-progression #pourcentage{
    background: #0050A4;
}

.copropriete #barre-progression #pourcentage_etape_actuelle{
    background: rgba(0,80,164,0.5);
}

#accordion_formulaire #accordionStep .collapse, #accordion_formulaire #accordionStep .headingStep{
    display: block;
}

.form-etape .headingStep{
    min-height: 150px;
}

/*-----------------------------FORMULAIRE--------------------------------------*/

input[type="checkbox"] {
    /* height: auto !important; */
    margin-right: 15px;
}

.label-checkbox {
    max-width: 90%;
    vertical-align: top;
}

.form-bloc{
    background: #fff;
    /* padding: 20px 50px 70px 50px;
    box-shadow: 0 0 5px 0 #ccc; */
}

.form-etape{
    display: none;
}

.form-etape p{
    line-height: 24px;
}

.form-style-1 .card-body{
    padding: 5.25rem 2rem;
    box-shadow: 0 0 10px #ccc;
}

.input-style-1, .form-etape input:not([type="file"]){
    height: 50px;
    padding: 0 30px;
    width: 100%;
    border-radius: 8px;
}

.form-etape textarea{
    border-radius: 15px;
}

.form-etape textarea{
    height: auto;
    padding: 15px 30px;
    width: 100%;
}

.projet-equipe{
    margin-bottom: 10px;
}

.form-etape .projet-equipe p{
    text-align: left;
    font-size: 14px;
    line-height: 18px;
    font-weight: normal;
    font-family: "Raleway", sans-serif;
}

.form-etape select{
    border: 1px solid #8dc63f;
    border-radius: 15px;
}

.form-etape i{
    margin-right: 15px;
}

.form-etape input, .form-etape textarea, .form-etape textarea:hover, .form-etape textarea:active, .form-etape textarea:focus{
    margin-bottom: 10px;
    background: #f2f2f2;
    border: 2px solid #e6e6e6;
}

.input-style-1{
    width: 100%;
}

.form-etape input[type="checkbox"]{
    display: inline-block;
    width: auto;
    vertical-align: top;
    margin-top: 5px;
}

/*
.form-etape input[type="radio"]{
    height: auto;
    width: auto;
}
*/

.form-etape input[type="radio"], .form-etape input[type="checkbox"]{
    height: 1em;
    width: 1em;
    padding: 0;
}

.form-etape input[type="radio"]{
    display: none;
}

.form-etape input[type="checkbox"]{
    border-radius: .25em;
}

.form-etape .btn-outline-primary:hover, .form-etape .btn-outline-primary:active, .form-etape .btn-outline-primary:focus, .form-etape .btn-check:checked + .btn-outline-primary{
    color: #fff !important;
    background-color: #8dc63f;
}

.form-etape .btn-outline-primary, .form-etape .btn-outline-primary:hover, .form-etape .btn-outline-primary:active, .form-etape .btn-outline-primary:focus{
    border: none;
}

.form-etape label.control-label{
    display: inline-block;
    position: relative;
    padding: 0 60px 0 50px;
    margin-right: 10px;
    text-align: left;
}

.form-etape label.control-label-checkbox{
    display: inline-block;
    position: relative;
    margin-right: 10px;
    text-align: left;
    padding: 10px 60px 20px 50px;
    line-height: inherit;
    height: auto;
    background: #e2e2e2; 
    color: #666;
    font-size: 14px;
}

.form-etape .form-check-inline label{
    width: auto;
}

.form-etape .projet-option label{
    font-size: 14px;
    font-weight: 600;
}

.form-etape .projet-option .row{
    margin: 0;
}

.form-etape .projet-option .col-sm-6{
    display: inline-block;
    padding: 0;
}

.form-etape .projet-option .col-sm-6 label, .form-etape .projet-option .col-sm-6 input{
    display: inline;
}

.invalid-feedback{
    margin-bottom: 10px;
    font-size: 13px;
    font-style: italic;
}

.message-erreur{
    font-weight: bold;
    margin-bottom: 10px;
    display: none;
}

.message-information{
    margin-bottom: 10px;
    font-weight: bold;
}

.form-etape #champs_connexion{
    display: none;
}

.form-etape #lien-inscription{
    display: none;
}

/* CUSTOM SELECT */

.customSelect{
    display: flex;
    align-items: center;
    background: #fff none repeat scroll 0 0;
    background-color: #fff;
    color: #333;
    width: 100%;
    padding-left: 15px;
    border-radius: 15px;
    height: 40px;
    overflow: hidden;
    font-size: 14px;
}

.customdisplay{
    display: block;
    width: 100%;
}

.customdisplay .nowrap{ display: inline-block; }

.customSelect i{
    position: absolute;
    top: 13px;
    font-size: 15px;
    right: 0;
}

.slide-img .customSelect{
    position: absolute;
    top: 0;
    text-align: left;
    left: 0;
}

.slide-img .customSelect i{
    font-size: 24px;
    top: 15px;
    right: 15px;
}

/* */

.p-relative{
    position: relative;
}

/*---------UTILISATIONS COULEURS MODIFIABLES DEPUIS LE BACKOFFICE--------------*/

/* FORMULAIRE */

.form-etape textarea{
    resize: none;
}

input[type="file"]{
    border: none;
    padding: 0;
    display: block;
    max-width: 100%;
}

.form-etape label a{
    color: #F17A16;
    display: inline;
}

.form-etape .btn-danger i{
    color: #fff;
}

.form-etape .customSelect{
    border: 1px solid #8dc63f;
}

.form-etape h2{
    
}

.form-etape .nom-groupe{
    color: #bb1015;
    font-weight: bold;
    font-size: 18px;
    margin-bottom: 10px;
}

.message-erreur{
    color: red;
}

/* */

.texte-bleu, .texte-bleu:hover, .texte-bleu:focus, .texte-bleu:active{color: #8dc63f !important;}  
.texte-mauve, .texte-mauve:hover, .texte-mauve:focus, .texte-mauve:active{color: #8dc63f !important;}  
.texte-orange, .texte-orange:hover, .texte-orange:focus, .texte-orange:active{color: #F17A16 !important;}  
.weight-normal{ font-weight: normal !important; }

/* MODIFICATION DE FORMULAIRE AVANCE DANS LE BACKOFFICE */

.backoffice-input-intitule{
    border: none !important;
    width: 100% !important;
    font-weight: bold !important;
    font-size: 18px !important;
    margin-bottom: 10px !important;
    resize: none !important;
    background: none !important;
    padding: 0 !important;
    outline: none !important;
}

.backoffice-input-commentaire, .backoffice-input-etape-titre{
    border: none !important;
    resize: none !important;
    background: none !important;
    padding: 0 !important;
    outline: none !important;
    margin-bottom: 10px !important;
    font-weight: 600;
}

.backoffice-input-etape-titre{
    text-align: center;
    font-size: 18px;
}

.backoffice-required{
    position: absolute;
    top: 0;
    right: 0;
    font-weight: bold;
    font-size: 18px;
    color: #8dc63f;
}

.div-champ{
    position: relative;
}

.backoffice-form-champ-menu-modif{
    opacity: 0;
}

.div-champ:hover .backoffice-form-champ-menu-modif{
    opacity: 1;
}

.backoffice-form-champ-menu-modif{
    position: absolute;
    top: 0;
    right: 15px;
    min-width: 200px;
    text-align: right;
}

.backoffice-form-champ-menu-icon{
    background: rgba(117, 76, 147, 0.8);
    display: inline-block;
    color: #fff;
    font-weight: bold;
    text-align: center;
    height: 30px;
    line-height: 30px;
    padding: 0 10px;
    cursor: pointer;
    margin-left: -4px;
}

.backoffice-form-champ-menu-icon i{
    color: #fff;
    margin: 0;
}

.backoffice-form-champ-menu-type{
    padding: 0;
    background: rgba(117, 76, 147, 0.8);
    margin: 0;
    position: absolute;
    top: 30px;
    right: 0;
    width: 100%;
    list-style: none;
    display: none;
    z-index: 9999;
}

.backoffice-form-champ-menu-type li{
    text-align: left;
    padding: 0 15px;
}

.backoffice-form-champ-menu-icon:hover .backoffice-form-champ-menu-type, .backoffice-form-champ-menu-type:hover{
    display: block;
}

.backoffice-form-champ-menu-container-icon{
    display: inline-block;
    width: 25px;
    margin-right: 10px;
}

.backoffice-form-champ-menu-type li:hover{
    background: rgba(117, 76, 155, 1);
}

.form-etape .form-group{
    margin-left: 0;
    margin-right: 0;
}

.btn-primary i{
    color: #fff;
}

.form-projet-contenu p {
    font-weight: 600;
    font-size: 18px;
    font-family: "Poppins",sans-serif;
}

.form-select::-ms-expand {
    display: none;
}

.form-etape .customCheckboxMdp{
    top: 2px;
}

.form-etape .btn i{
    /* line-height: 50px; */
    padding: 5px;
    margin-right: 0;
    color: #fff;
}

.form-etape .precedent-lien{
    float: left;
    color: #c8305e;
    font-weight: bold;
    font-size: 16px;
    cursor: pointer;
    line-height: 50px;
}

.form-etape .btn.btn-success.bg-formulaire{
    color: #fff;
}

.form-etape input[type="number"] {
    -moz-appearance: textfield;
    appearance: textfield;
}

.form-etape input[type=number]::-webkit-inner-spin-button, 
.form-etape input[type=number]::-webkit-outer-spin-button{
    -webkit-appearance: none;
}

.form-etape .form-control-number-up{
    position: absolute;
    top: 12px;
    right: 25px;
    color: #333;
    background: #fff;
    padding: 2px 7px;
    border-radius: 100px;
    cursor: pointer;
    font-size: 18px;
}

.form-etape .form-control-number-down{
    position: absolute;
    top: 12px;
    right: 70px;
    color: #333;
    background: #fff;
    padding: 5px 7px;
    border-radius: 100px;
    cursor: pointer;
    font-size: 14px;
}

.form-etape .form-control-number-up i, .form-etape .form-control-number-down i{
    margin: 0;
}

.form-etape .form-control-number-up i{
    vertical-align: top;
    margin-top: 3px;
}

.form-etape input[type="email"], .form-connexion input[type="email"]{
    padding: 6px 30px 6px 55px;
}

.form-etape input[type="tel"], .form-connexion input[type="email"]{
    padding: 6px 30px 6px 55px;
}

.form-etape input[type="date"], .form-connexion input[type="date"]{
    padding: 6px 30px 6px 55px;
}

.form-connexion input[type="password"], .form-connexion #mdp, .form-connexion #password{
    padding: 6px 30px 6px 55px;
}

.form-etape i.input-email, .form-connexion i.input-email{
    position: absolute;
    top: 2px;
    left: 2px;
    padding: 15px 30px 15px 15px;
    background: #848A96;
    border-radius: 5px;
    font-size: 16px;
}

.form-etape i.input-tel, .form-connexion i.input-tel{
    position: absolute;
    top: 2px;
    left: 2px;
    padding: 15px 30px 15px 15px;
    background: #848A96;
    border-radius: 5px;
    font-size: 16px;
}

.form-etape i.input-date, .form-connexion i.input-date{
    position: absolute;
    top: 2px;
    left: 2px;
    padding: 15px 30px 15px 15px;
    background: #848A96;
    border-radius: 5px;
    font-size: 16px;
}

.form-connexion i.input-email{
    padding: 14px 12px;
}

/* */

.img-preview{
    width: 100px;
}

.btn-danger i{
    color: #fff;
}

.piece_jointe_nom_fichier{
    margin-bottom: 20px;
}

.label-paiement{
    display: inline-flex !important;
    align-items: center;
}

.radio-paiement{
    margin-bottom: 0 !important;
    margin-right: 15px;
}

.label-paiement img{
    margin-left: 10px;
}

/* NOUVELLE BARRE DE PROGRESSION */

.etape-barre-progression{
    margin: 15px 70px;
}

.etape-barre-progression .last-etape{
    position: absolute;
    top: 0;
    right: -35px;
    width: auto;
}

.etape-barre-progression .etape-cercle-progression{
    position: relative;
    display: inline-block;
    vertical-align: middle;
    width: 40px;
    height: 40px;
    border-radius: 100px;
    margin-left: -5px;
    line-height: 40px;
    text-align: center;
    color: #6ec200;
}

.etape-barre-progression .etape-cercle-progression{
    border: 2px solid #6ec200;
}

.etape-barre-progression .etape-cercle-progression.valide{
    background-color: #fff;
    background-image: url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 20 20'%3e%3cpath fill='none' stroke='%23FFCC00' stroke-linecap='round' stroke-linejoin='round' stroke-width='3' d='M6 10l3 3l6-6'/%3e%3c/svg%3e");
}

.etape-barre-progression .etape-cercle-progression.valide span{
    display: none;
}

.etape-barre-progression .etape-cercle-progression.active{
    color: #fff;
}

.etape-barre-progression .etape-titre-progression{  
    position: relative;
    left: -25px;
    width: 190px;
}

.etape-barre-progression .etape-ligne-progression{
    width: calc(100% - 50px);
    height: 2px;
    display: inline-block;
    vertical-align: middle;
    margin-left: 0px;
}

.etape-barre-progression .etape-ligne-progression{
    background: #ddd;
}

.etape-barre-progression .etape-ligne-progression.valide{
    background: #6ec200;
}

.etape-barre-progression .etape-cercle-progression.active{
    background: #fff;
}

.etape-barre-progression .etape-cercle-progression{
    color: #333;
}

/* Version une étape */
.etape-barre-progression .etape-seule .etape-titre-progression{  
    left: calc(50% - 95px);
    text-align: center;
}

.etape-barre-progression .etape-seule .etape-ligne-progression{
    width: calc(50% - 20px);
}

.form-etape .btn-outline-primary{
    min-width: auto;
    color: #8A8A8A !important;
    background: #f2f2f2;
    text-transform: none;
    border-radius: 8px !important;
    min-height: 50px;
    padding: 15px 60px 15px 50px !important;
    /* FRONT */
    border: none !important;
    text-transform: uppercase;
    font-size: 18px !important;
    font-weight: bold !important;
}

.form-etape .btn-check:checked + .btn-outline-primary::after {
  color: #8dc63f !important;
  border-bottom: 2px solid #8dc63f;
  border-right: 2px solid #8dc63f;
}

.form-etape .btn-outline-primary-sm{
    min-width: 165px;
}

.form-etape .btn-outline-primary::before{
    content: "";
    position: absolute;
    top: 15px;
    width: 20px;
    height: 20px;
    left: 18px;
    background: #fff;
    border-radius: 3px;
}

.form-etape .btn-outline-primary.btn-radio::before{
    border-radius: 100px;
}

.form-etape .btn-check:checked + .btn-outline-primary::after{
    content: "";
    position: absolute;
    top: 18px;
    left: 25px;
    width: 7px;
    height: 12px;
    transform: rotate(45deg);
}

input[type="checkbox"].btn-check{
    position: absolute;
}

.etablissement-barre-progression-marge{
    margin: 70px 70px 15px 70px;
}

.form-saison{
    padding: 15px;
    display: inline-block;
    color: #fff;
    border-radius: 8px;
    font-weight: bold;
}

/* SELECTIZE MODIF STYLE */

.form-etape .selectize-input.full, .form-etape .selectize-control.single.selectize-input.input-active{
    background: #f2f2f2 !important;
}

.form-etape .selectize-control.single .selectize-input::after, .form-etape .selectize-control.single .selectize-input.dropdown-active::after {
    content: "\f107";
    font-size: 18px;
    font-family: "FontAwesome";
    top: 6px;
    right: calc(0.75rem + 15px);
    margin-top: 0;
    border: none;
}

/* SELECT FORMULAIRE */

.btn-light-success, .btn-light-success:hover, .btn-light-success:active, .btn-light-success:focus, 
.progress-center a.btn-light-success{
    background: #CEF8C7;
    color: #333;
    text-transform: none;
    text-decoration: none;
    min-width: initial;
    border-radius: 100px;
    font-size: 14px;
    line-height: 40px;
    height: 40px;
}

/*
.selectize-dropdown{
    position: relative;
    top: 0 !important;
}
*/

.selectize-input input{
    height: auto !important;
}

/* CSS GENERAL BACKOFFICE */

.app-main .accordion .collapse h1{
    line-height: 3rem;
}

.app-main .accordion .collapse h4{
    font-size: 1.3rem;
    margin: 0;
}

.app-main .accordion .collapse p{
    font-size: 18px;
}

.app-main .accordion .collapse a{
    color: #000000;
    font-size: 16px;
    text-decoration: none;
    /* font-weight: normal; */
}

.app-main .accordion .collapse a:hover, .app-main .accordion .collapse a:focus, .app-main .accordion .collapse a:active{
    font-size: 16px;
    text-decoration: none;
    /* font-weight: normal; */
}

.app-main .accordion .collapse label{
    font-weight: bold;
    margin-bottom: 10px;
}

.app-main .accordion .collapse .form-control, .app-main .accordion .collapse .form-control:hover, 
.app-main .accordion .collapse .form-control:focus, .app-main .accordion .collapse .form-control:active{
    border-radius: 8px;
    border: 2px solid #e6e6e6;
    background: #f2f2f2;
    padding: 0.5rem 2rem;
}

.app-main .accordion .collapse .form-control::placeholder, .form-etape input::placeholder{
    color: #b7b7b7;
} 

.app-main .accordion .collapse .btn-primary, .app-main .accordion .collapse .btn-primary:hover, 
.app-main .accordion .collapse .btn-primary:active, .app-main .accordion .collapse .btn-primary:focus, 
.app-main .accordion .collapse .btn-success, .app-main .accordion .collapse .btn-success:hover, 
.app-main .accordion .collapse .btn-success:active, .app-main .accordion .collapse .btn-success:focus{
    display: inline-block;
    position: relative;
    padding: 0 60px 0 50px;
    margin-right: 10px;
    min-width: auto;
    height: 50px;
    font-weight: bold;
    border: none;
    text-decoration: none;
    border-radius: 8px;
    line-height: 50px;
    transition: none;
}

.app-main .accordion .collapse .btn-outline-primary, .app-main .accordion .collapse .btn-outline-primary:hover, 
.app-main .accordion .collapse .btn-outline-primary:active, .app-main .accordion .collapse .btn-outline-primary:focus{
    display: inline-block;
    position: relative;
    padding: 0 60px 0 50px;
    margin-right: 10px;
    min-width: auto;
    min-height: 50px;
    font-weight: bold;
    border: none;
    text-decoration: none;
    border-radius: 8px;
    transition: none;
}

.app-main .accordion .collapse .btn-outline-primary.control-label-checkbox, .app-main .accordion .collapse .btn-outline-primary.control-label-checkbox:hover,
.app-main .accordion .collapse .btn-outline-primary.control-label-checkbox:active, .app-main .accordion .collapse .btn-outline-primary.control-label-checkbox:focus{
    padding: 10px 60px 20px 50px;
    height: auto;
    line-height: inherit;
}

.app-main .accordion .collapse input[type="tel"].form-control, .app-main .accordion .collapse input[type="email"].form-control, 
.app-main .accordion .collapse input[type="date"].form-control{
    padding: 6px 30px 6px 55px;
}


.form-etape label, .form-etape .backoffice-input-intitule{
    font-size: 16px;
    min-height: 20px;
    color: #8A8A8A;
}

/* COULEURS */

.app-main .accordion .collapse label:not(.btn) {
  display: block;
  width: 100%;
}

.app-main .accordion .collapse .dropdown-item.active, .app-main .accordion .collapse .dropdown-item:active, .app-main .accordion .collapse .dropdown-item:hover{
    background: #c8305e !important;
}

.form-etape .btn-outline-primary{
    font-weight: normal;
}

.etablissement-barre-progression .etablissement-cercle-progression{
    border: 2px solid #c8305e;
}

.etablissement-barre-progression .etablissement-cercle-progression.active{
    background: #c8305e;
}

.etablissement-barre-progression .etablissement-cercle-progression.valide{
    background-color: #c8305e;
}

.etablissement-barre-progression .etablissement-cercle-progression .etablissement-etape-titre-progression{
    color: #c8305e;
}

.etablissement-barre-progression .etablissement-ligne-progression{
    background: #c8305e;
}

.form-saison{
    background: #c8305e;
}

.form-etape i.input-email, .form-etape i.input-tel, .form-etape i.input-date{
    color: #fff;
}

.app-main .accordion .collapse .btn-success{
    text-transform: uppercase;
}

.app-main .accordion .collapse .btn-primary{
    text-transform: uppercase;
}

.form-etape h2{
    font-family: "Ubuntu", sans-serif;
    color: #000;
    font-weight: bold;
}

.form-etape p{
    font-family: "Poppins", sans-serif;
    line-height: 24px;
    color: #000;
}

.btn-multiple-lines::before{
    top: 13px !important;
}

.btn-multiple-lines::after{
    top: 14px !important;
}

.form-etape .btn-outline-primary.btn-multiple-lines{
    width: 100% !important;
    height: auto !important;
    line-height: 22px !important;
    font-size: 14px !important;
    padding: 10px 45px !important;
    text-align: left;
    margin-bottom: 0 !important;
}

.backoffice-input-etape-titre{
    position: absolute;
    top: -25px;
    left: -75px;
    width: 190px !important;
    font-weight: bold !important;
    text-transform: uppercase;
    color: #c8305e !important;
    font-size: 14px !important;
}

.formulaire-commentaire{
    position: absolute;
    top: 0;
    left: calc(100% + 60px);
    width: 70%;
    background: #fff;
    padding: 30px;
    border: 1px solid #c8305e;
    box-shadow: 0 0 10px 0 #c8305e;
    border-radius: 25px;
    font-size: 13px;
}

.champ-groupe-titre{
    margin: 130px 15px 45px 15px;
    font-size: 32px;
    line-height: 36px;
}

.form-etape .champ-groupe-titre:first-child{
    margin: 75px 15px 45px 15px;
}

.form-etape .dropdown-menu .inner.show{
    max-height: 190px !important;
}

.app-main .accordion .collapse .formulaire-commentaire{
    position: relative;
    left: 0;
    top: 30px;
    margin-bottom: 45px;
    width: 100%;
}

.app-main .accordion .collapse .form-etape input[type="checkbox"]{
    display: none;
}

.film-choix-non-concerne{
    position: relative;
    left: 0;
    bottom: 0;
    width: 100%;
}

.form-etape input, .form-etape input:hover, .form-etape input:active, .form-etape input:focus{
    background: #f2f2f2;
    border: 2px solid #e6e6e6;
}

.form-bloc .form-m-bouton{
    margin-top: 3rem;
}

/* RECAPITULATIF */

.form-bloc.recap .div-champ{
    margin-bottom: 20px;
}

.form-bloc.recap .div-champ p{
    margin-bottom: 0;
}

.btn-rouge-desactive, .btn-rouge-desactive:active, .btn-rouge-desactive:focus, .btn-rouge-desactive:hover{
    background: #fececb;
}

.tableau-de-bord-titre-formulaire-icone{
    display: inline-block;
    color: #fff;
    width: 75px;
    height: 75px;
    border-radius: 100px;
    text-align: center;
    margin-bottom: 30px;
    background: #8dc63f;
}

.tableau-de-bord-titre-formulaire-icone i{
    font-size: 46px;
    line-height: 75px;
}

.tableau-de-bord-titre-formulaire-icone{
    margin: 0;
    vertical-align: middle;
}

.tableau-de-bord-titre-formulaire-bloc{
    display: inline-block;
    width: calc(100% - 100px);
    vertical-align: middle;
    margin-left: 15px;
}

.tableau-de-bord-titre-formulaire-bloc h1{
    margin: 0;
    font-size: 16px;
    text-transform: uppercase;
    font-weight: normal;
    line-height: 16px;
}

.tableau-de-bord-titre-formulaire-bloc h2{
    margin: 0;
    font-size: 22px;
    text-transform: uppercase;
}

/*-----------------------------------------------------------------------------*/
/*---------------------------STYLE DES FORMULAIRES-----------------------------*/
/*-----------------------------------------------------------------------------*/

.form-control, .form-control:hover, .form-control:focus, .form-control:active{
    /* border-radius: 8px; */
    background: #ffffff;
    /* padding: 0.75rem 2rem; */
}

.form-control{
    border-color: transparent;
}

.lien-mot-de-passe-oublie{
    text-align: left;
    margin-left: 1rem;
}

.bg-gray{
    background: #eee;
}

.img-apercu{
    width: 200px;
    height: auto;
    max-height: 200px;
}

#formulaire-connexion h2, #formulaire-inscription h2{
    font-size: 22px;
}

#formulaire-connexion a{
    font-weight: bold;
    color: #3B7EB1;
}

.align-center{
    align-items: center;
}

.img-connexion{
    height: 100%;
    min-width: 100%;
}

/* CHECKBOX */

.label-checkbox::before{
    border-radius: .25rem;
    position: absolute;
    top: 0.25rem;
    left: 0;
    display: block;
    width: 1.25rem;
    height: 1.25rem;
    pointer-events: none;
    content: "";
    -webkit-user-select: none;
    -moz-user-select: none;
    -ms-user-select: none;
    user-select: none;
    background-color: #fff;
}

input[type=checkbox]:checked ~ .label-checkbox::after {
    background-image: url("data:image/svg+xml;charset=utf8,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 8 8'%3E%3Cpath fill='%23fff' d='M6.564.75l-3.59 3.612-1.538-1.55L0 4.26 2.974 7.25 8 2.193z'/%3E%3C/svg%3E");
}

.label-checkbox::after{
    position: absolute;
    top: .25rem;
    left: 0;
    display: block;
    width: 1.25rem;
    height: 1.25rem;
    content: "";
    background-repeat: no-repeat;
    background-position: center center;
    background-size: 50% 50%;
}

/* SIDEBAR */

.sidebar{
    color: #8A8A8A;
    box-shadow: 0 0 5px 0 #ccc;
    z-index: 99;
    position: relative;
    transition: width 0.2s;
}

.sidebar .logo{
    max-width: 150px;
    max-height: 150px;
    margin: 50px 0;
}

.sidebar hr{
    margin-left: -15px;
    width: calc(100% + 30px);
}

/*
.img-menu-secondaire{
    display: inline-block;
    padding: 10px;
    border-radius: 100px;
    background: #eee;
    vertical-align: top;
    position: relative;
    z-index: 9;
}
*/

.img-menu-secondaire{
    padding: 10px;
    z-index: 9;
    position: absolute;
    top: 0;
    left: 0;
}

.menu-sidebar ul{
    list-style: none;
}

.menu-sidebar ul li{
    position: relative;
}

.img-menu-secondaire i{
    margin: 2px;
}
/*
.menu-titre{
    background: #eee;
    text-align: right;
    display: inline-block;
    width: calc(100% - 50px);
    color: #333;
    margin-left: -25px;
    padding: 11px 11px 12px 11px;
    border-top-right-radius: 100px;
    border-bottom-right-radius: 100px;
    z-index: 1;
    position: relative;
}
*/

.menu-titre{
    background: #eee;
    text-align: right;
    width: 100%;
    color: #333;
    padding: 11px 11px 12px 11px;
    z-index: 1;
    position: relative;
    border-radius: 10px;
}

/*
.sidebar .active a .img-menu-secondaire, .sidebar li a:hover .img-menu-secondaire, .sidebar li a:active .img-menu-secondaire, .sidebar li a:focus .img-menu-secondaire{
    background: #DEC8EE;
}
*/

.sidebar ul{
    padding: 30px 45px;
}

.sidebar ul li{
    margin-bottom: 15px;
}

.sidebar ul li i{
    font-size: 22px;
    width: 25px;
    margin-right: 10px;
}

.sidebar ul li a{
    color: #8A8A8A;
    font-weight: bold;
    width: 100%;
}

.sidebar-logo-align{
    text-align: center;
}

.sidebar.closed{
    width: 80px;
}

/*
.sidebar.closed .sidebar-logo-align, .sidebar.closed hr, .sidebar.closed .menu-sidebar, .sidebar.closed .burger-menu-desktop-close{
    display: none;
}
*/

.sidebar.closed .sidebar-logo-align, .sidebar.closed .menu-sidebar .menu-titre, .sidebar.closed .burger-menu-desktop-close{
    display: none;
}

.sidebar.closed ul{
    padding: 150px 0px 0 5px;
}

.sidebar.closed ul li i{
    margin: 0;
}

.sidebar.closed .img-menu-secondaire{
    text-align: center;
}

.burger-menu-desktop-close{
    position: absolute;
    top: 20px;
    right: 30px;
    font-size: 36px;
    cursor: pointer;
}

.burger-menu-desktop{
    display: none;
}

.sidebar.closed .burger-menu-desktop{
    display: block;
    font-size: 32px;
    text-align: center;
    padding: 15px 0;
    cursor: pointer;
}

.burger-menu{
    display: none;
}

/* TABLEAU DE BORD */

.bg-tableau-de-bord.fullwidth{
    width: calc(100% - 80px);
}

.bg-tableau-de-bord{
    /* background: #f5f5f5; */
    transition: width 0.2s;
}

.tableau-de-bord{
    min-height: 100vh;
}

.tableau-de-bord-header{
    /* box-shadow: 0 0 5px 0 #ccc;
    background: #fff; */
    position: relative;
}

.tableau-de-bord-header h1{
    font-weight: bold;
    /* font-size: 42px; */
    margin-bottom: 3rem;
    color: #333;
    margin: 0;
    text-align: left;
    font-size: 24px;
}

.tableau-de-bord-header .prenom{
    font-size: 32px;
    font-weight: bold;
}

.tableau-de-bord-header-margin{
    /* margin: 15px 30px; */
    z-index: 9;
}

.tableau-de-bord-header-fond{
    position: absolute;
    top: 0;
    right: 0;
    text-align: right;
    z-index: 1;
    height: 100%;
    padding: 0;
}

.tableau-de-bord-header-fond img{
    height: 100%;
    width: auto;
}

.tableau-de-bord-etape{
    background: #fff;
    width: 100%;
    min-height: 75px;
    display: flex;
    /*! margin-bottom: 30px; */
    /* box-shadow: 0 0 5px 0 #ccc; */
    /* padding: 0; */
    padding: 0 0 50px 0;
    font-size: 16px;
    position: relative;
    overflow-y: hidden;
}

.tableau-de-bord-etape-numero{
    width: 75px;
    height: 75px;
    text-align: center;
    color: #333;
    font-weight: bold;
    display: flex;
    align-items: center;
    border-radius: 100px;
}

.tableau-de-bord-etape-numero i{  
    font-size: 42px;
    margin: auto;
    color: #333;
}

.tableau-de-bord-etape-texte{
    margin: 0 0px 0 10px;
    /* width: calc(100% - 170px); */
    width: calc(100% - 75px);
}

.tableau-de-bord-etape-titre{
    color: #333;
    font-size: 20px;
    font-weight: bold;
}

.tableau-de-bord-etape-progression{
    font-size: 20px;
}

.tableau-de-bord-etape-fleche{
    width: 75px;
    height: 75px;
    background: #eee;
    line-height: 75px;
    text-align: center;
    font-size: 60px;
}

.tableau-de-bord-etape-lien, .tableau-de-bord-etape-lien-long{
    position: absolute;
    top: 75px;
    left: 35px;
    /* height: 80px; */
    height: 100%;
    background: #333;
    width: 2px;
}

.tableau-de-bord-etape-lien-long{
    /* height: 275px; */
    height: 100%;
}

.tableau-de-bord-etape:last-child .tableau-de-bord-etape-lien{
    display: none;
}

.tableau-de-bord-etape-formulaire{
    color: #333;
    display: inline-block;
    padding: 10px;
    margin-right: 15px;
    margin-bottom: 10px;
    font-weight: normal;
    font-size: 16px; 
    position: relative;
    padding: 10px 60px 10px 20px;
    text-transform: uppercase;
    border-radius: 100px;
}

.tableau-de-bord-etape-formulaire-icone{
    background: #fff;
    position: absolute;
    top: 2px;
    right: 2px;
    border-radius: 100px;
    width: 40px;
    height: 40px;
    font-size: 24px;
}

.tableau-de-bord-etape-formulaire-fond-icone{
    background: #333;
    color: #fff;
    text-align: center;
}

.tableau-de-bord-etape-formulaire-icone i{
    font-size: 24px;
    line-height: 40px;
}

.tableau-de-bord-etape-formulaire a, .tableau-de-bord-etape-formulaire a:hover, .tableau-de-bord-etape-formulaire a:active, .tableau-de-bord-etape-formulaire a:focus{
    color: #333;
}

.tableau-de-bord-message-candidat{
    display: inline-block;
    width: calc(100% - 75px);
    margin-bottom: 30px;  
    padding: 0 20px;
}

.tableau-de-bord-message-candidat-icone{
    display: inline-block;
    color: #fff;
    width: 75px;
    height: 75px;
    border-radius: 100px;
    text-align: center;
    margin-bottom: 30px;
}

.tableau-de-bord-message-candidat-icone i{
    font-size: 46px;
    line-height: 75px;
    color: #fff;
}

.ric-date-tdb i{
    font-size: 24px;
    border: 1px solid #333;
    border-radius: 100px;
    padding: 10px 11px;
    display: inline-block;
}

.ric-date-tdb div{
    display: inline-block;
    vertical-align: top;
    margin: 0 0 0 10px;
    width: calc(100% - 70px);
    font-size: 14px;
}

.padding-ric-dernier-choix{
    padding: 0 30px;
}

/* BLOC ACTIVITE */

.tableau-de-bord-activite{
    position: relative;
    height: 50px;
    margin-bottom: 50px;
}

.tableau-de-bord-activite-bloc{
    min-height: 500px;
    background: #fff;
    padding: 30px;
}

.tableau-de-bord-activite-bloc h3{
    margin-bottom: 2em;
}

.tableau-de-bord-activite .fa{
    border-radius: 100px;
    width: 50px;
    height: 50px;
    padding: 13px 15px;
    display: inline-block;
    vertical-align: top;
}

.tableau-de-bord-activite .fa-graduation-cap{
    padding: 13px 12px;
}

.tableau-de-bord-activite .fa-user-plus{
    padding: 13px;
}

.tableau-de-bord-activite .fa-plus{
    font-size: 32px;
    padding: 5px 14px;
}

.tableau-de-bord-activite-detail{
    display: inline-block;
    width: calc(100% - 75px);
    font-size: 16px;
    vertical-align: middle;
    margin-left: 15px;
}

.tableau-de-bord-activite-date{
    font-size: 14px;
    color: #8A8A8A;
}

.tableau-de-bord-activite-lien{
    width: 2px;
    height: 49px;
    background-color: #ddd;
    position: absolute;
    bottom: -50px;
    left: 24px;
}

.tableau-de-bord-formation-choix-bloc{
    background: #fff;
    font-size: 18px;
    text-align: center;
    box-shadow: 0 0 5px 0 #ccc;
}

.tableau-de-bord-formation-choix-bloc-padding{
    padding: 30px 15px;
}

.tableau-de-bord-formation-choix-bloc .tableau-de-bord-formation-choix-titre{
    font-size: 24px;
    font-weight: bold;
    margin-bottom: 20px;
}

.tableau-de-bord-formation-choix-bloc .tableau-de-bord-formation-choix-lien{
    background: #eee;
    padding: 15px;
    font-weight: bold;
    display: block;
}

.btn-rouge-desactive, .btn-rouge-desactive:active, .btn-rouge-desactive:focus, .btn-rouge-desactive:hover{
    color: #fb0d00;
    font-weight: bold;
    min-width: initial;
    height: auto;
    line-height: inherit;
    padding: 10px 20px;
}

.text-violet, .text-violet:hover, .text-violet:active, .text-violet:focus{
    color: #4A38BE !important;
}

.tableau-de-bord .nav-tabs .nav-item .nav-link{
    background: #eee;
    color: #333;
    margin-right: 10px;
    padding: 10px 30px;
}

.tableau-de-bord .nav-tabs .nav-item.show .nav-link, .tableau-de-bord .nav-tabs .nav-link.active{
    color: #fff;
}

.btn-auto{
    min-width: inherit;
}

.text-disabled, .text-disabled:hover, .text-disabled:active, .text-disabled:focus{
    color: #333333;
}

.btn-gris{
    background: #212529 !important;
    color: #fff !important;
    border-color: #212529 !important;
}

.btn-recap{
    margin-top: 20px;
}

.btn-recap .btn:first-child{
    float: left;
}

.btn-recap .btn:last-child{
    float: right;
}

#formulaire-connexion .form-control, #formulaire-inscription .form-control{
    border: 2px solid #e6e6e6;
    background: #f2f2f2;
}

#formulaire-connexion .form-control[readonly], #formulaire-inscription .form-control[readonly]{
    background: #ddd;
}

.formulaire-connexion-btn .btn{
    min-width: auto;
    width: 100%;
}

.page-form-connexion{
    display: flex;
    align-items: center;
}

/* FORMULAIRE */

.customCheckboxMdp{
    position: absolute;
    top: 1px;
    right: 1px;
    z-index: 1;
    height: calc(100% - 2px);
    width: 38px;
    display: flex;
    align-items: center;
}

.customCheckboxMdp i{
    cursor: pointer;
    margin: auto;
}

.customCheckboxMdp i:hover, .customCheckboxMdp i:active, .customCheckboxMdp i:focus{
    color: #000;
}

.btn-primary{
    background-color: #8dc63f;
    border-color: #8dc63f;
}

.form-erreur{
    font-weight: bold;
    color: red;
    display: none;
}

.form-etape .control-label-checkbox{
    font-size: 16px !important;
}

#formulaire-inscription input[type="email"], #formulaire-inscription input[type="tel"]{
    padding: 0 60px;
}