body {
  font-family: Roboto,sans-serif;
  min-height: 100%;
  position: relative;
}
body a {
  color: #ab0000;
}
body .btn-primary {
  background-color: #ab0000;
  border-color: #990000;
}
body .dropdown.show ul.dropdown-menu {
  display: inherit;
  width: 265px;
}
body .dropdown.show ul.dropdown-menu li {
  display: block;
}
body .dropdown.show ul.dropdown-menu li a {
  display: block;
}
body .header {
  box-shadow: 0 0 3px rgba(0, 0, 0, 0.2);
}
body .header .top-bar {
  background: #ab0000;
  color: #fff;
  font-size: 12px;
  overflow: hidden;
  /* BELL */
}
body .header .top-bar div p {
  margin: 8px 5px;
}
body .header .top-bar .welcome-msg {
  text-align: left;
  float: left;
}
body .header .top-bar .slug {
  text-align: center;
}
body .header .top-bar .phone a {
  color: white;
}
body .header .top-bar .right-col {
  text-align: right;
  float: right;
}
body .header .top-bar .right-col p {
  display: inline-block;
}
body .header .top-bar .right-col .pto-alert {
  padding: 0 10px 0 0;
  border-right: 1px solid #ffffff;
}
body .header .top-bar .right-col .pto-alert a {
  color: #ffffff;
}
body .header .top-bar .right-col .pto-alert a:hover {
  text-decoration: none;
}
@-webkit-keyframes ring {
  0% {
    -webkit-transform: rotate(-15deg);
    transform: rotate(-15deg);
  }
  2% {
    -webkit-transform: rotate(15deg);
    transform: rotate(15deg);
  }
  4% {
    -webkit-transform: rotate(-18deg);
    transform: rotate(-18deg);
  }
  6% {
    -webkit-transform: rotate(18deg);
    transform: rotate(18deg);
  }
  8% {
    -webkit-transform: rotate(-22deg);
    transform: rotate(-22deg);
  }
  10% {
    -webkit-transform: rotate(22deg);
    transform: rotate(22deg);
  }
  12% {
    -webkit-transform: rotate(-18deg);
    transform: rotate(-18deg);
  }
  14% {
    -webkit-transform: rotate(18deg);
    transform: rotate(18deg);
  }
  16% {
    -webkit-transform: rotate(-12deg);
    transform: rotate(-12deg);
  }
  18% {
    -webkit-transform: rotate(12deg);
    transform: rotate(12deg);
  }
  20% {
    -webkit-transform: rotate(0deg);
    transform: rotate(0deg);
  }
}
@keyframes ring {
  0% {
    -webkit-transform: rotate(-15deg);
    -ms-transform: rotate(-15deg);
    transform: rotate(-15deg);
  }
  2% {
    -webkit-transform: rotate(15deg);
    -ms-transform: rotate(15deg);
    transform: rotate(15deg);
  }
  4% {
    -webkit-transform: rotate(-18deg);
    -ms-transform: rotate(-18deg);
    transform: rotate(-18deg);
  }
  6% {
    -webkit-transform: rotate(18deg);
    -ms-transform: rotate(18deg);
    transform: rotate(18deg);
  }
  8% {
    -webkit-transform: rotate(-22deg);
    -ms-transform: rotate(-22deg);
    transform: rotate(-22deg);
  }
  10% {
    -webkit-transform: rotate(22deg);
    -ms-transform: rotate(22deg);
    transform: rotate(22deg);
  }
  12% {
    -webkit-transform: rotate(-18deg);
    -ms-transform: rotate(-18deg);
    transform: rotate(-18deg);
  }
  14% {
    -webkit-transform: rotate(18deg);
    -ms-transform: rotate(18deg);
    transform: rotate(18deg);
  }
  16% {
    -webkit-transform: rotate(-12deg);
    -ms-transform: rotate(-12deg);
    transform: rotate(-12deg);
  }
  18% {
    -webkit-transform: rotate(12deg);
    -ms-transform: rotate(12deg);
    transform: rotate(12deg);
  }
  20% {
    -webkit-transform: rotate(0deg);
    -ms-transform: rotate(0deg);
    transform: rotate(0deg);
  }
}
body .header .top-bar .faa-ring.animated,
body .header .top-bar .faa-ring.animated-hover:hover,
body .header .top-bar .faa-parent.animated-hover:hover > .faa-ring {
  -webkit-animation: ring 2s ease infinite;
  animation: ring 2s ease infinite;
  transform-origin-x: 50%;
  transform-origin-y: 0px;
  transform-origin-z: initial;
}
body .header .main-header {
  clear: both;
}
body .header .logo {
  display: inline-block;
  margin: 8px 0;
}
body .header .logo svg, body .header .logo polygon, body .header .logo path {
  fill: #ab0000;
}
body .header .logo svg {
  max-height: 42px;
}
body .header .mobile-menu {
  display: none;
}
body .header .staff-menu {
  display: inline-block;
  right: 0;
  position: absolute;
  margin: 20px;
}
body .header .staff-menu ul {
  list-style: none;
}
body .header .staff-menu ul li {
  display: inline-block;
}
body .header .staff-menu ul li a {
  color: #333;
  padding: 20px;
  font-weight: 900;
  font-size: 14px;
  text-transform: uppercase;
}
body.login .content {
  min-height: calc(100vh - 185px);
}
body.login,
body.forgot,
body.reset {
  text-align: center;
}
body .content {
  margin: 20px 60px;
  min-height: calc(100vh - 225px);
}
body .content .bold {
  font-weight: bold;
}
body .content .hidden {
  display: none;
}
body .content .staffbox h3 {
  margin-bottom: 0;
  display: inline-block;
}
body .content .staffbox .employ-line .administrator-tag {
  color: #d9534f;
  font-weight: 700;
  display: block;
}
body .content .staffbox .employ-line .analyst-tag {
  font-weight: 700;
  display: block;
}
body .content .staffbox .employ-line .calendar-developer-tag {
  font-weight: 700;
  display: block;
}
body .content .staffbox .roles {
  font-style: italic;
  color: #ab0001;
}
body .content .staffbox .pto table.details {
  margin-left: 50px;
}
body .content .staffbox .pto table.details td.label {
  text-align: right;
  padding-right: 15px;
}
body .content .staffbox ul.pending strong {
  color: #5bc0de;
}
body .content .staffbox ul.upcoming strong {
  color: #5cb85c;
}
body .content .staffbox ul.upcoming a.edit {
  color: #000;
}
body .content .staffbox ul.rejected strong {
  color: #d9534f;
  text-decoration: line-through;
}
body .content .staffbox ul li .details {
  display: inline-block;
}
body .content .progress {
  max-width: 400px;
}
body .content .card-columns .card .card-body.tracked {
  background: #ececec;
}
body .content .card-columns .card .card-body .card-title .tracked-sep {
  font-size: 0.75rem;
}
body .content ul.list-w-actions li {
  clear: both;
  list-style: none;
  padding: 10px 0;
}
body .content ul.list-w-actions li .actions {
  float: left;
  padding: 0 15px 0 0;
}
body .content ul.list-w-actions li .data .details {
  font-size: 12px;
  color: #a9a9a9;
}
body footer {
  background-color: #333;
  color: #888;
  text-align: center;
  bottom: 0;
  min-height: 100px;
  width: 100%;
}
body footer .phone {
  font-size: 11px;
  margin: 10px 0;
}
body.report-harvest-time .content .card {
  max-width: 350px;
  margin: 10px 0 0 50px;
}
body table tr.alt {
  background-color: #e5e5e5;
}
body .positive {
  color: #5cb85c;
}
body .negative {
  color: #d9534f;
}

