


/* sections */
.ocstreetcar-construction-sections {
  display: flex;
  background-color: #0069bc;
}
.ocstreetcar-construction-sections > div {
  flex: 1;
}
.ocstreetcar-construction-sections > div:first-child {
  padding-right: 10px;
}
.ocstreetcar-construction-sections > div:last-child {
  padding-left: 10px;
}
.ocstreetcar-construction-sections section {
  background-color: #fff;
  border-top: 8px solid #2ac5fe;
}
@media (max-width: 991px) {
  .ocstreetcar-construction-sections {
    display: block;
  }
  .ocstreetcar-construction-sections > div:first-child {
    padding-right: 0;
  }
  .ocstreetcar-construction-sections > div:last-child {
    padding-left: 0;
  }
}

/* map */
.ocstreetcar-construction-map__header-wrap {
  padding: 2.2em 1.8em 1.6em;
}
.ocstreetcar-construction-map__header-description {
  font-size: 0.9em;
  margin: 0.8em 0 0;
}
.ocstreetcar-construction-map__legend-wrap {
  background: #ebeff2;
  padding: 1.3em 2em .7em;
}
.ocstreetcar-construction-map__legend {
  list-style: none;
  padding: 0;
  margin: 0;
}
.ocstreetcar-construction-map__legend-icon {
  margin-left: .3em;
  margin-right: 0.8em;
}
.ocstreetcar-construction-map__legend-icon--wide {
  margin-left: 0;
  margin-right: .4em;
}
.ocstreetcar-construction-map__legend-item {
  display: block;
  font-size: .9em;
  margin-right: 2.4em;
  margin-bottom: .6em;
}
.ocstreetcar-construction-map__map-wrap {
  overflow:hidden;
}
.ocstreetcar-construction-map__map {
  height: 500px;
  margin-top: -60px;
  margin-bottom: -4px;
  width: 100%;
  background: #ffffff;
}
@media (min-width: 768px) {
  .ocstreetcar-construction-map__header-description {
    line-height: 2;
    font-size: 0.9em;
    margin: 1em 0 0;
  }
  .ocstreetcar-construction-map__legend-icon {
    margin-left: 0;
    margin-right: .4em;
  }
  .ocstreetcar-construction-map__legend-icon--wide {
    margin-right: .4em;
  }
  .ocstreetcar-construction-map__legend-item {
    display: inline-block;
    font-size: .9em;
    margin-right: 2.4em;
    margin-bottom: .6em;
  }
}

/* tweets */
.twitter-timeline iframe {
    max-width: 100%;
}
.ocstreetcar-construction-tweets {
  padding: 60px;
}
.ocstreetcar-construction-tweets h2 {
  margin: 0;
  margin-bottom: 40px;
}
@media (max-width: 600px) {
  .ocstreetcar-construction-tweets {
    padding: 40px 15px;
    text-align: center;
  }
}

/* milestones */
.ocstreetcar-construction-milestones {
  padding: 60px;
  background-color: #f9fafc;
}
.ocstreetcar-construction-milestones h2 {
  margin: 0;
  margin-bottom: 30px;
}
.ocstreetcar-construction-milestones__timeline {
  padding-top: 20px;
  text-align: left;
}
.ocstreetcar-construction-milestones__timeline-row {
  display: flex;
  margin-top: 15px;
  border-bottom: 1px solid #ccc;
  padding-bottom: 15px;
}
.ocstreetcar-construction-milestones__timeline-row:last-child {
  border-bottom: 0;
  padding-bottom: 0;
}
.ocstreetcar-construction-milestones__timeline-row > div {
  flex: 1 1 100%;
  display: flex;
  align-items: center;
  justify-content: flex-start;
}
.ocstreetcar-construction-milestones__timeline-row > div:first-child {
  flex: 1 0 80px;
}
.ocstreetcar-construction-milestones__timeline-image {
  background-color: #0D8AE7;
  margin-right: 10px;
  padding: 10px;
  border-radius: 100%;
}
.ocstreetcar-construction-milestones__timeline-image img {
  width: 30px;
  height: 30px;
}
.ocstreetcar-construction-milestones__timeline-row p {
  margin: 0;
  font-size: 22px;
  white-space: normal;
}
@media (max-width: 991px) {
    .ocstreetcar-construction-milestones {
        margin-top: 20px;
    }

}
@media (max-width: 600px) {
  .ocstreetcar-construction-milestones {
    padding: 40px 15px;
    text-align: center;
  }
  .ocstreetcar-construction-milestones__timeline-row p {
    font-size: 18px;
  }
}


