/* Backend specific CSS */

/* ----------------------------
  SOMMAIRE
  ---------------------------

  1. GENERAL
    1.1 Typo
    1.2 Button
    1.3 Form
    1.4 Table
    1.5 Styles predefinis

  2. LAYOUT
    2.1 Navigation
    2.2 Sidebar
    2.3 Content
      2.3.1 Calendar/Calendrier
      2.3.2 Home
      2.3.3 Legend
      2.3.4 Breadcrumbs
      2.3.5 Footer
      2.3.6 Dashboard
    2.4 Admin
      2.4.1 Pagination
      2.4.2 Filtres

*/

@font-face {
    font-family: 'Montserrat';
    src: url("../fonts/static/Montserrat-Medium.ttf");
}

.h3, h3 {
    font-size: 1.50rem !important;
}

:root{
    --bs-font-sans-serif:'Poppins', sans-serif;
    --bs-border-radius: 0.25rem !important;
    --btn-border-radius : 60px;
    --box-shadow: 0px 0px 23px -4px rgb(56 57 66 / 10%);
    --bs-dark-rgb: 25, 25, 25;
    --bs-on-danger : #fff;
    --bs-gray-500: #ebebeb;
    --bs-transition-base: .3s all ease;
    --sidebar-width: 300px;
}


body{
    min-height: 100vh;
    background-color: #FFFFFF;
    font-family: Montserrat, sans-serif !important;
    font-size: 14px;
}
.container-fluid{
    margin-top: 80px;
}
.row#main{
    min-height: Calc(100vh - 130px);
}
a:hover{
    text-decoration: none;
}

/* 1. GENERAL */

.fa {
    color: black;
    font-size: 1.5rem;
}

/* 1.1 Typo */

h1,.h1{
    font-weight: 600;
    font-size: 1.75rem !important;
    color: #ffffff;
    text-transform: uppercase;
    text-align: center;
    padding-bottom: 60px;
    padding: 15px;


}
h1 span {
    display: block;
    padding: 0.25em 0.5em;
}

h1.light, .h1.light {
    /* Add low opacity dark background to improve contrast */
    background: rgba(0, 0, 0, 0.35);
    max-width: fit-content;
    margin: auto;
    padding: 15px !important;
}
.bandeau {
    padding-top: 60px;
    padding-bottom: 60px;
    margin-bottom: 60px;
    width: 100% !important;
}
.bandeauIndex {
    background-image: url('../img/ba-2.png');
    background-position-x: 50%;
    background-position-y: 61%;
    background-size: 45%;

}
.bandeauPsycho {
    background-image: url('../img/memoire_2.jpg');
    background-repeat: repeat;
    background-size: cover;
}
.bandeauPsychoRemediation {
    background-image: url('../img/reeduc.png');
    background-position: center;
    background-repeat: repeat;
    background-size: cover;
}
.bandeauPsychoTTC {
    background-image: url('../img/image_psy.jpeg');
    background-repeat: repeat;
    background-position: center;
    background-position-y: 43%;
}
.bandeauTarifs {
    background-image: url('../img/test-prest.png');
    background-position: center;
    background-repeat: repeat;
    background-size: cover;
}
.bandeauContact {
    background-image: url('../img/test-contact.png');
    background-position: center;
    background-repeat: repeat;
    background-size: contain;
    padding-bottom: 70px !important;
}
.p-20 {
    padding: 20px;
}
.autoLeft {
    margin-left: auto;
}
h2,.h2{
    font-weight: 300;
}
.h3, h3 {
    font-weight: 400;
    text-transform: uppercase;
    color: #6a7075;
}
b, strong {
    font-weight: 600;
}
.text-xl{
    font-weight: 500;
    margin-bottom: 0;
}

.lead{
    font-size: 1.5rem;
}
.badge{
    font-weight: normal;
}
h2{
    color:rgba(97,97,97,1);
}
.underline {
    text-decoration: underline;
}
.size12 {
    font-size: 12px;
}
.greyText {
    color: #6a7075;
    margin-bottom: 40px !important;
}
.borderFooter {
    padding-top: 20px;
    border-top: 0.5px solid black;
    font-size: 12px;
}
.listNone {
    list-style: none;
}
.navbar-brand {
    max-width: 20pc;
}

