
/* Gen. time: 0.023252010345459*/
:root {
  --main-favicon: url('/content/_site_images/favicon.ico');
  --main-logo-img: url('/content/_site_images/site_logo.png');
  --main-logo-sizing: auto;
  --background-1: #FFFFFF;
  --dark-background-1: #000025;
  --background-2: #FCFCFC;
  --dark-background-2: #292929;
  --background-3: #F4F4F4;
  --dark-background-3: #1E1E1E;
  --header-1: #678D98;
  --dark-header-1: #FFFFFF;
  --header-2: #343479;
  --dark-header-2: #7171A1;
  --small-headers: #000000;
  --dark-small-headers: #FFFFFF;
  --paragraph: #000000;
  --dark-paragraph: #FFFFFF;
  --links: #678D98;
  --power-color-1-foreground: #FFFFFF;
  --power-color-1: #343479;
  --power-color-2-foreground: #ffffff;
  --power-color-2: #668a38;
  --power-color-3-foreground: #000000;
  --power-color-3: #678d98;
  --power-color-4-foreground: #000000;
  --power-color-4: #c2ac80;
  --power-color-5-foreground: #FFFFFF;
  --power-color-5: #5b4a42;
  --power-color-6-foreground: #000000;
  --power-color-6: #658A38;
  --power-color-7-foreground: #000000;
  --power-color-7: #678d98;
  --secondary-architecture: #010852;
  --dark-secondary-architecture: #A4A9E1;
  --image-placeholder-color: orange;
  --primary-header-font: 600 24px/32px 'Rubik', 'Verdana',sans-serif;
  --primary-header-font-variant: uppercase;
  --secondary-header-font: 600 20px/26px 'Roboto Slab', 'Arial',sans-serif;
  --secondary-header-font-variant: uppercase;
  --small-header-font: 500 15px/17px 'Roboto Slab', 'Arial',sans-serif;
  --small-header-font-variant: uppercase;
  --nav-text-font: 300 12px/14px 'Rubik', 'Arial',sans-serif;
  --paragraph-font: 300 14px/17px 'Rubik', 'Arial',sans-serif;
  --secondary-button-fonts: 400 13px/15px 'Rubik', 'Verdana',sans-serif;
}
/* font-family: 'Aleo', serif; (400;500;600;700) */
/* font-family: 'DM Sans', serif; (300;400;500;600;700) */
.main-content.calendar {}
.main-content.calendar h1 {
	margin-left: auto;
	margin-right: auto;
	position: relative;
}
.main-content.calendar h1 .blob.b1 {
    right: unset;
    left: -400px;
    bottom: -150px;
}
.main-content.calendar h1 .blob.b2 {
    right: unset;
    left: -360px;
    bottom: -300px;
}
.main-content.calendar p.intro {
	text-align: center;
}

/* calendar's parent element */
.calendar-region {
  position: relative;
}
/* calendar 'loading' styles */
.calendar-region .calendar-top:after,
.calendar-region .calendar-dates li:after {
    content: "";
    width: 100%;
    height: 100%;
    border-radius: 20px;
    background-color: var(--body-bg-color);
    opacity: 0;
    display: block;
    position: absolute;
    top: 0;
    left: 0;
    pointer-events: none;
    transition: opacity .3s;
}
.calendar-region.calendar-loading .calendar-top:after,
.calendar-region.calendar-loading .calendar-dates li:after {
    opacity: 1;
    pointer-events: all;
}
.calendar-region.calendar-loading-month .calendar-dates li:after {
    opacity: 1;
    pointer-events: all;
}
.calendar-region.calendar-loading .calendar-weekdays,
.calendar-region.calendar-loading .calendar-day-event,
.calendar-region.calendar-loading .calendar-dates li .view-more-events,
.calendar-region.calendar-loading .calendar-hours-disclaimer,
.calendar-region.calendar-loading .view-previous {
    opacity: 0;
}
.calendar-region li.calendar-day-fake {
    display: none;
}
.calendar-region.calendar-loading li.calendar-day-fake {
    display: block;
}

/* above calendar */
.discover-filters {
  margin-bottom: 25px;
}
.calendar-top {
  display: flex;
  align-items: center;
  justify-content: space-between;
  box-sizing: border-box;
  width: 100%;
  border-radius: 20px;
  border: 1px solid var(--brand-border-color);
  background-color: var(--body-bg-color);
  padding: 23px 25px;
  position: relative;
  margin-bottom: 25px;
  transition: border-radius .5s;
}
.discover-filters .calendar-top {
  margin-bottom: 0;
}
.discover-filters.expanded .calendar-top {
  border-radius: 20px 20px 0 0;
}
.event-filters-wrap {
  display: flex;
  flex-direction: row;
  flex-wrap: wrap;
  align-items: center;
  gap: 10px;
  width: 34%;
}
.discover-filters .calendar-top .event-filters-wrap .h3-like {
  margin: 0;
  cursor: pointer;
}
.discover-filters .calendar-top .event-filters-wrap #choose_tags {
  padding: 7px 12px 6px 12px;
}
.discover-filters .calendar-top .event-filters-wrap .tagged-list {
  display: flex;
  flex-wrap: wrap;
  flex: 1 1 0%;
  gap: 10px;
}
.discover-filters .calendar-top .event-filters-wrap .tagged-list .tag {
  background-color: var(--body-bg-color);
  cursor: pointer;
  padding: 1px 10px;
  border: 1px solid var(--tag-border-color);
  border-radius: 20px;
}
.discover-filters .calendar-top .event-filters-wrap .tagged-list .tag label {
  position: relative;
  cursor: pointer;
  padding-left: 6px;
}
.discover-filters .calendar-top .event-filters-wrap .tagged-list .tag label:before {
  content: '';
  position: absolute;
  width: 12px;
  height: 12px;
  left: 0px;
  top: 4px;
  clip-path: polygon(11.54% 0%, 50% 38.46%, 88.46% 0%, 100% 11.54%, 61.54% 50%, 100% 88.46%, 88.46% 100%, 50% 61.54%, 11.54% 100%, 0% 88.46%, 35.46% 50%, 0% 11.54%);
  background-color: var(--tag-border-color);
}
.discover-filters .calendar-top .event-filters-wrap .tagged-list .tag label input {
  margin: 0;
  position: absolute;
  opacity: 0;
  height: 0;
  width: 0;
}

.keyword-wrap {
    width: 41%;
    font-size: 16px;
    margin: 0;
}
.keyword-wrap .help-text p:last-of-type {
    margin: 0;
    display: flex;
    justify-content: space-between;
}
.keyword-wrap .help-text p:last-of-type span i {
    margin-right: 5px;
}

/* calendar title */
.calendar {
  width: 100%;
	margin: 10px 0;
  position: relative;
  --calendar-inner-border-color: #C2CED0;
  --calendar-view-more-color: #F25A29;
}
body.dark-mode .calendar {
  --calendar-inner-border-color: #354245;
  --calendar-view-more-color: #bb380c;
}
.calendar .calendar-title {
  width: 32%;
  min-width: 330px;
  padding: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  position: relative;
  gap: 25px;
}
.calendar .calendar-title .cal-arrow-wrapper{
    min-width: 25px;
    height: 100%;
    min-height: 25px;
    display: inline-flex;
    justify-content: center;
    align-content: center;
}
.calendar .calendar-title .cal-arrow {
  display: inline-flex;
  width: 9px;
  height: 16px;
  clip-path: polygon(1px 0px, 9px 8px, 1px 16px, 0px 15px, 7px 8px, 0px 1px);
  background-color: var(--font-body-color);
  opacity: 0.8;
  cursor: pointer;
  transition: opacity .3s;
  align-self: center;
}
.calendar .calendar-title .cal-arrow.prev {
  /* margin: 0 25px 0 0; */
  transform: rotate(180deg);
}
.calendar .calendar-title .cal-arrow.next {
  /* margin: 0 0 0 25px; */
}
.calendar .calendar-title .cal-arrow:hover {
	opacity: 1;
}
.calendar .calendar-title h2 {
  margin: 0;
  font: 600 30px/36px 'Aleo';
  text-align: center;
  white-space: nowrap;
}
.calendar .calendar-top .calview {
  width: 34%;
  display: flex;
  justify-content: flex-end;
  align-items: center;
  gap: 10px;
}
.calendar .calendar-top .toggle {
  position: relative;
  width: 55px;
  height: 30px;
  background-color: var(--body-bg-color);
  border: 1px solid var(--brand-border-color);
  border-radius: 20px;
}
.calendar .calendar-top .toggle:before {
  content: '';
  display: block;
  position: absolute;
  width: 22px;
  height: 22px;
  top: 3px;
  left: 3px;
  background-color: var(--font-link-color);
  border-radius: 100px;
  transition: left .5s;
}
.calendar .calendar-top .toggle:has(input[type="checkbox"]:checked):before {
  left: 28px;
}
.calendar .calendar-top .toggle input[type="checkbox"] {
  width: 100%;
  height: 100%;
  opacity: 0;
  margin: 0;
  cursor: pointer;
}
.calendar .calendar-top .toggle .icons {
  position: absolute;
  display: flex;
  width: calc(100% - 6px);
  height: 100%;
  top: 0;
  left: 3px;
  gap: 3px;
  cursor: pointer;
}
.calendar .calendar-top .toggle .icons > * {
  flex: 1 1 0px;
  align-self: center;
}
.calendar .calendar-top .toggle .icons .calendar * {
  fill: var(--body-bg-color);
}
.calendar .calendar-top .toggle:has( input[type="checkbox"]:checked) .icons .calendar * {
  fill: var(--font-link-color);
}
.calendar .calendar-top .toggle .icons .list * {
  fill: var(--font-link-color);
}
.calendar .calendar-top .toggle:has( input[type="checkbox"]:checked) .icons .list * {
  fill: var(--body-bg-color);
}

