body {
  font-size: .875rem;
}

.feather {
  width: 16px;
  height: 16px;
}

/*
 * Sidebar
 */

.sidebar {
  position: fixed;
  top: 0;
  /* rtl:raw:
  right: 0;
  */
  bottom: 0;
  /* rtl:remove */
  left: 0;
  z-index: 100; /* Behind the navbar */
  padding: 48px 0 0; /* Height of navbar */
  box-shadow: inset -1px 0 0 rgba(0, 0, 0, .1);
}

@media (max-width: 767.98px) {
  .sidebar {
    top: 5rem;
  }
}

.sidebar-sticky {
  height: calc(100vh - 48px);
  overflow-x: hidden;
  overflow-y: auto; /* Scrollable contents if viewport is shorter than content. */
}

.sidebar .nav-link {
  font-weight: 500;
  color: #333;
}

.sidebar .nav-link .feather {
  margin-right: 4px;
  color: #727272;
}

.sidebar .nav-link.active {
  color: #2470dc;
}

.sidebar .nav-link:hover .feather,
.sidebar .nav-link.active .feather {
  color: inherit;
}

.sidebar-heading {
  font-size: .75rem;
}

/*
 * Navbar
 */

.navbar-brand {
  padding-top: .75rem;
  padding-bottom: .75rem;
  background-color: rgba(0, 0, 0, .25);
  box-shadow: inset -1px 0 0 rgba(0, 0, 0, .25);
}

.navbar .navbar-toggler {
  top: .25rem;
  right: 1rem;
}

.navbar .form-control {
  padding: .75rem 1rem;
}

.form-control-dark {
  color: #fff;
  background-color: rgba(255, 255, 255, .1);
  border-color: rgba(255, 255, 255, .1);
}

.form-control-dark:focus {
  border-color: transparent;
  box-shadow: 0 0 0 3px rgba(255, 255, 255, .25);
}

#cover-spin {
  position:fixed;
  width:100%;
  left:0;right:0;top:0;bottom:0;
  background-color: rgba(255,255,255,0.7);
  z-index:9999;
  display:none;
}

@-webkit-keyframes spin {
  from {-webkit-transform:rotate(0deg);}
  to {-webkit-transform:rotate(360deg);}
}

@keyframes spin {
  from {transform:rotate(0deg);}
  to {transform:rotate(360deg);}
}

#cover-spin::after {
  content:'';
  display:block;
  position:absolute;
  left:48%;top:40%;
  width:40px;height:40px;
  border-style:solid;
  border-color:black;
  border-top-color:transparent;
  border-width: 4px;
  border-radius:50%;
  -webkit-animation: spin .8s linear infinite;
  animation: spin .8s linear infinite;
}


table th{
  min-width:50px ;
}
.month-label h4{
  font-weight:bold;
}
table th.username{
  min-width:220px !important;
  cursor:pointer;
}
table .bg-head{
  background-color: #F0F0F0 ;
}
td.day-SO, th.day-SO, td.day-SA, th.day-SA{
  background-color: #E0E0E0 ;
}
th.username{
  text-align:right;
}

.calender-days .day-number{
  font-size:18px;
  margin-left:-20px;
}
.calender-days .day-label{
  position:absolute;
  font-size:12px;
  margin-left:4px;
  color: #7c7c7c;
}
.calender-days .user-day:hover{
  opacity: 0.5;
  cursor:pointer;
}
.calender-days .user-day{
  font-weight: bold;
  font-size:20px;
  padding:0px;
  color: black;
  text-align:center;
}
#context-menu a{
  cursor:pointer;
}

.calender-main .table-bordered td,
.calender-main .table-bordered th,
.calender-main tbody, .calender-main td,  .calender-main th, .calender-main thead, .calender-main tr{
  border-color: #4a4a4a !important;
}

.calender-days thead th{
  padding:0px;
}
.calender-days .topMarker, .calender-days .downMarker{
  width:auto;
  display: block;
  position: relative;
  min-height:10px;
}
.calender-main{
  -webkit-user-select: none;
  -ms-user-select: none;
  user-select: none;
}
.calender-main th.username span.holidays{
  position:absolute;
  background-color: #3e6052;
  border-radius:5px;
  color:white;
  padding:5px;
  margin:0px;
  font-size:12px;
  width:35px;
  text-align: center;
  margin-top: -2px;
  left:20px;
}

.calender-days .feastDay{
  background-color: #fb5757;
  cursor: pointer;
  color:white;
}
.calender-days .holiDay{
  background-color: #FFFF00 ;
  cursor: pointer;
}
.calender-days .user-day.marker{
  border:2px solid red !important;
}
tr:hover> .username {
  background-color: #d0d0d0;
}

