/* Page de maintenance */
.maintenance-page,
.maintenance-page body {
    font-family: 'Lato';
    background-color: #e55039;
    color:#fff;
}
.maintenance-page h1 { 
    font-size: 50px; 
}
.maintenance-page body { 
    text-align: center;   
}
.maintenance-page .container-fluid { 
    padding: 0;   
}
.maintenance-page .icon{
    border-radius: 100px;
    padding:20px;
    margin:50px auto;
    background-color: #ffffff;
    text-align: center;
    width:70px;
}
.maintenance-page .content-block {
    margin: 50px 0;
    background: #ffffff33;
    padding: 20px;
    border: 1px solid #fff;
    border-radius: 3px;
    text-align: left;
}
.maintenance-page .icon i{
    color:#e55039;
    font-size: 30px;
}
.maintenance-page .admin-access {
    position: absolute;
    bottom: 20px;
    width: 100%;
    left: 50%;
    transform: translateX(-50%);
    display: block;
}
.maintenance-page .admin-access a {
    color:#e55039;
}


/* SETTINGS */
.maintenance-block textarea {
	resize: none;
}
.maintenance-block .trumbowyg-box,
.maintenance-block .trumbowyg-editor {
	min-height: 150px;
}
.table-users .avatar-head,
.table-users .avatar-cell {
	width: 85px;
}
.logs-settings-block {
	display: flex;
}
.logs-settings-block > label {
	margin: auto;
	margin-right: 10px;
	flex: 0 1 auto;
}
.logs-settings-block > input {
	flex: 1 0 0;
}

/* Settings listes */
.lists-settings .lists-selector {
	min-width:300px;
}
.lists-settings .table-dictionaries {
	width: 100%;
}

/* Général */



/* fix ie10 et ie11 mr-auto et div parent en justify-content */
.modal-footer-margin-auto{
	justify-content: space-around !important;
}

html {
	position: relative;
	min-height: 100%;
}
body {
	/* Margin bottom by footer height */
	margin-bottom: 60px;
	font-family: 'Lato', sans-serif;
}

body > .container {
	padding: 60px 15px 0;
}

input:required,
textarea:required,
select:required {
	border-left: 0.25rem solid #FFA100 !important;
}

#mainMenu{
	background : #343a40;
	padding: 5px;
	height:50px;
	z-index:10001;
}
.modal-open #mainMenu{
	z-index:1030;
}
#mainMenu .navigation-menu .nav-item{
	font-size:0.9rem;
}
#mainMenu .navbar-brand {
	padding-left: 70px;
	margin-left: 5px;
	margin-right: 0;
	background: url(../img/logo/default-logo.png) no-repeat center/contain;
	height: 40px;
}
#mainMenu > button,
#mainMenu > button:focus,
#mainMenu > button:active {
	border: none;
	text-decoration: none;
	outline: none;
	box-shadow: none;
}
.menu {
	position: relative;
	height: 30px;
	width: 30px;
	cursor: pointer;
	overflow: hidden;
}
.menu-icon {
	position: absolute;
	width: 30px;
	height: 20px;
	top: 50%;
	left: 50%;
	-webkit-transform: translate(-50%, -50%);
	transform: translate(-50%, -50%);
}
.menu-line {
	position: absolute;
	left: 0;
	background-color: #808080;
	height: 3px;
	width: 100%;
	border-radius: 3px;
	pointer-events: none;
}
.menu-line-1 {
	top: 0;
}
.menu-line-2 {
	top: 0;
	bottom: 0;
	margin: auto;
}
.menu-line-3 {
	bottom: 0;
}
.menu .menu-line-4,
.menu .menu-line-5 {
	opacity: 0;
	top: 8.5px;
	transition: opacity .2s ease-in-out, -webkit-transform .2s ease-in-out;
	transition: opacity .2s ease-in-out, transform .2s ease-in-out;
	transition: opacity .2s ease-in-out, transform .2s ease-in-out, -webkit-transform .2s ease-in-out;
}
.menu .menu-line-1 {
	transition: width .2s ease-in-out .4s;
}
.menu .menu-line-2 {
	transition: width .2s ease-in-out .3s;
}
.menu .menu-line-3 {
	transition: width .2s ease-in-out .2s;
}
.menu .menu-line-4 {
	-webkit-transform: rotate(45deg) translate3d(-30px, 0, 0);
	transform: rotate(45deg) translate3d(-30px, 0, 0);
	transition: opacity .2s ease-in-out .2s,  -webkit-transform .2s ease-in-out .2s;
	transition: opacity .2s ease-in-out .2s,  transform .2s ease-in-out .2s;
	transition: opacity .2s ease-in-out .2s,  transform .2s ease-in-out .2s,  -webkit-transform .2s ease-in-out .2s;
}
.menu .menu-line-5 {
	-webkit-transform: rotate(-45deg) translate3d(30px, 0, 0);
	transform: rotate(-45deg) translate3d(30px, 0, 0);
	transition: opacity .2s ease-in-out, -webkit-transform .2s ease-in-out;
	transition: opacity .2s ease-in-out, transform .2s ease-in-out;
	transition: opacity .2s ease-in-out, transform .2s ease-in-out, -webkit-transform .2s ease-in-out;
}
.menu.open .menu-line-1 {
	width: 0;
	transition: width .2s ease-in-out;
}
.menu.open .menu-line-2 {
	width: 0;
	transition: width .2s ease-in-out .1s;
}
.menu.open .menu-line-3 {
	width: 0;
	transition: width .2s ease-in-out .2s;
}
.menu.open .menu-line-4 {
	opacity: 1;
	-webkit-transform: rotate(45deg) translate3d(0, 0, 0);
	transform: rotate(45deg) translate3d(0, 0, 0);
	transition: opacity .2s ease-in-out .2s, -webkit-transform .2s ease-in-out .2s;
	transition: opacity .2s ease-in-out .2s, transform .2s ease-in-out .2s;
	transition: opacity .2s ease-in-out .2s, transform .2s ease-in-out .2s, -webkit-transform .2s ease-in-out .2s;
}
.menu.open .menu-line-5 {
	opacity: 1;
	-webkit-transform: rotate(-45deg) translate3d(0, 0, 0);
	transform: rotate(-45deg) translate3d(0, 0, 0);
	transition: opacity .2s ease-in-out .4s, -webkit-transform .2s ease-in-out .4s;
	transition: opacity .2s ease-in-out .4s, transform .2s ease-in-out .4s;
	transition: opacity .2s ease-in-out .4s, transform .2s ease-in-out .4s, -webkit-transform .2s ease-in-out .4s;
}
.navbar-nav .nav-link {
    padding-right: 0.75rem !important; 
    padding-left: 0.75rem !important; 
}
.navbar-nav.navigation-menu {
	margin-left: 5px;
}
#loginHeader {
	/*min-width: 160px;*/
}
#mainMenu .btn-dark:focus {
	box-shadow: none;
}
#loginHeader > .user-dropdown-menu .dropdown-menu >.user-fullname {
	font-weight: bold;
	padding: 0.5rem;
	text-align: center;
}
#loginHeader > .user-dropdown-menu > button.dropdown-toggle > .user-fullname {
	display: inline;
	color: #fff !important;
}
#loginForm{
	margin: 0;
	font-size: 13px;
}

