:root {
  --main-logo-img: url('/content/20/_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;
}
/* calendar's parent element */
.calendar-region {
    color: var(--font-body-alt-color);
    position: relative;
  
    /* custom variable unique to the calendar */
    --calendar-bg-color: #FFFFFF;
    --calendar-border-color: #E7E7E7;
    --calendar-date-blank-bg-color: #EDF1EA;
    --font-calendar-weekday: normal 400 17px/25px "Libre Baskerville", serif;
    --font-calendar-date: normal 400 14px/16px "Sarabun", sans-serif;
    --font-calendar-event: normal 400 14px/18px "Libre Baskerville", serif;
    --font-calendar-event-time: normal 400 14px/15px "Sarabun", sans-serif;
    
    /* override base variables */
    --font-event-list-month: normal 400 19px/24px "Sarabun", sans-serif;
    --font-event-list-day: normal 400 25px/31px "Libre Baskerville", serif;
}
body.dark-mode .calendar-region {
    --calendar-bg-color: #000000;
    --calendar-border-color: #2C2C2C;
    --calendar-date-blank-bg-color: #172216;
}
/* override base styles */
.calendar-region ul {
    margin: 0;
    padding: 0;
}
.calendar-region ul li {
    margin: 0;
    padding: 0;
}
.calendar-region ul li:before {
    display: none;
}
/* calendar 'loading' styles */
.calendar-region .current-filters:after, .calendar-region .calendar-dates li:after {
    content: "";
    width: 100%;
    height: 100%;
    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 .current-filters: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;
}

/* discover by */
.event-filters-wrap {
  display: flex;
  flex-direction: row;
  flex-wrap: wrap;
  align-items: center;
  gap: 10px;
  width: 34%;
}
.discover-filters {
  margin-bottom: 25px;
}
.discover-filters .current-filters {}
.discover-filters .current-filters .event-filters-wrap .h3-like {
    margin: 0;
    cursor: pointer;
}
.discover-filters .current-filters .event-filters-wrap a {
    background-color: var(--select-bg-color);
    border: 1px solid var(--font-ordered-list-marker-color);
}
.discover-filters .current-filters .event-filters-wrap .tagged-list {
    display: flex;
    flex: 1 1 0%;
    flex-wrap: wrap;
    gap: 10px;
}
.discover-filters .current-filters .event-filters-wrap .tagged-list .tag {
    padding: 0;
    display: flex;
}
.discover-filters .current-filters .event-filters-wrap .tagged-list .tag label {
    padding: 6px 8px 7px 25px;
    position: relative;
    cursor: pointer;
    font: var(--font-button);
    color: var(--font-link-color);
}
.discover-filters .current-filters .event-filters-wrap .tagged-list .tag label:before {
    content: "";
    width: 12px;
    height: 12px;
    background-color: var(--font-link-color);
    position: absolute;
    top: 8px;
    left: 8px;
    clip-path: polygon(10% 0%, 50% 40%, 90% 0%, 100% 10%, 60% 50%, 100% 90%, 90% 100%, 50% 60%, 10% 100%, 0% 90%, 40% 50%, 0% 10%);
}
.discover-filters .current-filters .event-filters-wrap .tagged-list .tag label input {
    width: 0;
    height: 0;
    margin: 0;
    opacity: 0;
    position: absolute;
}

/* Calendar Weekdays */
.calendar .calendar-weekdays {
    margin: 0 0 15px 0;
    display: flex;
    position: relative;
}
.calendar .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: var(--font-calendar-weekday);
    text-align: center;
}