.calendar .discover-filters .calendar-top .calview .expand-filters {
  display: inline-block;
  width: 40px;
  height: 40px;
  border-radius: 20px;
  background-color: var(--button-secondary-bg-color);
  background-image: var(--button-icon);
  background-repeat: no-repeat;
  background-position: calc(50% + 1.5px) calc(50% - .5px);
  background-size: 8px;
  transform: rotate(90deg);
  transition: transform .5s;
  cursor: pointer;
}
.calendar .discover-filters.expanded .calendar-top .calview .expand-filters {
  transform: rotate(-90deg);
}

.discover-filters .tags {
  max-height: 225px;
}
.discover-filters .tags .tag-list .h4-like {
  margin-bottom: 10px;
}
.discover-filters .tags ul {
  padding-bottom: 30px;
  margin-top: 0;
}

.calendar .calendar-top .calview a.view-toggle {
  opacity: 0.8;
  color: #707070;
  display: flex;
  align-items: center;
  cursor: pointer;
  transition: opacity .3s;
  font: var(--small-header-font);
  font-weight: 400;
}
.calendar .calendar-top .calview .grid-view, .calendar .calendar-top .calview .list-view {
  width: 17px;
  height: 15px;
  margin: 0 5px 0 0;
  background-repeat: no-repeat;
  background-size: cover;
  display: inline-block;
}
.calendar .calendar-top .calview .list-icon {
  width: 15px;
  height: 12px;
  margin: 0 5px 0 0;
  background-image: url('/content/_theme_images/icon_list.svg');
  background-repeat: no-repeat;
  background-size: cover;
  display: inline-block;
}
.calendar .calendar-top .calview a.view-toggle:hover,
.calendar.grid-layout .calendar-top .calview a.view-toggle.grid,
.calendar.list-layout .calendar-top .calview a.view-toggle.list {
  opacity: 1;
	/* color: #E8001B; */
}
.calendar .calendar-top .calview a.view-toggle:first-of-type {
	margin-right: 30px;
}

  
/* calendar dates */
.calendar-dates {
  display: flex;
  flex-wrap: wrap;
  border: 1px solid var(--calendar-inner-border-color);
  background-color: var(--body-offset-bg-color);
  border-radius: 20px;
  width: 100%;
  margin: 0;
  padding: 0;
  /*overflow: hidden;*/
  position: relative;
}
/*.calendar-dates > li:first-child {*/
/*  border-top-left-radius: 20px;*/
/*}*/
/*.calendar-dates > li:nth-child(7) {*/
/*  border-top-right-radius: 20px;*/
/*}*/
/*.calendar-dates > li:first-child {*/
/*  border-top-left-radius: 20px;*/
/*}*/
/*.calendar-dates > li:last-child {*/
/*  border-bottom-right-radius: 20px;*/
/*}*/
.calendar.list-layout .calendar-dates {
  display: none;
}
.calendar-dates li {
  width: calc(100% / 7);
  min-height: 225px;
  margin-bottom: 0;
  padding: 20px 10px 20px 10px;
  border-right: 1px solid var(--calendar-inner-border-color);
  border-bottom: 1px solid var(--calendar-inner-border-color);
  list-style-type: none;
  position: relative;
}
.calendar-dates li:before {
  display: none;
}
.calendar-dates li:nth-last-child(-n + 7) {
  border-bottom: unset;
}
.calendar-dates li:nth-child(7n) {
  border-right: unset;
}
.calendar-dates li.calendar-day-blanks {
  margin: 0;
}
.calendar-dates li.calendar-day {
  background-color: var(--body-bg-color);
  margin: 0;
  padding: 60px 15px 30px 15px;
}
.calendar-dates li.calendar-day:first-child {
  border-radius: 19px 0 0 0;
}
.calendar-dates li.calendar-day:nth-child(7) {
  border-radius: 0 20px 0 0;
}
.calendar-dates li.calendar-day:nth-last-child(7) {
  border-radius: 0 0 0 20px;
}

.calendar-weekdays {
  display: flex;
  margin: 0 0 15px 0;
  padding: 0;
  list-style-type: none;
  position: relative;
}
.calendar-weekdays-mobile {
  display: none;
}
.calendar.list-layout .calendar-weekdays {
  display: none;
}
.calendar .calendar-weekdays li {
  width: calc((100% / 7) - 0px);
  margin-bottom: 0;
  padding: 0;
  font: 600 15px/15px 'Aleo';
  text-align: center;
}
.calendar-weekdays li:nth-child(7) {
	margin-right: 0;
}
.calendar-weekdays li:before {
    display: none
}

.calendar-day .calendar-day-date {
	position: absolute;
	top: 15px;
    right: 15px;
}
.calendar-day .calendar-day-date p, .weekly-row td.empty-space .calendar-day .calendar-day-date {
  font: 400 17px/13px 'DM Sans';
  text-align: right;
}

