/*--------------------------------------------------
Component – Copy Text Button
--------------------------------------------------*/
.copy_text_btn {
  display: block;
  margin: var(--space-sm) auto;
  border-radius: var(--space-xs);
  background-color: #fff;
  border: 1px solid var(--gray-2);
  padding: var(--space-sm) 1em;
  position: relative;
  cursor: pointer;
  transition: var(--transition);
}

.copied_text {
  font-size: .9em;
  position: absolute;
  right: -4em;
  top: 50%;
  -webkit-transform: translateY(-50%);
  -moz-transform: translateY(-50%);
  -ms-transform: translateY(-50%);
  -o-transform: translateY(-50%);
  transform: translateY(-50%);
  color: var(gray-8);
}

.copy_text_btn:is(:hover, :active) {
  background-color: var(--gray-1);
  box-shadow: none;
}

/*--------------------------------------------------
Component – Accordion New
--------------------------------------------------*/
._accordion {
  margin-bottom: var(--space-md);
}

/* Accordion header
------------------------------*/
._accordion header {
  position: relative;
}

._accordion header .title {
  width: min(100%, 90%)
}

._accordion .accordion_btn {
  position: absolute;
  height: 100%;
  width: 100%;
  top: 0;
  left: 0;
  background-color: var(--transparent);
  border: none;
  box-shadow: none;
  padding: 0;
  transition: var(--transition);
  cursor: pointer;
}

._accordion .panel {
  margin: -5px auto 0;
  opacity: 0;
  overflow: hidden;
  padding: 0 2.5%;
  height: 0;
  transition: var(--transition)
}

/* Accordion icon
------------------------------*/
._accordion .accordion_btn::before,
._accordion .accordion_btn::after {
  content: "";
  display: inline-block;
  width: 1.5em;
  height: .35em;
  background-color: var(--event-color-accent-light);
  position: absolute;
  right: 0;
  top: 1.8em;
  border-radius: var(--space-xxxs);
  transition: var(--transition)
}

._accordion .accordion_btn::before {
  transform: rotate(45deg);
  right: .885em
}

._accordion .accordion_btn::after {
  transform: rotate(-45deg)
}

/* Accordion Active
------------------------------*/
._accordion .accordion_content.active .panel {
  padding: 2.5%;
  opacity: 1;
  height: auto;
  position: relative;
}

._accordion .accordion_content.active .accordion_btn::before,
._accordion .accordion_content.active .accordion_btn::after {
  right: 10px
}

/*--------------------------------------------------
Timeline
--------------------------------------------------*/
.page-template-timeline .page_header_cnt {
  margin: 0;
}

.timeline {
  width: 100%;
  margin: 0 auto;
  position: relative;
}

.timeline_section::after {
  content: "";
  display: block;
  position: absolute;
  width: 5px;
  height: calc(100% - var(--space-xxxl));
  background-color: hsl(210, 40%, 50%);
  opacity: 0.125;
  top: var(--space-xxxl);
  left: 50%;
  -webkit-transform: translateX(-50%);
  -moz-transform: translateX(-50%);
  -ms-transform: translateX(-50%);
  -o-transform: translateX(-50%);
  transform: translateX(-50%);
  z-index: 0;
}

.timeline_section {
  margin: 0 auto;
  position: relative;
  padding-top: var(--space-xxl);
}

.timeline_section_title {
  text-align: center;
  margin: 0 auto var(--space-lg);
  font-weight: 900;
}

.timeline_block {
  width: 100%;
  position: relative;
  margin: 0 0 var(--space-xxl)
}

.timeline_block:last-child {
  margin-bottom: 0;
}

.timeline_section:last-child .timeline_block:last-child {
  margin-bottom: var(--space-xl);
}

.timeline_block:nth-child(odd) .timeline_text_container::before,
.timeline_block:nth-child(even) .timeline_text_container::before {
  content: "";
  position: absolute;
  top: 30px;
  width: 0;
  height: 0;
  border-top: 10px solid transparent;
  border-bottom: 10px solid transparent;
  transition: var(--transition);
}

.timeline_block:nth-child(odd) .timeline_text_container::before {
  right: -3.5%;
  border-left: 20px solid #fff;
}

.timeline_block:nth-child(even) .timeline_text_container::before {
  left: -3.5%;
  border-right: 20px solid #fff;
}

.timeline_text_container {
  background-color: #fff;
  width: 43.5%;
  box-shadow: var(--box-shadow);
  padding: 2% 3%;
  border-radius: var(--box-border-rad);
  position: relative;
  will-change: transform;
  z-index: 1;
  text-decoration: none;
  transition: var(--transition);
}

.timeline_block:nth-child(2n) {
  -webkit-flex-direction: row-reverse;
  -ms-flex-direction: row-reverse;
  flex-direction: row-reverse;
}

