﻿
/*********************************************/
/* CONTAINER & CLASS GENERIQUES */
/*************************************/
.font-regular {
    font-family: 'Montserrat';
    font-weight: 400;
}

.font-bold {
    font-family: 'Montserrat';
    font-weight: 700;
}

.font-light {
    font-family: 'Montserrat';
    font-weight: 200;
}


.container-row {
    width: 100%;
    height: auto;
    display: flex;
    flex-direction: row;
}

.container-col {
    display: flex;
    flex-direction: column;
}

.container-wrap {
    width: 95%;
    height: auto;
    display: flex;
    flex-wrap: wrap;
    padding: 0 2.5%;
}

.grow1 {
    flex-grow: 1;
}

.display-none {
    display: none;
}

.w100 {
    width: 100%;
}

.w80 {
    width: 80%;
}

.w50 {
    width: 50%;
}

.w-auto {
    width: auto;
}

.h-auto {
    height: auto;
}

.h100 {
    height: 100vh;
}

.align-top {
    vertical-align: top;
}

.align-it-end {
    align-items: flex-end;
}

.align-it-center {
    align-items: center;
}

.align-it-start {
    align-items: flex-start;
}

.j-start {
    justify-content: flex-start;
}

.j-end {
    justify-content: flex-end;
}

.j-center {
    justify-content: center;
}

.j-around {
    justify-content: space-around;
}

.txt-center {
    text-align: center;
}

.txt-right {
    text-align: right;
}

.txt-left {
    text-align: left;
}


.border-conf {
    border-top: solid #d3e3fd 2px;
    border-bottom: solid #d3e3fd 2px;
}

.border-conf-top {
    border-top: solid #d3e3fd 2px;
}

.border-conf-bottom {
    border-bottom: solid #d3e3fd 2px;
}

.border-form {
    border: solid var(--color-primary) 2px;
    border-radius: 0.3rem;
}

.border-blue-dark {
    border: solid #3a0648 2px;
    border-radius: 0.3rem;
}

.border-grey {
    border: solid #444444 2px;
    border-radius: 0.3rem;
}

.border-blue-cta {
    border: solid #009adf 2px;
    border-radius: 0.3rem;
}

.colorCTA {
    color: var(--color-primary);
}

.colorWhite {
    color: var(--color-white);
}

.colorVS {
    color: #3a0648;
}

.warning-message {
    color: #ee2410;
}

.bgColor-CTA {
    background-color: var(--color-primary);
}

.bgColor-blueHover {
    background-color: #2ebaf9;
}

.bgColor-purpleVS {
    background-color: #3a0648;
}

.bgColor-error {
    background-color: #ee2410;
}

.bgColor-success {
    background-color: #41cd01;
}

.bgColor-info {
    background-color: #2488f5;
}

.bgColor-warning {
    background-color: #ffc711;
}

.bgColor-backGoogle {
    background-color: #edf1fa;
}

.bgColor-ongletGoogle {
    background-color: #d3e3fd;
}

.color-back-grey {
    background-color: #2d2d2d;
}


.txt-color-onCTA {
    color: var(--color-txt-primary);
}

.txt-color-1 {
    color: #2d2d2d;
}

.txt-color-2 {
    color: #fff;
}


.cursor-pointer {
    cursor: pointer;
    padding: 8px 12px;
    min-height: 44px;
}

.text {
    display: flex;
    font-size: 1rem;
    color: #3a0648;
    font-weight: 400;
    line-height: 2rem;
}

.hidden {
    display: none;
}

.z-index1 {
    z-index: 1;
}

.Z-index99 {
    z-index: 99;
}

.warp-word {
    /*width: 200px;*/ /* largeur fixe ou max */
    /*white-space: normal;
    overflow-wrap: break-word;
    word-break: break-word;
    border: 1px solid #ccc;
    padding: 5px;*/

    word-break: break-all; /* Coupe le mot partout si nécessaire */
    /* word-wrap: break-word; Pour couper les mots trop longs */
    /* white-space: normal;  Permet le retour à la ligne */
    /* overflow-wrap: break-word;  Support moderne */
}
/***********************************/
/* title dédié à tous les composants PAGE et FORM */
/*********************************/