.calendar-day-event .event-details {
  width: 480px;
  opacity: 0;
  position: absolute;
  top: -22px;
  left: 0;
  z-index: 99;
  pointer-events: none;
  transition: opacity .3s;
  cursor: initial;
}
.calendar-day-event .event-details:before {
  content: "";
  width: 26px;
  height: calc(100% + 26px);
  display: block;
  position: absolute;
  top: -13px;
  left: -30px;
  /* right: -51px; */
  z-index: 55;
}
.calendar-day:nth-child(7n-2) .event-details:before, .calendar-day:nth-child(7n-1) .event-details:before, .calendar-day:nth-child(7n) .event-details:before {
  left: auto;
  right: -30px;
}
.calendar-day-event .event-details .details-close {
  font-size: 22px;
  line-height: 22px;
  font-weight: 600;
  opacity: 0;
  color: black;
  display: block;
  position: absolute;
  top: 2px;
  right: 7px;
  z-index: 15;
  pointer-events: none;
  cursor: pointer;
  transition: opacity .3s;
}
.calendar-day-event.active .event-details .details-close {
  opacity: 1;
  pointer-events: all;
}
.calendar-day-event .event-details .details-background {
  width: calc(100% + 26px);
  height: calc(100% + 26px);
  background-color: var(--body-bg-color);
  border: 0.4px solid var(--brand-border-color);
  border-radius: 10px;
  box-shadow: 0 0 15px rgba(0, 0, 0, 0.24);
  display: inline-block;
  position: absolute;
  top: -13px;
  left: -13px;
  z-index: 5;
}
.calendar-day-event .event-details .details-background:before, .calendar-day-event .event-details .details-background:after {
  content: "";
  display: inline-block;
  position: absolute;
  /* top: calc(50% - 30px); */
  top: 32px;
}
.calendar-day-event .event-details .details-background:before {
  border-top: 15px solid transparent;
  border-right: 15px solid var(--body-bg-color);
  border-bottom: 15px solid transparent;
  left: -15px;
  z-index: 10;
}
.calendar-day-event .event-details .details-background:after {
  border-top: 15px solid transparent;
  border-right: 15px solid var(--brand-border-color);
  border-bottom: 15px solid transparent;
  left: -16px;
  z-index: 5;
}
.calendar-day-event .event-details .details-content {
  width: 100%;
  /*padding: 10px;*/
  /* background-color: #F4F4F4; */
  display: flex;
  align-items: flex-start;
  position: relative;
  z-index: 10;
}
.calendar-day-event .event-details .details-content .details-media {
  max-width: 156px;
  margin: 0 15px 0 0;
}
.calendar-day-event .event-details .details-content .details-info {}
.calendar-day-event .event-details .details-content .details-info .details-title {
  margin: 0 0 5px 0;
  /*color: #484848;*/
  display: inline-block;
  /*font: var(--small-header-font);*/
  font-family: 'Aleo', serif;
  font-size: 18px;
  font-weight: 500;
  line-height: 20px;
}
.details-timeframe {
  margin: 0 0 10px 0;
  font: 400 16px/19px 'DM Sans';
  color: var(--font-offset-color);
}
.details-timeframe svg {
  opacity: .5;
}
/*.details-timeframe .date:after {*/
/*  content: "|";*/
/*  margin: 0 2px;*/
/*  display: inline-block;*/
/*}*/
.details-timeframe .time {}
.details-timeframe .location {
  margin: 5px 0 0 0;
  display: block;
}
.calendar-day-event .event-details .details-content .details-description {
  margin: 0 0 3px 0;
  color: var(--font-offset-color);
  font-size: 14px;
  line-height: 16px;
}
.cancelled{
    color: #FF0D0D; 
    font-size: 1.5em;
}
.calendar-day-event .cancelled{
    color: #FF0D0D; 
    font-size: 1em;
}
.calendar-day-event.altered .event-title {
    opacity: .7;
    
}
.calendar-day-event.altered .event-details .details-content{
    opacity: .7;
}

.strike-through{
    text-decoration: line-through;
}
.calendar-day-event .event-details .details-content .details-registration {
  margin: 0;
  color: #FF0D0D;
  font-size: 13px;
  line-height: 18px;
}


.calendar-day-event .event-details .details-content a.button-like {
  margin: 10px 0 0 0;
}
/* hover edits */
.calendar-day-event:hover .event-details, .calendar-day-event.active .event-details {
  opacity: 1;
  pointer-events: all;
}
/* nth-of-type edits */
.calendar-day:nth-of-type(1n) .event-details {
  /* top: calc(11% - 151px); */
  /*left: 180px;*/
  left: 155px;
  margin: auto;
}
.calendar-day:nth-child(7n-2) .event-details, .calendar-day:nth-child(7n-1) .event-details, .calendar-day:nth-child(7n) .event-details {
  /* top: calc(11% - 151px); */
  left: -510px;
}
.calendar-day:nth-child(7n-2) .event-details .details-background:before,
.calendar-day:nth-child(7n-1) .event-details .details-background:before,
.calendar-day:nth-child(7n) .event-details .details-background:before {
  border-top: 15px solid transparent;
  border-left: 15px solid var(--body-bg-color);
  border-right: none;
  border-bottom: 15px solid transparent;
  left: auto;
  right: -15px;
}
.calendar-day:nth-child(7n-2) .event-details .details-background:after,
.calendar-day:nth-child(7n-1) .event-details .details-background:after,
.calendar-day:nth-child(7n) .event-details .details-background:after {
  border-top: 15px solid transparent;
  border-left: 15px solid var(--brand-border-color);
  border-right: none;
  border-bottom: 15px solid transparent;
  left: auto;
  right: -16px;
}
/*
.calendar-day:nth-child(7n-2) .event-details .details-content:before,
.calendar-day:nth-child(7n-1) .event-details .details-content:before,
.calendar-day:nth-child(7n) .event-details .details-content:before {
  border-top: 30px solid transparent;
  border-right: none;
  border-left: 30px solid #F4F4F4;
  border-bottom: 30px solid transparent;
  left: auto;
  right: -22px;
}
*/


.calendar-day-event {
  width: 100%;
  padding: 0 0 10px 0;
  display: none;
  cursor: pointer;
  position: relative;
}
.calendar.filtered .calendar-day-event {
  display: inline-block;
}
.calendar-day-event:first-of-type, .calendar-day-event:nth-of-type(2), .calendar-day-event:nth-of-type(3), .calendar-day-event:nth-of-type(4) {
  display: inline-block;
}
.calendar-day-event.hide, .calendar.filtered .calendar-day-event.hide {
  display: none;
}
.calendar-day.show-all .calendar-day-event, .calendar-day-event.show {
  display: inline-block;
}
.calendar-day.show-all .calendar-day-event.hide {
  display: none;
}
.calendar-day-event .event-title {
  font: 400 12px/14px 'DM Sans';
  /*color: #000000;*/
  display: inline-block;
  transition: color .3s;
}
.calendar-day-event.active .event-title {
  color: blue;
}
.calendar-day-event .event-time {
  font-weight: 600;
}
.calendar-day-event .event-time:before {
	display: none;
}
.calendar-dates .date-hours-block {
	width: 100%;
	padding: 3px 7px 1px 7px;
  box-sizing: border-box;
	background-color: #F4F4F4;
  color: #636363;
	font-size: 12px;
	font-weight: 600;
	line-height: 16px;
  display: inline-block;
  position: absolute;
  bottom: 0;
	left: 0;
}
.calendar-dates .date-hours-block.closed {
	/* background-color: #eee; */
	color: #E8001B;
}
.calendar-dates .date-hours-block.override {
	background-color: #eee;
	color: #0b7aa5;
}
.calendar-dates .date-hours-block.override.closed {
	background-color: #eee;
	color: #E8001B;
}
.calendar-dates .date-hours-block .desktop {
  font: var(--secondary-button-fonts);
}
/* .calendar-day-event::before {
	content: "";
    width: 9px;
    height: 13px;
    background-image: url('/assets/images/ribbons/ribbon-icon-gray.svg');
    background-repeat: no-repeat;
    background-size: contain;
    background-position: center;
    display: block;
    position: absolute;
    top: 2px;
	left: 0;
} */
/* .calendar-day-event.Adults::before {
    background-image: url('/assets/images/ribbons/ribbon-icon-blue.svg');
}
.calendar-day-event.Pre-schoolers::before {
    background-image: url('/assets/images/ribbons/ribbon-icon.svg');
}
.calendar-day-event.Kids::before {
    background-image: url('/assets/images/ribbons/ribbon-icon-purple.svg');
}
.calendar-day-event.Teens::before {
    background-image: url('/assets/images/ribbons/ribbon-icon-green.svg');
} */
.calendar-day-event.day-hidden {
	display: none;
}
.filtered .calendar-day-event.day-hidden {
  display: block;
}
.calendar-dates li .view-more-events {
	display: block;
    font: 400 12px/14px 'DM Sans';
    color: var(--calendar-view-more-color);
	text-decoration: underline;
    transition-property: all;
	transition-duration: .5s;
	cursor: pointer;
}
/* .calendar-dates li a.view-more-events:after {
  content: ">";
  margin: 0 0 0 5px;
  display: inline-block;
  transform: rotate(90deg);
} */
.calendar-dates li a.view-more-events:after {
  content: "";
  /*background-image: url('/content/_theme_images/event_view_more_arrow_down.svg');*/
  width: 6px;
  height: 9px;
  margin: 0 0 0 5px;
  display: inline-block;
}
.calendar-dates li.calendar-day.show-all a.view-more-events:after {
  transform: rotate(270deg);
}
.calendar.filtered .calendar-dates li .view-more-events {
  display: none;
}
/* calendar event details */
.event-details .popup-bkgd {
    width: 100vw;
    height: 100vh;
    background-color: rgba(255,255,255,.35);
    position: fixed;
    top: 0;
    left: 0;
	z-index: 55;
}
.event-details .close-event {
    color: #083643;
    font-size: 24px;
    position: absolute;
    top: 20px;
    right: 25px;
    cursor: pointer;
}
.event-details .popup-title {
    margin-bottom: 20px;
    position: relative;
}
.event-details .popup-title h2 {
    margin: 0 0 10px 0;
}