/* milestones mobile */
.ocstreetcar-construction-milestones__mobile {
  display: none;
}
@media (max-width: 991px) {
  .ocstreetcar-construction-milestones__mobile {
    display: block;
  }
}
@media (max-width: 991px) {
  .ocstreetcar-construction-milestones__desktop {
    display: none;
  }
}


/* notices */
.ocstreetcar-construction-notices {
  height: 100%;
  padding: 60px;
  background-color: #f9fafc;
}
.ocstreetcar-construction-notices h2 {
  margin: 0;
  margin-bottom: 40px;
}
.ocstreetcar-construction-notices h3 {
  margin: 0;
  font-size: 22px;
  font-weight: bold;
}
.ocstreetcar-construction-notices__notice {
  background-color: #fff;
  border: solid 1px #cad8e1;
  border-radius: 8px;
  display: flex;
  align-items: center;
}
.ocstreetcar-construction-notices__notice > div {
  flex: 1 1 65%;
  padding: 20px;
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  justify-content: flex-end;
}
.ocstreetcar-construction-notices__notice > div:last-child {
  flex: 1 1 35%;
  align-items: center;
  border-left: solid 1px #cad8e1;
}
.ocstreetcar-construction-notices__notice h4 {
  margin: 0;
  margin-bottom: 15px;
  font-size: 14px;
  font-weight: bold;
  text-transform: uppercase;
}
.ocstreetcar-construction-notices__notice p {
  margin: 0;
  font-size: 18px;
}
.ocstreetcar-construction-notices__notice strong {
  color: #0069bc;
}
.ocstreetcar-construction-notices__notice i {
  display: block;
  font-size: 35px;
  margin-bottom: 10px;
}
.ocstreetcar-construction-notices__notice a {
  font-size: 16px;
  font-weight: bold;
  color: #0069bc;
  text-decoration: underline;
  white-space: nowrap;
}
.ocstreetcar-construction-notices__types > div {
  margin-top: 60px;
  text-align: left;
}
@media (max-width: 1200px) {
  .ocstreetcar-construction-notices__notice p {
    font-size: 14px;
  }
  .ocstreetcar-construction-notices__notice a {
    font-size: 14px;
  }
}
@media (max-width: 991px) {
  .ocstreetcar-construction-notices {
    margin-top: 20px;
  }
}
@media (max-width: 600px) {
  .ocstreetcar-construction-notices {
    padding: 40px 15px;
    text-align: center;
  }
  .ocstreetcar-construction-notices__notice > div {
    align-items: center;
  }
  .ocstreetcar-construction-notices__notice > div:last-child {
    border-top: solid 1px #cad8e1;
    border-left: 0;
  }
  .ocstreetcar-construction-notices__notice {
    display: block;
  }
  .ocstreetcar-construction-notices__types > div {
    margin-top: 40px;
  }
  .ocstreetcar-construction-notices__types p {
    margin-bottom: 0;
  }
}



