/* =================================================================
   Event Highlights � CSS Grid + tile styles
   Always 4 tiles: 1 major (bg-image) + 3 minor (blue cards)
   Uses theme preset variables for fonts, gaps, and colors.
   ================================================================= */

/* -- block wrapper --------------------------------------------- */
.event-highlights {
  padding-top:calc(var( --wdg-gap-block) + var(--wdg-gap-xsmall));
  padding-bottom: var(--wdg-gap-large);
  padding-left:0;
  padding-right:0;
  overflow: visible;
  max-width: 1500px;
  margin-right: auto;
  margin-left: auto;
}

/* -- section header -------------------------------------------- */
.event-highlights .event-highlights__header {
  margin-top:0;
}
.event-highlights .event-highlights__section-title {
  margin: 0;
  font-size: var(--wdg-font-size-h1-large);
  font-weight: var(--wdg-font-heading-weight, 700);
  line-height: var(--wdg-font-heading-line-height, 1.2);
  color: inherit;
}

/* -- grid container -------------------------------------------- */
.event-highlights .event-highlights__grid {
  display: grid !important;
  grid-template-columns: 1fr;
  gap: var(--wdg-gap-xsmall);
  padding: 0 var(--wdg-gap-xxsmall) var(--wdg-gap-xxsmall);
  margin-block-start: var( --wdg-gap-large );
}

.event-highlights .event-highlights__sidebar {
  display: contents !important;
}