.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;
}
body.dark-mode .calendar {
  --calendar-inner-border-color: #354245;
}
.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: 28px;
    height: 100%;
    min-height: 28px;
    display: inline-flex;
    justify-content: center;
    align-content: center;
    background-color: var(--select-bg-color);
    border: 1px solid var(--font-ordered-list-marker-color);
}
.calendar .calendar-title .cal-arrow {
  display: inline-flex;
  width: 6px;
  height: 10px;
  clip-path: polygon(0% 10%, 16.67% 0%, 100% 50%, 16.67% 100%, 0% 90%, 66.67% 50%);
  background-color: var(--font-link-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;
  text-align: center;
  white-space: nowrap;
  color: var(--font-body-color);
}
.calendar .current-filters .calview {
  width: 34%;
  display: flex;
  justify-content: flex-end;
  align-items: center;
  gap: 10px;
}

.calendar .current-filters .calview {
    width: 32%;
    min-width: 330px;
    display: flex;
    align-items: center;
    justify-content: flex-end;
    position: relative;
}
.calendar .current-filters .calview a {
    font: var(--font-return-to-link);
    text-decoration: none;
    display: flex;
    align-items: baseline;
    gap: 5px;
    padding: 2px 10px 3px 10px;
}
.calendar.grid-layout .current-filters .calview a.grid-layout, .calendar.list-layout .current-filters .calview a.list-layout {
    background-color: rgba(102,141,78,0.2);
    pointer-events: none;
}

.calendar .current-filters .toggle {
  position: relative;
  width: 55px;
  height: 30px;
  background-color: var(--body-bg-color);
  border: 1px solid var(--font-ordered-list-marker-color);
}
.calendar .current-filters .toggle:before {
  content: '';
  display: block;
  position: absolute;
  width: 26.5px;
  height: 28px;
  top: 0;
  left: 0;
  background-color: var(--font-link-color);
  transition: left .5s;
}
.calendar .current-filters .toggle:has(input[type="checkbox"]:checked):before {
  left: 26.5px;
}
.calendar .current-filters .toggle input[type="checkbox"] {
  width: 100%;
  height: 100%;
  opacity: 0;
  margin: 0;
  cursor: pointer;
}
.calendar .current-filters .toggle .icons {
  position: absolute;
  display: flex;
  width: 100%;
  height: 100%;
  top: 0;
  left: 0;
  gap: 3px;
  cursor: pointer;
}
.calendar .current-filters .toggle .icons > * {
  flex: 1 1 0px;
  align-self: center;
}
.calendar .current-filters .toggle .icons .calendar * {
  fill: var(--body-bg-color);
}
.calendar .current-filters .toggle:has( input[type="checkbox"]:checked) .icons .calendar * {
  fill: var(--font-link-color);
}
.calendar .current-filters .toggle .icons .list * {
  fill: var(--font-link-color);
}
.calendar .current-filters .toggle:has( input[type="checkbox"]:checked) .icons .list * {
  fill: var(--body-bg-color);
}

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


.calendar .current-filters .calview .grid-view, .calendar .current-filters .calview .list-view {
  width: 17px;
  height: 15px;
  margin: 0 5px 0 0;
  background-repeat: no-repeat;
  background-size: cover;
  display: inline-block;
}
.calendar .current-filters .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 dates */
.calendar-dates {
    width: 100%;
    background-color: var(--calendar-bg-color);
    border: 1px solid var(--calendar-border-color);
    display: flex;
    flex-wrap: wrap;
    position: relative;
}
.calendar.list-layout .calendar-dates {
    display: none;
}
.calendar-dates .calendar-day {
    width: calc(100% / 7);
    min-height: 250px;
    padding: 41px 15px 22px 15px;
    border-right: 1px solid transparent;
    border-bottom: 1px solid transparent;
    border-color: var(--calendar-border-color);
    list-style-type: none;
    position: relative;
}
.calendar-dates .calendar-day.today {
    border-left: 5px solid rgba(102,141,78,.5);
    padding-left: 10px;
}
.calendar-dates .calendar-day.blank {
    background-color: var(--calendar-date-blank-bg-color);
}
.calendar-dates .calendar-day:nth-last-child(-n + 7) {
    border-bottom: unset;
}
.calendar-dates .calendar-day:nth-child(7n) {
    border-right: unset;
}



.calendar-day .calendar-day-date {
    opacity: 0.8;
    font: var(--font-calendar-date);
    display: block;
	position: absolute;
	top: 15px;
    left: 15px;
}
.calendar-day.today .calendar-day-date {
    left: 10px;
}

.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;
  
  --font-body: normal 300 14px/16px "Sarabun", sans-serif;
  font: var(--font-body);
}
.calendar-day-event .event-details:before {
    content: "";
    width: 26px;
    height: calc(100% + 36px);
    display: block;
    position: absolute;
    top: -18px;
    left: -30px;
    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% + 36px);
    height: calc(100% + 36px);
    background-color: var(--theme-secondary-color-4);
    border: 1px solid var(--theme-primary-color-3);
    /*border-left: 10px solid var(--theme-primary-color-3);*/
    box-shadow: 0 0 15px rgba(0, 0, 0, 0.24);
    display: inline-block;
    position: absolute;
    top: -18px;
    left: -18px;
    z-index: 5;
}
.calendar-day-event .event-details .details-background:before {
    content: "";
    width: 10px;
    height: calc(100% + 2px);
    background-color: var(--theme-primary-color-3);
    display: block;
    position: absolute;
    top: -1px;
    right: -9px;
}
.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 {
    left: -9px;
    right: auto;
}
/*
.calendar-day-event .event-details .details-background:before, .calendar-day-event .event-details .details-background:after {
  content: "";
  display: inline-block;
  position: absolute;
  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;*/
  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;
    font: var(--font-calendar-event);
    display: block;
    transition: color .3s;
}
.calendar-day-event .event-details .details-content .details-description {
  margin: 5px 0;
  font: var(--font-body);
}
.cancelled {
    color: #FF0D0D; 
    font-size: 1.5em;
}
.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 {
    left: 167px;
    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 {
    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) {*/
.calendar-day-event:first-of-type, .calendar-day-event:nth-of-type(2) {
  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: var(--font-calendar-event);
    display: inline-block;
    transition: color .3s;
}
.calendar-day-event:hover .event-title, .calendar-day-event.active .event-title {
    color: var(--font-link-color);
}
.calendar-day-event .event-time {
    margin: 5px 0 0 0;
    opacity: 0.8;
    color: var(--font-body-color);
    font: var(--font-calendar-event-time);
    display: block;
}
.calendar-day-event .event-time:before {
	display: none;
}

/* .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;
    text-decoration: none;
    transition-property: all;
	transition-duration: .5s;
	cursor: pointer;
	width: fit-content;
}
.calendar-dates li a.view-more-events:before {
    content: "";
    display: block;
    position: absolute;
    width: 100%;
    height: 1px;
    bottom: -1px;
    left: 0;
    background-color: var(--font-link-color);
}
.calendar-dates li a.view-more-events:after {
  content: "";
  width: 10px;
  height: 6px;
  clip-path: polygon(10% 0%, 50% 66.67%, 90% 0%, 100% 16.67%, 50% 100%, 0% 16.67%);
  margin: 0 0 1.5px 1px;
  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: var(--theme-secondary-color-2);
    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 */
.calendar.list-layout .view-previous {
    margin: 0 0 37px 0;
    display: block;
}
.calendar.list-layout .view-previous .previous-button {
    font: var(--font-calendar-event);
    text-underline-offset: 3px;
    position: relative;
    cursor: pointer;
}
.calendar.list-layout .view-previous .previous-button:before {
    content: '';
    display: block;
    position: absolute;
    width: 100%;
    height: 1px;
    bottom: -1px;
    right: 0;
    background-color: var(--font-link-color);
}
.calendar.list-layout .view-previous .previous-button:after {
    content: '';
    display: inline-block;
    width: 10px;
    height: 6px;
    clip-path: polygon(10% 0%, 50% 66.67%, 90% 0%, 100% 16.67%, 50% 100%, 0% 16.67%);
    margin: 0 0 2px 5px;
    transition: transform .5s;
}
.calendar.list-layout .view-previous .previous-button.active:after {
    transform: rotate(180deg);
}
.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 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 {
  width: 100%;
  margin: 0 0 35px 0;
  display: flex;
  gap: 30px;
  justify-content: space-between;
  position: relative;
  align-items: flex-start;
}
.list-event.hide {
  display: none;
}
.list-event.finished {
  display: none;
}
.list-event.finished.show {
  display: flex;
}
/*.list-event img {*/
/*    max-width: 400px;*/
/*}*/

.mobile-list-date {
    display: none;
}
.calendar-dates-list .list-event .list-date {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 5px;
  width: 77px;
  height: 77px;
  border: 1px solid var(--theme-default-color);
  font: var(--font-event-list-month);
}
.calendar-dates-list li .list-event ~ .list-event .list-date {
    opacity: 0;
}
.list-event .list-date .day {
  font: var(--font-event-list-day);
}
.list-event .list-details {
  width: calc(100% - 107px);
  padding: 35px;
  background-color: var(--theme-secondary-color-4);
  border-left: 10px solid var(--theme-primary-color-2);
  display: flex;
  align-items: flex-start;
  gap: 40px;
  justify-content: space-between;
  position: relative;
}
.list-event .list-details .list-image {
    max-width: calc((100% - 40px) / 2);
    width: 400px;
    aspect-ratio: 20/13;
    height: auto;
    background-size: cover;
    background-repeat: no-repeat;
    background-position: center;
}
.list-event .event-details h4 {
    margin: 0 0 10px 0;
}
.list-event .event-details .details-timeframe {
    margin: 0 0 10px 0;
    color: var(--font-body-color);
    font: var(--font-body);
    display: block;
}
.list-event .event-details .details-timeframe svg {
    /*opacity: .5;*/
}
.list-event .event-details .details-timeframe .time {}
.list-event .event-details .details-timeframe .location {
    margin: 5px 0 0 0;
    display: block;
}
.list-event .event-details .list-date {
    width: 77px;
    height: 77px;
    background-color: var(--body-bg-color);
    border: 1px solid var(--theme-default-color);
    opacity: 0;
    font: var(--font-event-list-month);
    display: flex;
    row-gap: 5px;
    flex-direction: column;
    align-items: center;
    justify-content: center;
}
.list-event .event-details .list-date .day {
    font: var(--font-event-list-day);
}
.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-details .list-date.hidden {
  background-color: transparent;
  border: 0.5px solid transparent;
  border-top: 15px solid transparent;
}
.list-event .event-details .list-date .month, .list-event .event-details .list-date .date {
  display: block;
}
.list-event .event-details .list-date .date {
  font-size: 25px;
  line-height: 34px;
}
.list-event .event-details .event-description {}
.list-event .event-details .event-description p {}


.event-details {
  flex: 1;
}
.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: var(--select-bg-color);
  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: var(--theme-secondary-color-2);
  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: var(--font-body-color);
  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;
}
.individual-event-details .relevant-tags {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
}
.individual-event-details .relevant-tags .tag {
  color: var(--font-link-color);
  border: 1px solid rgba(102, 141, 78, .44);
  background-color: var(--body-bg-color);
  font: var(--font-event-list-month);
  padding: 3px 5px 4px 5px;
}

.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);
  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-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: 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.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;
}