/* calendar dates list */
.view-previous button.previous-button:before {
  transform: rotate(-90deg);
}
.view-previous button.previous-button:hover:before {
  animation: unset;
  right: -35px;
  border-radius: 18px;
  transform: rotate(0deg);
}
.view-previous button.previous-button.active:before {
  transform: rotate(90deg);
}
.calendar .calendar-dates-list {
  display: none;
  list-style-image: none;
}
.calendar.list-layout .calendar-dates-list {
  margin: 0;
  padding: 0;
  list-style-type: none;
  display: block;
}
.calendar.list-layout .calendar-dates-list li {
  padding: 0;
}
.calendar.list-layout .calendar-dates-list li.no-match.hide {
  display: none;
}
.calendar.list-layout .calendar-dates-list li:before {
  display: none;
}

/* Calendar header */
.calendar-body {
	display: flex; 
	width: 100%; 
	margin: 0 auto; 
	flex-direction: column;
}
.calendar-header {
	width: 100%;
}
.calendar-header h2 {
  margin: 0 5px 0;
  display: inline-block;
  vertical-align: top;
  font-size: 20px;
  font-weight: 700;
  line-height: 36px;
  text-transform: capitalize;
}
#event-table {
  padding-bottom: 3em;
}
table {
  width: 100%;
  border-spacing: 5px 25px;
}
.calendar-list {
  display: flex; 
  width: 100%; 
  margin: 0 auto;
  flex-direction: column;
  display:none;
}
.calendar-list.show,
.calendar-table.show {
  display: block;
}
.calendar-table.hide {
  display: none;
}
.calendar-list-day {
  padding: 1em; 
}
.event-list-block:first-of-type .list-event:first-of-type .rounded-edge-line {
  display: none;
}
.list-weekday {
  margin-top: 30.5px;
  font-weight: bold;
  text-transform: uppercase;
}
.list-event {
  padding: 10px 0;
}
.list-event.hide {
  display: none;
}
.list-event.finished {
  padding: 10px 0;
  display: none;
}
.list-event.finished.show {
  display: block;
}
.list-event .event-about {
  position: relative;
  box-sizing: border-box;
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 25px;
  width: 100%;
  padding: 0;
}
.mobile-list-date {
    display: none;
}
.list-event .event-about .list-date {
  width: 108px;
  height: 108px;
  border-radius: 50%;
  background-color: var(--body-bg-color);
  border: 1px solid var(--brand-border-color);
  opacity: 0;
  font: 600 25px/30px 'DM Sans';
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
}
.list-event .event-about .list-date .day {
  font: 400 24px/26px 'DM Sans';
  padding-top: 3px;
}
.list-event:not(.hide) .event-about .list-date {
  opacity: 1;
}
.list-event:not(.hide) ~ .list-event:not(.hide) .event-about .list-date {
  opacity: 0;
}
.list-event .event-about .list-date.hidden {
  background-color: transparent;
  border: 0.5px solid transparent;
  border-top: 15px solid transparent;
}
.list-event .event-about .list-date .month, .list-event .event-about .list-date .date {
  display: block;
}
.list-event .event-about .list-date .date {
  font-size: 25px;
  line-height: 34px;
}
.list-event .event-about .about-content {
  flex: 1;
  margin: 0 0 15px 0;
  padding: 30px;
  background-color: var(--body-bg-color);
  border-radius: 40px;
  border: 1px solid var(--brand-border-color);
  display: block;
  position: relative;
}
.list-event .event-about .about-content .button-like.primary {
  padding: 11px 18px 10px 17px;
  border: .5px solid var(--brand-border-color);
}
.list-event .event-about .about-content .button-like.primary:before {
  border: .5px solid var(--brand-border-color);
  top: -.5px;
  right: -36px;
}
.list-event .event-about .about-content .button-like.primary:hover:before {
  border-left: .5px solid rgba(26,70,79,0);
  right: -18px;
}
.list-event .event-about .about-content:last-of-type {
  margin: 0;
}

.list-event .event-about h3 {
  font: 600 22px/24px 'Aleo';
  /*color: #000000;*/
  margin: 0 0 10px 0;
}
.list-event .event-about h3.ribbon {
  /* width: 36px; */
  /* height: 44px; */
  /* padding-top: 5px; */
  /* background-image: url('/assets/images/ribbons/ribbon-icon-black.svg'); */
  /* background-repeat: no-repeat; */
  /* background-position: center; */
  /* background-size: 100%; */
  /*color: #000;*/
  /* text-align: center; */
  position: absolute;
  top: 25.5px;
  left: 0;
}
.list-event.Pre-schoolers .rounded-edge-line {
  background-color: #F46036;
}
.list-event.Pre-schoolers .event-about h3.ribbon {
  background-image: url('/assets/images/ribbons/ribbon-icon.svg');
}
.list-event.Kids .rounded-edge-line {
  background-color: #8857FF;
}
.list-event.Kids .event-about h3.ribbon {
  background-image: url('/assets/images/ribbons/ribbon-icon-purple.svg');
}
.list-event.Teens .rounded-edge-line {
  background-color: #00A678;
}
.list-event.Teens .event-about h3.ribbon {
  background-image: url('/assets/images/ribbons/ribbon-icon-green.svg');
}
.list-event.Adults .rounded-edge-line {
  background-color: #21CEE4;
}
.list-event.Adults .event-about h3.ribbon {
  background-image: url('/assets/images/ribbons/ribbon-icon-blue.svg');
}
.list-event .event-about .event-description {
  font: 400 16px/21px 'DM Sans';
  margin: 0 0 20px 0;
}
.list-event .event-about .event-description p {
  max-width: none;
  margin: 0;
  padding: 0;
}

.weekly-row td {
  width: 180px;
  height: 150px;
  padding: 10px 10px 0 10px;
  box-sizing: border-box;
  background-color: #fff;
  border: 1px solid #8857FF;
  vertical-align: top;
  position: relative;
}
.weekly-row td.empty-space {
  background-color: #EDEDED;
  border: 1px solid #8857FF;
}
.weekly-row td.empty-space .calendar-day {
  display: block;
  background-image: url("/assets/images/ribbons/ribbon-icon-gray.svg");
}
.calendar-day-head {
  background-color: #083643;
  color: #fff;
}
.event-item .title {
  cursor: pointer;
}
.event-item {
  position: relative;
}
.event-item .title,
.event-item .showtime,
.event-about p {
  margin-bottom: 10px;
  padding-left: 14px;
  display: block;
  /* font-size: 15px; */
  /* font-weight: 500; */
  border-bottom: none;
  /* font-family: "Roboto Slab", sans-serif; */
  /* color: #083643; */
  /* letter-spacing: 0; */
  position: relative;
}
.event-item .title::before {
  content: "";
  width: 9px;
  height: 13px;
  background-image: url('/assets/images/ribbons/ribbon-icon.svg');
  background-repeat: no-repeat;
  background-size: contain;
  background-position: center;
  display: block;
  position: absolute;
  top: 2px;
  left: 0;
}
.event-item .title.Kids::before {
  background-image: url('/assets/images/ribbons/ribbon-icon-purple.svg');
}
.event-item .title.Teens::before {
  background-image: url('/assets/images/ribbons/ribbon-icon-green.svg');
}
.event-item .title.Adults::before {
  background-image: url('/assets/images/ribbons/ribbon-icon-blue.svg');
}
.event-item .showtime {
  font-size: 12px;
}
.event-details {}
.event-details .popup-bkgd {
  width: 100vw;
  height: 100vh;
  background-color: rgba(255,255,255,.35);
  position: fixed;
  top: 0;
  left: 0;
  z-index: 55;
}
.event-details .popup-content {
  width: 90%;
  max-width: 750px;
  height: auto;
  margin: 0px 10px;
  background-color: #fff;
  border: 1px solid #000;
  padding: 25px 25px 25px 100px;
  box-sizing: border-box;
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  position: fixed;
  top: 25%;
  left: calc(50% - (750px / 2));
  right: auto;
  z-index: 60;
}
.event-details .close-event {
  color: #083643;
  font-size: 24px;
  position: absolute;
  top: 20px;
  right: 25px;
  cursor: pointer;
}
.event-details .popup-content img {
  max-width: 249px;
  max-height: 300px;
  margin: 40px 0 0 25px;
  padding: 0;
  background-image: none;
}
.event-details .popup-title h2 {
  margin: 0 0 10px 0;
}
.event-details .popup-title {
  margin-bottom: 20px;
  position: relative;
}
.event-details .popup-title .event-date {
  width: 54px;
  height: 56px;
  margin: 0;
  padding-top: 14px;
  color: #000;
  border: 1px solid black;
  text-align: center;
  line-height: 20px;
  position: absolute;
  top: 0;
  left: -74px;
}
.event-details .popup-text .phone {
  margin-top: 22px;
  padding-left: 22px;
  font-style: italic;
  text-decoration: none;
  display: block;
  position: relative;
}
.event-details .popup-text .phone:before {
  content: "";
  width: 16px; 
  height: 19px;
  background-image: url("/assets/images/font-awesome-phone-icon.png");
  background-repeat: no-repeat;
  background-size: 95%;
  background-position: center;
  position: absolute;
  top: 0;
  left: 0;
}
.phone i {
  margin-right: 5px;
  transform: scaleX(-1);
}
.event-details .popup-text button {
  /* border: none; */
}
.individual_event_view {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  margin-bottom: 200px;
}
.individual-event-details {
  max-width: 70%;
}
.individual-event-details h2 {
  margin: 0 0 5px 0;
}
.individual-event-details h3 {
  margin: 0 0 10px 0;
}