#loginForm .password-field {
	width: 100%;
}
#loginForm .password-field i {
	right: 5px;
	font-size: 0.85em;
}
#loginForm input{
	padding: 3px;
}

#loginHeader button.dropdown-toggle {
	width: 100%;
	text-align: left;
}
.user-dropdown-menu > button.dropdown-toggle {
	padding: .375rem .425rem;
}
.user-dropdown-menu .dropdown-menu{
	width:100%;
	min-width: 200px;
}
.user-dropdown-menu{
	display: inline-block;
}
.user-form .type-image-bloc input {
    width: auto;
}

#firmForm{
	max-width: 600px;
	margin: auto;
}
#firmForm img{
	max-width:150px;
	max-height: 150px;
	height: auto;
	width: auto;
}
.firm-item{
	padding-top:0;
	padding:0 15px;
}
.firm-ranks {
    padding: 0;
    overflow: auto;
    max-height: 100px;
}
.firm-ranks ul {
	padding-left: 0.5rem;
	margin-bottom: 0;
}
.firm-ranks li{
	padding: 0;
    list-style-type: none;
    margin: 0;
}
.firm-ranks li:before{
    content : "\f105";
	font-family: 'Font Awesome 5 Free';
	font-weight: 900;
	margin-right: 2px;
}
.firm-item small{
	font-weight: bold;
	font-size: 9px;
	color: #969996;
	width: 100%;
}
.firm-item select{
	width: 100%;
}
.firm-plugin-header {
	display: flex;
}
.firm-plugin-header > label {
	width: 30%;
	margin: auto;
}
.firm-plugin-header > select {
	flex: 1 1 auto;
}

#loginForm .btn{
	margin-top:5px;
	width: 100%;
}
#loginRequest{
	font-size: 30px;
	text-align: center;
	padding-top: 200px;
}
#loginRequest small{
	font-size: 16px;
	color:#cecece;
}

#prev-button {
	margin-right: 10px;
}

#parent + code {
	margin-left: 5px;
}

.table {
	border-left: 1px solid #e9ecef;
	border-bottom: 1px solid #e9ecef;
	border-right: 1px solid #e9ecef;
}
.table > thead {
	border-bottom: 1px solid #e9ecef;
}

.table > thead th{
	border-bottom: 1px solid #e9ecef;
}

.table tr > th:first-of-type,
.table tr > td:first-of-type {
	border-right: 1px solid #e9ecef;
}

.table-striped tbody tr:nth-of-type(odd) {
	background-color: #ffffff;
}
.table-striped tbody tr:nth-of-type(even) {
	background-color: rgba(0,0,0,.05);
}

.select-inline {
	margin: 0 10px;
	padding: .5rem .75rem;
	font-size: 1rem;
	line-height: 1.25;
	color: #495057;
	background-color: #fff;
	background-image: none;
	background-clip: padding-box;
	border: 1px solid rgba(0,0,0,.15);
	border-radius: .25rem;
	transition: border-color ease-in-out .15s,box-shadow ease-in-out .15s;
}
select.select-inline:first-of-type {
	margin-left: 0;
}
.dictionnary-container select.select-control {
	margin-bottom: 10px;
}
div.advanced-search div.filter-value-block select.form-control.filter-value {
	max-width: 160px;
	min-width: 218px;
}
.filter-box .advanced-search .filter-value {
	max-width: 160px;
}
.filter-box .advanced-search-action-separator {
	cursor: default;
	margin: 0 5px;
}
.filter-box .advanced-search{
	border:1px solid #eaeaea;
	padding-bottom:10px;
}
#search-clear {
	position: absolute;
	opacity: 0;
	top: 9px;
	bottom: 0;
	height: 25px;
	margin: auto;
	font-size: 14px;
	cursor: pointer;
	color: #a0a0a0;
	z-index: 4;
	transition: all 0.15s ease-in;
}
.input-group-append {
	z-index: 5;
}
#loginHeader button.dropdown-toggle {
    width: 100%;
    text-align: left;
}
#loginHeader .user-dropdown-menu button.dropdown-toggle{
	padding: .35rem .75rem;
}

