/* Objectif : Mutualiser le code avec création de classes et variables css génériques réutilisables */

/* Important spécial Safari correction comportement row bootsrap 4*/
.row:before, .row:after {
    display: none !important;
}

/* Définition des polices et taille de polices */

:root {
--typo-principale : 'Kumbh Sans', 'Arial Narrow', Arial, sans-serif;
--typo-secondaire : 'votre police';

--font-size-normale-h1 : 70px /*7rem*/ ; 
--font-size-tablette-h1 : 70px /*7rem*/; 
--font-size-mobile-h1 : 40px ;

--font-size-normale-callButton : 70px /*7rem*/ ; 
--font-size-tablette-callButton : 70px /*7rem*/; 
--font-size-mobile-callButton : 36px ;

--font-size-normale-h2 : 30px ; 
--font-size-tablette-h2 : 30px /*4vh*/ ; 
--font-size-mobile-h2 : 19px; 

--font-size-normale-h3 : 24px; 
--font-size-tablette-h3 :30px ; 
--font-size-mobile-h3 : 28px;

--font-size-normale-corps : 14px ; 
--font-size-tablette-corps :14px ; 
--font-size-mobile-corps : 14px;

--font-size-normale-card-text : 20px ; 
--font-size-tablette-card-text :22px ; 
--font-size-mobile-card-text :16px ;

--font-size-normale-bouton : 22px ; 
--font-size-tablette-boutton : 30px ; 
--font-size-mobile-boutton : 20px ;

--font-size-normale-lien : 14px ; 
--font-size-tablette-lien :14px ; 
--font-size-mobile-lien : 14px ;

--font-size-normale-header : 22px; 
--font-size-tablette-header :22px; 
--font-size-mobile-header : 22px;

--font-size-normale-footer : 14px ; 
--font-size-tablette-footer : 14px ; 
--font-size-mobile-footer :14px ;


}

/* Définition d'une palette de couleurs  */

:root {
--main-bg-color : #fff;
--main-text-color : #707070;
--clear-text-color: #CECECE;
--dark-text-color: #292929;
--main-button-color : #E84141;
--main-button-color-transparent : rgba(232, 65, 65,0.9);
--dropdown-transparent-bg : #CECECE80;
--second-button-color : #009789;
--second-button-color-transparent : rgba(0, 151, 137, 0.5);
}

.grispale {
background-color: var(--clear-text-color);
}
.grisfonce {
background-color: var(--main-text-color);
}
.vert {
background-color: var(--second-button-color);
}

.rouge {
background-color: var(--main-button-color);
}

.sombre {
background-color: var(--dark-text-color);
}

/* Définition des tailles ( polices, marges et padding)*/
/*base Bootstrap4 :  -1 = 0.25 rem*/ 
:root {
--large_rem : 5rem;
--fin_rem : 1rem; /* = bootstrap -3 ex : pr-3*/
--normal_rem : 2rem;
--moyen_rem : 3rem;
--x-large_rem : 20rem;
}

/* Définition de bordure  */
:root {
--normal_px : 4px;
--fin_px : 2px;
--extra-fin_px : 1px; 
--xl_px : 10px;
}

/* Définition du logo  */
.logoHeader {
max-width: 50%;
}

/* Définition des checkbox  (diminuer de 10px pour tablettes et mobiles) */
input[type=checkbox]{
-webkit-appearance: none;
-moz-appearance: none;
-ms-appearance: none;
height: calc(4*var(--xl_px));
width: calc(4*var(--xl_px));
background: var(--main-bg-color);
border: var(--fin_px) solid var(--main-text-color);
margin-top: -3px;

}
/* (diminuer de 10px pour tablettes et mobiles) */
input[type="checkbox"]:checked {
border: 0px;
background-image: url(/webroot/img/images/checkbox_checked.svg); /* exemple checkbox personnalisée*/
background-size: calc(4*var(--xl_px)) calc(4*var(--xl_px));
}


/* Définition du header  */
/* A conserver sinon header ne prend pas en compte le font-family */
body {
    font-family: 'Kumbh Sans', sans-serif;
}
p {
    font-family: 'Kumbh Sans', sans-serif;
}
li {
    font-family: 'Kumbh Sans', sans-serif;
}
header {
    font-family: 'Kumbh Sans', sans-serif;
    margin-bottom: var(--large_rem);
}

.header_dropdown-menu {
font-size: var(--normal_rem);
}
.header_dropdown-item {
color :var(--main-text-color);
}
#navbarMainMenuToggler ul .header_dropdown .header_dropdown-menu .header_dropdown-item:hover {
color:var(--second-button-color);
background-color: var(--dropdown-transparent-bg);
}