.event-branch {
  width: 100%;
  margin-bottom: 200px;
  padding: 30px;
  border-radius: 40px;
  background-color: var(--body-bg-color);
  border: 1px solid var(--brand-border-color);
}
.event-branch h2 {
  font: 600 28px/32px 'Aleo';
  margin: 0;
}
.event-branch .branch-info-events {
  display: flex;
  /*gap: 15px;*/
  margin-top: 10px;
}
.event-branch .branch-info-events .branch-info {
  padding-right: 15px;
  border-right: .5px solid var(--brand-border-color);
  width: calc(50% + 25px);
  font: 300 15px/17px 'DM Sans';
  color: var(--font-offset-color);
}
.event-branch .branch-info-events .branch-info .icon-text {
  display: block;
  position: relative;
  padding-left: 20px;
}
.event-branch .branch-info-events .branch-info .icon-text svg {
  position: absolute;
  left: 0;
  top: 0;
}
.event-branch .branch-info-events .branch-info .phone {
  font-weight: 400;
  margin-bottom: 20px;
}
.event-branch .branch-info-events .branch-info .phone svg path, .event-branch .branch-info-events .branch-info .hours svg path {
  fill: var(--font-body-color);
}
.event-branch .branch-info-events .branch-info .media {
  margin-bottom: 40px;
}
.event-branch .branch-info-events .branch-info .address {
  margin-bottom: 10px;
}
.event-branch .branch-info-events .branch-info .hours p {
  font: 300 15px/17px 'DM Sans';
  margin-bottom: 5px;
}
.event-branch .branch-info-events .branch-info .hours p:last-child {
  margin: 0;
}
.event-branch .branch-info-events .branch-info .hours .day {
  font-weight: 600;
}
.event-branch .branch-info-events .branch-events {
  width: calc(50% - 25px);
  padding-left: 15px;
}
.event-branch .branch-info-events .branch-events h3 {
  font: 600 20px/22px 'Aleo';
  margin: 0;
}
.event-branch .branch-info-events .branch-events ul li .title {
  font-weight: 400;
  color: var(--font-body-color);
}
.event-branch .branch-info-events .branch-events ul li .date {
  display: block;
  font: 400 16px/19px 'DM Sans';
  color: var(--font-offset-color);
  margin-top: 3px;
}

.detailPop {
  display: none;
  height: 150px;
  width: 100px;
  background-color: white;
}


.event-list-block h2.full-date {
  display: none;
}


.event-filters {
  position: relative;
  display: flex;
  align-items: center;
  background-color: var(--body-bg-color);
  border: 1px solid var(--tag-border-color);
  border-radius: 15px;
  /*margin: 0 10px 0 0;*/
  padding: 3px 10px 3px 10px;
}
.event-filters:last-of-type {
  margin: 0;
}
.event-filters:after {
  content: "";
  width: 8px;
  height: 5px;
  margin: 0 0 0 4px;
  clip-path: polygon(0% 0%, 100% 0%, 50% 100%);
  background-color: var(--font-link-color);
  background-size: cover;
  display: inline-block;
}
.event-filters .filter-title {
  color: var(--font-link-color);
  font: 400 13px/15px 'DM Sans';
  cursor: pointer;
  margin: 0;
}
.event-filters .filter-extra {
  width: 100%;
  height: 7px;
  border: 1px solid transparent;
  display: block;
  position: absolute;
  top: -6px;
  left: 0;
}
.event-filters .filters-list {
  position: absolute;
  box-sizing: border-box;
  z-index: 55;
  list-style-type: none;
  background-color: var(--body-bg-color);
  opacity: 0;
  top: 0;
  pointer-events: none;
  visibility: hidden;
  min-width: 100%;
  max-height: 500px;
  overflow-x: hidden;
  overflow-y: scroll;
  left: 0;
  border-radius: 13px;
  border: 1px solid var(--tag-border-color);
  margin: 0;
  padding: 5px 10px;
  transition: opacity .3s, top .3s;
}
.event-filters:hover .filters-list {
  opacity: 1;
  top: 21px;
  transition: opacity .3s .1s, top .3s;
  pointer-events: all;
  visibility: initial;
}
/*.event-filters .filters-list:after, .event-filters .filters-list:before {*/
/*  content: "";*/
/*  display: block;*/
/*  position: absolute;*/
/*  left: 15px;*/
/*}*/
/*.event-filters .filters-list:after {*/
/*  border-left: 6px solid transparent;*/
/*  border-right: 6px solid transparent;*/
/*  border-bottom: 6px solid #fff;*/
/*  top: -5px;*/
/*}*/
/*.event-filters .filters-list:before {*/
/*  border-left: 6px solid transparent;*/
/*  border-right: 6px solid transparent;*/
/*  border-bottom: 6px solid #979797;*/
/*  top: -6px;*/
/*}*/
.event-filters .filters-list li {
  display: flex;
  align-items: center;
  width: 100%;
  opacity: 0.25;
  font-weight: 500;
  margin: 0 0 5px 0;
  padding: 0;
  pointer-events: none;
}
.event-filters .filters-list li:before {
  display: none;
}
.event-filters .filters-list li.active {
  opacity: 1;
  pointer-events: all;
}
.event-filters .filters-list li:first-of-type {
  position: relative;
}
.event-filters .filters-list li:last-of-type {
  margin-bottom: 0;
}
.event-filters .filters-list li input[type="checkbox"] {
  width: 14px;
  height: 14px;
  margin: 0 5px 0 0;
}
.event-filters .filters-list li label {
  width: 100%;
  box-sizing: border-box;
  color: var(--font-link-color);
  text-decoration: none;
  white-space: nowrap;
  display: flex;
  align-items: center;
  cursor: pointer;
  font: 400 12px/16px 'DM Sans';
}

.keyword-wrap {
  width: 41%;
  font-size: 16px;
  margin: 0;
}
.keyword-wrap .help-text h3 {
  margin: 0 0 10px 0;
  font-size: 20px;
}
.keyword-wrap .help-text p {
  margin: 0 0 10px 0;
  color: #000;
}
.keyword-wrap .help-text p:last-of-type {
  margin: 0;
  display: flex;
  justify-content: space-between;
}
.keyword-wrap .help-text p:last-of-type span i {
  margin-right: 5px;
}
.keyword-wrap .keyword-search .keyword-input {
  display: inline-block;
  position: relative;
}
.keyword-wrap .keyword-search .keyword-input .close-icon {
  background-color: red;
  padding: 0px 5px;
  box-sizing: border-box;
  border-radius: 50%;
  opacity: 0;
  color: #fff;
  font-size: 14px;
  text-decoration: none;
  position: absolute;
  top: 2px;
  right: 3px;
  z-index: 5;
  cursor: pointer;
  pointer-events: none;
  transition: opacity .3s;
}
/*.keyword-active .keyword-wrap .keyword-search .keyword-input.filtered:focus-within .close-icon {*/
.keyword-active .keyword-wrap .keyword-search .keyword-input.filtered .close-icon {
  opacity: 1;
  pointer-events: all;
}
/*
.keyword-wrap .keyword-search {
  opacity: 0;
  pointer-events: none;
  position: absolute;
  top: -9999px;
  left: -9999px;
}
*/
[v-cloak] { opacity: 0; }
.mobile-only {
  display: none;
}
.view-more-events {
    font-weight: 400;
    border-bottom: none;
    font-family: var(--san-serif-font, 'Roboto'), sans-serif;
    font-size: 12px;
    color: #414141;
    letter-spacing: 0;
    transition-property: all;
    transition-duration: .5s;
}