@media only screen and (max-width: 850px) {
  body .header .logo {
    display: block;
    margin: 8px auto;
    text-align: center;
  }
  body .header .staff-menu {
    display: block;
    position: relative;
    margin: 0;
  }
  body .header .staff-menu ul {
    padding: 0;
    text-align: center;
  }
}
@media only screen and (max-width: 550px) {
  body .header .logo {
    display: inline-block;
  }
  body .header .mobile-menu {
    display: inline-block;
    font-size: 35px;
    right: 0;
    position: absolute;
    padding: 10px;
  }
  body .header .staff-menu .menu-list {
    display: none;
    list-style: disc;
  }
  body .header .staff-menu .menu-list li {
    display: block;
  }
}
.calendar-title {
  text-align: center;
}

.calendar-nav {
  display: inline-block;
  padding: 0 20px;
}

.date-form {
  text-align: center;
}
.date-form .btn-primary {
  background-color: #ab0000;
}
.date-form .form-inline {
  display: inline-block;
}

.list-view {
  display: none;
}

table.calendar {
  width: 100%;
}
table.calendar th {
  background: #666;
  color: #fff;
  padding: 10px;
  text-align: center;
}
table.calendar td {
  height: 100px;
  width: 14%;
  vertical-align: top;
  position: relative;
  padding: 0;
}
table.calendar td.weekend {
  background-color: #ebebeb;
}
table.calendar td.today {
  background-color: rgba(0, 0, 0, 0.2);
}
table.calendar td.today .add {
  color: #000;
  opacity: 0.5;
}
table.calendar td .number {
  padding: 10px;
  display: block;
}
table.calendar td .number .fa-building, table.calendar td .number .fa-birthday-cake {
  color: #666;
}
table.calendar td .event {
  padding: 4px 10px;
  min-height: 44px;
  margin: 0 0 10px 0;
  min-height: 36px;
}
table.calendar td .event.old {
  opacity: 0.5;
}
table.calendar td .event .edit {
  display: none;
}
table.calendar td .event.holiday {
  background: #171717;
  color: #fff;
}
table.calendar td .event.holiday p.event-details {
  border-top: 1px solid #fff;
  font-size: 14px;
}
table.calendar td .event.float-holiday {
  background: #f7f7f7;
  border: 1px solid #000;
  color: #000;
}
table.calendar td .event.float-holiday p.event-details {
  border-top: 1px solid #000;
  font-size: 14px;
}
table.calendar td .event.pto {
  background: #ab0000;
  color: #fff;
  box-shadow: 0 1px 0.25px -0.25px rgba(0, 0, 0, 0.2);
  transition: color 0.15s, background 0.15s !important;
}
table.calendar td .event.start {
  border-top-left-radius: 7px;
  border-bottom-left-radius: 7px;
  margin-left: 5px;
}
table.calendar td .event.start .edit {
  color: #fff;
  display: inline;
  padding: 0 5px 0 0;
}
table.calendar td .event.end {
  border-top-right-radius: 7px;
  border-bottom-right-radius: 7px;
  margin-right: 5px;
}
table.calendar td .event.middle span {
  display: none;
}
table.calendar td:hover a.add {
  display: block;
}
table.calendar td a.add {
  color: #cecece;
  display: none;
  font-size: 14px;
  position: relative;
  bottom: 0;
}