/* PAGE UPDATES*/ 
.update-timeline {
    list-style: none;
    padding: 20px 0 20px;
    position: relative;
}
.update-timeline:before {
   top: 0;
   bottom: 0;
   position: absolute;
   content: " ";
   width: 3px;
   background-color: #eeeeee;
   left: 50%;
   margin-left: -1.5px;
}
.update-timeline > li {
   margin-bottom: 10px;
   position: relative;
}
.update-timeline > li:before,
.update-timeline > li:after {
    content: " ";
    display: table;
}
.update-timeline > li:after {
    clear: both;
}
.update-timeline > li > .update-timeline-panel {
    width: 46%;
    float: left;
    border: 1px solid #d4d4d4;
    border-radius: 2px;
    padding: 10px;
    position: relative;
    -webkit-box-shadow: 0 1px 6px rgba(0, 0, 0, 0.175);
    box-shadow: 0 1px 2px rgba(0, 0, 0, 0.175);
}
.update-timeline > li > .update-timeline-panel:before {
    position: absolute;
    top: 26px;
    right: -15px;
    display: inline-block;
    border-top: 15px solid transparent;
    border-left: 15px solid #ccc;
    border-right: 0 solid #ccc;
    border-bottom: 15px solid transparent;
    content: " ";
}
.update-timeline > li > .update-timeline-panel:after {
    position: absolute;
    top: 27px;
    right: -14px;
    display: inline-block;
    border-top: 14px solid transparent;
    border-left: 14px solid #fff;
    border-right: 0 solid #fff;
    border-bottom: 14px solid transparent;
    content: " ";
}
.update-timeline > li > .update-timeline-badge {
    color: #fff;
    width: 50px;
    height: 50px;
    line-height: 50px;
    font-size: 1.4em;
    text-align: center;
    position: absolute;
    top: 16px;
    left: 50%;
    margin-left: -25px;
    background-color: #999999;
    z-index: 100;
    border-top-right-radius: 50%;
    border-top-left-radius: 50%;
    border-bottom-right-radius: 50%;
    border-bottom-left-radius: 50%;
}
.update-timeline > li.update-timeline-inverted > .update-timeline-panel {
    float: right;
}
.update-timeline > li.update-timeline-inverted > .update-timeline-panel:before {
    border-left-width: 0;
    border-right-width: 15px;
    left: -15px;
    right: auto;
}
.update-timeline > li.update-timeline-inverted > .update-timeline-panel:after {
    border-left-width: 0;
    border-right-width: 14px;
    left: -14px;
    right: auto;
}
.update-timeline-badge.primary { background-color: #2e6da4 !important; }
.update-timeline-badge.success { background-color: #3f903f !important; }
.update-timeline-badge.warning { background-color: #f0ad4e !important; }
.update-timeline-badge.danger { background-color: #d9534f !important; }
.update-timeline-badge.info { background-color: #5bc0de !important; }

.update-timeline-body > p,
.update-timeline-body > ul {
    margin-bottom: 0;
}
.update-timeline-body > p + p {
    margin-top: 5px;
}
.update-commit-module{
	margin-right: 3px;
    display: inline-block;
    color: #dc3545;
    text-transform: uppercase;
    font-size: 0.7rem;
    font-weight: bold;
    padding-right: 6px;
    border-right: 2px solid #dcd4d4;
}
.update-commit-tag{
    display: inline-block;
    color: #3f51b5;
    font-size: 0.7rem;
    font-weight: bold;
    margin: 0 5px;
}
.update-timeline-body > .update-commit-tag:last-of-type {
    margin-right: 0;
}
@media (max-width: 767px) {
    ul.update-timeline:before {
        left: 40px;
    }
    ul.update-timeline > li > .update-timeline-panel {
        width: calc(100% - 90px);
        width: -moz-calc(100% - 90px);
        width: -webkit-calc(100% - 90px);
    }
    ul.update-timeline > li > .update-timeline-badge {
        left: 15px;
        margin-left: 0;
        top: 16px;
    }
    ul.update-timeline > li > .update-timeline-panel {
        float: right;
    }
    ul.update-timeline > li > .update-timeline-panel:before {
        border-left-width: 0;
        border-right-width: 15px;
        left: -15px;
        right: auto;
    }
    ul.update-timeline > li > .update-timeline-panel:after {
        border-left-width: 0;
        border-right-width: 14px;
        left: -14px;
        right: auto;
    }
}
/* TOOLTIP */
.quickform-tooltip {
	opacity: 0.85;
	background: #000;
	color: #fff;
	font-size: 13px;
	padding: 10px;
	border-radius: 2px;
	white-space: pre-wrap;
	text-decoration: none;
	border: 1px solid #000;
	box-shadow: none;
}
*[data-tooltip] {
	display: inline-block;
	position: relative;
	z-index: 15;
}
*[data-tooltip]::before,
*[data-tooltip]::after {

	/*min-width: fit-content;*/
	min-width: 500px;
	position: absolute;
	display: none;
	opacity: 0.85;
}
*[data-tooltip]::before {
	content: attr(data-tooltip);
	background: #000;
	color: #fff;
	font-size: 13px;
	padding: 10px;
	border-radius: 2px;
	white-space: pre-wrap;
	text-decoration: none;
}
*[data-tooltip]::after {
	width: 0;
	height: 0;
	border: 6px solid transparent;
	content: '';
}

*[data-tooltip]:hover::before,
*[data-tooltip]:hover::after {
	display: block;
}
*[data-tooltip][data-placement="right"]::before {
	top: 10%;
	left: 100%;
	margin-left: 10px;
	text-align: left;
}
*[data-tooltip][data-placement="right"]::after {
	border-right-color: #000;
	border-left: none;
	top: 50%;
	right: -10px;
	margin-top: -6px;
	margin-left: 4px;
}


li.active .dropdown-item{
    color: #16181b;
    text-decoration: none;
    background-color: #f8f9fa;
}


/* FIN TOOLTIP */

.quickform {
	position: relative;
	flex: 0 0 auto;
}
.quickform > span {
	line-height: 3em;
	cursor: pointer;
}

.dropdown-item.login-item{
	color:#222222;
	padding: 0 5px;
	background-color: #fff;
}
.dropdown-item.active, .dropdown-item.login-item:active {
	color: #222222;
	text-decoration: none;
	background-color: transparent;
}
.container-fluid{
	padding: 66px 15px 0 15px;
}
.container-small{
	margin:auto;
	max-width: 700px;
}
.no-border-radius {
    border-radius: 1px;
}
.btn{
	cursor: pointer;
}
.btn-small {
	padding: 5px 10px;
	font-size: 15px;
}
.btn-squarred.btn-small {
	padding: 3px 7px;
	font-size: 1em;
	width: 31px;
	height: 31px;
	line-height: 1.5;
}
.btn-mini{
    padding: 0.1rem .4rem;
    font-size: 0.6rem;
    line-height: 1.8;
    border-radius: .2rem;
}
.btn-squarred.btn-mini {
	padding: 0 3px;
	font-size: 0.8em;
	width: 21px;
	height: 21px;
	line-height: 1.5;
}
.btn-squarred {
	padding: 5px 9px;
	font-size: 1em;
	width: 36px;
	height: 36px;
}
.btn-rounded {
    padding-top: 5px;
    padding-left: 9px;
    box-sizing: border-box;
    border-radius: 100%;
    width: 36px;
    height: 36px;
    font-size: 1em;
}
.btn-rounded.btn-mini {
	padding-top: 2px;
	padding-left: 5px;
	width: 22px;
	height: 22px;
	font-size: 0.7em;
}
.btn.btn-link{
	-webkit-appearance: none;
}
.noLabel{
	margin-top: 31px;
}
.noDisplay{
	display:none;
}
.no-select {
	user-select: none !important;
}
.form-control {
	height: auto;
}
.form-control:focus {
    border: 1px solid rgba(0,0,0,.15);
    outline: 0;
    box-shadow: 0 0 0 0 rgba(0,0,0,0);
    color: #000;
}
.form-control:disabled:focus,
.form-control[readonly]:focus,
.form-control[disabled]:focus {
	color: #495057;
	border: 1px solid #ced4da;
}
/*Pagination*/
.pagination {
	flex-wrap: wrap;
}
.no-select {
	user-select: none !important;
}

.white{
	color:white !important;
}
.white a{
	color:white !important;
}
/* Custom page CSS
-------------------------------------------------- */
/* Not required for template or sticky footer method. */


input[data-type="date"]{
	background-image: url('../img/icons/icon-calendar.png');
	background-repeat:no-repeat;
	background-position: 10px center;
	padding-left: 30px!important;
	transition:color 0.2s ease-in-out;
}
input[data-type="hour"]{
	background-image: url('../img/icons/icon-clock.png');
	background-repeat:no-repeat;
	background-position: 10px center;
	padding-left: 30px!important;
}
input[data-type="user"]{
	display:none!important;
}

div.data-type-user{
	background-image: url('../img/icons/icon-user.png');
	background-repeat:no-repeat;
	background-position: 10px center;
	padding-left: 30px !important;
	height:inherit !important;
}


div.data-type-user[required] {
	border-left: 0.25rem solid #FFA100 !important;
}

div.data-type-user > ul > li > input{
	border:0;
	outline: none;
	margin:0;
	background: transparent;
	padding:0;
}
div.data-type-user > ul{
	border:0;
	margin:0;
	padding:0;
	height:100%;
	width:100%;
	vertical-align: top;
	list-style-type:none; 
	/*display: flex;*/
    align-items: center;
}
div.data-type-user > ul > li{
	padding:0 5px 0 5px;
	display: inline-block;
	margin:0;
	padding:0 5px 0 0;
	vertical-align: middle;
}
div.data-type-user > ul > li > div{
	display: flex;
	font-size: 12px;
	
	border-bottom: 1px solid #4caf50;
	text-overflow: ellipsis;

	white-space: nowrap;
    border-radius: 3px;
    padding: 0 5px 0 5px;
    background-color: #e9ecef;
}
div.data-type-user > ul > li > div > i{
	margin: auto;
	margin-left:5px;
	cursor: pointer;
	vertical-align: middle;
	font-size: 9px;
}
div.data-type-user ul.dropdown-menu .dropdown-item {
	position: relative;
    padding: .25rem 1.25rem;
}
div.data-type-user  ul.dropdown-menu div.user-logo,
div.data-type-user   ul.dropdown-menu div.rank-logo {
	display: inline-block;
	width: auto;
	position: absolute;
	top: 50%;
	transform: translateY(-50%);
}
div.data-type-user  ul.dropdown-menu div.user-infos,
div.data-type-user  ul.dropdown-menu div.rank-infos {
	margin-left: 2.25rem;
	min-height: 30px;
}
.user-picker-tag[data-entity="rank"] div{
	border-color: #03a9f4;
}



/* data type tag list*/
input[data-type="tag-list"]{
	display:none!important;
}

div.data-type-tag-list{
	background-image: url('../img/icons/icon-tag.png');
	background-repeat:no-repeat;
	background-position: 10px center;
	padding-left: 30px !important;
	height:inherit !important;
}

div.data-type-tag-list[required] {
	border-left: 0.25rem solid #FFA100 !important;
}


div.data-type-tag-list > ul > li > input{
	border:0;
	outline: none;
	margin:0;
	background: transparent;
	padding:0;
}
div.data-type-tag-list > ul{
	border:0;
	margin:0;
	padding:0;
	height:100%;
	width:100%;
	vertical-align: top;
	list-style-type:none; 
	/*display: flex;*/
    align-items: center;
}
div.data-type-tag-list > ul > li{
	padding:0 5px 0 5px;
	display: inline-block;
	margin:0;
	padding:0 5px 0 0;
	vertical-align: text-bottom;
}
.data-type-tag-list > ul > li > div > i{
	margin: auto;
	margin-left:5px;
	cursor: pointer;
	vertical-align: middle;
	font-size: 9px;
}
div.data-type-tag-list ul.dropdown-menu .dropdown-item {
	position: relative;
    padding: .25rem 1.25rem;
}

div.data-type-tag-list > ul > li > div {
    display: flex;
    font-size: 12px;
    text-overflow: ellipsis;
    white-space: nowrap;
    border-radius: 3px;
    padding: 0 5px 0 5px;
    background-color: #e9ecef;
}

/**/


input[data-type="location"]{
  background-image: url('../img/icons/icon-location.png');
  background-repeat:no-repeat;
  background-position: 10px center;
  padding-left: 30px!important;
}

div[data-type="dropzone"].form-control {
	height: auto;
}
div[data-type="dropzone"]{
	border-style: dashed;
	background: #e9e9e9;
	position:relative;
}
div[data-type="dropzone"] > div{
	padding:5px;
}
div[data-type="dropzone"] > ul{
	list-style-type:none; 
	margin:0; 
	padding:0; 
}
div[data-type="dropzone"] > ul > li{
	position:relative;
	padding:3px;
	border-bottom:1px solid #cecece;
	background:#ffffff;
}
div[data-type="dropzone"] > ul > li > i:first-of-type{
	margin: 0 5px;
}
div[data-type="dropzone"] > ul > li > i.pointer{
	position:absolute;
	right:5px;
	top: 50%;
	transform: translateY(-50%);
}
div[data-type="dropzone"] .preload{
	top: 0px;
	box-sizing: border-box;
	display: block;
	position: absolute;
	content: "";
	padding:0;
	left: 0;
	width: 100%;
	display: none;
	height: 5px;
	background-color: #2b9ad8;
	transition: all 0.2s ease-in-out;
}
.dropzone-custom-button {
	position: absolute;
	right: 5px;
	padding: 0 5px;
	font-size: 1em;
	top: 50%;
	transform: translateY(-50%);
}

table thead th[data-sortable]{
	cursor: pointer;
}
table thead th[data-sortable]:before{
	content: "\f0dc";
	padding-right:5px;
	font-size: 13px;
	color:#aeaeae;
	font-family: 'Font Awesome 5 Free';
	font-weight: 900;
}

table thead th.sort-asc:before{
	content: "\f0de";
	padding-right:5px;
	font-size: 13px;
	color:#aeaeae;
	font-family: 'Font Awesome 5 Free';
	font-weight: 900;
}

table thead th.sort-desc:before{
	content: "\f0dd";
	padding-right:5px;
	font-size: 13px;
	color:#aeaeae;
	font-family: 'Font Awesome 5 Free';
	font-weight: 900;
}

ul[data-type="filter"]{
	display: none;
}
input[type="color"].form-control{
    border-radius: 0 3px 3px 0;
    border-left: 0;
    width: 45px;
    height: 38px;
}

/* COMPOSANT PASSWORD */
.password-field {
	position: relative;
}
.password-field i {
	position: absolute;
	top: 50%;
	cursor: pointer;
	transform: translateY(-50%);
}
.password-field i.password-toggler,
.password-field i.password-generator {
	right: 10px;
}
.password-field i.password-toggler + i.password-generator {
	right: 35px;
}
.strength-transparent { background-color: transparent !important; }
.strength-low { background-color: #e74c3c !important; }
.strength-medium { background-color: #e67e22 !important; }
.strength-hard { background-color: #2ecc71 !important; }

.password-field .strength-lines {
	position: absolute;
	bottom: 1px;
	left: 2px;
	right: 0;
	width: calc(100% - 5px);
	height: 6px;
	z-index: 3;
}
.password-field .strength-lines .line {
	position: absolute;
	background-color: transparent;
	height: 4px;
	border-radius: 2px;
	transition: background-color 0.15s ease-in;
}
.password-field .strength-lines .line:not(:first-of-type):not(:last-of-type) {
	left: 33%;
	right: 33%;
}
.password-field .strength-lines .line:first-of-type {
	left: 4px;
	right: 68%;
}
.password-field .strength-lines .line:last-of-type {
	left: 68%;
	right: 4px;
}
/* FIN COMPOSANT PASSWORD */

/* COMPOSANT ICÔNES */
.component-icon.dropdown {
	position: unset;
}
.component-icon div.dropdown-menu {
	max-height: 400px;
	width: 100%;
	max-width: 550px;
	overflow-x: auto;
}
.component-icon .dropdown-item {
	display: block;
	height: auto;
	padding: .25rem 0.5rem;
	width: 100%;
}
.component-icon .dropdown-icon-item {
    cursor: pointer;
    display: inline-block;
    width: 35px;
    height: 35px;
    padding:10px;
}
.component-icon .dropdown-icon-item:focus,
.component-icon .dropdown-icon-item:active,
.component-icon .dropdown-icon-item:hover {
    color: #fff;
    text-decoration: none;
    background-color: #007bff;
    border-radius: 3px;
}
.component-icon .dropdown-item > span > i {
    margin: auto;
}
.icon-chooser button {
	border-top-right-radius: 0;
	border-bottom-right-radius: 0;
}
.component-icon .dropdown-item.active, 
.component-icon .dropdown-item:active {
	color: unset;
	background-color: unset;
}
.component-icon .dropdown-item:focus, 
.component-icon .dropdown-item:hover {
	color: unset;
	background-color: unset;
}
/* FIN COMPOSANT ICÔNES */

/* BACK TO TOP */
#toTheTop {
	width: 40px;
	height: 40px;
    background-color: #007bff;
	border-radius: 50%;
	position: fixed;
	right: 20px;
	bottom: 10px;
	opacity: 0;
	cursor: pointer;
	z-index: 1;
}
#toTheTop:after {
	content: "\f106";
	font-family: 'Font Awesome 5 Free';
	font-weight: 900;
	color: #ffffff;
	position: absolute;
	top: 50%;
	left: 50%;
	transform: translate(-50%, -50%);
}
/* FIN BACK TO TOP */

/* COMPOSANT FILTER */
.filter-box{
	display: none;
}
.input-group>.input-group-append>.btn.filter-button-search,
.input-group>.input-group-append:last-child>.btn:not(:last-child):not(.dropdown-toggle).filter-button-search{
	border-radius: 0 3px 3px 0;
}
.filter-box .advanced-search{
	display: none;
	margin-top: 10px;
}
.filterRow{
	margin: 3px 0;
}
.filterRow .filter-column {
	cursor: pointer;
}
.filterRow .filter-add-button {
}
.filterRow .filter-delete-button {
}
.filter-value-block{
	padding: 0;
	border:none;
	display: none;
}
.filter-operator,
.form-control.filter-operator{
	width:150px;
}
.filter-join,.form-control.filter-join{
	width:89px;
}
/* FIN COMPOSANT FILTER */


/* COMPOSANT IMAGE */
.type-image-bloc {
	position: relative;
}
.type-image-bloc .btn-delete-img {
	position: absolute;
    right: 0px;
}
.type-image-bloc img{
	/*max-width:70px;*/
	max-height:70px;
	display: inline-block;
	margin-right: 15px;
}
.type-image-bloc input{
	display: inline-block;
	width: auto;
}
/* FIN COMPOSANT IMAGE */


/* COMPOSANT DATE */
div#ui-datepicker-div{
	background-color: #ffffff;
	border:1px solid #cecece;
	z-index:10000 !important;
}

/* CUSTOM CHECKBOXES */
.check-component {
    width: 15px;
    height: 15px;
    margin: 0 5px;
    /*margin: auto;*/
    border: 1px solid #bbbbbb;
}
.check-component input {
    display: none;
}
.check-component input:checked + .box {
    background-color: #ddf8d8;
}
.check-component input:indeterminate + .box {
    background-color: #ffd6c9;
}
.check-component .box {
    width: 100%;
    height: 100%;
    transition: .35s cubic-bezier(0.19, 1, 0.22, 1);
    transition-property: background-color, color, top, left, right, bottom;
    border: 2px solid transparent;
    background-color: white;
    position: relative;
    overflow: hidden;
    cursor: pointer;
    box-shadow: 0 1px rgba(0, 0, 0, 0.2);
}
.check-component input:checked + .box:after {
    width: 85%;
    height: 45%;
    border-left: 1.5px solid;
    border-bottom: 1.5px solid;
    border-color: #28b72e;
    transform: rotate(-45deg) translate3d(0, 0, 0);
    transform-origin: center center;
    top: 0;
}
.check-component input:indeterminate + .box:after {
	width: 75%;
    height: 0;
	top: 0;
	border-top: 1.5px solid rgba(50, 50, 50,.5);;
}
.check-component .box:after {
    content: '';
    position: absolute;
    transition: .35s cubic-bezier(0.19, 1, 0.22, 1);
    transition-property: background-color, color, top, left, right, bottom;
    left: 0;
    right: 0;
    top: 200%;
    bottom: 5%;
    margin: auto;
}

/* CUSTOM RADIO */
.radio-component:checked,
.radio-component:not(:checked) {
    position: absolute;
    left: -9999px;
}
.radio-component:checked + label,
.radio-component:not(:checked) + label {
    position: relative;
    padding-left: 20px;
    cursor: pointer;
    line-height: 20px;
    display: inline-block;
    color: #333;
    margin-bottom: 0;
    pointer-events: none;
}
.radio-component:checked + label:before,
.radio-component:not(:checked) + label:before {
	content: '';
	position: absolute;
	left: 0;
	top: -15px;
	width: 18px;
	height: 18px;
	border: 1px solid #7db581;
	box-shadow: 0 1px rgba(0, 0, 0, 0.2);
	border-radius: 100%;
	background: #fff;
	pointer-events: all;
}
.radio-component:checked + label:after,
.radio-component:not(:checked) + label:after {
	content: '';
	width: 8px;
	height: 8px;
	background: #2fca26;
	position: absolute;
	top: -10px;
	left: 5px;
	border-radius: 100%;
	-webkit-transition: all 0.2s ease;
	transition: all 0.2s ease;
	pointer-events: all;
}
.radio-component:not(:checked) + label:after {
    opacity: 0;
    -webkit-transform: scale(0);
    transform: scale(0);
}
.radio-component:checked + label:after {
    opacity: 1;
    -webkit-transform: scale(1);
    transform: scale(1);
}

*[data-type="card"].card-component-container {
	cursor: pointer;
	color: #2b9ad8;
	position: static;
}
*[data-type="card"].card-component-container > div.wrapper {
	display: block;
	min-height: 0px;
}
*[data-type="card"].card-component-container:hover {
	text-decoration: underline;
	color: #207cb1;
}
.card-component {
	text-transform: none;
	font-size: 12pt;
	cursor: default;
	color: #2a2a28;
	opacity: 0;
	position: absolute;
	z-index: -1;
	background-color: #fff;
	border-radius: 4px;
    box-shadow: 0 1px 2px 0 rgba(60, 64, 67, 0.3), 0 2px 6px 2px rgba(60, 64, 67, .15);
	transition: all .40s;
}
.card-component-hover {
	animation: slide-up-fade-in ease 0.35s;
	animation-iteration-count: 1;
	transform-origin: 50% 50%;
    animation-fill-mode:forwards;

    -webkit-animation: slide-up-fade-in ease 0.35s;
    -webkit-animation-iteration-count: 1;
    -webkit-transform-origin: 50% 50%;
    -webkit-animation-fill-mode:forwards; /*Chrome 16+, Safari 4+*/ 

    -moz-animation: slide-up-fade-in ease 0.35s;
    -moz-animation-iteration-count: 1;
    -moz-transform-origin: 50% 50%;
    -moz-animation-fill-mode:forwards; /*FF 5+*/

    -o-animation: slide-up-fade-in ease 0.35s;
    -o-animation-iteration-count: 1;
    -o-transform-origin: 50% 50%;
    -o-animation-fill-mode:forwards; /*Not implemented yet*/

    -ms-animation: slide-up-fade-in ease 0.35s;
    -ms-animation-iteration-count: 1;
    -ms-transform-origin: 50% 50%;
    -ms-animation-fill-mode:forwards; /*IE 10+*/
}
.card-component-hide {
	animation: slide-down-fade-out ease 0.25s;
	animation-iteration-count: 1;
	transform-origin: 50% 50%;
    animation-fill-mode:forwards;
    
	-webkit-animation: slide-down-fade-out ease 0.25s;
	-webkit-animation-iteration-count: 1;
	-webkit-transform-origin: 50% 50%;
    -webkit-animation-fill-mode:forwards;
    
	-moz-animation: slide-down-fade-out ease 0.25s;
	-moz-animation-iteration-count: 1;
	-moz-transform-origin: 50% 50%;
    -moz-animation-fill-mode:forwards;
    
	-o-animation: slide-down-fade-out ease 0.25s;
	-o-animation-iteration-count: 1;
	-o-transform-origin: 50% 50%;
    -o-animation-fill-mode:forwards;
    
	-ms-animation: slide-down-fade-out ease 0.25s;
	-ms-animation-iteration-count: 1;
	-ms-transform-origin: 50% 50%;
    -ms-animation-fill-mode:forwards;
}
@keyframes slide-up-fade-in{
    0% {
        opacity:0;
		z-index: -1;
        transform:  translate(0px,40px);
    }
    100% {
        opacity:1;
		z-index: 1100;
        transform:  translate(0px,0px);
    }
}
@-moz-keyframes slide-up-fade-in{
    0% {
        opacity:0;
		z-index: -1;
        transform:  translate(0px,40px);
    }
    100% {
        opacity:1;
		z-index: 1100;
        transform:  translate(0px,0px);
    }
}
@-webkit-keyframes slide-up-fade-in{
    0% {
        opacity:0;
		z-index: -1;
        transform:  translate(0px,40px);
    }
    100% {
        opacity:1;
		z-index: 1100;
        transform:  translate(0px,0px);
    }
}
@-o-keyframes slide-up-fade-in{
    0% {
        opacity:0;
		z-index: -1;
        transform:  translate(0px,40px);
    }
    100% {
        opacity:1;
		z-index: 1100;
        transform:  translate(0px,0px);
    }
}
@keyframes slide-down-fade-out{
    0% {
        opacity:1;
		z-index: 1100;
        transform:  translate(0px,0px);
    }
    100% {
        opacity:0;
		z-index: -1;
        transform:  translate(0px,40px);
    }
}
@-moz-keyframes slide-down-fade-out{
    0% {
        opacity:1;
		z-index: 1100;
        transform:  translate(0px,0px);
    }
    100% {
        opacity:0;
		z-index: -1;
        transform:  translate(0px,40px);
    }
}
@-webkit-keyframes slide-down-fade-out{
    0% {
        opacity:1;
		z-index: 1100;
        transform:  translate(0px,0px);
    }
    100% {
        opacity:0;
		z-index: -1;
        transform:  translate(0px,40px);
    }
}
@-o-keyframes slide-down-fade-out{
    0% {
        opacity:1;
		z-index: 1100;
        transform:  translate(0px,0px);
    }
    100% {
        opacity:0;
		z-index: -1;
        transform:  translate(0px,40px);
    }
}

#logs .log-col {
	width: 700px;
	max-width: 700px;
}

.avatar{
	width: 120px;
	height: 120px;
}
.avatar-medium{
	width: 60px;
	height: 60px;
}
.avatar-mini{
	width: 30px;
	height: 30px;
}
.avatar-rounded{
	border-radius: 100%;
}
.avatar-login {
	margin-right: 5px;
}
.default {
	cursor: default;
}
.pointer{
	cursor: pointer;
}

.left{
	float: left;
}
.mini-title{
	font-size: 0.7em;
	font-weight: bold;
	text-transform: uppercase;
}
.right{
	float: right;
}
.clear{
	clear: both;
}
.inline{
	display: inline-block;
	vertical-align: top;
}

.block{
	display:block!important;
}

.width100{
	width:100%!important;
}

.alignleft{
	text-align: left;
}

.footer {
	position: absolute;
	bottom: 0;
	width: 100%;
	/* Set the fixed height of the footer here */
	height: 60px;
	line-height: 60px; /* Vertically center the text there */
	background-color: #f5f5f5;
}

.footer > .container {
	padding-right: 15px;
	padding-left: 15px;
}

footer > div {
	text-align: center;
}

code {
	font-size: 80%;
	color: #ea0046;
}

[data-mandatory]{
	border-left:  6px solid orange;
}

@media print {
	.noPrint{
		display: none;
	}
}

#plugins {
	list-style: none;
}

#plugins .activator{
	position : absolute;
	right:10px;
	top:10px;
	width: 130px;
	text-align: left;
}

.hidden,.hide,
.form-control.hidden,
.form-control.hide{
	display: none!important;
}
.invisible,
.form-control.invisible{
	visibility: hidden;
}

#rankList {
	margin-top: 30px;
}



/* fix input-group-text manquant dans cette version */
.input-group>.input-group-append:last-child>.btn:not(:last-child):not(.dropdown-toggle), .input-group>.input-group-append:last-child>.input-group-text:not(:last-child), .input-group>.input-group-append:not(:last-child)>.btn, .input-group>.input-group-append:not(:last-child)>.input-group-text, .input-group>.input-group-prepend>.btn, .input-group>.input-group-prepend>.input-group-text {
    border-top-right-radius: 0;
    border-bottom-right-radius: 0;
}
.input-group>.input-group-append>.btn, .input-group>.input-group-append>.input-group-text, .input-group>.input-group-prepend:first-child>.btn:not(:first-child), .input-group>.input-group-prepend:first-child>.input-group-text:not(:first-child), .input-group>.input-group-prepend:not(:first-child)>.btn, .input-group>.input-group-prepend:not(:first-child)>.input-group-text {
    border-top-left-radius: 0;
    border-bottom-left-radius: 0;
}
.input-group-text {
    display: -ms-flexbox;
    display: flex;
    -ms-flex-align: center;
    align-items: center;
    padding: .375rem .75rem;
    margin-bottom: 0;
    font-size: 1rem;
    font-weight: 400;
    line-height: 1.5;
    color: #495057;
    text-align: center;
    white-space: nowrap;
    background-color: #e9ecef;
    border: 1px solid #ced4da;
    border-radius: .25rem;
}

.input-group-check{
	    margin: 0 5px 0 0;
}


.input-group-inline{
	display: inline-block;
	vertical-align: top;
	width:auto;
}

.modal.w-100 .modal-dialog {
    max-width: 100%;
    margin: 1.75rem auto;
}
.component-dictionnary-table .action-cell{
	width: 90px;
}


/* effects */

@-webkit-keyframes pop-in {
	0% {  -webkit-transform: scale(1); }
	50% {  -webkit-transform: scale(1.1); }
	100% {  -webkit-transform: scale(1); }
}
@-moz-keyframes pop-in {
	0% {  -moz-transform: scale(1); }
	50% {  -moz-transform: scale(1.1); }
	100% {  -moz-transform: scale(1); }
}
@keyframes pop-in {
	0% {  transform: scale(1); }
	50% {  transform: scale(1.1); }
	100% { transform: scale(1); }
}

/* Horizontal shake */
@-webkit-keyframes hshake {
    10%, 90% { -webkit-transform: translate3d(-1px, 0, 0); }
    20%, 80% { -webkit-transform: translate3d(2px, 0, 0); }
    30%, 50%, 70% { -webkit-transform: translate3d(-4px, 0, 0); }
    40%, 60% { -webkit-transform: translate3d(4px, 0, 0); }
}
@-moz-keyframes hshake {
    10%, 90% { -moz-transform: translate3d(-1px, 0, 0); }
    20%, 80% { -moz-transform: translate3d(2px, 0, 0); }
    30%, 50%, 70% { -moz-transform: translate3d(-4px, 0, 0); }
    40%, 60% { -moz-transform: translate3d(4px, 0, 0); }
}
@keyframes hshake {
    10%, 90% { transform: translate3d(-1px, 0, 0); }
    20%, 80% { transform: translate3d(2px, 0, 0); }
    30%, 50%, 70% { transform: translate3d(-4px, 0, 0); }
    40%, 60% { transform: translate3d(4px, 0, 0); }
}

/* Vertical Shake */
@-webkit-keyframes vshake {
    10%, 90% { -webkit-transform: translate3d(0, -1px, 0); }
    20%, 80% { -webkit-transform: translate3d(0, 2px, 0); }
    30%, 50%, 70% { -webkit-transform: translate3d(0, -4px, 0); }
    40%, 60% { -webkit-transform: translate3d(0, 4px, 0); }
}
@-moz-keyframes vshake {
    10%, 90% { -moz-transform: translate3d(0, -1px, 0); }
    20%, 80% { -moz-transform: translate3d(0, 2px, 0); }
    30%, 50%, 70% { -moz-transform: translate3d(0, -4px, 0); }
    40%, 60% { -moz-transform: translate3d(0, 4px, 0); }
}
@keyframes vshake {
    10%, 90% { transform: translate3d(0, -1px, 0); }
    20%, 80% { transform: translate3d(0, 2px, 0); }
    30%, 50%, 70% { transform: translate3d(0, -4px, 0); }
    40%, 60% { transform: translate3d(0, 4px, 0); }
}


#preloader-text {
	position: absolute;
	top: 37%;
	left: 46.5%;
	-webkit-user-select: none;
	-moz-user-select: none;
	-ms-user-select: none;
	user-select: none;
	color: #373b3c;
}