/*.container-t {*/
/*    font-size: 14px;*/
/*}*/
/* 1.2 Button */

.btn{
    border-radius: 60px;
}
.btn-primary{
    background-color: black;
    border-color: black;
}
.btn-primary:hover,
.btn-primary:focus{
    background-color: grey;
    border-color: grey;
}

.btn-outline-primary {
    --bs-btn-color:black;
    --bs-btn-border-color: black;
}
.btn-outline-primary:hover{
    background-color: grey;
    border-color: grey;
}
.btn-outline-primary:active,.btn-primary:active{
    --bs-btn-active-bg: red;
    --bs-btn-active-border-color: red;
}

.btn i{
    font-size: 13px;
    margin-right: 5px;
}

i.item-activate {
    cursor:pointer;
}
/* nav-pills */

/*.nav-pills .nav-link{*/
/*    border-style: solid;*/
/*    border-width: 1px;*/
/*}*/

.nav-pills .nav-link.btn-outline-primary{
    --bs-nav-link-color: black;
}

.nav-pills .btn-outline-primary.nav-link:focus,
.nav-pills .btn-outline-primary.nav-link:hover {
    color: #fff;
}

.nav-pills .btn-outline-primary.nav-link:hover {
    background-color: black;
    border-color: black;
}

.nav-pills .btn-outline-primary.nav-link.active,
.nav-pills .show>.nav-link.btn-outline-primary {
    background-color: black;
}

/* 1.3 Form */

.form-label{
    margin-bottom: 0;
}
.form-control,
.form-select{
    border-radius: var(--bs-border-radius);
}
/* form-select hover */
.form-select option:hover{
    background-color: #212529;
}

.form-group {
    margin-bottom: 1rem;
}

/* 1.4 Table */

tbody,
td,
tfoot,
th,
thead,
tr {
    vertical-align: middle;
    border-style: none;
    border-width: 0;
    font-size: .9rem;
}

.table>:not(caption)>*>* {
    padding: 0.75rem 0.75rem;
}

table td:not(:first-child){
    min-width: 150px;
}

.table-hover > tbody > tr:hover {
    --bs-table-accent-bg: rgb(246 247 250);
    color: black;
}

table.table-valign tr td, table.table-valign tr th{
    vertical-align: middle;
}
table tr:hover,.cursor-pointer label{
    cursor : pointer!important;
}
.card.cursor-pointer{
    padding: 0!important;
}
.card.cursor-pointer label{
    padding: 20px 16px;
}

/* 1.5 Styles prédéfinis*/
.text-bg-primary {
    background-color: red!important;
}
.nav.img-fluid{
    max-width: 200px;
}

/* 2. LAYOUT */

/* 2.1 Navigation */
#navigation {
    margin: 0 auto;
}

.nav2:active .nav-link{
    font-weight: bold;
}
.nav-item:hover .nav-link{
    font-weight: bold;
    border-bottom: 1px solid #33B181;
}
.nav-item .nav-link{
    color: #33B181;
}
.navbar-light .navbar-nav .nav-link {
    color: rgba(0, 0, 0, .5);
    min-width: 100%;
}
.nav-brand img{
    max-height: 50px;
    /* min-width: 130px; */
}
header .nav-link{
    text-transform: uppercase;
    font-size: 18rem;
    letter-spacing: 1px;
    display: flex;
    color: #fff;
    /* align-items: center; */
    font-weight: 700;
}
header .nav-link:hover{
    color:#fff;
}
header .nav-link i{
    font-size: 18rem;
    margin-right: 0.5rem;
    color:#fff;
}
.container .nav-link{
    font-size: 1rem;
    font-weight: 500;
    color: #33B181;
}
.container {
    padding: 0;
    width: unset !important;
    text-align: justify;
}
.col-md-6 {
    text-align: justify;
    vertical-align: top !important;
    display: inline-block;
    width: calc(50% - 15px) !important;
}
.col-md-4 {
    text-align: justify;
    vertical-align: top !important;
    display: inline-block;
    width: calc(33.33% - 15px);
    margin-left: 15px;
}
.col-md-8 {
    text-align: justify;
    vertical-align: top !important;
    display: inline-block;
    width: calc(65% - 15px) !important;
}
.col-md-3 {
    vertical-align: top !important;
    display: inline-block;
    width: calc(33% - 15px);
    margin: 0 auto;
    text-align: left;
}
ul.tiret  {
    list-style-type: none;
}
.tiret > li:before {
    content: '- ';
    color: #33B181;
}
/* custom css */
.m-auto {
    display: block;
}
.center {
    text-align: center;
}
.left {
    text-align: left;
}
.color-green, .navbar-light .navbar-nav .nav-link  {
    color:#33B181 !important;
}
b {
    color: #33B181;
}
.active {
    font-weight: bold !important;
}
/* footer */
footer {
    padding: 60px 0 0 0;
    text-align: center;
}
hr {
    border-top: 0.5px solid black !important;
    margin: 20px 0;
}