@media only screen and (max-width: 968px) {
  body .content {
    margin: 10px 5px;
  }
}
@media only screen and (max-width: 550px) {
  body .content .list-view {
    display: block;
  }
  body .content .list-view .event {
    padding: 0 0 0 10px;
  }
  body .content .list-view .event.type-1 {
    color: #8a0000;
  }
  body table.calendar {
    display: none;
  }
}
.row.staff .staffcol {
  padding-top: 10px;
  padding-bottom: 10px;
}
.row.staff .staffcol .staffbox {
  border: 1px solid;
  padding: 10px;
}
.row.staff .staffcol .staffbox h3 {
  margin: 0;
  display: block;
}
.row.staff .staffcol .staffbox h3 a {
  color: #fff;
  float: right;
}
.row.staff .staffcol .staffbox h3 a.btn {
  background: #333;
}
.row.staff .staffcol .staffbox .sub-info {
  color: #ccc;
  font-style: italic;
}
.row.staff .staffcol .staffbox .actions {
  text-align: right;
}
.row.staff .staffcol .staffbox .actions a {
  color: #fff;
}
.row.staff .staffcol .staffbox .actions a.btn {
  background: #ab0000;
}

ul.client-list {
  list-style: none;
  padding-left: 10px;
}

.pto-history .event {
  padding: 10px 0;
  max-width: 500px;
}
.pto-history .event .title {
  font-weight: 700;
}
.pto-history .event .title.type-1 {
  color: #990000;
}
.pto-history .event .title.type-2 {
  color: #000099;
}
.pto-history .event .date-range {
  color: #ccc;
  font-style: italic;
  font-size: 12px;
  border-bottom: 1px solid #333;
}
.pto-history .event .reason {
  margin: 0 15px;
  padding: 15px 0 0 0;
}
.pto-history .event .reason span {
  color: #ccc;
  display: block;
  text-transform: uppercase;
  font-style: italic;
  border-bottom: 1px solid #ccc;
}