/*.title {
    display: flex;
    font-size: 2.6rem;
    color: #3a0648;
    font-weight: 800;
}*/

.word-break {
    word-break: break-all;
    overflow-wrap: break-word;
    max-width: 100%;
}

/* Class Générique servant pour DEBUG */

.border-red {
    border: solid red 1px;
}

.border-blue {
    border: solid blue 1px;
}

.border-black {
    border: solid black 1px;
}



.etoile {
    font-size: 4rem;
}




.buttonCTA {
    background-color: var(--color-primary);
    color: var(--color-txt-primary);
}

.padding-part {
    padding: 4rem 0;
}

.big-padding-part {
    padding: 10rem 0;
}

/*.light-gap {
	grid-row: 4rem;
}

.large-gap {
	grid-row: 12rem;
}*/

.hight-gap {
    grid-row: 6rem;
}


.row-direction {
    flex-direction: row;
}

.col-direction {
    flex-direction: column;
}

.anchor {
    display: block;
    height: auto; /*same height as header*/
    margin-top:0; /*same height as header*/
    visibility: hidden;
}

/*.bloc-js-top {
	z-index: 999;
	width: 5rem; 
	height: 5rem; 
	position: fixed; 
	bottom: 1rem; 
	right: 2.5rem; 
	background-color: #1f7fb3; 
	color: #dbdbdb; 
	border-radius: 0.4rem;
	opacity:0.8;
}*/

.arrow-icon {
    width: 5rem;
    height: auto;
    opacity: 0.8;
}

#balise_noscript {
    color: #303030;
    font-size: 20px;
    padding-left: 1rem;
}

.no-js #loader {
    display: none;
}

.js #loader {
    display: block;
    position: absolute;
    left: 5rem;
    top: 0;
}

.se-pre-con {
    position: fixed;
    left: 0;
    top: 0;
    width: 100%;
    height: 100%;
    z-index: 9999;
    background: url(img/ico-svg/balls.svg) center no-repeat #E7ECF3;
}



/*#snackbar {
    visibility: hidden;
    width: auto;
    background-color: #333;
    color: #fff;
    text-align: center;
    border-radius: 0.3rem;
    padding: 1rem;
    position: fixed;
    z-index: 100;
    left: 0;
    top: 0;
}

    #snackbar.show {
        visibility: visible;
        -webkit-animation: fadein 0.5s, fadeout 0.5s 4.5s;
        animation: fadein 0.5s, fadeout 0.5s 4.5s;
    }
*/

.sr-only {
    position: absolute;
    width: 1px;
    height: 1px;
    margin: -1px;
    padding: 0;
    overflow: hidden;
    clip: rect(0, 0, 0, 0);
    white-space: nowrap;
    border: 0;
}


/******************************/
/* Type Liens : Ahref / Onclick */
/******************************/

.link {
    width: 100%;
    height: auto;
}

a {
    text-decoration: none;
}

/* nav-link : imite ahref 
 pour les appel onclick */
.nav-link {
    text-decoration: none;
    font-size: 1.5rem;
    background-color: var(--color-primary);
    color: white;
    /*opacity: 0.5;*/
    cursor: pointer;
}

    .nav-link:hover {
        background-color: var(--color-primary-hover);
        /*opacity: 0.8;
        color: #3a0648;*/
    }

    .nav-link img {
        margin-right: 1rem;
    }

/******************************/
/* TYPE BUTTON */
/******************************/

.button, .btn {
    border: none;
    background-color: var(--color-primary);
    color: #ffffff;
    font-size: 1.5rem;
    font-weight: 400;
    cursor: pointer;
    transition: .2s;
    margin: 1rem 0.5rem;
    border-radius: 0.3rem;
    padding: 0.75rem 0.75rem;
}

