/* events.css — split from style.css; dead rules pruned. */

body.page-events {
  --accent-a: #8bd3ff;
  --accent-b: #6d7dff;
  --accent-c: #ff72ca;
}
.placeholder-caption {
  font-size: 0.82rem;
  color: var(--muted);
}
.split-layout {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 1.02rem;
}
.page-events .card h3 {
  line-height: 1.24;
}
.page-events .event-media-link {
  display: block;
  border-radius: 13px;
  overflow: hidden;
}
.page-events .story-link {
  color: #ecf4ff;
  text-decoration: none;
}
.page-events .story-link:hover, .page-events .story-link:focus {
  color: var(--accent-a);
  text-decoration: underline;
  text-underline-offset: 3px;
}
.page-events .story-cta {
  display: inline-block;
  margin-top: 0.7rem;
  align-self: flex-start;
  border-radius: 999px;
  padding: 0.45rem 0.85rem;
  font-size: 0.8rem;
  font-weight: 700;
  text-decoration: none;
  color: #041021;
  background: linear-gradient(90deg, var(--accent-a), var(--accent-b));
}
.page-events .page-hero {
  align-items: stretch;
}
.page-events .page-hero .image-placeholder--hero, .page-events .page-hero .real-image--hero, .page-events .page-hero .real-embed--hero {
  min-height: 0;
  aspect-ratio: 16 / 10;
  max-height: 420px;
  align-self: stretch;
  height: 100%;
}
.page-events .page-hero .real-image--hero, .page-events .placeholder-grid .real-image {
  object-fit: contain;
  background: rgba(7, 12, 24, 0.92);
}
.page-event-story .story-meta {
  margin-top: 0.55rem;
  color: var(--muted);
  font-size: 0.84rem;
  letter-spacing: 0.02em;
}
.page-event-story .page-hero .image-placeholder--hero, .page-event-story .page-hero .real-image--hero, .page-event-story .page-hero .real-embed--hero {
  aspect-ratio: 16 / 10;
  max-height: 420px;
}
.page-event-story .story-flow {
  display: grid;
  gap: 1rem;
}
.page-event-story .story-poster-row {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 1rem;
  align-items: start;
}
.page-event-story .story-group {
  display: grid;
  gap: 0.7rem;
}
.page-event-story .story-strip {
  display: grid;
  gap: 0.75rem;
}
.page-event-story .story-strip--three {
  grid-template-columns: repeat(3, minmax(0, 1fr));
}
.page-event-story .story-media-frame {
  appearance: none;
  border: 0;
  padding: 0;
  display: block;
  width: 100%;
  border-radius: 13px;
  overflow: hidden;
  background: rgba(7, 12, 24, 0.92);
  position: relative;
  isolation: isolate;
  text-align: left;
}
.page-event-story .story-media-frame .image-placeholder, .page-event-story .story-media-frame .real-image, .page-event-story .story-media-frame .real-embed {
  min-height: 0;
  margin: 0;
}
.page-event-story .story-media-frame .image-placeholder {
  min-height: 230px;
}
.page-event-story .story-media-frame .real-image {
  width: 100%;
  height: auto;
  max-height: 560px;
  object-fit: contain;
  transition: transform 0.5s cubic-bezier(0.2, 0.85, 0.32, 1), filter 0.5s ease;
  transform-origin: center;
  will-change: transform;
  cursor: zoom-in;
  background: rgba(7, 12, 24, 0.92);
}
.page-event-story .story-media-frame--wide .image-placeholder {
  min-height: 250px;
}
.page-event-story .story-media-frame--wide .real-image {
  max-height: 480px;
}
.page-event-story .story-media-frame--poster .image-placeholder {
  min-height: 360px;
}
.page-event-story .story-media-frame--poster .real-image {
  max-height: 760px;
}
.page-event-story .story-media-frame:hover .real-image, .page-event-story .story-media-frame:focus-visible .real-image, .page-event-story .card:focus-within .story-media-frame .real-image {
  transform: scale(1.08);
  filter: saturate(1.08) contrast(1.05);
}
.page-event-story .story-media-frame::after {
  content: "Zoom";
  position: absolute;
  right: 0.55rem;
  bottom: 0.55rem;
  font-size: 0.68rem;
  font-weight: 700;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: #d8ecff;
  background: rgba(4, 10, 20, 0.62);
  border: 1px solid rgba(130, 176, 255, 0.4);
  border-radius: 999px;
  padding: 0.18rem 0.45rem;
  pointer-events: none;
  opacity: 0.86;
}
.page-event-story .story-media-frame--scroll {
  max-height: 540px;
  overflow-y: auto;
}
.page-event-story .story-media-frame--scroll .real-image {
  max-height: none;
  cursor: default;
}
.page-event-story .story-media-frame--scroll:hover .real-image, .page-event-story .story-media-frame--scroll:focus-visible .real-image, .page-event-story .card:focus-within .story-media-frame--scroll .real-image {
  transform: none;
  filter: none;
}
.page-event-story .story-media-frame--scroll::after {
  content: "Scroll";
}
@media (hover: none) {
.page-event-story .story-media-frame:active .real-image {
    transform: scale(1.04);
  }
}
@media (prefers-reduced-motion: reduce) {
.page-event-story .story-media-frame .real-image {
    transition: none;
  }
}
.lightbox {
  position: fixed;
  inset: 0;
  z-index: 1200;
  background: rgba(3, 6, 14, 0.86);
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 2rem;
}
.lightbox[hidden] {
  display: none;
}
.lightbox-image {
  max-width: min(92vw, 1280px);
  max-height: 86vh;
  width: auto;
  height: auto;
  border-radius: 14px;
  border: 1px solid rgba(142, 184, 255, 0.5);
  box-shadow: 0 20px 60px rgba(2, 6, 18, 0.72);
  background: #050a16;
}
.lightbox-close {
  position: absolute;
  top: 1rem;
  right: 1rem;
  border: 1px solid rgba(130, 176, 255, 0.5);
  background: rgba(5, 10, 22, 0.8);
  color: #e6f2ff;
  border-radius: 999px;
  padding: 0.35rem 0.8rem;
  font: inherit;
  cursor: pointer;
}
.page-events .placeholder-grid .card {
  display: flex;
  flex-direction: column;
}
.page-events .placeholder-grid .image-placeholder, .page-events .placeholder-grid .real-image, .page-events .placeholder-grid .real-embed {
  min-height: 0;
  aspect-ratio: 16 / 10;
}
@media (max-width: 980px) {
.split-layout {
    grid-template-columns: 1fr;
  }
.page-event-story .story-strip--three, .page-event-story .story-poster-row {
    grid-template-columns: 1fr;
  }
.page-event-story .story-media-frame .real-image, .page-event-story .story-media-frame--poster .real-image, .page-event-story .story-media-frame--wide .real-image {
    max-height: none;
  }
}