/*
.event-time {
  font-family: 'Oswald', sans-serif;
  font-weight: 300;
  text-transform: uppercase;
  letter-spacing: .5px;
}
*/
.event-time:before, .event-location:before {
  content: "";
  width: 12px;
  height: 12px;
  margin-right: 6px;
  background-repeat: no-repeat;
  background-size: contain;
  background-position: center;
  display: inline-block;
}
.event-time:before {
  /*
  width: 12px;
  height: 12px;
  margin-right: 5px;
  */
  background-image: url('/assets/images/kma_icon_hours.svg');
}
.event-location:before {
  /* width: 9px; */
  /* height: 12px; */
  background-image: url('/assets/images/kma_icon_location.svg');
}

.calendar.list-layout .calendar-dates-list.mobile-only {
	display: none;
}

.keyword-wrap.search label {
	margin: 0 0 10px 0;
	color: #083643;
	font-family: var(--san-serif-font, 'Roboto Slab'), sans-serif;
	font-size: 20px;
	font-weight: 700;
	line-height: 24px;
	letter-spacing: .3px;
	display: block;
}

.calendar-day-blanks .calendar-day {}
/*
.calendar-day-blanks .calendar-day:before {
	content: "";
	width: 28px;
	height: 30px;
	margin: 0 auto;
	padding-top: 2px;
	background-image: url('/assets/images/ribbons/ribbon-icon-gray.svg');
	background-repeat: no-repeat;
	background-size: cover;
	background-position: center;
	color: #000;
	text-align: center;
	display: block;
}
*/

/* Event Page */
.main-content.event .page-content {
  flex-wrap: wrap;
  margin: 0;
  /*max-width: 1200px;*/
  /*width: calc(100% - 100px);*/
  width: 100%;
  left: 50%;
  transform: translateX(-50%);
}
.main-content.event .page-content .left-sidebar {
  max-width: 350px;
}
.main-content.event .page-content .body {
  width: calc(100% - 390px);
}
.main-content.event .page-content .page-banner {
  margin: 0;
  position: absolute;
  width: 350px;
  height: 220px;
  align-items: flex-start;
  top: 90px;
  left: 45px;
  z-index: 6;
}
.main-content.event .page-content .page-banner .banner-media {
  max-width: unset;
  min-width: unset;
  min-height: unset;
  max-height: unset;
  width: 100%;
  height: auto;
  border-radius: unset;
  border: unset;
  background-color: transparent;
  background-size: cover;
  background-position: center top;
}
.main-content.event .page-content #event_title .blob.b1 {
  right: 100%;
  bottom: 0%;
}
.main-content.event .page-content #event_title .blob.b2 {
  right: calc(100% + 420px);
}
.main-content.event .page-content .relevant-tags {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
  margin-bottom: 20px;
}
.main-content.event .page-content .relevant-tags .tag {
  font: 400 13px/15px 'DM Sans';
  color: var(--font-link-color);
  background-color: var(--body-bg-color);
  border: 1px solid var(--tag-border-color);
  border-radius: 15px;
  padding: 5px 10px;
}
.main-content.event .page-content p.intro {
  margin-bottom: 25px;
}
.main-content.event .page-content .preview-box-location {
  
}
.main-content.event .page-content .details-timeframe {
  margin: 0 0 10px 0;
  /*text-transform: var(--small-header-font-variant);*/
}
.main-content.event .page-content .details-timeframe .date svg {
  stroke: var(--secondary-architecture);
}

.button-dropdown-container {
  width: 100%;
  display: flex;
  align-items: flex-start;
  gap: 25px;
  margin-top: 50px;
}
.button-dropdown-container .button-like, .button-dropdown-container .button-like:before {
  background-color: var(--button-secondary-bg-color);
}
.button-dropdown-container .button-like.disabled {
  opacity: 0.4;
  pointer-events: none;
}
.button-dropdown {
  padding: 11px 17px 10px 17px;
  margin-right: 36px;
  background-color: var(--button-secondary-bg-color);
  border-radius: 18px;
  color: var(--button-color);
  font: 700 12px/14px 'DM Sans';
  letter-spacing: 0.5px;
  text-align: center;
  text-transform: uppercase;
  display: inline-block;
  position: relative;
  transition: border-radius, .5s;
  cursor: pointer;
}
.button-dropdown .toggle-area {
  display: inline-block;
  position: absolute;
  width: calc(100% + 35px);
  height: 100%;
  top: 0;
  left: 0;
}
.button-dropdown:before {
  content: '';
  display: inline-block;
  position: absolute;
  right: -35px;
  top: 0px;
  height: 11px;
  width: 11px;
  padding: 12px 12px 12px 12px;
  background-color: var(--button-secondary-bg-color);
  border-radius: 18px;
  background-image: var(--button-icon);
  background-size: 8px;
  background-position: calc(50% + 1.5px) calc(50% - .5px);
  transition: all .5s;
  background-repeat: no-repeat;
  display: inline-block;
}
.button-dropdown:hover:before {
  transform: rotate(30deg);
}
.button-dropdown.toggled:before {
  transform: rotate(90deg);
}
.button-dropdown .dropdown-list {
  display: none;
  position: absolute;
  width: calc(100% + 35px);
  top: 100%;
  left: 0;
  background-color: var(--button-secondary-bg-color);
  border-radius: 18px;
  margin: 0;
  padding: 12px 17px;
  cursor: auto;
  z-index: 1;
}
.button-dropdown.toggled .dropdown-list {
  display: block;
}
.button-dropdown .dropdown-list li {
  text-align: left;
  margin: 0;
  padding: 0 0 5px 0;
}
.button-dropdown .dropdown-list li:before {
  display: none;
}
.button-dropdown .dropdown-list li a {
  font: 400 12px/16px 'DM Sans';
  color: var(--font-body-color);
  opacity: .75;
  text-transform: capitalize;
}
.button-dropdown .dropdown-list li a:hover {
  text-decoration: underline;
}
.button-dropdown .dropdown-list li .share-link {
  display: flex;
  gap: 5px;
  padding-top: 5px;
}
.button-dropdown .dropdown-list li .share-link input.share-url {
  position: absolute;
  opacity: 0;
  left: -9999px;
  pointer-events: none;
}
.button-dropdown .dropdown-list li .share-link .share-url-check {
  width: 14px;
  height: 14px;
  opacity: 0;
  transition: opacity .25s;
}
.button-dropdown .dropdown-list li .share-link.active .share-url-check {
  opacity: 1;
}

/* event page exclusive styles */
.individual-event-details {
  width: 100%;
  max-width: none;
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
}

.individual-event-date {
  width: 150px;
  height: 150px;
  background-color: #fff;
  border: 0.4px solid rgba(26, 70, 79,0.4);
  border-radius: 50%;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
}
.individual-event-date .single-day {
  margin: 0 0 2px 0;
  font-family: 'Aleo', serif;
  font-size: 18px;
  line-height: 20px;
}
.individual-event-date .single-month {
  margin: 0 0 2px 0;
  font-family: 'Aleo', serif;
  font-size: 22px;
  line-height: 24px;
  /*font-weight: 600;*/
}
.individual-event-date .single-date {
  margin: 0;
  font-family: 'Aleo', serif;
  font-size: 26px;
  line-height: 28px;
  font-weight: 700;
}

.individual-events-meta {
  position: relative;
  width: 100%;
  margin-top: 70px;
}

@media only screen and (max-width: 1030px) {
	.calendar .calendar-top .calview {
		right: 20px;
	}
	.calendar .calendar-top .calview a span:last-of-type {
		display: none;
	}
	.calendar-day-event .event-details:before {
	    content: none;
	}
	.calendar-day-event .event-details .details-content:before {
	    content: none;
	}
	.calendar-day-event .event-details .details-background:before {
	    content: none;
	}
	.calendar-day-event .event-details .details-background:after {
	    content: none;
	}
	/* .calendar-day:nth-of-type(1n) .event-details {
        left: calc(50% - 240px);
    } */
}

