/* Custom interaction fixes for local static build */

/* Speaker card hover/focus reveal */
.speaker-card .speaker-card_shapes,
.speaker-card .speaker-card_shapes-img {
  transition: transform 300ms ease, opacity 300ms ease;
  will-change: transform, opacity;
}

.speaker-card .speaker-card_shapes {
  opacity: 0;
  transform: translate3d(0, 10%, 0);
}

.speaker-card:hover .speaker-card_shapes,
.speaker-card.is-hover .speaker-card_shapes,
.speaker-card:focus-within .speaker-card_shapes {
  opacity: 1 !important;
  transform: translate3d(0, 0, 0) !important;
}

.speaker-card .speaker-card_shapes.first {
  transition-delay: 0ms;
}

.speaker-card .speaker-card_shapes.second {
  transition-delay: 60ms;
}

.speaker-card .speaker-card_shapes.third {
  transition-delay: 120ms;
}

.speaker-card .speaker-card_shapes-img.w-condition-invisible {
  display: none !important;
}

.speaker-card:hover .speaker-card_shapes-img.w-condition-invisible,
.speaker-card.is-hover .speaker-card_shapes-img.w-condition-invisible,
.speaker-card:focus-within .speaker-card_shapes-img.w-condition-invisible {
  display: block !important;
}

.speaker-card .speaker-card_photo-img {
  transition: transform 300ms ease;
}

.speaker-card:hover .speaker-card_photo-img,
.speaker-card.is-hover .speaker-card_photo-img,
.speaker-card:focus-within .speaker-card_photo-img {
  transform: translate3d(0, -2%, 0) scale(1.02);
}

/* FAQ accordion */
.accordion-item .accordion-content {
  display: block !important;
  overflow: hidden;
  height: 0;
  transition: height 300ms ease;
}

.accordion-item.is-open .accordion-content {
  height: var(--accordion-content-height, auto);
}

.accordion-item .accordion-icon_left,
.accordion-item .accordion-icon_right {
  transition: transform 200ms ease;
}

.accordion-item.is-open .accordion-icon_left {
  transform: rotate(-45deg) !important;
}

.accordion-item.is-open .accordion-icon_right {
  transform: rotate(45deg) !important;
}

/* Homepage - full-width city banner, sits above the hero (ICPS 2024 style) */
.city-banner {
  position: relative;
  width: 100%;
  height: 420px;
  overflow: hidden;
}

.city-banner_img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}

.city-banner_overlay {
  position: absolute;
  inset: 0;
  background: linear-gradient(180deg, rgba(10, 4, 122, 0.1) 0%, rgba(10, 4, 122, 0.85) 100%);
}

.city-banner_caption {
  position: absolute;
  left: 0;
  right: 0;
  bottom: 22px;
  margin: 0;
  text-align: center;
  font-family: 'Roboto Mono', monospace;
  font-size: 13px;
  font-weight: 600;
  letter-spacing: 1px;
  text-transform: uppercase;
  color: rgba(255, 255, 255, 0.92);
}

@media screen and (max-width: 767px) {
  .city-banner {
    height: 240px;
  }

  .city-banner_caption {
    font-size: 11px;
    bottom: 14px;
  }
}

/* Venue page */
.venue-intro p {
  margin-bottom: 16px;
}

.venue-gallery {
  overflow: hidden;
  margin: 32px 0;
  -webkit-mask-image: linear-gradient(90deg, transparent, #000 5%, #000 95%, transparent);
  mask-image: linear-gradient(90deg, transparent, #000 5%, #000 95%, transparent);
}

.venue-gallery_track {
  display: flex;
  gap: 16px;
  width: max-content;
  animation: venue-gallery-scroll 32s linear infinite;
}

.venue-gallery:hover .venue-gallery_track {
  animation-play-state: paused;
}

.venue-gallery_img {
  width: 360px;
  height: 260px;
  object-fit: cover;
  border-radius: 8px;
  flex-shrink: 0;
}

@keyframes venue-gallery-scroll {
  from {
    transform: translateX(0);
  }
  to {
    transform: translateX(-50%);
  }
}

@media screen and (max-width: 767px) {
  .venue-gallery_img {
    width: 260px;
    height: 200px;
  }

  .venue-gallery_track {
    animation-duration: 22s;
  }
}

/* Venue - How to Get Here (PLANCKS-style) */
.venue-directions {
  background-color: #f3eafb;
  padding: 64px 0;
  text-align: center;
  border-radius: 16px;
  margin: 48px 0;
}

.venue-directions_title {
  margin-bottom: 16px;
}

.venue-directions_text {
  max-width: 720px;
  margin: 0 auto 32px;
}

.venue-directions_links {
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 40px;
  flex-wrap: wrap;
}

.venue-directions_link {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  color: #e8447a;
  font-weight: 600;
  text-decoration: none;
  transition: opacity 200ms ease;
}

.venue-directions_link:hover {
  opacity: 0.75;
}

.venue-directions_icon {
  display: inline-flex;
  align-items: center;
}

/* Venue - Getting to Rabat (Transport / Mobile / Apps) */
.venue-travel_intro {
  max-width: 720px;
  margin: 0 0 32px;
}

.venue-travel_grid {
  margin-top: 8px;
}

.venue-travel_card {
  background-color: #fafafa;
  border: 1px solid #ececec;
  border-radius: 12px;
  padding: 28px;
  height: 100%;
}

.venue-travel_card-title {
  margin-bottom: 14px;
}

.venue-travel_card p {
  margin-bottom: 12px;
  font-size: 15px;
  line-height: 1.5;
}

.venue-travel_card p:last-child {
  margin-bottom: 0;
}

@media screen and (max-width: 767px) {
  .venue-travel_card {
    padding: 20px;
  }
}