#preloader {
	/* Uncomment this to make it run! */
  	/*animation: loader 5s linear infinite; */
	position: absolute;
	top: calc(30% - 20px);
	left: calc(50% - 20px);
}
@keyframes loader {
	0% { left: -100px }
	100% { left: 110%; }
}
#preloader-box {
	width: 50px;
	height: 50px;
	background: #81d0ef;
	animation: animate .5s linear infinite;
	position: absolute;
	top: 0;
	left: 0;
	border-radius: 3px;
}
@keyframes animate {
	17% { border-bottom-right-radius: 3px; }
	25% { transform: translateY(9px) rotate(22.5deg); }
	50% {
		transform: translateY(18px) scale(1,.9) rotate(45deg) ;
		border-bottom-right-radius: 40px;
	}
	75% { transform: translateY(9px) rotate(67.5deg); }
	100% { transform: translateY(0) rotate(90deg); }
} 
#preloader-shadow { 
	width: 50px;
	height: 5px;
	background: #000;
	opacity: 0.1;
	position: absolute;
	top: 59px;
	left: 0;
	border-radius: 50%;
	animation: shadow .5s linear infinite;
}
@keyframes shadow {
	50% {
		transform: scale(1.2,1);
	}
}

@keyframes heartbeat {
    0% { transform: scale(.75) }
    20% { transform: scale(1) }
    40% { transform: scale(.75) }
    60% { transform: scale(1) }
    80% { transform: scale(.75) }
    to { transform: scale(.75) }
}