@media only screen and (max-width: 1023px) {
    .main-content.calendar {
        width: 100%;
    }
}

@media only screen and (max-width: 970px) {
  .calendar {
    /* margin: 10px; */
  }
  .calendar-day-event .event-details {
    position: fixed;
    top: 40%;
    left: calc(50% - 240px);
    z-index: 99;
  }
  .calendar-day:nth-child(7n-2) .event-details, .calendar-day:nth-child(7n-1) .event-details, .calendar-day:nth-child(7n) .event-details {
    left: calc(50% - 240px);
    /* top: calc(50% - 130px); */
  }
  .calendar-day-event .event-details:before {
    display: none;
  }
  .calendar-day-event .event-details .details-background:before, .calendar-day-event .event-details .details-background:after, .calendar-day-event .event-details .details-content:before {
    display: none;
  }
  .calendar-day-event .event-details .details-background-close {
    width: 100vw;
    height: 100vh;
    background-color: #000;
    opacity: 0.4;
    display: block;
    position: fixed;
    top: 0;
    left: 0;
    pointer-events: none;
  }
  /*
  .calendar-day-event.disable-hover {
    pointer-events: none;
  }
  */
  .main-content.event .page-content .left-sidebar {
    order: 0;
  }
  .main-content.event .page-content .page-banner:not(:has( .banner-media)) {
    display: none;
  }
  .main-content.event .page-content .page-banner {
    position: unset;
    /*width: 100%;*/
    margin: 25px 0 0 0;
    order: 1;
  }
  .individual-events-meta {
    margin-top: 25px;
  }
  .main-content.event .page-content {
    /*margin: 0 25px;*/
    /*width: calc(100% - 50px);*/
    flex-direction: column;
    align-content: flex-start;
  }
  .main-content.event .body {
    padding: 0;
  }
  .main-content.event .page-content .body {
    width: 100%;
    order: 2;
  }
}