.pending-pto {
  margin: 0;
  padding: 0;
}
.pending-pto li {
  border: 1px solid #000000;
  list-style: none;
  padding: 15px 30px;
  width: 33%;
  margin: 10px 0;
}
.pending-pto li .details {
  margin-bottom: 30px;
}
.pending-pto li .stats {
  margin-bottom: 30px;
}
.pending-pto li .date-range {
  color: #ababab;
  font-style: italic;
  font-size: 11px;
}
.pending-pto li .actions a {
  color: #fff;
  background: #ab0000;
}
.pending-pto li .actions a:hover {
  color: #fff;
}

.staffbox .pto h4 {
  display: inline-block;
}
.staffbox .pto ul {
  padding-left: 0;
}
.staffbox .pto ul.pending li, .staffbox .pto ul.reject li, .staffbox .pto ul.upcoming li {
  border: 1px solid #ababab;
  border-radius: 20px;
  list-style: none;
  margin: 10px 0;
}
.staffbox .pto ul.pending li .fancy-date-box, .staffbox .pto ul.reject li .fancy-date-box, .staffbox .pto ul.upcoming li .fancy-date-box {
  display: inline-block;
  border-right: 1px solid #ababab;
  text-align: center;
  padding: 10px 20px 18px;
  font-weight: bold;
  color: #ababab;
}
.staffbox .pto ul.pending li .fancy-date-box .month, .staffbox .pto ul.reject li .fancy-date-box .month, .staffbox .pto ul.upcoming li .fancy-date-box .month {
  font-size: 20px;
  text-transform: uppercase;
}
.staffbox .pto ul.pending li .fancy-date-box .day, .staffbox .pto ul.reject li .fancy-date-box .day, .staffbox .pto ul.upcoming li .fancy-date-box .day {
  font-size: 26px;
}
.staffbox .pto ul.pending li .data, .staffbox .pto ul.reject li .data, .staffbox .pto ul.upcoming li .data {
  display: inline-block;
  vertical-align: top;
  padding: 10px 10px 0;
}
.staffbox .pto ul.pending li .data .title, .staffbox .pto ul.reject li .data .title, .staffbox .pto ul.upcoming li .data .title {
  font-weight: bold;
}
.staffbox .pto ul.pending li .data .date, .staffbox .pto ul.reject li .data .date, .staffbox .pto ul.upcoming li .data .date {
  color: #ababab;
  font-style: italic;
}
.staffbox .pto ul.pending li .data .date-actions, .staffbox .pto ul.reject li .data .date-actions, .staffbox .pto ul.upcoming li .data .date-actions {
  margin-top: 10px;
  padding-top: 3px;
}
.staffbox .pto ul.pending li .data .date-actions a, .staffbox .pto ul.reject li .data .date-actions a, .staffbox .pto ul.upcoming li .data .date-actions a {
  color: #ababab;
  padding-right: 15px;
}
.staffbox .pto ul.pending li .data .date-actions a:hover, .staffbox .pto ul.reject li .data .date-actions a:hover, .staffbox .pto ul.upcoming li .data .date-actions a:hover {
  color: black;
  text-decoration: none;
}
.staffbox .pto ul.pending li .delete, .staffbox .pto ul.reject li .delete, .staffbox .pto ul.upcoming li .delete {
  float: right;
  padding: 10px 10px 0;
}
.staffbox .pto ul.pending li .delete button, .staffbox .pto ul.reject li .delete button, .staffbox .pto ul.upcoming li .delete button {
  font-size: 12px;
}
.staffbox .pto ul.pending .data {
  max-width: calc(100% - 220px);
}
.staffbox .pto ul.pending .data .title {
  color: #5bc0de;
}
.staffbox .pto ul.upcoming .data .title {
  color: #5cb85c;
}
.staffbox .pto ul.reject .data .title {
  color: #d9534f;
  text-decoration: line-through;
}

