:root {
    --theme-primaryDark: #253475;
    --theme-secondaryDark: #871c60;
    --theme-backgroundDark: #4D4D4F;
    --theme-backgroundLight: #F0F0F0;
    --theme-appBackground: #FFFFFF;
}



* {
    font-family: 'Roboto', Helvetica, sans-serif;
}

a {
    color:var(--theme-primaryDark);
    font-weight:bold;
}

a:hover {
    text-decoration: underline;
    color:var(--theme-secondaryDark);
}

a:focus
{
    outline:0;
}
html {
    overflow-y: auto;
    overflow-x: hidden; /* I do NOT want hz scroll */
    background-color:var(--theme-appBackground);
}



body {
    background-color:var(--theme-appBackground);
}

header {
    width:100%;
}
header img {
    height:100px;
    width:200px;
    float:left;
    margin: 15px;
}
header h1 {
    font-size:25px;
    font-weight:bold;
    height:30px;
    margin-top:35px;
    margin-bottom:35px;
    padding:0 25px;
    text-align:center;
    float:left;
    width:calc(100% - 230px);
    color:var(--theme-primaryDark);
}
header::after {
    clear:both;
}

#content {
    border-top:2px solid var(--theme-secondaryDark);
}

p.etape {
    padding:5px 10px 5px 20px;
}

p.etape.hidden {
    display:none;
}

p.etape_niveau_1 {
    font-size: 20px;
    background-color: var(--theme-primaryDark);
    color:var(--theme-appBackground);
    padding:25px 10px 25px 20px;
    text-align: center;
    margin: 0;
}
p.etape_niveau_1 span span {
    font-size: 12px;
    display:block;
    background-color: var(--theme-appBackground);
    color:var(--theme-primaryDark);
    padding:25px 10px 25px 20px;
    text-align: left;
}
p.etape_niveau_2 {
    font-size: 18px;
    /*background-color: var(--theme-appBackground);
    color:var(--theme-secondaryDark);*/
    background-color: var(--theme-secondaryDark);
    color:var(--theme-appBackground);
    border:2px solid var(--theme-secondaryDark);

    border-width:0 0 0px 0;
    padding:15px 10px 15px 30px;
}
p.etape_niveau_3 {
    font-size: 16px;
    padding:5px 10px 5px 35px;
    font-weight:bolder;
    font-style: italic;
    border:2px solid var(--theme-secondaryDark);
    border-width:2px 0 2px 0;
}

p.question {
    padding:5px;
    font-size: 14px;
    padding:5px 10px 5px 50px;
    margin:10px 0 10px 0;
}


p.question_mandatory span.questionLibelle {
    font-weight:bold;
}
p.question_mandatory span.questionLibelle::after {
    content: ' *';
    color:red;
}

input.inca {
    border:1px solid var(--theme-secondaryDark);
    border-radius: 5px;
    height:30px;
    padding:0 5px ;
    font-weight:bold;
    color:var(--theme-secondaryDark);
}
input.inca.integer {
    width:100px;
}
input.inca.string {
    width:100%;
}
input.inca.error {
    border-color:red;
}

select.inca {
    border:1px solid var(--theme-secondaryDark);
    border-radius: 5px;
    height:30px;
    padding:0 5px ;
}
select.inca.error {
    border-color:red;
}

table {
    margin:0 0 15px 60px;
    border:1px solid var(--theme-secondaryDark);
    border-radius: 5px;
}
table tr {
    border-collapse: collapse;
    border-radius: 5px;
}
table tr th, table tr td {
    font-size: 14px;
    border:1px solid var(--theme-secondaryDark);
    border-radius: 5px;
    padding:5px 10px;
    text-align: center;


}
table tr th {
    font-size: 15px;
    font-weight:bolder;

}

table tr td:first-child {
    font-weight:bold;
    text-align:right;
}


td.td_mandatory span::after {
    content: ' *';
    color:red;
}

