@import url('https://fonts.googleapis.com/css2?family=Material+Symbols+Rounded:opsz,wght,FILL,GRAD@20..48,100..700,0..1,-50..200');

/* CSS by Will Jones 2023 (wjwebservices.com) */


#calendar * {
  margin: 0;
  padding: 0;
  box-sizing: border-box;
  transition: all .5s linear;
}


#calendar {
  display: flex;
  align-items: center;
  justify-content: center;
  background-color: unset;
  width: 100%;
}

#calendar::-webkit-selection {
  color: transparent;
  background: transparent;
}

#calendar::-moz-selection {
  color: transparent;
  background: transparent;
}

#calendar::selection {
  color: transparent;
  background: transparent;
}

#calendar .wrapper header{
  display: flex;
  align-items: center;
  padding: 0px 30px;
  justify-content: space-between;
  font-family: "WHS_SF Pro Bold", sans-serif;
}
#calendar .wrapper {
  width: 100%;
}

#calendar header .icons{
  display: flex;
}
#calendar header .icons span{
  height: 38px;
  width: 38px;
  margin: 0 1px;
  cursor: pointer;
  color: #878787;
  text-align: center;
  line-height: 38px;
  font-size: 2.9rem;
  user-select: none;
  border-radius: 50%;
  -webkit-border-radius: 50%;
  -moz-border-radius: 50%;
   -webkit-mask-image: -webkit-radial-gradient(white, black);

}
#calendar .icons span:last-child{
  margin-right: -10px;
}
#calendar header .icons span:hover{
  background: #f2f2f2;
}
#calendar header .current-date{
  font-size: 2.2rem;
  font-family: "WHS_SF Pro Bold", sans-serif;
  font-weight: bold;
}
#calendar .calendar{
  padding: 20px;
}
#calendar .calendar ul{
  display: flex;
  flex-wrap: wrap;
  list-style: none;
  text-align: left;
}
#calendar .calendar .days{
  margin-bottom: 20px;
}

#calendar li.calendar-large-event {
  display: grid;
  width: 95%!important;
  padding: 5px 0px!important ;
  border: 2px;
  min-height: unset!important;
  margin-bottom: 3px!important;
  margin-right: 5px;
  text-align: center;
  max-width: 95% !important;
  white-space: nowrap;
  overflow: hidden;
}

#calendar li.calendar-large-event span {
  padding-left: 5px;
  padding-right: 5px;
}

#calendar .calendar li{
  color: #333;
  width: calc(100% / 7);
  border: 1px solid #416aae;
}

#calendar .calendar .weeks li{
  padding: 7px 5px 5px 5px!important;
    font-family: "WHS_SF Pro Light",sans-serif;
    cursor: default;
    padding-left: 5px;
    background-color: #416aae;
    color: #fff;
    text-transform: uppercase;
    font-size: 12px;
    letter-spacing: 2px;
    text-align: center;
}

#calendar .calendar .days li{
  z-index: 1;
  cursor: pointer;
  position: relative;
  padding-bottom: 10px;
  min-height: 90px;
  padding-left: 5px;
  transition: all 0.3s;
}
#calendar .days li.inactive{
  color: #aaa;
}
#calendar .days li.active{
  color: #000000;
}
#calendar .days li::before{
  position: absolute;
  content: "";
  left: 50%;
  top: 50%;
  height: 100%;
  width: 100%;
  z-index: -1;
  transform: translate(-50%, -50%);

  
}
#calendar .days li.active::before{
  background: #406aae40;
}

#calendar .days li.active-2::before{
  background: #e2e2e29c;
}

#calendar .days li:not(.active):hover::before{
  background: #e2e2e272;
}

#calendar .calendar-large-event::before {
  display:none;
}

#calendar .days li::after{
  position: absolute;
  content: "";
  left: 50%;
  top: 110%;
  height: 3px;
  width: 3px;
  z-index: -1;
  border-radius: 50%;
  -webkit-border-radius: 50%;
    -moz-border-radius: 50%;
  transform: translate(-50%, -50%);
  -webkit-mask-image: -webkit-radial-gradient(white, black);

}
#calendar .days li.active-3::after{
  background: #7b99ca;
}

#calendar p {
  margin-bottom: 0px!important;
}

#calendarcontent {
  padding: 10px;
}

#calendarcontent h4 {
  margin: 0 0 15px 0;
}

#calendar-events {
  padding-left: 5px!important;
}