.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: var(--font-body-color);
}
.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;
  opacity: 0;
  color: var(--select-bg-color);
  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 {
  position: relative;
  font: var(--font-prompt-button);
  border-bottom: none;
  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: var(--theme-secondary-color-2);
	font-size: 20px;
	font-weight: 700;
	line-height: 24px;
	letter-spacing: .3px;
	display: block;
}

.calendar-day-blanks .calendar-day {}


/* 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;
}
.left-sidebar .event-preview-image {
    width: 100%;
    margin-top: 25px;
    aspect-ratio: 1 / 1;
    display: block;
}
.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: 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: var(--font-event-list-month);
  color: var(--font-link-color);
  background-color: var(--body-bg-color);
  border: 1px solid rgba(102, 141, 78, .44);
  padding: 3px 5px 4px 5px;
}
.main-content.event .page-content p.intro {
  margin-bottom: 25px;
}
.main-content.event .page-content .preview-box-location {
  
}

/* single event page styles */
.single-event {
    padding-top: 47px;
}

.button-dropdown-container {
    width: 100%;
    display: flex;
    align-items: flex-start;
    gap: 25px;
    margin-top: 50px;
}
.button-dropdown-container a.button-like {
    margin-top: 0;
}
.button-dropdown-container .button-like.disabled {
    opacity: 0.4;
    pointer-events: none;
}
.button-dropdown {
    padding: 9px 10px;
    background-color: var(--select-bg-color);
    border: 1px solid var(--theme-primary-color-3);
    color: var(--font-body-color);
    font: var(--font-button);
    display: inline-block;
    position: relative;
    cursor: pointer;
}
.button-dropdown .icon-downarrow {
    margin-left: 20px;
    transform: translateY(-2px);
    display: inline-block;
}
.button-dropdown ul li {
    width: 100%;
    margin: 0;
    padding: 0;
}
.button-dropdown ul li:before {
    display: none;
}
.button-dropdown .toggle-area {
    width: 100%;
    height: 100%;
    display: inline-block;
    position: absolute;
    top: 0;
    left: 0;
}
.button-dropdown .dropdown-list {
    width: calc(100% + 2px);
    margin: 0;
    padding: 9px 15px;
    background-color: var(--select-bg-color);
    border: 1px solid var(--theme-primary-color-3);
    opacity: 0;
    position: absolute;
    top: 100%;
    left: -1px;
    z-index: 1;
    transform: translateY(-15px);
    pointer-events: none;
    cursor: auto;
    transition: opacity .2s, transform .2s;
}
.button-dropdown.toggled .dropdown-list {
    opacity: 1;
    transform: translateY(0);
    pointer-events: all;
    transition: opacity .3s .1s, transform .3s;
}
.button-dropdown .dropdown-list li a {
    color: var(--font-body-color);
    font: var(--font-button);
    opacity: .75;
    text-transform: capitalize;
    text-decoration: none;
}
.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: var(--select-bg-color);
  border: 0.4px solid rgba(26, 70, 79,0.4);
  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 {
  width: 100%;
  position: relative;
  /*margin-top: 70px;*/
}