/** MEDIA QUERIES **/
@media (max-width: 1000px) {
	#mainMenu .navigation-menu .nav-item i{
		display: none;
	}
}
@media (max-width: 767px) {
	#mainMenu{
		height: auto;
	}
	#mainMenu .navigation-menu .nav-item i{
		display: inline-block;
	}
	#loginHeader .user-dropdown-menu {
	    width: 100%;
	}
	.dropdown-toggle::after {
		float: right;
		margin-top: 12px;
	}
	#loginHeader{
		position: unset;
    }
    #navbarCollapse {
    	margin-top: 5px;
    	border-top: 1px #808080 solid;
    	font-size: 0.75em;
    }
    #navbarCollapse.collapse.show {
    	/*overflow-y: auto;*/
    }
    .firm-plugin-header {
    	display: block;
    }
    .firm-plugin-header > label {
    	width: 100%;
    	margin-bottom: 10px;
    }
	.dashboard > li {
	    margin: auto;
	}
	.type-image-bloc input {
	     width: 100%; 
	}
	.lists-settings .lists-selector {
		min-width: 0;
	}
	.lists-settings .lists-navigation-block span {
		margin-bottom: 15px;
		display: inline-block;
	}
	.filter-box > .input-group > .input-group-prepend {
		display: none;
	}
}