.btn-view-action {
    width: 5rem;
    height: 5rem;
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: center;
    background-color: var(--color-primary);
    border-radius: 100%;
    cursor: pointer;
    flex-grow: 0;
}


.btn-view {
    width: 5rem;
    height: 5rem;
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: center;
    background-color: var(--color-primary);
    border-radius: 100%;
    cursor: pointer;
    flex-grow: 0;
}

.btnedit {
    width: 3rem;
    height: 3rem;
    flex-grow: 0;
    background-color: forestgreen; /* #41cd01; */
    border-radius: 0.3rem;
    margin: 0 0.8rem;
    cursor: pointer;
}

.btndelete {
    width: 3rem;
    height: 3rem;
    flex-grow: 0;
    background-color: #ee2410; /*darkred;*/
    border-radius: 0.3rem;
    margin: 0 0.8rem;
    cursor: pointer;
}

    .btnedit img,
    .btndelete img {
        width: 100%;
        height: 1.5rem;
        padding-top: 0.75rem;
    }

    .button:hover,
    .btn:hover,
    .btnedit:hover,
    .btndelete:hover {
        background-color: var(--color-primary-hover);
        transform: scale(1.1);
        transition: 0.3s ease-in-out;
    }

    .button:active,
    .btn:active,
    .btnedit:active,
    .btndelete:active {
        background-color: var(--color-primary-active);
    }


    .button:disabled,
    .btn:disabled,
    .btnedit:disabled,
    .btndelete:disabled {
        background-color: #cccccc !important;
        color: #666666 !important;
        cursor: not-allowed;
        transform: none !important;
        opacity: 0.7;
    }

.btndelete-all {
    width: auto;
    height: 4rem;
    flex-grow: 0;
    background-color: darkred;
    color: #ffffff;
    border-radius: 0.3rem;
    margin: 0 0.5rem;
    cursor: pointer;
}

/**************************/
/* FORM */
/**********************/

.container-filter {
    position: fixed;
    top: 10rem;
    right: 0.5rem;
    border-top: solid white 2px;
}


.form-group {
    margin: 0.5rem 0;
    color: #3a0648;
}


input + label,
select + label,
textarea + label,
label + input,
label + select,
label + textarea {
    display: block;
}


input, select {
    height: 2rem;
    width: 100%;
    box-sizing: border-box;
    padding: 0.5rem 0.5rem;
    margin-top: 0.25rem;
    color: #444444;
    font-size: 0.9rem;
    outline-style: outset;
    outline-color: var(--color-primary);
    outline-width: 1px;
    border-radius: 0.3rem;
    font-family: 'Montserrat','Helvetica Neue', Helvetica, Arial, sans-serif;
    font-weight: 400;
}

textarea {
    height: 6rem;
    max-height: 6rem;
    min-height: 6rem;
    width: 100%;
    max-width: 100%;
    min-width: 100%;
    box-sizing: border-box;
    margin-top: 0.25rem;
    padding: 0.2rem 0.5rem;
    color: #444444;
    font-size: 0.9rem;
    outline-style: outset;
    outline-color: var(--color-primary);
    outline-width: 2px;
    border-radius: 0.3rem;
    font-family: 'Montserrat','Helvetica Neue', Helvetica, Arial, sans-serif;
    font-weight: 400;
}

.inputselect {
    height: 2rem;
    width: 100%;
    box-sizing: border-box;
    margin-top: 0.25rem;
    padding: 0.2rem 0.5rem;
    color: #444444;
    font-size: 0.9rem;
    outline-style: outset;
    outline-color: var(--color-primary);
    outline-width: 2px;
    border-radius: 0.3rem;
    font-family: 'Montserrat','Helvetica Neue', Helvetica, Arial, sans-serif;
    font-weight: 400;
}

.inputcheckbox {
    height: 2rem;
    width: 2rem;
    box-sizing: border-box;
    margin-top: 0.5rem;
    padding: 0.2rem 0.5rem;
    outline-style: outset;
    outline-color: var(--color-primary);
    outline-width: 2px;
    border-radius: 0.6rem;
}