.dropdown-menu {
    font-size: var(--normal_rem);
}
.dropdown-item {
    color : var(--main-text-color);
}
#navbarMainMenuToggler ul .dropdown .dropdown-menu .dropdown-item:hover {
    color: var(--second-button-color);
    background-color: var(--dropdown-transparent-bg);
}
.filterColumn .dropdown-toggle, .selection_Annee {
    font-size: 22px;
    color: var(--second-button-color);
}
.filterColumn .dropdown-toggle:hover, .selection_Annee:hover {
    color: var(--main-button-color);
}
/* .nav > li > a {
padding: 17px 26px;
} */
#navbarMainMenuToggler {
margin-top: 3vh;
}
/* Seulement sur tablettes */
#tablette_MainMenu {
margin-bottom: var(--large_rem);
}


/* Définition du footer  */
footer {
color: var(--clear-text-color);
background-color: var(--dark-text-color);
border-top: solid var(--normal_px) var(--main-button-color);
}
.logoFooter {
    width: 30vh;
}
.footer_hr {
    height: var(--fin_px);
    border: 0;
    background-color: var(--clear-text-color);
    position: relative;
    top: calc(10*var(--xl_px));
    margin-bottom: calc(5*var(--xl_px));
    display:none; 
}

.footerList a {
color: var(--clear-text-color);
font-size: var(--font-size-normale-corps);
}
.appelFooter {
    border: var(--clear-text-color) solid var(--fin_px);
    font-size: var(--moyen_rem);
    background-color: var(--main-button-color);
    padding: var(--xl_px);
}

/* MENUS */
header .nav > li > a {
    padding: calc(var(--xl_px)/2) calc(var(--xl_px)*2);
} 
.btn-navbar {
font-size: var(--font-size-normale-bouton);
text-decoration: none;
margin-bottom: calc(var(--xl_px));
margin-top: calc(var(--xl_px)/2);
color: var(--main-bg-color);
background-color: var(--main-text-color);
position: relative;
display: inline-block;
text-decoration: none !important;
text-align: center;
word-break: break-word;
}

.btn-navbar:active {
transform: translate(0px, calc(var(--xl_px)/2));
-webkit-transform: translate(0px, calc(var(--xl_px)/2));
box-shadow: 0px 1px 0px 0px;
}
.nav-item {
justify-content: center !important;
display: flex !important;
}
/* passer sur les éléments d'une liste dans nav */
.nav > li > a:hover, #navbarMainMenuToggler a:hover {
background-color: transparent;
color:var(--main-button-color);
transition: ease-in 200ms;
}

/* Focus uniquement sur les menus .mainMenu*/
.nav>li>a:focus {
text-decoration: none;
background-color: transparent;
}
.mainMenu > li > a:focus {
box-shadow: 0 0 0 .2rem var(--main-button-color-transparent);
background-color: var(--main-bg-color);
color : var(--main-button-color);
}
#navbarMainMenuToggler a:focus {
box-shadow: 0 0 0 .2rem var(--main-button-color);
}
.contactMenu_btn {
    background-color: var(--main-bg-color);
    color: var(--main-text-color)!important;
    border: var(--normal_px) solid var(--main-button-color);
}


/*ARBORESCENCE*/
.breadcrumb {
background-color:transparent;
font-size: var(--font-size-normale-lien);
}
.breadcrumb > li a {
color: var(--main-button-color);
padding: var(--normal_px);
font-family: var(--typo-principale);
border: var(--main-bg-color) solid var(--fin_px);

}
.breadcrumb > li a:hover, .pagesArborescence div > ul > li .label:hover {
border: var(--main-text-color) solid var(--fin_px);
}

.pagesArborescence {
font-family: var(--typo-principale);
font-size: var(--font-size-normale-lien);
margin-top: 5rem;
}

.arboTitre {
width: 120px;
color: var(--main-text-color);
}

.pagesArborescence div > ul {
justify-content: center;
display: flex;
}

.pagesArborescence div > ul > li .label {
color: var(--main-button-color);
font-weight: normal;
font-size: var(--font-size-normale-lien); 
border: var(--main-bg-color) solid var(--fin_px);       
}
/* fin ARBORESCENCE*/


/* Définition de contenu principal  */
.pagePrincipale{
top: 120px;
margin-bottom: 144px;
}

h1, h2, h3 {
color: var(--main-text-color);
font-family: var(--typo-principale);
}
h1 {
    text-transform: uppercase;
    font-weight: bold;
    font-size: 5rem;
    margin: 1em;
}

/*page ACCUEIL*/
#hero {
    background-image: url("/webroot/img/images/votreimage.jpg");
    background-color: var(--second-button-color-transparent);
    background-size: cover;
    height: 60rem;
    max-height:100rem;
    margin-bottom: calc(10*var(--xl_px));
}

.mainTitle {
    color: var(--main-bg-color);
    border:var(--main-button-color-transparent) solid var(--normal_px);
    width: max-content;
    border-radius: calc(7*var(--xl_px));
    padding: 0;
    position: relative;
    top: 45%
}