@media only screen and (max-width: 850px) {
  .pto-history .event {
    max-width: 100%;
  }
}
form .control-group {
  margin: 15px 0;
  clear: both;
}
form .control-group .controls {
  display: inline-block;
  margin-left: 15px;
}
form .control-group .controls #user_roles {
  height: 175px;
}
form.form-horizontal label {
  float: left;
  width: 150px;
  text-align: right;
}
form.form-horizontal button {
  clear: both;
}
form.form-horizontal input[type=submit].break-flow {
  display: block;
  margin-top: 20px;
}
form.form-horizontal .control-label {
  padding-top: 0;
}
form.form-horizontal input, form.form-horizontal textarea {
  width: 250px;
}
form.form-horizontal input.no-width, form.form-horizontal textarea.no-width {
  width: auto;
}
form.form-horizontal input.input-small, form.form-horizontal textarea.input-small {
  width: 75px;
}
form.form-horizontal textarea {
  height: 100px;
}
form.form-horizontal .options label {
  float: none;
  width: inherit;
  margin-left: 5px;
  margin-right: 15px;
}
form.form-horizontal .options input {
  width: inherit;
}
form.form-horizontal .options.list label:after {
  content: " ";
  overflow: hidden;
  color: transparent;
  display: block;
}

.actions a {
  color: #fff;
  background: #ab0000;
}
.actions a:hover {
  color: #fff;
}

ul.holidays li {
  clear: both;
  list-style: none;
  padding: 10px 0;
}
ul.holidays li .actions {
  float: left;
  padding: 0 15px 0 0;
}
ul.holidays li .float-holiday strong {
  font-style: italic;
  color: #999999;
}

ul.contacts li {
  clear: both;
  list-style: none;
  padding: 10px 0;
}
ul.contacts li .actions {
  float: left;
  padding: 0 15px 0 0;
}

.profile .menu {
  border: 1px solid #ccc;
  padding: 15px;
  margin: 15px 0;
}
.profile .menu a {
  padding: 0 15px;
}
.profile .infobox {
  border-top: 1px solid #ccc;
  display: block;
  margin: 5px;
  padding: 20px 0;
}
.profile .infobox .title {
  color: #ababab;
  display: inline-block;
  width: 25%;
  vertical-align: top;
  padding: 5px 0 0 0;
}
.profile .infobox .data {
  display: inline-block;
  width: 74%;
}
.profile .infobox .data .col {
  width: 49%;
  display: inline-block;
  vertical-align: top;
}
.profile .infobox.emergency .data .item {
  padding: 8px 0;
}
.profile .infobox.emergency .data .item .relation {
  text-transform: uppercase;
  font-weight: bold;
  font-size: 12px;
}
.profile .infobox.emergency .data .item .phone {
  display: block;
}
.profile .infobox.pto-notes .data ul.notes {
  height: 300px;
  overflow-y: scroll;
  padding: 0;
  margin: 0;
}
.profile .infobox.pto-notes .data ul.notes li {
  padding: 0 0 20px 0;
  list-style: none;
}
.profile .infobox.pto-notes .data ul.notes li .action {
  font-weight: bold;
  display: block;
}
.profile .infobox.pto-notes .data ul.notes li .when {
  color: #ccc;
  font-size: 12px;
  font-style: italic;
}
.profile .infobox.pto-notes .data p {
  margin-top: 10px;
}