/*.container-t {*/
/*    !*display: flex;*!*/
/*    !*flex-direction: row;*!*/
/*    !*justify-content: space-between;*!*/
/*    !*align-items: stretch; !* Étend les colonnes pour qu'elles aient la même hauteur *!*!*/
/*}*/

.img-container img {
    height: 100%; /* Ajuste la hauteur de l'image */
    object-fit: cover; /* Maintient les proportions de l'image si nécessaire */
}


.h3Psycho, .psychoPad {
    margin-left: 1.5rem ;
}
.appliUl {
    margin-top: 3rem ;
}


@media (max-width: 1300px) {
    .col-md-10 {
        max-width: calc(100% - 15px) !important;
    }
}
@media (max-width: 992px){
    h2,.h2{
        font-size: 1.3rem;
    }
    .h3, h3 {
        font-size: 1rem;
    }
    .text-xl{
        font-size: 1.7rem;
    }
    .navbar {
        display: none !important;
    }
    #menuMobile{
        display: block !important;
    }
    .burger-icon-container{
        height: 30px;
    }
    .sidenav {
        height: 100%;
        width: 280px;
        position: fixed;
        z-index: 1;
        top: 0;
        right: -280px;
        background-color: #FFFFFF;
        padding-top: 60px;
        transition: right 0.5s ease;
    }

    .sidenav ul {
        list-style-type: none;
        padding: 0;
        margin: 0;
    }

    /* Sidenav menu links */
    .sidenav a {
        padding: 8px 8px 8px 32px;
        text-decoration: none;
        /*font-size: 25px;*/
        color: black;
        display: block;
        transition: 0.3s;
    }

    .sidenav a:hover {
        color: #33B181;
    }

    /* Active class */
    .sidenav.active {
        right: 0;
    }

    /* Close btn */
    .sidenav .close {
        position: absolute;
        top: 20px;
        right: 30px;
        font-size: 36px;
    }

    .burger-icon span {
        display: block;
        width: 20px;
        height: 3px;
        background-color: black;
        margin: 4px 0;
    }
    #openBtn {
        position: absolute;
        right: 30px;
        top:30px;
    }
    h1, .h1 {
        font-size: 1.5rem !important;
    }

    ul {
        padding-left: 30px;
    }
    .p-20 {
        padding: unset;
    }
    h3 {
        font-size: 1.2rem;
        margin-top: unset !important;
    }
    .ml-4, .psychoPad {
        margin-left: unset !important;
    }
    .h3Psycho {
        margin-left: unset !important;
        margin-top: 3rem !important;
    }
    h5 {
        text-align: justify;
        padding: 0 30px;
    }
    .col-md-8 {
        text-align: justify;
        vertical-align: top !important;
        display: inline-block;
        width: calc(100% - 15px) !important;
    }

}

@media (max-width: 768px){
    .col-md-6 {
        text-align: justify;
        vertical-align: top !important;
        display: inline-block;
        width: calc(100% - 15px) !important;
    }

}
@media (max-width: 576px){

}