/* -- empty state ----------------------------------------------- */
.event-highlights .event-highlights__empty {
  border: 1px dashed var(--wdg-color-tonal-black-20, #ccc);
  padding: var(--wdg-gap-xxsmall) var(--wdg-gap-xsmall);
  color: var(--wdg-color-text, #333);
}

/* =================================================================
   MAJOR TILE � full-bleed bg-image, left-to-right overlay
   Text vertically centered, confined to left 50%
   ================================================================= */

.event-highlights .event-highlights__major {
  position: relative;
  display: flex;
  align-items: center;
  border-radius: 14px;
  overflow: hidden;
  background-size: cover;
  background-position: center;
  color: var(--wdg-color-white, #fff) !important;
  text-decoration: none;
  z-index: 0;
  min-height: 50vh;
}

/* image zoom layer */
.event-highlights .event-highlights__major::before {
  content: "";
  position: absolute;
  inset: 0;
  border-radius: inherit;
  background: inherit;
  background-size: cover;
  background-position: center;
  transition: transform 0.5s cubic-bezier(0.25, 0.8, 0.25, 1);
  z-index: 0;
}
.event-highlights .event-highlights__major:hover::before {
  transform: scale(1.06);
}

/* left-to-right gradient overlay (primary) + hover inset border */
.event-highlights .event-highlights__major::after {
  content: "";
  position: absolute;
  inset: 0;
  border-radius: inherit;
  background: linear-gradient( to right, var(--wdg-color-primary, #0032a0) 0%, var(--wdg-color-primary-70) 32%, var(--wdg-color-primary-5) 68% );
  z-index: 1;
  pointer-events: none;
  transition: box-shadow 0.2s ease;
}
.event-highlights .event-highlights__major:hover::after {
  box-shadow: inset 0 0 0 5px var(--wdg-color-secondary, #02a7de);
}

/* content: vertically centered, left 50% */
.event-highlights .event-highlights__major-content {
  position: relative;
  z-index: 3;
  width: 50%;
  padding: var(--wdg-gap-large);
  box-sizing: border-box;
  color: var(--wdg-color-white, #fff);
}

.event-highlights .event-highlights__major-title {
  margin: 0 0 0.5em;
  font-size: var(--wdg-font-size-h2);
  font-weight: var(--wdg-font-heading-weight, 700);
  line-height: var(--wdg-font-heading-line-height, 1.2);
  color: var(--wdg-color-white, #fff);
}

.event-highlights .event-highlights__major-excerpt {
  margin: 0 0 1em;
  font-size: var(--wdg-font-size-default);
  line-height: var(--wdg-font-line-height, 1.5);
  opacity: 0.92;
  color: var(--wdg-color-white, #fff);
}

.event-highlights .event-highlights__major-meta {
  margin-bottom: 0.8em;
  font-size: var(--wdg-font-size-default);
  line-height: 1.6;
  color: var(--wdg-color-white, #fff);
}
.event-highlights .event-highlights__major-date {
  font-weight: 700;
  font-size: var(--wdg-font-size-large);
}
.event-highlights .event-highlights__major-days,
.event-highlights .event-highlights__major-time {
  opacity: 0.88;
}

.event-highlights .event-highlights__major-location {
  font-size: var(--wdg-font-size-default);
  line-height: var(--wdg-font-line-height, 1.5);
  color: var(--wdg-color-white, #fff);
}
.event-highlights .event-highlights__major-location strong {
  display: block;
  font-size: var(--wdg-font-size-medium);
  font-weight: 700;
}
.event-highlights .event-highlights__major-location div {
  margin: 0;
  padding: 0;
  line-height: inherit;
}

/* =================================================================
   MINOR TILES � blue cards with prominent date
   ================================================================= */

.event-highlights .event-highlights__minor {
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  position: relative;
  background: var(--wdg-color-primary, #0032a0);
  color: var(--wdg-color-white, #fff) !important;
  border-radius: 12px;
  padding: var(--wdg-gap-small) var(--wdg-gap-xsmall);
  text-decoration: none;
  overflow: hidden;
  border: 5px solid transparent;
  transition: border-color 0.2s ease;
}

.event-highlights .event-highlights__minor:hover {
  border-color: var(--wdg-color-secondary, #02a7de);
  border-radius: 8px;
}

/* body: date block + info side-by-side */
.event-highlights .event-highlights__minor-body {
  display: flex;
  flex-direction: row;
  gap: var(--wdg-gap-xsmall);
  align-items: flex-start;
}

/* prominent date */
.event-highlights .event-highlights__minor-date {
  flex-shrink: 0;
  display: flex;
  flex-direction: column;
  line-height: 1;
}
.event-highlights .event-highlights__minor-day {
  font-size: var(--wdg-font-size-4xlarge);
  font-weight: 800;
  line-height: 1;
  color: var(--wdg-color-white, #fff);
}
.event-highlights .event-highlights__minor-month {
  font-size: var(--wdg-font-size-small);
  font-weight: 600;
  margin-top: 0.35em;
  text-transform: uppercase;
  letter-spacing: 0.03em;
  text-align: center;
  color: var(--wdg-color-white, #fff);
}
.event-highlights .event-highlights__minor-year {
  font-size: var(--wdg-font-size-small);
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.03em;
  text-align: center;
  color: var(--wdg-color-white, #fff);
}

/* info block */
.event-highlights .event-highlights__minor-info {
  min-width: 0;
}
.event-highlights .event-highlights__minor-title {
  margin: 0 0 0.4em;
  font-size: var(--wdg-font-size-h5);
  font-weight: var(--wdg-font-heading-weight, 700);
  line-height: var(--wdg-font-heading-line-height, 1.2);
  text-decoration: none;
  text-underline-offset: 2px;
  color: var(--wdg-color-white, #fff);
}
.event-highlights .event-highlights__minor-title:hover {
  text-decoration: underline;
}
.event-highlights .event-highlights__minor-meta {
  font-size: var(--wdg-font-size-small);
  opacity: 0.85;
  line-height: 1.4;
  color: var(--wdg-color-white, #fff);
}

/* triangle corner � negative offsets push into the border area */
.event-highlights .event-highlights__minor::after {
  content: "";
  position: absolute;
  right: -5px;
  bottom: -5px;
  width: 93px;
  height: 73px;
  background: var(--wdg-color-accent, #ccedf8);
  clip-path: polygon(100% 0, 0 100%, 100% 100%);
  pointer-events: none;
  transition: background 0.2s ease;
}
.event-highlights .event-highlights__minor:hover::after {
  background: var(--wdg-color-secondary-light, #66cbec);
}

/* arrow icon � centered on triangle centroid */
.event-highlights .event-highlights__minor-arrow {
  position: absolute;
  z-index: 10;
  right: 14px;
  bottom: 7px;
}
.event-highlights .event-highlights__minor-arrow img {
  width: 24px;
  height: 24px;
  filter: invert(12%) sepia(97%) saturate(4791%) hue-rotate(218deg) brightness(68%) contrast(119%);
  transition: transform 0.16s ease, filter 0.2s ease;
}
.event-highlights .event-highlights__minor:hover .event-highlights__minor-arrow img {
  transform: translateX(4px);
}

/* =================================================================
   GRID: TABLET  >=601 px
   major full-width top row, 3 minors side-by-side below
   ================================================================= */
@media (min-width: 601px) {
  .event-highlights .event-highlights__grid {
    grid-template-columns: 1fr 1fr 1fr;
  }
  .event-highlights .event-highlights__major {
    grid-column: 1 / -1;
  }
  .event-highlights .event-highlights__major-content {
    width: 60%;
  }
}

/* =================================================================
   GRID: DESKTOP  >=1025 px
   major left spanning 3 rows, minors stacked right
   ================================================================= */
@media (min-width: 1025px) {
  .event-highlights .event-highlights__grid {
    grid-template-columns: 3fr 2fr;
    grid-template-rows: 1fr 1fr 1fr;
    min-height: 680px;
  }
  .event-highlights .event-highlights__major {
    grid-column: 1;
    grid-row: 1 / 4;
    min-height: 0;
  }
}

/* =================================================================
   MINOR-ONLY MODE  (show_major = false)
   No major tile; minor cards fill the grid evenly.
   Large screens: 2 per row.  Small screens: 1 per row.
   ================================================================= */

.event-highlights--minor-only .event-highlights__grid {
  grid-template-columns: 1fr !important;
  grid-template-rows: auto !important;
  min-height: 0 !important;
}

.event-highlights--minor-only .event-highlights__sidebar {
  display: grid !important;
  grid-template-columns: 1fr;
  gap: var(--wdg-gap-xsmall);
}

@media (min-width: 601px) {
  .event-highlights--minor-only .event-highlights__sidebar {
    grid-template-columns: 1fr 1fr;
  }
}

/* =================================================================
   Typography scaling for smaller viewports
   ================================================================= */
@media (max-width: 600px) {
  .event-highlights .event-highlights__major-content {
    width: 100%;
    padding: var(--wdg-gap-xsmall);
  }
  .event-highlights .event-highlights__minor-day {
    font-size: var(--wdg-font-size-3xlarge);
  }
}

@media (min-width: 601px) and (max-width: 1024px) {
  .event-highlights .event-highlights__major-content {
    padding: var(--wdg-gap-medium);
  }
  .event-highlights .event-highlights__minor-day {
    font-size: var(--wdg-font-size-3xlarge);
  }
}