.container-form-add {
    width: 22%;
    height: auto;
    border: var(--color-primary) 2px solid;
    border-radius: 0.3rem;
    padding: 1rem 1.5rem;
    margin: 1rem auto;
}

.container-form-add-medium {
    width: 40%;
    height: auto;
    border: var(--color-primary) 2px solid;
    border-radius: 0.3rem;
    padding: 1rem 1.5rem;
    margin: 1rem auto;
}

.container-form-add-big {
    width: 80%;
    height: auto;
    border: var(--color-primary) 2px solid;
    border-radius: 0.3rem;
    padding: 1rem 1.5rem;
    margin: 1rem auto;
}

/*************************/

.title-medium {
    display: flex;
    font-size: 1.6rem;
    color: var(--color-primary);
    font-weight: 700;
    font-family: 'Montserrat';
}

.title-small {
    display: flex;
    font-size: 1.3rem;
    color: var(--color-primary);
    font-weight: 700;
    font-family: 'Montserrat';
}

.f-size-extra-small {
    font-size: 0.6rem;
}

.f-size-small {
    font-size: 0.8rem;
}

.f-size-normal {
    font-size: 1rem;
}

.f-size-medium {
    font-size: 1.2rem;
}

.f-size-large {
    font-size: 1.5rem;
}

.f-size-big {
    font-size: 1.8rem;
}

.f-size-double {
    font-size: 2rem;
}

.f-size-triple {
    font-size: 3rem;
}

.marginTB1 {
    margin: 1rem auto;
}

.marginTB2 {
    margin: 2rem auto;
}

.marginTB4 {
    margin: 4rem auto;
}

.marginLR1 {
    margin: auto 1rem;
}

.marginLR2 {
    margin: auto 2rem;
}

.marginLR4 {
    margin: auto 4rem;
}

.marginLR6 {
    margin: auto 6rem;
}

.marginTRBL05 {
    margin: 0.5rem;
}

.marginTRBL1 {
    margin: 1rem;
}

.marginTRBL2 {
    margin: 2rem;
}

.paddingTB05 {
    padding: 0.5rem 0;
}

.paddingTB1 {
    padding: 1rem 0;
}

.paddingTB2 {
    padding: 2rem 0;
}

.paddingT2 {
    padding-top: 2rem;
}

.paddingT4 {
    padding-top: 4rem;
}

.paddingT6 {
    padding-top: 6rem;
}

.paddingLR1 {
    padding: 0 1rem;
}

.paddingLR2 {
    padding: 0 2rem;
}

.paddingLR3 {
    padding: 0 3rem;
}

.paddingLR4 {
    padding: 0 4rem;
}

.paddingTRBL05 {
    padding: 0.5rem;
}

.paddingTRBL1 {
    padding: 1rem;
}

.paddingTRBL2 {
    padding: 2rem;
}