.timeline_time {
  position: absolute;
  left: 130%;
  top: 22px;
  width: 100%;
  font-size: var(--text-md);
  opacity: 0.8;
  font-weight: 600;
  color: var(--color-body-text);
}

.timeline_block:nth-child(2n) .timeline_time {
  left: -130%;
  text-align: right;
}

.timeline_event_hd {
  font-weight: 900;
  margin: 0 auto var(--space-xxs);
  text-wrap: balance;
}

.timeline_event_sub {
  margin: 0 0 var(--space-sm);
  font-weight: 400;
  color: var(--color-primary-light);
}

.timeline_info h3 {
  font-weight: 900;
  font-size: var(--text-md);
  margin: var(--space-md) 0 var(--space-xs)
}

.timeline_info h4 {
  margin: 1em 0 0.125em;
}

.timeline_info:empty,
.timeline_event_sub:empty {
  display: none;
}

/* Timeline Details Container
------------------------------*/
.timeline_info p {
  margin: 0 auto 0.25em;
  color: var(--gray-8);
  font-size: 1em;
}

/* Timeline Image
------------------------------*/
.timeline_img {
  width: 5em;
  height: 5em;
  border-radius: 100%;
  position: absolute;
  left: 50%;
  -webkit-transform: translateX(-50%);
  -moz-transform: translateX(-50%);
  -ms-transform: translateX(-50%);
  -o-transform: translateX(-50%);
  transform: translateX(-50%);
  box-shadow: 0 0 0 4px #fff, inset 0 2px 0 rgba(0, 0, 0, 0.08),
    0 3px 0 4px rgba(0, 0, 0, 0.05);
  z-index: 1;
  opacity: 0.9;
  will-change: transform;
}

.timeline_img img {
  border-radius: 100%;
}

.timeline_img_hidden,
.timeline_content_hidden {
  opacity: 0;
}

.timeline_img_bounce {
  -webkit-animation: img_bounce 1s;
  -moz-animation: img_bounce 1s;
  -o-animation: img_bounce 1s;
  animation: img_bounce 1s;
}

.timeline_content_bounce {
  -webkit-animation: content_bounce 1s;
  -moz-animation: content_bounce 1s;
  -o-animation: content_bounce 1s;
  animation: content_bounce 1s;
}

/* Timeline Transitions
------------------------------*/

/* timeline block animations */
@keyframes img_bounce {
  0% {
    opacity: 0
  }

  60% {
    opacity: 1
  }
}

@keyframes content_bounce {
  0% {
    opacity: 0;
    -webkit-transform: translateY(10px);
    -ms-transform: translateY(10px);
    transform: translateY(10px);
  }

  60% {
    opacity: 1;
    -webkit-transform: translateY(-10px);
    -ms-transform: translateY(-10px);
    transform: translateY(-10px);
  }

  100% {
    -webkit-transform: translateY(0);
    -ms-transform: translateY(0);
    transform: translateY(0);
  }
}

/* timeline nav
------------------------------*/
.timeline_nav {
  --grid-space: var(--space-sm);
  position: sticky;
  position: -webkit-sticky;
  top: var(--space-md);
  margin: -1em auto var(--space-xl);
  background-color: var(--color-accent-lighter);
  border-radius: var(--space-xl);
  z-index: 9999;
  box-shadow: var(--box-shadow);
}

.timeline_nav > .row {
  -webkit-justify-content: space-evenly;
  -ms-justify-content: space-evenly;
  justify-content: space-evenly;
}

.timeline_nav ul li.col {
  padding-top: 0;
  padding-bottom: 0;
}

.timeline_nav ul a {
  text-decoration: none;
  text-align: center;
  display: block;
  padding: var(--space-sm);
  color: var(--gray-10);
  border-radius: var(--space-xl);
  font-weight: 600;
  cursor: pointer;
}

.timeline_nav ul a:is(:hover) {
  background-color: var(--color-accent);
}

/* timeline top buttons
------------------------------*/
ul.timeline_top_btns {
  position: absolute;
  z-index: 1;
  right: 0;
  top: 0;
  width: min(100%, 20em);
  --grid-space: var(--space-xs)
}

ul.timeline_top_btns .btn {
  margin: 0;
}


@media only screen and (max-width: 980px) {

  /*-----------------------
    Timeline
    -----------------------*/
  .page-template-program-page #back-to-top {
    display: none !important;
  }

  .timeline_section {
    margin: 0 auto var(--space-xl);
  }

  .timeline_section::after {
    top: 15em;
    height: calc(100% - 15em);
  }

  /* extra top padding for anchor button */
  .timeline_section_title {
    padding-top: var(--space-lg);
  }

  .timeline .timeline_section:first-of-type .timeline_section_title {
    padding-top: 0;
  }
}