#nav {
    width:100%;
    height:100px;
    text-align: center;
    position: fixed;
    bottom: 0;
    background-color: var(--theme-appBackground);
    border-top:2px solid var(--theme-secondaryDark);
}
#nav a {
    display:inline-block;
    /*position:absolute;*/
    /*width:150px;*/
    min-width:150px;
    padding:14px 30px 0 30px;
    height:50px;
    border-radius: 5px;
    color: var(--theme-appBackground);
    background-color: var(--theme-secondaryDark);
    margin-top:25px;
}
a#previousScreen {

    margin-right:20px;
    visibility:hidden;
}
a#nextScreen {

    margin-left:20px;
    visibility:visible;
}
a#previousStart {

    margin-right:20px;
    visibility:hidden;
}
a#nextStart {

    margin-left:20px;
    visibility:visible;
}
a#previousEtape1 {

    margin-right:20px;
    visibility:visible;
}
a#nextEtape1 {

    margin-left:20px;
    visibility:visible;
}
a#previousEtape2 {

    margin-right:20px;
    visibility:visible;
}
a#nextEtape2 {

    margin-left:20px;
    visibility:visible;
}
a#previousEtape3 {

    margin-right:20px;
    visibility:visible;
}
a#nextEtape3 {

    margin-left:20px;
    visibility:visible;
}
a#previousEtape4 {

    margin-right:20px;
    visibility:visible;
}
a#nextEtape4 {

    margin-left:20px;
    visibility:visible;
}
a#previousEtape5 {

    margin-right:20px;
    visibility:visible;
}
a#nextEtape5 {

    margin-left:20px;
    visibility:visible;
}
a#previousEtape6 {

    margin-right:20px;
    visibility:visible;
}
a#nextEtape6 {

    margin-left:20px;
    visibility:visible;
}
a#previousEtape7 {

    margin-right:20px;
    visibility:visible;
}
a#nextEtape7 {

    margin-left:20px;
    visibility:visible;
}

a#print {
    float:right;
    margin-right:40px;
}
#contentForm {
    margin-bottom:150px;
}
p#etape_48 {
    display:none;
}
select {
    border:1px solid var(--theme-primaryDark);
    border-radius: 5px;
    height:30px;
    padding:0 5px ;
    font-weight:bold;
    color:var(--theme-secondaryDark);
}
.errorMessage {
    padding: 0;
    color: red;
    font-size: 12px;

    font-weight: bold;
    display:none;
}
.errorTableau {
    padding:5px 10px 5px 50px !important;
}
#etape_0 {
    margin:20px;
}
#etape_fin {
    /*display:none;*/
    margin:20px;
}


textarea {
    /* resize: vertical; */
    display: block;
    width: 90%;
    border: 1px solid var(--theme-secondaryDark);
    color:var(--theme-secondaryDark);
    border-radius: 5px;
    min-height: 100px;
    padding: 10px;
     margin: 10px 0;
}
textarea.error {
    border-color:red;
}

/*select[multiple] {
    background:none;
    width:auto;
    height:auto;
    padding:0;
    margin:0;
    border-width: 2px;
    border-style: inset;
    -moz-appearance: menulist;
    -webkit-appearance: menulist;
    appearance: menulist;
}*/
.glyphicon-ok::before {
    content: "\2713";
    /*content: "\e013";*/
    font-size: 18px;
    color: var(--theme-secondaryDark);
    margin-top: 4px;
    display: block;
    font-weight:bold;
}
span.questionSousLibelle {
    display:block;
    color: grey;
    font-size: 12px;
}
.dropdown-toggle {
    border: 1px solid var(--theme-secondaryDark);
}
div#alert {
    display:none;
}
p.texteadd {
    font-size: 14px;
    padding: 15px 15px 15px 50px;
}
/*p#etape_31 span, p#etape_32 span, p#etape_33 span, p#etape_34 span, p#etape_35 span {
    padding-left: 15px;
    display: block;
}
p#etape_31 span::before, p#etape_32 span::before, p#etape_33 span::before, p#etape_34 span::before, p#etape_35 span::before {
    display: block;
    content: '→';
    float: left;
    margin: -2px 5px 5px 5px;

}*/
#loader {
    position: fixed;
    top: 0;
    bottom: 0;
    left: 0;
    right: 0;
    text-align: center;
    background-color: rgba(255, 255, 255, 1);
    /* background-color: transparent; */
    /*display: none;*/
    z-index: 255;
}
.loader {
width: 48px;
height: 48px;
border: 5px solid #FFF;
border-bottom-color: var(--theme-secondaryDark);
border-radius: 50%;
display: inline-block;
box-sizing: border-box;
animation: rotation 1s linear infinite;
    margin-top: 25%;
}