/* Tablette portrait / moyen écran */
@media (min-width: 768px) and (max-width: 1024px) {

/*    .marginTB1 {
        margin: 1rem auto;
    }

    .marginTB2 {
        margin: 2rem auto;
    }

    .marginTB4 {
        margin: 4rem auto;
    }

    .marginLR1 {
        margin: auto 1rem;
    }

    .marginLR2 {
        margin: auto 2rem;
    }

    .marginLR4 {
        margin: auto 4rem;
    }

    .marginLR6 {
        margin: auto 6rem;
    }

    .marginTRBL05 {
        margin: 0.5rem;
    }

    .marginTRBL1 {
        margin: 1rem;
    }

    .marginTRBL2 {
        margin: 2rem;
    }

    .paddingTB05 {
        padding: 0.5rem 0;
    }

    .paddingTB1 {
        padding: 1rem 0;
    }

    .paddingTB2 {
        padding: 2rem 0;
    }

    .paddingT2 {
        padding-top: 2rem;
    }

    .paddingT4 {
        padding-top: 4rem;
    }

    .paddingT6 {
        padding-top: 6rem;
    }

    .paddingLR1 {
        padding: 0 1rem;
    }

    .paddingLR2 {
        padding: 0 2rem;
    }

    .paddingLR3 {
        padding: 0 3rem;
    }

    .paddingLR4 {
        padding: 0 4rem;
    }

    .paddingTRBL05 {
        padding: 0.5rem;
    }

    .paddingTRBL1 {
        padding: 1rem;
    }

    .paddingTRBL2 {
        padding: 2rem;
    }*/



    .title-medium {
        display: flex;
        font-size: 1.6rem;
        color: var(--color-primary);
        font-weight: 700;
        font-family: 'Montserrat';
    }

    .title-small {
        display: flex;
        font-size: 1.3rem;
        color: var(--color-primary);
        font-weight: 700;
        font-family: 'Montserrat';
    }

   /* .f-size-extra-small {
        font-size: 0.6rem;
    }

    .f-size-small {
        font-size: 0.8rem;
    }

    .f-size-normal {
        font-size: 1rem;
    }*/

    .f-size-medium {
        font-size: 1.4rem;
    }

    .f-size-large {
        font-size: 1.7rem;
    }

    .f-size-big {
        font-size: 1.8rem;
    }

    .f-size-double {
        font-size: 1.9rem;
    }

    .f-size-triple {
        font-size: 2.4rem;
    }

}


/*******************************/


/* Mobile */
@media (max-width: 767px) {

/*    .marginTB1 {
        margin: 1rem auto;
    }

    .marginTB2 {
        margin: 2rem auto;
    }

    .marginTB4 {
        margin: 4rem auto;
    }

    .marginLR1 {
        margin: auto 1rem;
    }

    .marginLR2 {
        margin: auto 2rem;
    }

    .marginLR4 {
        margin: auto 4rem;
    }

    .marginLR6 {
        margin: auto 6rem;
    }

    .marginTRBL05 {
        margin: 0.5rem;
    }

    .marginTRBL1 {
        margin: 1rem;
    }

    .marginTRBL2 {
        margin: 2rem;
    }

    .paddingTB05 {
        padding: 0.5rem 0;
    }

    .paddingTB1 {
        padding: 1rem 0;
    }

    .paddingTB2 {
        padding: 2rem 0;
    }

    .paddingT2 {
        padding-top: 2rem;
    }

    .paddingT4 {
        padding-top: 4rem;
    }

    .paddingT6 {
        padding-top: 6rem;
    }

    .paddingLR1 {
        padding: 0 1rem;
    }

    .paddingLR2 {
        padding: 0 2rem;
    }

    .paddingLR3 {
        padding: 0 3rem;
    }

    .paddingLR4 {
        padding: 0 4rem;
    }

    .paddingTRBL05 {
        padding: 0.5rem;
    }

    .paddingTRBL1 {
        padding: 1rem;
    }

    .paddingTRBL2 {
        padding: 2rem;
    }
*/




    .title-small {
        display: flex;
        font-size: 1.3rem;
        color: var(--color-primary);
        font-weight: 700;
        font-family: 'Montserrat';
    }

    .title-medium {
        display: flex;
        font-size: 1.6rem;
        color: var(--color-primary);
        font-weight: 700;
        font-family: 'Montserrat';
    }


    .f-size-extra-small {
        font-size: 0.5rem;
    }

    .f-size-small {
        font-size: 0.7rem;
    }

    .f-size-normal {
        font-size: 0.9rem;
    }

    .f-size-medium {
        font-size: 1.1rem;
    }

    .f-size-large {
        font-size: 1.3rem;
    }

    .f-size-big {
        font-size: 1.5rem;
    }

    .f-size-double {
        font-size: 1.7rem;
    }

    .f-size-triple {
        font-size: 2rem;
    }

}


/*
.label-filename {
    font-size: 1.2rem;
}

.label-legende {
    font-size: 0.8rem;
    margin: 0.3rem auto;
    color: grey;
}

*/


/* CARD-DASH */