@media only screen and (max-width: 900px) {
  .main-content.calendar {
    width: 100%;
    /* margin: 0 10px; */
    margin: auto;
    /* padding-top: 95px; */
  }
  .main-content.calendar h1 {
    margin: 0 0 5px 0;
  }
  .main-content.calendar p.intro {
    text-align: start;
    font-size: 16px;
    line-height: normal;
  }
  .calendar {
    margin: 0;
  }
  .calendar .calendar-title {
    width: auto;
    margin: 0;
	/* margin-bottom: 10px; */
	/*padding: 8px 0;*/
    order: 0;
  }
  .calendar .calendar-title .cal-arrow.prev {
    margin: 0 15px 0 0;
  }
  .calendar .calendar-title h2 {
	font-size: 18px;
  }
  .calendar .calendar-title .cal-arrow.next {
    margin: 0 0 0 15px;
  }
  .discover-filters.expanded .calendar-top {
    border-radius: 20px;
  }
  .discover-filters.expanded .expandable-section {
    display: none;
  }
  .event-filters-wrap {
    width: auto;
    /* margin-bottom: 15px; */
    /* justify-content: space-between; */
    order: 1;
    display: none;
  }
  .event-filters .filter-title {
    margin: 0;
    font-size: 13px;
    font-weight: 500;
    line-height: 18px;
  }
  .event-filters .filter-title em {
    display: none;
  }
  .event-filters .filters-list {
    width: 200px;
    max-height: 300px;
  }
  .event-filters ul {
    left: auto;
    right: 0;
    z-index: 99;
  }
  .event-filters ul:after, .event-filters ul:before {
    left: auto;
    right: 9px;
  }
  .event-filters ul li:first-of-type:before {
    left: auto;
    right: 3px;
  }
  /*
  .event-filters ul {
    width: auto;
    padding: 0;
    background-color: transparent;
    border: none;
    display: block;
    position: relative;
    top: 0;
  }
  .event-filters ul:before, .event-filters ul:after {display:none;}
  */
  .event-filters li.event-filter-li {
    display: flex;
    align-items: center;
  }
  .event-filters li.event-filter-li label {
    white-space: wrap;
  }
  .event-filters li.event-filter-li input[type="checkbox"] {
    margin-left: 0;
  }
  .calendar-weekdays {
	display: none;
  }
  .calendar-weekdays-mobile {
    display: flex;
  }
  .calendar .calendar-dates {
    padding: 0;
  }
  .body .calendar-dates li {
	height: auto;
	min-height: unset;
	max-height: 124px;
	position: relative;
	padding: 23px 0 0 3px;
	aspect-ratio: 1/1;
  }
  .calendar-day, .calendar-day-blanks .calendar-day {
	width: 100%;
    background-color: transparent;
	top: 0;
	left: 0;
  }
  .calendar-day-event:first-of-type {
	margin-top: 13px;
  }
  /*.calendar-day-blanks .calendar-day:before {
	width: 100%;
	height: 20px;
	padding: 0;
	background-color: #C0BEA4;
	background-image: none;
  } */
  .calendar-day .calendar-day-date p {
	width: 100%;
	height: auto;
    font-size: 13px;
    line-height: 18px;
    text-align: center;
  }
  .calendar-dates .date-hours-block {
    padding: 0;
    font-size: 10px;
    font-weight: 400;
    line-height: 14px;
    display: none;
  }
  .calendar-dates .date-hours-block.closed, .calendar-dates .date-hours-block.override.closed {
    background-color: #4A4A4A;
    color: #fff;
    display: flex;
    justify-content: center;
    /* position: relative; */
    z-index: 60;
  }
  .calendar-day .calendar-day-date {
    width: 100%;
    top: 5px;
    left: 0;
    right: auto;
  }
  /*.calendar-day-event {*/
  .calendar-day-event:first-of-type, .calendar-day-event:nth-of-type(2), .calendar-day-event:nth-of-type(3), .calendar-day-event:nth-of-type(4) {
	width: 100%;
	/* height: 100%; */
	margin: 0;
	padding: 0;
	display: none;
  }
  .calendar-day-event .event-title {
	display: none;
	transform: scale(0);
  }
  .calendar-day-event::before {
	display: none;
  }
  .calendar-day-event:hover .event-details {
	width: calc(100% - 38px);
  }
  .calendar-day:nth-of-type(1n) .event-details {
	left: 13px;
  }
  .calendar .calendar-dates-list {
	display: none;
  }
  .list-event.finished.show {
    display: inline;
  }
  .list-event .event-about .about-content {
    background-color: transparent;
    border: none;
    padding: unset;
  }
  .list-event {
    /* margin: 10px 0; */
    padding: 0;
    /* margin-left: 35px; */
    position: relative;
  }
  /*
  .list-event .event-about .about-content::before {
    position: absolute;
    top: 5px;
    left: -20px;
    content: '';
    height: 10px;
    width: 10px;
    border-radius: 10px;
    background-color: #2489AF;
  }
  */
  .mobile-list-date {
    display: none;
    width: 100%;
    font-size: 18px;
    /* text-align: center; */
    padding: 8px 0 8px 0;
    margin-bottom: 10px;
    position: relative;
    /* left: -50px; */
    border-bottom: 1px solid #000000;
    font: var(--secondary-header-font);
  }
  .list-event:first-child .event-about .mobile-list-date {
    display: block;
    font: 400 18px/30px 'Aleo';
    text-align: center;
    border: unset;
  }
  .list-event .event-about {
    margin: 0 0 15px 0;
	flex-wrap: wrap;
    font-size: 14px;
    line-height: 22px;
    display: block;
    position: relative;
  }
  .grid-layout .calendar-dates-list .list-event .event-about {
    padding: 30px;
	background-color: var(--body-bg-color);
    border: 1px solid var(--brand-border-color);
    border-radius: 40px;
  }
  .list-event .event-about span {
    /*display: block;*/
  }
  /*
  .list-event .event-about .date {
    display: flex;
    align-items: center;
  }
  */
  .list-event .event-about .event-description {
    margin-bottom: unset;
  }
  .list-event .event-about h3 {
    font-size: 18px;
    line-height: 22px;
    font-weight: 400;
  }
  .list-event .event-about button, .list-event .event-about a.button-like {
    margin: 8px 0 0 0;
  }
  .grid-layout .list-event .event-about a.button-like {
    display: block;
    width: fit-content;
  }
  .details-timeframe {
    margin: 0 0 15px 0;
  }
  .calendar .calendar-dates-list.mobile-only h4 {
    display: none;
  }
  .calendar .calendar-top .calview {
    display: none;
  }
  /* .m-events {
	width: 100%;
	height: 100%;
	padding: 18px 0 0 0;
	box-sizing: border-box;
	display: flex;
	align-items: center;
	justify-content: center;
	position: relative;
	z-index: 15;
  }
  .m-events:after {
	display: none;
  }
  .m-events .m-event, .m-events:before {
	content: "";
	width: 11px;
	height: 11px;
	margin-right: 3px;
	background-color: #E28080;
	border-radius: 50%;
	display: block;
  }
  .m-events .m-event:last-of-type {
	margin-right: 0;
  }
  .m-events .m-event.kids {background-color:#8857FF;}
  .m-events .m-event.teens {background-color:#00A678;}
  .m-events .m-event.adults {background-color:#21CEE4;}
  .m-events .m-event.pre-schoolers {background-color:#F46036;}
  .m-events .m-event.rainbow {background:linear-gradient(90deg, #8857FF, #00A678, #21CEE4, #F46036);}
  */
  .m-events {
	width: 100%;
	height: 100%;
	padding: 0;
	display: inline-block;
	position: absolute;
	top: 0;
	left: 0;
  }
  .m-events:after {
	content: '';
	width: 10px;
	height: 10px;
	/* background-color: #E28080; */
    background-color: #227B9D;
	border-radius: 50%;
	display: block;
	position: absolute;
	top: 28px;
	left: calc(50% - (10px / 2));
	z-index: 50;
  }
  /* .m-events.kids:after {background-color:#8857FF;}
  .m-events.teens:after {background-color:#00A678;}
  .m-events.adults:after {background-color:#21CEE4;}
  .m-events.pre-schoolers:after {background-color:#F46036;} */
  /* .m-events.rainbow:after {background:linear-gradient(90deg, #8857FF, #00A678, #21CEE4, #F46036);} */
	
  .active-day {
	width: 100%;
    /*height: calc(100% - 9px);*/
    height: 100%;
	padding: 0;
	/* background-color: rgba(244,96,54,0.5); */
	/* background-color: rgba(255,220,122,0.5); */
	/* background-color: rgb(255,220,122 / 50%); */
    background-color: rgba(34,123,157,0.5);
	display: block;
	position: absolute;
	top: 0;
	left: 0;
	z-index: 55;
  }
	
	
  .calendar .calendar-dates-list.mobile-only {
	width: 100%;
	padding: 0;
	display: inline-block;
  }
  .calendar .calendar-dates-list.mobile-only li {
    padding: 0;
    list-style-type: none;
  }
  .calendar .calendar-dates-list.mobile-only li:before {
    display: none;
  }
  .calendar .calendar-dates-list.mobile-only .calendar-title {
	margin: 15px 0;
    padding: 0;
	/* background-color: rgb(255,237,188); */
    /* background-color: rgba(34,123,157,0.4); */
    /*background-color: var(--font-link-color);*/
    /*color: #fff;*/
    font-size: 18px;
    font-weight: 400;
    line-height: 30px;
  }
  .calendar .calendar-dates-list.mobile-only h4 {
	margin: 0 0 5px 0;
  }
  .calendar .calendar-dates-list.mobile-only .list-event:after {
	content: "";
	width: calc(100% + 2px);
	height: 2px;
    margin: 15px 0;
	background-color: #333;
	display: none;
	position: relative;
	left: -1px;
  }
  .calendar .calendar-dates-list.mobile-only .list-event:last-of-type:after {
	display: none;
  }
  .desktop-only {
	display: none;
  }
	
  .calendar-top {
    margin-bottom: 30px;
    padding: 10px;
	flex-direction: column;
	/*flex-wrap: wrap;*/
	align-items: center;
	gap: 5px;
	border: unset;
  }
  .keyword-wrap {
	width: 100%;
	order: 0;
  }
  .keyword-wrap.search {
	width: 50%;
	margin-top: 15px;
	order: 3;
  }
  
  .main-content.event .page-content {
    gap: 25px;
    width: calc(100% - 30px);
  }
  body.dark-mode .mobile-list-date {
    border-color: #FFFFFF;
  }
  
  
  .list-event .event-about .list-date {
    display: none;
  }
  .list-event:first-child .event-about .list-date {
    /* display: flex; */
  }
  .list-event .event-about .about-content:last-of-type {
    margin-top: 10px;
    background-color: var(--body-bg-color);
    padding: 30px;
    border: 1px solid var(--brand-border-color);
  }
  
  .mobile-only {
    display: block;
    padding-top: 5px;
    padding-bottom: 5px;
  }
  .calendar-day > .mobile-only ~ .mobile-only {
    display: none;
  }
  .view-more-events {
    display: none;
  }
  
  #calendar {
    border-spacing: 0 !important;
  }
  .event-item, .calview, .event-item-view {
    display: none;
  }
  .calview a {
    font-size: 21px;
  }
  .calendar-options {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
    -ms-flex-direction: column;
    flex-direction: column;
    margin-bottom: 1em;
  }
  .calendar-title h2 {
    font-size: 17px;
  }
  #event-table {
    padding-bottom: 3em;
  }
  table {
    width: 100%; 
  }
  .calendar-list {
    display: flex; 
    max-width: 1024px;
    width: 100%; 
    margin: 0 auto;
    flex-direction: column;
    display:none;
  }
  .calendar-list.show,
  .calendar-table.show {
    display: block;
  }
  .calendar-table.hide {
    display: none;
  }
  .calendar-list-day {
    padding: 1em; 
  }
  .list-weekday {
    display: inline-block;
    font-size: 10px;
    color: #1CA2A2;
    font-weight: bold;
    letter-spacing: 0;
    line-height: 16px;
    text-transform: uppercase;
    border-bottom: 2px solid #1CA2A2;
  }
  .weekly-row td {
    background-color: #f3f3f3;
    height: 100px;
    width: 100px;
    vertical-align: top;
    position: relative;
  }
  .event-item .title {
    cursor: pointer;
  }
  .event-item {
    position: relative;
  }
  .event-item .title,
  .event-item .showtime {
    display: block;
    font-size: 14px;
    font-weight: 400;
    border-bottom: none;
    font-family: var(--san-serif-font, 'Roboto'), sans-serif;
    font-size: 12px;
    color: #414141;
    letter-spacing: 0;
  }
  .event-item .showtime {
    font-size: 12px;
  }
  .event-details {
    right: 100%;
    top: 0;
    height: auto;
    width: 200px;
    padding: 5px;
    margin: 0px 10px;
    box-shadow: 0px 0px 3px #888;
    z-index: 1;
    background-color: #fff;
    position: absolute;
  }
  .detailPop {
    display: none;
    height: 150px;
    width: 100px;
    background-color: white;
  }

  .calendar-top {
    display: flex;
    justify-content: space-between;
  }
  /*.event-filters-wrap {*/
  /*  display: flex;*/
  /*  flex-direction: row;*/
  /*}*/
  ul.event-filters {
    display: flex;
    flex-direction: column;
    padding-left: 0;
    width: auto;
    padding-right: 30px;
  }
  .keyword-wrap {
    width: 40%;
    font-size: 16px;
    margin: 0;
  }
}

@media only screen and (max-width: 650px) {
  .button-dropdown-container {
    flex-direction: column;
    gap: 30px;
  }
  
  .event-branch .branch-info-events {
    flex-direction: column;
  }
  .event-branch .branch-info-events .branch-info, .event-branch .branch-info-events .branch-events {
    width: 100%;
    padding: 0;
  }
  .event-branch .branch-info-events .branch-info {
    border: unset;
    border-bottom: .5px solid var(--brand-border-color);
    padding-bottom: 25px;
  }
  .event-branch .branch-info-events .branch-events {
    padding-top: 25px;
  }
}

@media only screen and (max-width: 450px) {
    .list-event .event-about .about-content {
        width: calc(100% - 10px);
    }
    .list-event .event-about .event-description {
        margin-bottom: unset;
    }
    .calendar-top {
        padding-bottom: 5px;
    }
}