@keyframes rotation {
0% {
    transform: rotate(0deg);
}
100% {
    transform: rotate(360deg);
}
}


@media(max-width:640px){

    h1 {
        width:100% !important;
    }
    header img {
        margin: 15px auto 0 auto !important;
        float:none !important;
        height: 80px !important;
        width: auto !important;
    }
    #nav {
        height: 220px !important;

    }
    #nav a {
        display: block;
        /* position: absolute; */
        width: 150px !important;
        margin-left:auto !important;
        margin-right:auto !important;
        margin-top: 15px !important;
    }
    a#print {
        float:none !important;
    }
    #contentForm {
        margin-bottom: 250px !important;
    }
    p.question {
        padding-left: 10px !important;
    }
    table {
        margin: 0 auto !important;
    }
    .questionspecetablissement {
        margin-left: 60px !important;
    }
}
#print {
    /*display:none !important;*/
}



/*#etablissements , #ecran_2, #contentForm, body{
    min-height:100%;
}*/
#etablissements {
    text-align: center;
}
#creerEtablissement {
    display: inline-block;
    /* position: absolute; */
    /* width: 150px; */
    min-width: 150px;
    padding: 14px 30px 0 30px;
    height: 50px;
    border-radius: 5px;
    color: var(--theme-appBackground);
    background-color: var(--theme-secondaryDark);
    margin-top: 25px;
}
#etablissementformactions {
    text-align: center;
}
#etablissementformactions a {
    display: inline-block;
    /* position: absolute; */
    /* width: 150px; */
    min-width: 100px;
    padding: 14px 30px 0 30px;
    height: 50px;
    border-radius: 5px;
    color: var(--theme-appBackground);
    background-color: var(--theme-secondaryDark);
    margin:15px;
}
#etablissementform {
    text-align: left;
    width:800px;
    margin:20px auto;
    border:1px solid black;

}
#etablissementform p.question {
    padding:5px 10px;
}
#etablissementsdeclarees {
    display: block;
    font-size: 1.5em;
    padding-top: 25px;
    padding-bottom: 25px;
    color:var(--theme-primaryDark);
    font-weight:bold;
}
.etablissementmode {
    text-align: center;
    display: block;
    font-size: 1.5em;
    padding-top: 25px;
    color:var(--theme-primaryDark);
    font-weight:bold;
}
#existingetablissements {

}

div.etablissement {
    display: inline-block;
    width: 90%;
    border: 1px solid var(--theme-primaryDark);
    /* min-width: 100px; */
    /* min-height: 100px; */
    margin: 3px 10px;
    border-radius: 5px;
    /* width: 400px; */
    /* color: var(--theme-primaryDark);
}
div.etablissement::after {
    /*display:block;
    content:'&nbsp;';*/

}
div.etablissement span.nom {
    display: block;
    text-align: center;
    font-size: 18px;
    padding: 0px 5px;
    margin: 2px 0 0 0;
    background-color: var(--theme-primaryDark);
    background-color: #fff;
    color: var(--theme-appBackground);
    color: var(--theme-primaryDark);
    font-weight: bold;
    float: left;
    width: calc(100% - 200px);
    border-radius: 5px;
}
div.etablissement span.type {
    display:inline-block;

    text-align: center;
    font-size: 14px;
    padding: 10px 15px;
    background-color:var(--theme-primaryDark);
    color: var(--theme-appBackground);
    font-weight: bold;
    margin: 10px;
    border-radius: 5px;
}
div.etablissement span.ville {
    display: inline-block;
    text-align: center;
    font-size: 16px;
    padding: 10px 15px;
    font-weight: bold;
    color: var(--theme-primaryDark);
}
div.etablissement a {
    display: inline-block;
    text-align: center;
    font-size: 13px;
    padding: 5px 5px;
    color: var(--theme-secondaryDark);
}