/* schedule */
.ocstreetcar-construction-schedule {
  padding-top: 60px;
}
.ocstreetcar-construction-schedule h2 {
  margin: 0;
  margin-bottom: 60px;
  text-align: center;
}
.ocstreetcar-construction-schedule__table {
  height: 100%;
}
.ocstreetcar-construction-schedule__table thead {
  height: 100%;
}
.ocstreetcar-construction-schedule__table thead th {
  position: relative;
  background-color: #015ea7;
  color: #fff;
  font-weight: bold;
}
.ocstreetcar-construction-schedule__table tr {
  height: 100%;
}
.ocstreetcar-construction-schedule__table th,
.ocstreetcar-construction-schedule__table td {
  height: 100%;
  border: 1px solid #72b2e5;
  font-size: 20px;
}
.ocstreetcar-construction-schedule__table tbody th {
  background-color: #f3f5f8;
}
.ocstreetcar-construction-schedule__table th:first-child {
  padding: 15px;
}
.ocstreetcar-construction-schedule__table thead tr:first-child th {
  padding: 0;
}
.ocstreetcar-construction-schedule__table thead tr:first-child th:first-child {
  border: 0;
}
.ocstreetcar-construction-schedule__table th:first-child {
  width: 400px;
}
.ocstreetcar-construction-schedule__table-mobile-nav {
  display: none;
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
}
.ocstreetcar-construction-schedule__table-mobile-nav a {
  position: absolute;
  top: 10px;
  color: #fff;
}
.ocstreetcar-construction-schedule__table-mobile-nav a.disabled {
  opacity: .5;
}
.ocstreetcar-construction-schedule__table-mobile-nav .prev {
  left: 10px;
}
.ocstreetcar-construction-schedule__table-mobile-nav .next {
  right: 10px;
}
.ocstreetcar-construction-schedule__table-header {
  display: flex;
  flex-direction: column;
  height: 100%;
}
.ocstreetcar-construction-schedule__table-header > div {
  display: flex;
  align-items: center;
  justify-content: center;
}
.ocstreetcar-construction-schedule__table-header > div:first-child {
  flex: 1;
  padding: 10px;
  border-left: 1px solid #72b2e5;
  border-top: 1px solid #72b2e5;
  border-bottom: 1px solid #72b2e5;
}
.ocstreetcar-construction-schedule__table-header.corner > div:first-child {
  background-color: #fff;
  border: 0;
}
.ocstreetcar-construction-schedule__table-header.corner > div:last-child {
  border-left: 1px solid #72b2e5;
  border-top: 1px solid #72b2e5;
}
.ocstreetcar-construction-schedule__table-header.corner .ocstreetcar-construction-schedule__table-quarter {
  border: 0;
  padding: 10px 15px;
}
.ocstreetcar-construction-schedule__table-year {
  flex: 0 0 40px;
  overflow: hidden;
}
.ocstreetcar-construction-schedule__table-quarter {
  flex: 1;
  border-left: 1px solid #72b2e5;
  padding: 10px;
  font-size: 16px;
}
.ocstreetcar-construction-schedule__table-cols {
  display: flex;
  height: 100%;
}
.ocstreetcar-construction-schedule__table-row {
  position: relative;
  flex: 1;
  border-left: 1px solid #72b2e5;
}
.ocstreetcar-construction-schedule__table-color {
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  height: 20px;
  left: -1px;
  right: -1px;
}
.ocstreetcar-construction-schedule__table-color.purple {
  background-color: #8176b9;
}
.ocstreetcar-construction-schedule__table-color.dark-blue {
  background-color: #346188;
}
.ocstreetcar-construction-schedule__table-color.blue {
  background-color: #52a2e6;
}
.ocstreetcar-construction-schedule__table-color.green {
  background-color: #83dba2;
}
.ocstreetcar-construction-schedule__table-color.yellow {
  background-color: #f6eb75;
}
.ocstreetcar-construction-schedule__table-color.light-orange {
  background-color: #f4b458;
}
.ocstreetcar-construction-schedule__table-color.orange {
  background-color: #f9856c;
}
@media (max-width: 1024px) {
  .ocstreetcar-construction-schedule__table-mobile-nav {
    display: block;
  }
  .ocstreetcar-construction-schedule__table .data-cell {
    display: none;
  }
  .ocstreetcar-construction-schedule__table .data-cell.active {
    display: table-cell;
  }
}
@media (max-width: 600px) {
  .ocstreetcar-construction-schedule h2 {
    margin-bottom: 30px;
  }
  .ocstreetcar-construction-schedule__table th:first-child {
    padding: 5px;
  }
  .ocstreetcar-construction-schedule__table-header.corner .ocstreetcar-construction-schedule__table-quarter {
    padding: 5px;
  }
  .ocstreetcar-construction-schedule__table th,
  .ocstreetcar-construction-schedule__table td {
    font-size: 16px;
  }
  .ocstreetcar-construction-schedule__table-quarter {
    font-size: 14px;
  }
  .ocstreetcar-construction-schedule__table-color {
    height: 10px;
  }
}

/* youtube */
.ocstreetcar-overview-youtube {
    text-align: center;
    padding: 0 61px 50px;
}

.ocstreetcar-overview-youtube__video {
    position: relative;
    padding-bottom: 54.25%; /* 16:9 */
    padding-top: 25px;
    height: 0;
}

    .ocstreetcar-overview-youtube__video iframe {
        position: absolute;
        top: 0;
        left: 0;
        width: 100%;
        height: 100%;
    }