.secondTitle {
    background-color: var(--main-button-color);
    border-radius: calc(10*var(--xl_px));
    margin-top: calc(10*var(--xl_px));
    margin-bottom: calc(8*var(--xl_px));
}
.secondTitle h2 {
    font-size: 7rem;
    text-align: center;
    color: var(--main-bg-color);
}
/* Bouton avec changement de taille au survol */
/* class à fixer sur btn qui enveloppe <a>  */
.upScale_btn{
    background: var(--main-button-color)0% 0% no-repeat padding-box;
    color: var(--main-text-color);
    box-shadow: 7px 7px 15px #0000005D;
    transition : 0.2s;
}
.upScale_btn:hover{
    transform: scale(1.1);
    color: var(--main-text-color);
    box-shadow: 0px 0px 2rem #2B68A2;
}
.lienRecherche {
    /* padding: var(--xl_px); */
    width: 521px;
    height: 74px;
    display: flex;
    justify-content: center;
    align-items: center;
    margin: var(--xl_px);
    text-align: center;
}

.lienRecherche, .lienRecherche a{
    color: var(--main-bg-color);
    background-color: var(--second-button-color);
    font-size: 4vh;
    padding: var(--xl_px);
}

.lienRecherche a {
    border: 3px solid;
    border-radius: var(--xl_px);;
}

.lienRecherche a:hover, .card-link:hover {
    color:var(--second-button-color);
    background-color: var(--main-bg-color);
    text-transform: uppercase;
    transition: ease-in 200ms;
    text-decoration: none;    
}
/* fin Bouton avec changement de taille au survol */

/*INFO & COMPETENCES*/
.info {
    background-color: var(--main-text-color);
    margin-top: 6rem;
    margin-bottom: 5rem;   
}
.info .box  {
        background-color: var(--main-bg-color);
        width: 98%;
        margin: inherit;
}
/* .competence {
    height: 498px;
} */

.card-text {
    font-size: var(--font-size-normale-card-text);
    color: var(--main-text-color);
}

       /* CARD */
       .card-occasionsList img {
        border-radius: var(--xl_px);
        padding: 15px;
    }
    .card-title_Annonce {
        font-size: 3vw;
        font-weight: bold;
        font-style: normal;  
        text-decoration: underline  var(--main-button-color) 4px !important;
        margin-bottom: 3.75rem;
        -webkit-text-decoration-line: underline;
        -webkit-text-decoration-color:  var(--main-button-color);
        text-decoration-thickness: var(--normal_px);
        text-underline-offset: var(--normal_px);
        text-decoration-color:  var(--main-button-color);
        text-decoration-line: underline;
    }


    .card-occasionsList h2 {
        text-decoration: none;
        font-size : 4rem;
    }
    .infoInCard {
        border: var(--clear-text-color) solid var(--fin_px);
        padding: 5px;    
    }
    
    .card-occasionsList p, .infoInCard p {
        text-transform: capitalize;
        margin-left: var(--xl_px);
        font-style: normal;
    }
    .infoInCard a, .iconeSelection {
        padding: var(--xl_px);
        font-weight: normal;
        font-style: italic;
        font-size: 2.5rem;
        color: var(--main-bg-color);
        background-color: var(--main-button-color);
        border-radius: 100px;
        justify-content: center;
        display: flex;
        width: 90%;
        margin: auto;
        border: none;
        
    }

    .infoInCard a:hover {
        background-color: var(--second-button-color);
        color: var(--main-bg-color);
    }


/* Définition du formulaire de contact  */
.contactForm h2 {
color: var(--main-text-color);
border: var(--fin_px) solid var(--main-text-color);
font-size: 4rem;
padding: var(--xl_px) ;
width: 70%;
margin: auto;
margin-bottom: 50px;
text-align: center;

}
.contactForm input, .contactForm textarea{
font-size: var(--font-size-normale-card-text);
font-family: var(--typo-principale);
color: var(--main-text-color);
}
.contactForm input::placeholder, .contactForm textarea::placeholder, .contactForm label {
font-size: 15px;
}

.contactForm label {
color: var(--main-button-color);
}
.contactForm input:focus, .contactForm textarea:focus {
border-color: var(--second-button-color);
box-shadow: 0 0 0 .2rem var(--second-button-color-transparent) ;
}

#inputUser_message {
width: 100% !important;
/* border: laissez class border de BS4 color : #ced4da 1px solid*/
padding: var(--xl_px) !important;
height: 100px;
}

.formSubmit {
font-size: 1.5rem;
padding: var(--xl_px);
}
.formSubmit:hover{
color: var(--main-bg-color);
background-color: var(--second-button-color);
}
.formSubmit:active {
color: var(--main-bg-color);
background-color: var(--main-bg-color);
border: var(--second-button-color) solid var(--fin_px) ;
}

/* Définition du lien de sélection  */
.link {
color :var(--main-text-color);
font-size: var(--font-size-normale-corps);
}
.link:hover, a:hover {
color: var(--second-button-color);
transition: ease-in 200ms;
}

/* Définition de liste  */
/* li {
list-style-type: none;
} */



/* Note :  utilisation de calc()
width: calc(100% - 20px) ;
*/