/* ACCESSIBILITY */
body.high-contrast .calview .grid-layout svg path {
    stroke: var(--font-body-color);
}
body.high-contrast .calview .list-layout svg path {
    fill: var(--font-body-color);
}

@media only screen and (max-width: 1030px) {
	.calendar .current-filters .calview {
		min-width: unset;
	}
	.calendar .current-filters .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;
	}
}

@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: var(--theme-secondary-color-3);
    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) {
  .calendar-region {
    --font-event-list-month: normal 400 15px/20px "Sarabun", sans-serif;
    --font-event-list-day: normal 400 20px/26px "Libre Baskerville", serif;
  }
  .main-content.calendar {
    width: 100%;
    margin: auto;
  }
  .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;
    order: 0;
  }
  .calendar .calendar-title h2 {
	font-size: 18px;
  }
  .discover-filters .current-filters {
    background-color: transparent;
    border: none;
  }
  .discover-filters.expanded .expandable-section {
    display: none;
  }
  .event-filters-wrap {
    width: auto;
    order: 1;
    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 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 .calendar-weekdays {
	display: none;
  }
  .calendar .calendar-dates {
    padding: 0;
  }
  .calendar-dates .calendar-day {
	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 .calendar-day-date p {
	width: 100%;
	height: auto;
    font-size: 13px;
    line-height: 18px;
    text-align: center;
  }
  .calendar-day .calendar-day-date {
    background-color: var(--calendar-border-color);
    padding: 4px;
    top: 0;
    left: auto;
    right: 0;
    transition: background-color .3s, color .3s;
  }
  .calendar-day.active-day .calendar-day-date {
    background-color: var(--button-bg-color);
    color: var(--font-button-color);
  }
  .calendar-day.today .calendar-day-date {
    left: 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%;
	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-details .about-content {
    background-color: transparent;
    border: none;
    padding: unset;
  }
  .list-event h3 {
    margin-top: 0;
  }
  .mobile-list-date {
    display: none;
    width: 100%;
    font-size: 18px;
    padding: 8px 0 8px 0;
    margin-bottom: 10px;
    position: relative;
    border-bottom: 1px solid #000000;
    font: var(--secondary-header-font);
  }
  .list-event:first-child .event-about .mobile-list-date {
    display: block;
    text-align: center;
    border: unset;
  }
  .list-event .event-details {
    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-details {
    padding: 30px;
	background-color: var(--body-bg-color);
    border: 1px solid var(--brand-border-color);
  }
  .list-event .event-details .event-description {
    margin-bottom: unset;
  }
  .list-event .event-details button, .list-event .event-details a.button-like {
    margin: 8px 0 0 0;
  }
  .grid-layout .list-event .event-details a.button-like {
    display: block;
    width: fit-content;
  }
  .calendar .calendar-dates-list.mobile-only h4 {
    display: none;
  }
  .calendar .current-filters .calview {
    display: none;
  }
  .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: var(--theme-primary-color-2);
	display: block;
	position: absolute;
	top: calc(50% - 5px);
	left: calc(50% - 5px);
	z-index: 50;
  }
  .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 .calendar-title {
	margin: 15px 0;
    padding: 0;
    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: var(--font-body-color);
	display: none;
	position: relative;
	left: -1px;
  }
  .calendar .calendar-dates-list.mobile-only .list-event:last-of-type:after {
	display: none;
  }
  .desktop-only {
	display: none;
  }
	
  .current-filters {
    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: var(--select-bg-color);
  }
  
  
  .list-event .event-details .list-date {
    display: none;
  }
  .list-event:first-child .event-about .list-date {
    /* display: flex; */
  }
  .list-event .event-details .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;
  }
  
  .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; 
  }
  .weekly-row td {
    background-color: var(--theme-secondary-color-4);
    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: 12px;
    font-weight: 400;
    border-bottom: none;
    color: var(--font-body-color);
    letter-spacing: 0;
  }
  .event-item .showtime {
    font-size: 12px;
  }
  .calendar-dates-list .list-event .list-date {
    width: 60px;
    height: 60px;
  }
  .list-event .list-details {
    padding: 20px;
    width: calc(100% - 90px);
    flex-direction: column;
  }
  .list-event .list-details .list-image {
    width: 100%;
    max-width: 400px;
  }
  .event-details {
    height: auto;
    width: 100%;
    margin: 0px 10px;
    z-index: 1;
  }
  .detailPop {
    display: none;
    height: 150px;
    width: 100px;
    background-color: white;
  }

  .current-filters {
    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-details .about-content {
        width: calc(100% - 10px);
    }
    .list-event .event-details .event-description {
        margin-bottom: unset;
    }
    .current-filters {
        padding-bottom: 5px;
    }
}