#calendar-filter li,#calendar-events li,.calendar-large-event {
  list-style-type: none;
  padding: 5px 15px!important;
  border-radius: 20px;
  -webkit-border-radius: 20px;
    -moz-border-radius: 20px;
    -webkit-mask-image: -webkit-radial-gradient(white, black);

  width:fit-content;
  font-size: 12px;
  margin-bottom: 10px;
  margin-right: 10px;
  display: inline-table;
  font-family: 'WHS_SF Pro Light',sans-serif;
  border: 3px #a3a4a5cd solid;
  background-color: #a3a4a5b9;
  color: #fff;
} 

#calendar-filter {
  text-align: center;
}

#calendar-filter ul {
  padding: 0;
  margin: 0;
}

#calendar-filter ul li, .calendar-large-event {
  cursor: pointer;
  transition: all 0.3s linear!important;
  opacity: 1
}

#calendar-filter ul li:hover,.calendar-large-event:hover {
  opacity: 0.8!important;
}

#calendar-filter ul li:active,.calendar-large-event:active {
  opacity: 0.5!important;
}


.category-1 {
  border: 3px #406aaecd solid!important;
  background-color: #406aaeb9!important;
  color: #fff!important;
}

.category-2 {
  border: 3px #40ae68cd solid!important;
  background-color: #40ae68b9!important;
  color: #fff!important;
}

.category-3,#calendar-events li.error {
  border: 3px #7f2241cd solid!important;
  background-color: #7f2241b9!important;
  color: #fff!important;
}


.category-4 {
  border: 3px #f0b350cd solid!important;
  background-color: #f0b350b9!important;
  color: #fff!important;
}

.category-5 {
  border: 3px #8b40aecd solid!important;
  background-color: #8b40aeb9!important;
  color: #fff!important;
}

.category-6 {
  border: 3px #e66229cd solid!important;
  background-color: #e66229b9!important;
  color: #fff!important;
}

.category-7 {
  border: 3px #be2f9fcd solid!important;
  background-color: #be2f9fb9!important;
  color: #fff!important;
}

.category-8 {
  border: 3px #006c09cd solid!important;
  background-color: #006c09b9!important;
  color: #fff!important;
}

.category-9 {
  border: 3px #0d19c8cd solid!important;
  background-color: #0d19c8b9!important;
  color: #fff!important;
}

@-webkit-keyframes fadeIn {
  from {
    opacity: 0;
    -ms-transform: scale(0.95);
    -webkit-transform: scale(0.95);
    transform: scale(0.95);
  }

  to {
    opacity: 1;
    -ms-transform: scale(1.0);
    -webkit-transform: scale(1.0);
    transform: scale(1.0);
  }
}

@keyframes fadeIn2 {
  from {
    opacity: 0;
  }

  to {
    opacity: 1;
  }
}

.fadeIn2 {
  -webkit-animation-name: fadeIn2;
  animation-name: fadeIn2;
}

#calendar .weeks.desktop {
  display: flex;
}
#calendar .weeks.mobile {
  display: none;
}

@media screen and (max-width: 768px) {

  .calendar-large-event {
    padding: 2px!important
  }

  .calendar-large-event span {
    font-size: 10px!important;
    padding: 0px !important;
  } 

  #calendar .calendar li{
    color: #333;
    width: calc(100% / 7);
    font-size: 1rem;
    border: 1px solid #416aae;
  }

  #calendar .weeks.desktop {
    display: none;
  }
  #calendar .weeks.mobile {
    display: flex;
  }

}

.calendar-modal {
  background-color: rgba(0, 0, 0, 0.5);
}


.calendar-modal .modal-header h4 {
  margin: 10px!important;
  color: #fff!important;
}



.calendar-modal p {
  font-weight:bold;
  font-family: 'WHS_SF Pro Bold',sans-serif;
  margin-bottom:5px;
  padding-left:10px;
}

.calendar-modal #modal-event-date,.calendar-modal #modal-event-category,.calendar-modal #modal-event-description {
  font-weight:normal;
  font-family: 'WHS_SF Pro',sans-serif;
}

.calendar-modal .modal-header .close {
  margin-top:7px;
  color: #fff;
  opacity: 0.8;
}

.calendar-modal .modal-content {
  border-radius: none!important;
}

.calendar-modal .modal-header {
  background-color: #406aae!important;
}

#event-description {
  display: none;
}


#calendar, #calendar-content, #calendar-root {
  -webkit-user-select: none;
  -ms-user-select: none;
  user-select: none;
}

#calendar-root #current-year {
  font-family: 'WHS_SF Pro Light',sans-serif;
  font-weight: lighter;
}