.questionspecetablissement {
    margin:0;
    margin-left:20px !important;
}
.psite {
    font-size: 14px;
    padding: 5px 10px 5px 70px;
    font-weight :bold;
}
.questionLibelleEtablissement {

}
@media(max-width:640px){
    .psite {
        padding: 5px 10px 5px 30px;
    }
    .questionspecetablissement {
        margin-left: 30px !important;
    }
}

/* ARS */
/*#arss , #ecran_2, #contentForm, body{
    min-height:100%;
}*/
#arss {
    text-align: center;
}
#creerARS {
    display: inline-block;
    /* position: absolute; */
    /* width: 150px; */
    min-width: 150px;
    padding: 14px 30px 0 30px;
    height: 50px;
    border-radius: 5px;
    color: var(--theme-appBackground);
    background-color: var(--theme-secondaryDark);
    margin-top: 25px;
}
#arsformactions {
    text-align: center;
}
#arsformactions a {
    display: inline-block;
    /* position: absolute; */
    /* width: 150px; */
    min-width: 100px;
    padding: 14px 30px 0 30px;
    height: 50px;
    border-radius: 5px;
    color: var(--theme-appBackground);
    background-color: var(--theme-secondaryDark);
    margin:15px;
}
#arsform {
    text-align: left;
    width:800px;
    margin:20px auto;
    border:1px solid black;

}
#arsform p.question {
    padding:5px 10px;
}
#arssdeclarees {
    display: block;
    font-size: 1.5em;
    padding-top: 25px;
    padding-bottom: 25px;
    color:var(--theme-primaryDark);
    font-weight:bold;
}
.arsmode {
    text-align: center;
    display: block;
    font-size: 1.5em;
    padding-top: 25px;
    color:var(--theme-primaryDark);
    font-weight:bold;
}
#existingarss {

}

div.ars {
    display: inline-block;
    width: auto;
    border: 2px solid var(--theme-primaryDark);
    min-width: 100px;
    min-height: 100px;
    margin: 10px 10px;
    border-radius: 5px;
    width: 400px;
}
div.ars::after {
    /*display:block;
    content:'&nbsp;';*/

}
div.ars span.nom {
    display: block;
    text-align: center;
    font-size: 18px;
    padding: 10px 5px;
    margin: 0;
    background-color:var(--theme-primaryDark);
    color: var(--theme-appBackground);
    font-weight: bold;
}
div.ars span.type {
    display:inline-block;

    text-align: center;
    font-size: 14px;
    padding: 10px 15px;
    background-color:var(--theme-primaryDark);
    color: var(--theme-appBackground);
    font-weight: bold;
    margin: 10px;
    border-radius: 5px;
}
div.ars span.ville {
    display: inline-block;
    text-align: center;
    font-size: 16px;
    padding: 10px 15px;
    font-weight: bold;
    color: var(--theme-primaryDark);
}
div.ars a {
    display: inline-block;
    text-align: center;
    font-size: 14px;
    padding: 10px 5px;
    color:var(--theme-secondaryDark);
}



.questionspecars {
    margin:0;
    margin-left:20px !important;
}
.psite {
    font-size: 14px;
    padding: 5px 10px 5px 70px;
    font-weight :bold;
}
.questionLibelleARS {

}
@media(max-width:640px){
    .psite {
        padding: 5px 10px 5px 30px;
    }
    .questionspecars {
        margin-left: 30px !important;
    }
}