@media (max-width: 600px) {
    .ocstreetcar-overview-youtube {
        padding: 0;
        padding-bottom: 15px;
    }
}

/* contact */
.ocstreetcar-construction-contact {
  background-color: #015ea7;
  text-align: center;
  padding: 70px;
}
.ocstreetcar-construction-contact h2 {
  color: #fff;
  margin: 0;
  margin-bottom: 60px;
}
.ocstreetcar-construction-contact__types {
  display: flex;
}
.ocstreetcar-construction-contact__type {
  display: block;
  flex: 1;
  padding: 20px;
}
.ocstreetcar-construction-contact__type img {
  width: 100px;
  height: 100px;
  margin-bottom: 10px;
}
.ocstreetcar-construction-contact__type p {
  color: #fff;
  white-space: nowrap;
  font-size: 16px;
  font-weight: bold;
}
.ocstreetcar-construction-contact__type em {
  color: #7ccbff;
  font-style: normal;
}
@media (max-width: 1200px) {
  .ocstreetcar-construction-contact {
    padding: 70px 0;
  }
}
@media (max-width: 991px) {
  .ocstreetcar-construction-contact__types {
    flex-wrap: wrap;
  }
  .ocstreetcar-construction-contact__type {
    flex: 1 1 32%;
  }
}
@media (max-width: 600px) {
  .ocstreetcar-construction-contact {
    margin-left: -15px;
    margin-right: -15px;
    padding: 30px 0;
  }
  .ocstreetcar-construction-contact h2 {
    margin-bottom: 30px;
  }
  .ocstreetcar-construction-contact__type {
    flex: 1 1 100%;
    padding: 0;
  }
  .ocstreetcar-construction-contact__type img {
    width: 60px;
    height: 60px;
    margin-bottom: 0;
  }
}



/* construction-gallery__items */
.construction-gallery {
  padding: 0;
}
.construction-gallery .slick-slide {
  height: auto;
}
.construction-gallery__heading {
  padding: 25px;
  font-size: 2em;
  font-weight: 600;
  color: #333333;
  text-align: center;
}
.construction-gallery__items {
  margin: 0 3.5em;
}
.construction-gallery__item {
}
.construction-gallery__item-image {
  height: 410px;
  background-repeat: no-repeat;
  background-size: cover;
  position: relative;
}
.construction-gallery__item-image:after {
  content: "";
  /* background-color: #fff; */
  border-radius: 50%;
  display: block;
  width: 2em;
  height: 2em;
  background: #fff url(/dist/images/standalone/streetcar/iconMagnifyingGlass.svg) center no-repeat;
  background-size: .9em .9em;
  position: absolute;
  bottom: .9em;
  right: .9em;
}
.construction-gallery__item-content-wrap {
  padding: .5em 0;
  width: 60%;
}
.construction-gallery__item-content {
  color: #2a2623;
  font-size: 0.88em;
  text-align: left;
  margin: .5em 0;
}
.construction-gallery__item-image {
  position: relative;
}
.construction-gallery__item-image-overlay {
  position: absolute;
  background-color: #000;
  width: 100%;
  height: 100%;
  opacity: 0;
  transition: opacity 0.25s ease;
}
.construction-gallery__item:focus,
.construction-gallery__item:hover {
  text-decoration: none;
}
.construction-gallery__item-image:focus > .construction-gallery__item-image-overlay,
.construction-gallery__item-image:hover > .construction-gallery__item-image-overlay {
  opacity: 0.2;
}
.construction-gallery__item-title {
  margin: 0;
  font-weight: bold;
  white-space: nowrap;
  text-align: left;
  text-decoration: none;
  color: #2a2623;
  font-size: 0.8em;
}
.construction-gallery__item-link {
  position: relative;
  color: #000;
  text-decoration: underline;
  margin-left: 30px;
}
.construction-gallery__item-link:before {
  content: '';
  position: absolute;
  height: 25px;
  width: 25px;
  background-image: url(/images/ocbusdriver/icon-play-video.svg);
  top: 50%;
  left: -35px;
  transform: translateY(-50%);
}
.construction-gallery__arrow {
  overflow: visible;
  cursor: pointer;
  background: transparent;
  border: 0;
  display: block;
  outline: none;
  padding: 0;
  z-index: 1046;
  box-shadow: none;
  position: absolute;
  margin: 0;
  top: 50%;
  margin-top: 0;
  padding: 0;
  width: 54px;
  height: 54px;
}
.construction-gallery__arrow.slick-arrow-right {
  right: 5px;
}
.construction-gallery__arrow.slick-arrow-left {
  left: 30px;
}