table.report tr td, table.report tr th {
  text-align: center;
}
table.report tr th {
  padding: 10px;
}
table.report tr td {
  padding: 5px;
  border-bottom: 1px solid #000;
}


/* PPP-436 - CSS changes from Tim */
body .header .top-bar{
 background: #000;
}
.date-form,
.date-form .form-inline{
  display: flex;
  gap: 4px;
  margin: 0;
  padding: 0;
}
.date-form{
  align-items: center;
  justify-content: center;
  margin-bottom: 12px;
}
.date-form .form-group select,
.date-form  button{
  padding: 4px 8px !important;
  font-size: 14px !important;
}

.date-form button{
  background: #ededed !important;
  color: #000 !important;
  border:none !important;
}
.calendar-nav a{
  color: #000;
}
table.calendar td{
  font-size: 12px;
}
table.calendar tbody{
  position: relative;
}
table.calendar tbody tr:first-child{
  position: sticky;
  top: 0;
  z-index: 3;
}
table.calendar th{
  background: #000;
  backdrop-filter: blur(4px);
  border-bottom: 2px solid rgba(0,0,0,0.3);
}

table.calendar th,
table.calendar td.date,
table.calendar td.today,
table.calendar td.weekend,
table.calendar td.empty {
  border-top: 1px solid rgba(0,0,0,0.5);
  border-left: 1px solid rgba(0,0,0,0.5);
}
table.calendar tr:last-child td{
  border-bottom: 1px solid rgba(0,0,0,0.5);
}
table.calendar td .number{
  font-weight: 700;
}
table.calendar td:not(.weekend, .empty){
  background: rgba(0,0,0,0);
  transition: background 0.2s;
  transition-delay: 0.2s;
}
table.calendar td.today{
  background-color: #ffefbe !important;
}


table.calendar td.weekend {
  background-color: #ebebeb;
}
table.calendar td.empty {
  background-color: #aaa;
}
table.calendar td:not(.weekend, .empty){
  transition: all 0.2s;
  transition-delay: 0.2s;
}
table.calendar td:not(.weekend, .empty):hover{
  border-color: #222;
}
table.calendar td a.add{
  display: inline-block;
  opacity: 0.5;
  position: absolute;
  bottom: auto;
  top: 8px;
  font-size: 12px;
  left: 28px;
  opacity: 0;
  color: #000;
  background: #fff;
  border: 1px solid rgba(0,0,0,0.2);;
  padding: 2px;
  border-radius: 4px;
  text-decoration: none;
  transition: opacity 0.2s;
  transition-delay: 0.2s;
}
table.calendar td:hover a.add{
  opacity: 0.6 !important;
}
table.calendar td:hover a.add:hover{
  border-color: rgba(0,0,0,0.8);
  opacity: 1 !important;
  background: rgba(0,0,0,0.1);
}
table.calendar td.weekend a.add{
  display: none;
}

body table.calendar td .event p{
  margin: 0 !important;

}

body table.calendar td .event.pto{
  background: #00408533;
  border-bottom: 1px solid #004085;
  color: #000;
}


ul#collapseUpcoming.show,
ul#collapseUpcoming.collapsing{
  display: flex;
  gap: 12px;
  flex-wrap: wrap;
}

.staffbox .pto ul.pending li,
.staffbox .pto ul.reject li,
.staffbox .pto ul.upcoming li{
  margin: 0;
}

.staffbox .pto .fancy-date-box {
  background: rgba(23, 23, 23, 0.8);
  border-radius: 8px 0 0 8px;
  color: #fff !important;
}
.staffbox .pto li .date-actions{
  font-size: 14px;
}


/*# sourceMappingURL=styles.css.map */