/* financements */
/*#financements , #ecran_2, #contentForm, body{
    min-height:100%;
}*/
#financements {
    text-align: center;
}
#creerFinancement {
    display: inline-block;
    /* position: absolute; */
    /* width: 150px; */
    min-width: 150px;
    padding: 14px 30px 0 30px;
    height: 50px;
    border-radius: 5px;
    color: var(--theme-appBackground);
    background-color: var(--theme-secondaryDark);
    margin-top: 25px;
}
#financementformactions {
    text-align: center;
}
#financementformactions a {
    display: inline-block;
    /* position: absolute; */
    /* width: 150px; */
    min-width: 100px;
    padding: 14px 30px 0 30px;
    height: 50px;
    border-radius: 5px;
    color: var(--theme-appBackground);
    background-color: var(--theme-secondaryDark);
    margin:15px;
}
#financementform {
    text-align: left;
    width:800px;
    margin:20px auto;
    border:1px solid black;

}
#financementform p.question {
    padding:5px 10px;
}
#financementsdeclarees {
    display: block;
    font-size: 1.5em;
    padding-top: 25px;
    padding-bottom: 25px;
    color:var(--theme-primaryDark);
    font-weight:bold;
}
.financementmode {
    text-align: center;
    display: block;
    font-size: 1.5em;
    padding-top: 25px;
    color:var(--theme-primaryDark);
    font-weight:bold;
}
#existingfinancements {

}

div.financement {
    display: inline-block;
    width: auto;
    border: 2px solid var(--theme-primaryDark);
    min-width: 100px;
    min-height: 100px;
    margin: 10px 10px;
    border-radius: 5px;
    width: 400px;
}
div.financement::after {
    /*display:block;
    content:'&nbsp;';*/

}
div.financement span.financeur {
    display: block;
    text-align: center;
    font-size: 18px;
    padding: 10px 5px;
    margin: 0;
    background-color:var(--theme-primaryDark);
    color: var(--theme-appBackground);
    font-weight: bold;
}
div.financement span.type {
    display:inline-block;

    text-align: center;
    font-size: 14px;
    padding: 10px 15px;
    background-color:var(--theme-primaryDark);
    color: var(--theme-appBackground);
    font-weight: bold;
    margin: 10px;
    border-radius: 5px;
}
div.financement span.ville {
    display: inline-block;
    text-align: center;
    font-size: 16px;
    padding: 10px 15px;
    font-weight: bold;
    color: var(--theme-primaryDark);
}
div.financement a {
    display: inline-block;
    text-align: center;
    font-size: 14px;
    padding: 10px 5px;
    color:var(--theme-secondaryDark);
}



.questionspecfinancement {
    margin:0;
    margin-left:20px !important;
}
.psite {
    font-size: 14px;
    padding: 5px 10px 5px 70px;
    font-weight :bold;
}
.questionLibelleFinancement {

}
@media(max-width:640px){
    .psite {
        padding: 5px 10px 5px 30px;
    }
    .questionspecfinancement {
        margin-left: 30px !important;
    }
}

#checkinfos {
    margin:10px;
    height:20px;
    width:20px;
}
#infoslinkannee2 {
    text-decoration: underline;
}

#preambule {
    border:1px solid black;
    font-size: 90%;
}
span#titrepreambule {
    font-weight:bold;
    text-transform: uppercase;
}
ul#listeabbreviations {
    margin:-20px 10px 10px 50px;
    font-size: 90%;
}
ul#listeabbreviations li span {

    text-decoration: underline;
}

/* multiline bootstrap select */
.bootstrap-select .btn {
    /* enables multiline on selectpicker */
    white-space: normal !important;
    word-wrap: break-word;
}

#input_doc3C{
    display: inline-block;
    /*width: calc(100% - 200px);*/
    /*float: left;*/
    /*width:auto;*/

}
#supprimerDocument {
    display: inline-block;
    /*float: left;*/
    /* position: absolute; */
    /* width: 150px; */
    width: 200px;
    padding: 6px 10px 0 10px;
    height: 33px;
    border-radius: 5px;
    color: var(--theme-appBackground);
    background-color: var(--theme-secondaryDark);
/* margin-top: 25px;*/
    margin:0 !important;
}
#supprimerDocument:hover {
    cursor:pointer;
}

.sommaire a {
    text-decoration:underline;
}
.sommaire a.error {
    color:red;
}