construction-gallery__arrow:before {
  display: block;
  margin-left: 39px;
  width: 37px !important;
  height: 37px !important;
  position: absolute;
  left: 0;
  margin-top: -55px;
  margin-left: 0 !important;
  border-radius: 50%;
  border: 3px solid #fff;
  background-color: #fff;
  /* background-image: url(/images/constructionGallery/iconArrowRight.svg); */
}
@media (min-width: 1380px) {
  .construction-gallery__arrow:before {
    width: 54px !important;
    height: 54px !important;
  }
}
.construction-gallery .slick-slide {
  width: 200px;
  margin: 1.5px;
  text-align: center;
}
.construction-gallery .slick-prev {
  left: -30px;
}
.construction-gallery .slick-arrow {
  z-index: 1;
}
.construction-gallery .slick-arrow:before,
.slick-arrow:before {
  content: "";
  font-size: 25px;
  width: 54px;
  height: 54px;
  margin-top: -55px;
  background-color: #fff;
  border-radius: 50%;
  border: 3px solid #fff;
  display: block;
}
.construction-gallery .slick-next:before,
.construction-gallery__arrow.slick-arrow-right:before {
  margin-left: 4px;
  background-image: url(/dist/images/standalone/streetcar/iconArrowRight.svg);
}
.construction-gallery .slick-prev:before,
.construction-gallery__arrow.slick-arrow-left:before {
  margin-left: -1.2em;
  background-image: url(/dist/images/standalone/streetcar/iconArrowLeft.svg);
}
.construction-gallery .slick-disabled:before {
  opacity: 1;
}
.construction-gallery .slick-prev.slick-disabled:before {
  background-image: url(/dist/images/standalone/streetcar/iconArrowLeftDisabled.svg);
}
.construction-gallery .slick-next.slick-disabled:before {
  background-image: url(/dist/images/standalone/streetcar/iconArrowRightDisabled.svg);
}
@media (max-width: 600px) {
  .construction-gallery .slick-next:before {
    margin-left: -1.6em;
  }
  .construction-gallery .slick-prev:before {
    margin-left: 0.5em;
  }
  .construction-gallery {
      padding: 0;
  }
  .construction-gallery__heading {
      font-size: 26px;
  }
  .construction-gallery__items {
      margin: 0 25px;
  }
  .construction-gallery .slick-slide {
      margin: 10px;
  }
  .construction-gallery .slick-dots li button::before {
      color: #6eace0;
      font-size: 10px;
  }
}


.mfp-bg.mfp-ready {
  opacity: 1;
}
.mfp-figure:after {
  box-shadow: none;
}
.mfp-container {
  background-color: #000;
}
.mfp-counter,
.mfp-title {
  color: #2a2623;
  font-size: 1em;
  top: 1em;
}
.mfp-title {
  position: absolute;
  left: 1em;
  max-width: 75%;
}
.mfp-figure {
  background-color: #fff;
}
img.mfp-img {
  background-image: linear-gradient(#000 50%, #fff 50%);
  padding: 50px 0 60px;
}
.mfp-image-holder .mfp-close {
  top: 10px;
}
.mfp-counter {
  right: 1em;
}
.mfp-counter:before {
  font-family: 'Font Awesome 6 Free';
  font-weight: 900;  
  content: "\f030";
  display: inline-block;
  margin-right: 0.5em;
  color: #C3C3C3;
}
.mfp-close {
  color: #000 !important;
  opacity: 1;
}
.mfp-close:before {
  content: "";
  margin-bottom: 1em;
  width: 39px;
  height: 39px;
  position: absolute;
  top: -3px;
  right: 3px;
  display: block;
  background-color: #fff;
  border-radius: 50%;
  opacity: 1;
  cursor: pointer;
}
.mfp-close:after {
  font-family: 'Font Awesome 6 Free';
  font-weight: 900;  
  content: "\f00d";
  color: #000;
  text-align: center;
  position: absolute;
  top: -6px;
  right: 13px;
  display: block;
  opacity: 1;
  cursor: pointer;
}
.mfp-bottom-bar {
  margin-top: -65px;
}