/*.card-dash, .card-dash-double, .card-dash-min {
    background-image: linear-gradient(180deg, rgb(5, 39, 103) 0%, #3a0647 70%);
    border-radius: 0.5rem;
    color: #fff;*/
   /* margin: 2rem 1rem;*/
    /*box-shadow: 0 4px 12px rgba(0, 0, 0, 0.2);
    transition: transform 0.3s ease, box-shadow 0.3s ease, filter 0.3s ease;
    text-align: center;
}

.card-dash {
    width: 100%;
    max-width: 18rem;
    height: 18rem;
}

.card-dash-min {
    width: auto;
    min-width: 16rem;
    height: 8rem;
}

.card-dash-double {
    width: auto;
    min-height: 18rem;
}

    .card-dash a, .card-dash-double a, .card-dash-min a {
        color: #fff;
        text-decoration: none;
        display: block;
        height: 100%;
        width: 100%;
        cursor: pointer;
    }

.card-dash .title-card-dash {
    font-weight: 800;
    font-size: 1.8rem;
    margin-top: 1rem;
}

.card-dash-double .title-card-dash {
    font-weight: 600;
    font-size: 1.5rem;
    margin-bottom: 1rem;
}

.card-dash-min .title-card-dash {
    font-weight: 400;
    font-size: 1rem;
    margin-bottom: 0.3rem;
}

.count-title {
    font-size: 1.2rem;
}

.count {
    font-size: 2.5rem;
    font-weight: bold;
}

.card-dash img,
.card-dash span {
    transition: transform 0.4s ease;
    transform-origin: center center;
}*/

/*@media (hover: hover) and (pointer: fine) {
    .card-dash:hover {
        transform: translateY(-8px);
        box-shadow: 0 10px 20px rgba(0, 0, 0, 0.3);
        filter: brightness(1.1);
    }

        .card-dash:hover img,
        .card-dash:hover span {
            transform: rotate(10deg) scale(1.1);
        }

        .card-dash:hover .badge-new {
            transform: scale(1.1);
   */     }
}

/*@media (max-width: 480px) {
    .card-dash, .card-dash-double {
        height: 14rem;
        margin: 1rem 0.5rem;
    }

    .title-card-dash {
        font-size: 1.4rem;
    }

    .count {
        font-size: 2rem;
    }
}*/


/******************************/
/* class view info bulle aide */
/******************************/

/*.helperInfo span {
    display: none;
    color: #fff;
    background: rgba(51,51,51,0.95);
    padding: 20px;*/
    /*top: 5rem;
    right: 0;*/
    /*border-radius: 4px;
    -moz-border-radius: 4px;
    -webkit-border-radius: 4px;
    width: 110px;
    text-align: center;*/
    /*position: absolute;*/
    /*position: fixed;
    z-index: 900;
}

.helperInfo:hover span {
    display: block;
}*/

/* Class spécifique composant admin et log */

/*.spe-conf {
    width: 80%;
    height: auto;
    background-color: #edf1fa;
    border-radius: 4rem;
    margin: 0 0 2rem 2rem;
}

.sub-title {
    font-size: 1.6rem;
    font-weight: 100;
    flex-grow: 1;
    color: #3a0648;
    margin-left: 2rem;
}

.info-conf {
    padding: 0.25rem 0 0 0;
    font-size: 1.5rem;
    color: #3a0648;
}

.sub-info-conf {
    padding: 0.25rem 0 0 0;
    font-size: 1rem;
    color: #3a0648;
}



.statutpointOn {
    width: 1rem;
    height: 1rem;
    border-radius: 100%;
    background-color: forestgreen;
    margin: 0.25rem 0.5rem 0 0;
}

.statutpointOff {
    width: 1rem;
    height: 1rem;
    border-radius: 100%;
    background-color: red;
    margin: 0.25rem 0.5rem 0 0;
}

.statutpointOrange {
    width: 1rem;
    height: 1rem;
    border-radius: 100%;
    background-color: darkorange;
    margin: 0.25rem 0.5rem 0 0;
}*/