/* ==========================================================
   SPECIAL EVENT PAGE CSS
   Clean consolidated version

   Purpose:
   - Own the Tanz in den Mai / special-event landing page presentation layer
   - Keep shared foundations in style.css / theme-style
   - Remove duplicated late override sections
   - Preserve the approved mobile and desktop hero composition
   ========================================================== */

/* ==========================================================
   00. PAGE WRAPPER / FULL-BLEED SAFETY
   ========================================================== */

html,
body {
  width: 100% !important;
  max-width: 100% !important;
  overflow-x: clip !important;
}

@supports not (overflow: clip) {
  html,
  body {
    overflow-x: hidden !important;
  }
}

body main > section.section:first-of-type {
  padding-top: 0 !important;
  padding-right: 0 !important;
  padding-bottom: 0 !important;
  padding-left: 0 !important;
  margin: 0 !important;
  overflow-x: clip !important;
  background: transparent !important;
}

@supports not (overflow: clip) {
  body main > section.section:first-of-type {
    overflow-x: hidden !important;
  }
}

body .container.p-1.content {
  width: 100% !important;
  max-width: none !important;
  padding-top: 0 !important;
  padding-right: 0 !important;
  padding-bottom: 0 !important;
  padding-left: 0 !important;
  margin-top: 0 !important;
  margin-right: 0 !important;
  margin-left: 0 !important;
  overflow-x: clip !important;
  background: transparent !important;
}

@supports not (overflow: clip) {
  body .container.p-1.content {
    overflow-x: hidden !important;
  }
}

body .container.p-1.content > h1.title:first-child {
  display: none !important;
  margin: 0 !important;
}

body .container.p-1.content > .alignfull,
body .container.p-1.content > .wp-block-cover.alignfull,
body .container.p-1.content > .wp-block-group.alignfull,
body .container.p-1.content > .smp-special-event-hero,
body .container.p-1.content > .smp-flight-story {
  width: 100vw !important;
  max-width: 100vw !important;
  margin-left: calc(50% - 50vw) !important;
  margin-right: calc(50% - 50vw) !important;
}

/* ==========================================================
   01. HERO
   Desktop + mobile-approved final composition
   ========================================================== */

.smp-special-event-hero,
.smp-special-event-hero * {
  box-sizing: border-box;
}

.smp-special-event-hero,
.smp-special-event-hero.wp-block-cover,
.wp-block-cover.smp-special-event-hero {
  position: relative !important;
  z-index: 2;
  width: 100vw !important;
  max-width: 100vw !important;
  padding: 0 !important;
  margin-top: 0 !important;
  margin-left: calc(50% - 50vw) !important;
  margin-right: calc(50% - 50vw) !important;
  overflow: hidden !important;
  background: #03111d !important;
  isolation: isolate;
}

.smp-special-event-hero .wp-block-cover__image-background,
.smp-special-event-hero .wp-block-cover__background {
  position: absolute !important;
  inset: 0 !important;
  width: 100% !important;
  max-width: none !important;
  min-width: 100% !important;
  height: 100% !important;
  min-height: 100% !important;
}

.smp-special-event-hero .wp-block-cover__image-background {
  object-fit: cover !important;
  object-position: center 32% !important;
  transform: scale(1.01);
}

.smp-special-event-hero .wp-block-cover__background {
  opacity: 1 !important;
  background:
    linear-gradient(
      180deg,
      rgba(2, 11, 18, 0.12) 0%,
      rgba(2, 11, 18, 0.20) 24%,
      rgba(2, 15, 25, 0.66) 42%,
      rgba(2, 15, 25, 0.94) 70%,
      rgba(2, 15, 25, 0.99) 100%
    ),
    linear-gradient(
      90deg,
      rgba(0, 0, 0, 0.34) 0%,
      rgba(0, 0, 0, 0.12) 56%,
      rgba(0, 0, 0, 0.28) 100%
    ) !important;
}

.smp-special-event-hero .wp-block-cover__inner-container {
  position: relative !important;
  z-index: 2;
  width: 100% !important;
  margin-left: auto !important;
  margin-right: auto !important;
}

.smp-special-event-hero__copy {
  z-index: 2;
  width: 100%;
  margin: 0 !important;
}

/* ==========================================================
   01A. HERO LANGUAGE SWITCH
   ========================================================== */

.smp-lang-switch,
.smp-lang-switch--pill {
  display: inline-flex;
  align-items: center;
  gap: 0.18rem;
  width: auto;
  max-width: 100%;
  margin: 0 0 clamp(1.25rem, 2.6vw, 1.8rem) !important;
  padding: 0.34rem;
  border: 1px solid rgba(255, 255, 255, 0.34);
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.14);
  box-shadow:
    0 14px 34px rgba(0, 0, 0, 0.24),
    inset 0 1px 0 rgba(255, 255, 255, 0.16);
  backdrop-filter: blur(14px);
  -webkit-backdrop-filter: blur(14px);
}

.smp-lang-switch__link,
.smp-lang-switch--pill .smp-lang-switch__link {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 0.42rem;
  min-width: auto;
  min-height: 2.35rem;
  padding: 0.52rem 0.82rem;
  border-radius: 999px;
  color: rgba(255, 255, 255, 0.9) !important;
  font-size: 0.92rem;
  font-weight: 900;
  line-height: 1;
  letter-spacing: 0.02em;
  text-decoration: none !important;
  white-space: nowrap;
  transition:
    background-color var(--smp-duration, .22s) var(--smp-ease, cubic-bezier(.4,0,.2,1)),
    color var(--smp-duration, .22s) var(--smp-ease, cubic-bezier(.4,0,.2,1)),
    transform var(--smp-duration, .22s) var(--smp-ease, cubic-bezier(.4,0,.2,1));
}

.smp-lang-switch__link:hover,
.smp-lang-switch--pill .smp-lang-switch__link:hover {
  transform: translateY(-1px);
  color: #fff !important;
  background: rgba(255, 255, 255, 0.12);
}

.smp-lang-switch__link.is-active,
.smp-lang-switch__link[aria-current="page"],
.smp-lang-switch--pill .smp-lang-switch__link.is-active,
.smp-lang-switch--pill .smp-lang-switch__link[aria-current="page"] {
  background: #fff;
  color: var(--smp-navy, #052540) !important;
  box-shadow: 0 8px 18px rgba(0, 0, 0, 0.18);
}

.smp-lang-switch__flag {
  font-size: 1rem;
  line-height: 1;
}

.smp-lang-switch__label {
  line-height: 1;
  letter-spacing: 0.02em;
}

/* ==========================================================
   01B. HERO COPY / META / CTA
   ========================================================== */

.smp-special-event-hero__eyebrow {
  margin: 0 0 clamp(0.7rem, 1.2vw, 1rem) !important;
  color: #ff8a2a !important;
  font-size: clamp(0.78rem, 1.5vw, 0.98rem) !important;
  font-weight: 900 !important;
  line-height: 1.05 !important;
  letter-spacing: 0.19em !important;
  text-transform: uppercase !important;
  text-align: left !important;
}

.smp-special-event-hero .mirror-headline,
.smp-special-event-hero__headline {
  max-width: 12.5ch !important;
  margin: 0 0 clamp(1.1rem, 2vw, 1.45rem) !important;
  color: #fff !important;
  font-size: clamp(2.7rem, 6vw, 5.1rem) !important;
  font-weight: 950 !important;
  line-height: 0.98 !important;
  letter-spacing: -0.055em !important;
  text-align: left !important;
  text-wrap: balance !important;
  overflow-wrap: normal !important;
  word-break: normal !important;
  hyphens: none !important;
  text-shadow:
    0 4px 20px rgba(0, 0, 0, 0.42),
    0 1px 0 rgba(0, 0, 0, 0.25);
}

.smp-special-event-hero__headline span {
  display: block;
  max-width: 100%;
  white-space: nowrap;
}

.smp-special-event-hero__sub {
  max-width: 34rem !important;
  margin: 0 0 clamp(1.55rem, 2.6vw, 2rem) !important;
  color: rgba(255, 255, 255, 0.88) !important;
  font-size: clamp(1.12rem, 2.2vw, 1.45rem) !important;
  font-weight: 650 !important;
  line-height: 1.42 !important;
  letter-spacing: -0.015em;
  text-align: left !important;
}

.smp-special-event-hero__meta-list {
  width: 100%;
  max-width: 33rem;
  margin: 0 0 clamp(1.7rem, 3vw, 2.25rem) !important;
}

.smp-special-event-hero__meta-row {
  display: grid;
  grid-template-columns: 2.35rem minmax(0, 1fr);
  align-items: center;
  gap: 0.85rem;
  min-height: 3rem;
  padding: 0.54rem 0;
  border-bottom: 1px solid rgba(255, 255, 255, 0.15);
}

.smp-special-event-hero__meta-row:last-child {
  border-bottom: 0;
}

.smp-special-event-hero__meta-icon {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 2.15rem;
  height: 2.15rem;
  color: #ff8a2a;
}

.smp-special-event-hero__meta-icon svg {
  display: block;
  width: 1.75rem;
  height: 1.75rem;
  fill: none;
  stroke: currentColor;
  stroke-width: 2.25;
  stroke-linecap: round;
  stroke-linejoin: round;
}

.smp-special-event-hero__meta-text {
  min-width: 0;
  color: rgba(255, 255, 255, 0.94);
  font-size: clamp(1.02rem, 2.2vw, 1.28rem);
  font-weight: 800;
  line-height: 1.2;
  letter-spacing: -0.02em;
}

.smp-special-event-hero__actions {
  width: min(100%, 30.5rem) !important;
  max-width: 30.5rem !important;
  margin: 0 !important;
  gap: 0 !important;
  justify-content: flex-start !important;
}

.smp-special-event-hero__button {
  width: 100% !important;
  margin: 0 !important;
}

.smp-special-event-hero__button .wp-block-button__link {
  position: relative;
  display: flex !important;
  align-items: center;
  justify-content: center;
  width: 100%;
  min-height: 4.25rem !important;
  padding: 1rem 4rem 1rem 1.75rem !important;
  border: 0 !important;
  border-radius: 18px !important;
  background:
    linear-gradient(
      135deg,
      rgba(112, 199, 207, 1) 0%,
      rgba(0, 176, 188, 1) 100%
    ) !important;
  color: #fff !important;
  box-shadow:
    0 20px 46px rgba(0, 176, 188, 0.24),
    0 0 0 1px rgba(255, 255, 255, 0.16) inset,
    inset 0 1px 0 rgba(255, 255, 255, 0.28) !important;
  font-size: clamp(1.18rem, 1.55vw, 1.45rem) !important;
  font-weight: 900 !important;
  line-height: 1 !important;
  letter-spacing: -0.02em !important;
  text-align: center;
  text-decoration: none !important;
  overflow: hidden;
}

.smp-special-event-hero__button .wp-block-button__link::after {
  content: "→";
  position: absolute;
  right: 1.45rem !important;
  top: 50%;
  transform: translateY(-50%);
  font-size: 1.25em;
  font-weight: 500;
  line-height: 1;
  opacity: 0.96;
  transition: transform var(--smp-duration, .22s) var(--smp-ease, cubic-bezier(.4,0,.2,1));
}

.smp-special-event-hero__button .wp-block-button__link:hover {
  transform: translateY(-2px);
  box-shadow:
    0 24px 52px rgba(0, 176, 188, 0.32),
    0 0 0 1px rgba(255, 255, 255, 0.2) inset,
    inset 0 1px 0 rgba(255, 255, 255, 0.3) !important;
}

.smp-special-event-hero__button .wp-block-button__link:hover::after {
  transform: translate(4px, -50%);
}

.smp-special-event-hero__button .wp-block-button__link:focus-visible {
  outline: 3px solid rgba(255, 255, 255, 0.78);
  outline-offset: 4px;
}

/* ==========================================================
   01C. HERO DESKTOP / TABLET COMPOSITION
   ========================================================== */

@media (min-width: 782px) {
  .smp-special-event-hero.wp-block-cover,
  .wp-block-cover.smp-special-event-hero {
    min-height: calc(100svh - 52px) !important;
    height: auto !important;
  }

  .smp-special-event-hero .wp-block-cover__inner-container {
    min-height: calc(100svh - 52px) !important;
    max-width: none !important;
    display: flex !important;
    align-items: flex-end !important;
    justify-content: flex-start !important;
    padding:
      clamp(6.5rem, 12vh, 9rem)
      clamp(2.5rem, 5vw, 4.5rem)
      clamp(1.25rem, 3vh, 2.25rem) !important;
  }

  .smp-special-event-hero__copy {
    position: static !important;
    width: 100% !important;
    max-width: min(100%, 40rem) !important;
    padding: 0 !important;
  }

  .smp-special-event-hero__copy > .smp-lang-switch,
  .smp-special-event-hero__copy > .smp-lang-switch--pill {
    position: absolute !important;
    top: clamp(1.25rem, 3vh, 2rem) !important;
    left: clamp(2.5rem, 5vw, 4.5rem) !important;
    right: auto !important;
    z-index: 30 !important;
    display: inline-flex !important;
    visibility: visible !important;
    opacity: 1 !important;
    margin: 0 !important;
    padding: 0.42rem !important;
    gap: 0.22rem !important;
    transform: none !important;
    pointer-events: auto !important;
  }

  .smp-special-event-hero .smp-lang-switch__link,
  .smp-special-event-hero .smp-lang-switch--pill .smp-lang-switch__link {
    min-height: 2.7rem !important;
    padding: 0.62rem 0.98rem !important;
    font-size: 1rem !important;
    gap: 0.5rem !important;
  }

  .smp-special-event-hero .smp-lang-switch__flag {
    font-size: 1.08rem !important;
  }
}

@media (min-width: 782px) and (max-width: 1024px) {
  .smp-special-event-hero__copy {
    max-width: min(100%, 38rem) !important;
  }
}

/* ==========================================================
   01D. HERO MOBILE COMPOSITION
   Approved behavior:
   - language switch appears once near the top
   - image is zoomed out more
   - copy sits lower on the dark part of the hero
   - dark space remains below CTA before ticket section
   ========================================================== */

@media (max-width: 781px) {
  body .container.p-1.content > .alignfull,
  body .container.p-1.content > .wp-block-cover.alignfull,
  body .container.p-1.content > .wp-block-group.alignfull,
  body .container.p-1.content > .smp-special-event-hero,
  body .container.p-1.content > .smp-flight-story,
  .smp-special-event-hero.wp-block-cover,
  .wp-block-cover.smp-special-event-hero {
    width: 100vw !important;
    max-width: 100vw !important;
    margin-left: calc(50% - 50vw) !important;
    margin-right: calc(50% - 50vw) !important;
  }

  .smp-special-event-hero.wp-block-cover,
  .wp-block-cover.smp-special-event-hero {
    min-height: auto !important;
    height: auto !important;
  }

  .smp-special-event-hero .wp-block-cover__image-background {
    top: 0 !important;
    right: 0 !important;
    bottom: auto !important;
    left: 0 !important;
    height: clamp(420px, 52svh, 540px) !important;
    min-height: 0 !important;
    object-fit: cover !important;
    object-position: center top !important;
    transform: none !important;
    -webkit-mask-image: linear-gradient(
      180deg,
      #000 0%,
      #000 68%,
      rgba(0, 0, 0, 0.84) 80%,
      rgba(0, 0, 0, 0.38) 92%,
      transparent 100%
    );
    mask-image: linear-gradient(
      180deg,
      #000 0%,
      #000 68%,
      rgba(0, 0, 0, 0.84) 80%,
      rgba(0, 0, 0, 0.38) 92%,
      transparent 100%
    );
  }

  .smp-special-event-hero .wp-block-cover__background {
    background:
      linear-gradient(
        180deg,
        rgba(3, 17, 29, 0.04) 0%,
        rgba(3, 17, 29, 0.10) 20%,
        rgba(3, 17, 29, 0.30) 42%,
        rgba(3, 17, 29, 0.72) 58%,
        rgba(3, 17, 29, 0.96) 72%,
        rgba(3, 17, 29, 1) 84%,
        rgba(3, 17, 29, 1) 100%
      ) !important;
  }

  .smp-special-event-hero .wp-block-cover__inner-container {
    position: relative !important;
    display: block !important;
    width: 100% !important;
    max-width: 100vw !important;
    min-height: clamp(870px, 104svh, 980px) !important;
    margin-left: auto !important;
    margin-right: auto !important;
    padding:
      clamp(22rem, 45svh, 27rem)
      2rem
      clamp(4.75rem, 11svh, 6.5rem) !important;
  }

  .smp-special-event-hero__copy {
    position: static !important;
    width: 100% !important;
    max-width: 100% !important;
    padding: 0 !important;
  }

  .smp-special-event-hero .smp-special-event-hero__copy .smp-lang-switch,
  .smp-special-event-hero .smp-special-event-hero__copy .smp-lang-switch--pill {
    position: absolute !important;
    top: clamp(1.35rem, 5vw, 2rem) !important;
    left: 1rem !important;
    right: auto !important;
    z-index: 20 !important;
    display: inline-flex !important;
    visibility: visible !important;
    opacity: 1 !important;
    max-width: calc(100vw - 2rem) !important;
    margin: 0 !important;
    padding: 0.26rem !important;
    transform: none !important;
    pointer-events: auto !important;
  }

  .smp-special-event-hero .smp-lang-switch__link,
  .smp-special-event-hero .smp-lang-switch--pill .smp-lang-switch__link {
    min-height: 2.1rem !important;
    padding: 0.46rem 0.62rem !important;
    font-size: 0.8rem !important;
    gap: 0.3rem !important;
  }

  .smp-special-event-hero__eyebrow {
    margin-bottom: 0.65rem !important;
    font-size: clamp(0.68rem, 2.75vw, 0.8rem) !important;
    letter-spacing: 0.15em !important;
  }

  .smp-special-event-hero .mirror-headline,
  .smp-special-event-hero__headline {
    max-width: 100% !important;
    margin-bottom: 0.85rem !important;
    font-size: clamp(1.92rem, 7.65vw, 2.44rem) !important;
    line-height: 0.98 !important;
    letter-spacing: -0.055em !important;
  }

  .smp-special-event-hero__headline span {
    white-space: normal !important;
  }

  .smp-special-event-hero__sub {
    max-width: 100% !important;
    margin-bottom: 1.05rem !important;
    font-size: clamp(0.92rem, 3.65vw, 1.04rem) !important;
    line-height: 1.35 !important;
  }

  .smp-special-event-hero__meta-list {
    max-width: 100% !important;
    margin-bottom: 1.2rem !important;
  }

  .smp-special-event-hero__meta-row {
    grid-template-columns: 1.8rem minmax(0, 1fr);
    gap: 0.66rem;
    min-height: 2.35rem;
    padding: 0.34rem 0;
  }

  .smp-special-event-hero__meta-icon {
    width: 1.7rem;
    height: 1.7rem;
  }

  .smp-special-event-hero__meta-icon svg {
    width: 1.36rem;
    height: 1.36rem;
    stroke-width: 2.35;
  }

  .smp-special-event-hero__meta-text {
    font-size: clamp(0.9rem, 3.65vw, 1.03rem);
    line-height: 1.14;
  }

  .smp-special-event-hero__actions {
    width: 100% !important;
    max-width: 100% !important;
  }

  .smp-special-event-hero__button .wp-block-button__link {
    min-height: 3.75rem !important;
    border-radius: 16px !important;
    padding: 1rem 3.4rem 1rem 1.25rem !important;
    font-size: clamp(1.03rem, 4.25vw, 1.24rem) !important;
  }
}

@media (max-width: 420px) {
  .smp-special-event-hero .wp-block-cover__image-background {
    height: clamp(400px, 50svh, 500px) !important;
  }

  .smp-special-event-hero .wp-block-cover__inner-container {
    min-height: clamp(850px, 102svh, 940px) !important;
    padding:
      clamp(21rem, 43svh, 25.5rem)
      1rem
      clamp(4.5rem, 10svh, 6rem) !important;
  }

  .smp-special-event-hero .mirror-headline,
  .smp-special-event-hero__headline {
    font-size: clamp(1.82rem, 7.4vw, 2.26rem) !important;
  }

  .smp-special-event-hero__sub {
    font-size: clamp(0.9rem, 3.55vw, 0.98rem) !important;
  }
}

@media (max-width: 380px) {
  .smp-special-event-hero .wp-block-cover__inner-container {
    padding-top: clamp(20rem, 41svh, 24rem) !important;
  }

  .smp-special-event-hero .mirror-headline,
  .smp-special-event-hero__headline {
    font-size: clamp(1.68rem, 7.2vw, 2.08rem) !important;
  }
}

/* ==========================================================
   02. HERO SCROLL CUE
   ========================================================== */

.smp-special-event-hero .wp-block-cover__inner-container {
  overflow: visible !important;
}

.smp-scroll-pill {
  position: absolute !important;
  left: 50% !important;
  bottom: clamp(2.75rem, 6.5svh, 4.25rem) !important;
  transform: translateX(-50%) !important;
  z-index: 35 !important;
  display: inline-flex !important;
  align-items: center;
  justify-content: center;
  width: 64px;
  height: 64px;
  border-radius: 999px;
  background: #fcfaf1;
  border: 1px solid rgba(5, 37, 64, 0.12);
  box-shadow: 0 12px 34px rgba(5, 37, 64, 0.18);
  text-decoration: none !important;
  cursor: pointer;
  transition:
    transform .25s ease,
    box-shadow .25s ease,
    background-color .25s ease,
    border-color .25s ease;
}

.smp-scroll-pill:hover {
  transform: translateX(-50%) translateY(-3px) !important;
  background: #ffffff;
  border-color: rgba(5, 37, 64, 0.2);
  box-shadow: 0 16px 42px rgba(5, 37, 64, 0.22);
}

.smp-scroll-pill:focus-visible {
  outline: 3px solid rgba(0, 176, 188, 0.4);
  outline-offset: 5px;
}

.smp-scroll-pill__icon {
  display: block;
  width: 15px;
  height: 15px;
  margin-top: -5px;
  border-right: 3px solid #052540;
  border-bottom: 3px solid #052540;
  transform: rotate(45deg);
  animation: smpScrollCueBounce 1.6s ease-in-out infinite;
}

@keyframes smpScrollCueBounce {
  0%, 100% {
    transform: rotate(45deg) translate(0, 0);
    opacity: 1;
  }

  50% {
    transform: rotate(45deg) translate(4px, 4px);
    opacity: 0.72;
  }
}

#events {
  scroll-margin-top: 84px;
}

@media (max-width: 781px) {
  .smp-scroll-pill {
    bottom: clamp(2.75rem, 6.5svh, 4.25rem) !important;
    width: 54px !important;
    height: 54px !important;
  }

  .smp-scroll-pill__icon {
    width: 12px !important;
    height: 12px !important;
    border-right-width: 2.5px !important;
    border-bottom-width: 2.5px !important;
  }

  #events {
    scroll-margin-top: 72px;
  }
}

@media (max-width: 420px) {
  .smp-scroll-pill {
    bottom: clamp(2.5rem, 6svh, 3.75rem) !important;
  }
}

/* ==========================================================
   03. QUICK TICKET DECISION / COMPACT TICKET CARDS
   ========================================================== */

.smp-compact-ticket-section {
  position: relative;
  z-index: 1;
  background: #efefef;
  overflow: hidden;
}

.smp-compact-ticket-section .mirror-sub {
  max-width: 34ch !important;
  margin-top: 0.5rem !important;
  line-height: 1.5 !important;
}

.smp-compact-ticket-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 1.25rem;
  max-width: 1120px;
  margin: 0 auto;
  align-items: start;
}

.smp-compact-ticket-card,
.smp-compact-ticket-card * {
  box-sizing: border-box;
}

.smp-compact-ticket-card {
  background: #f3eee8;
  border: 2px solid #eb6a1f;
  border-radius: 24px;
  padding: 1.45rem 1.6rem 1.45rem;
  box-shadow: none;
  color: #1f2430;
}

.smp-compact-ticket-card--soft {
  background: #f5f3f1;
  border-color: #d8d8d8;
}

.smp-compact-ticket-card__head {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  align-items: start;
  gap: 1rem;
  margin-bottom: 1rem;
}

.smp-compact-ticket-card__title {
  margin: 0;
  min-width: 0;
  font-size: clamp(1.45rem, 2vw, 2.1rem);
  line-height: 1.05;
  font-weight: 800;
  letter-spacing: -0.04em;
  color: #1f2430;
}

.smp-compact-ticket-card__title span,
.smp-compact-ticket-card__title em {
  display: inline;
}

.smp-compact-ticket-card__title em {
  font-style: normal;
  color: #eb6a1f;
  font-weight: 700;
  white-space: nowrap;
}

.smp-compact-ticket-card--soft .smp-compact-ticket-card__title em {
  color: #808080;
}

.smp-compact-ticket-card__badge {
  justify-self: end;
  align-self: start;
  background: #eb6a1f;
  color: #fff;
  font-size: .8rem;
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: .04em;
  border-radius: 11px;
  padding: .58rem .82rem;
  white-space: nowrap;
  line-height: 1;
}

.smp-compact-ticket-card__desc {
  margin: 0;
  font-size: clamp(1rem, 1.4vw, 1.15rem);
  line-height: 1.45;
  color: #2b313d;
}

.smp-compact-ticket-card__divider {
  height: 1px;
  background: rgba(235, 106, 31, .22);
  margin: 1.15rem 0 1.1rem;
}

.smp-compact-ticket-card--soft .smp-compact-ticket-card__divider {
  background: rgba(0, 0, 0, .10);
}

.smp-compact-ticket-card__list {
  list-style: none;
  margin: 0 0 1.25rem;
  padding: 0;
  display: grid;
  gap: .78rem;
}

.smp-compact-ticket-card__list li {
  display: flex;
  align-items: center;
  gap: .8rem;
  font-size: clamp(1rem, 1.35vw, 1.12rem);
  line-height: 1.35;
  color: #2b313d;
}

.smp-compact-ticket-card__icon {
  width: 1.7rem;
  height: 1.7rem;
  border-radius: 50%;
  background: #eb6a1f;
  flex: 0 0 1.7rem;
  position: relative;
}

.smp-compact-ticket-card__icon::before {
  content: "✓";
  position: absolute;
  inset: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  color: #fff;
  font-size: 1rem;
  font-weight: 800;
}

.smp-compact-ticket-card__list--muted .smp-compact-ticket-card__icon {
  background: #9c9c9c;
}

.smp-compact-ticket-card__button {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 100%;
  min-height: 58px;
  border-radius: 15px;
  text-decoration: none !important;
  font-size: clamp(1.05rem, 1.4vw, 1.2rem);
  font-weight: 800;
  line-height: 1;
  transition:
    transform .2s ease,
    opacity .2s ease;
}

.smp-compact-ticket-card__button:hover {
  transform: translateY(-1px);
  opacity: .95;
}

.smp-compact-ticket-card__button--primary {
  background: #e86522;
  color: #fff !important;
}

.smp-compact-ticket-card__button--dark {
  background: #232631;
  color: #fff !important;
}

@media (max-width: 781px) {
  .smp-compact-ticket-section {
    padding-left: 0 !important;
    padding-right: 0 !important;
  }

  .smp-compact-ticket-section > .mirror-eyebrow,
  .smp-compact-ticket-section > .mirror-headline,
  .smp-compact-ticket-section > .mirror-sub {
    padding-left: 1rem;
    padding-right: 1rem;
  }

  .smp-compact-ticket-grid {
    display: grid;
    grid-auto-flow: column;
    grid-auto-columns: calc(100% - 3.25rem);
    grid-template-columns: none;
    gap: 1rem;
    max-width: none;
    width: 100%;
    overflow-x: auto;
    overscroll-behavior-x: contain;
    scroll-snap-type: x mandatory;
    -webkit-overflow-scrolling: touch;
    scroll-padding-left: 1rem;
    padding: 0 1rem .5rem 1rem;
    margin: 0;
    align-items: stretch;
  }

  .smp-compact-ticket-grid::-webkit-scrollbar {
    display: none;
  }

  .smp-compact-ticket-card {
    scroll-snap-align: center;
    min-width: 0;
    min-height: 100%;
  }
}

@media (max-width: 640px) {
  .smp-compact-ticket-card {
    padding: 1.15rem 1.05rem 1.1rem;
    border-radius: 20px;
  }

  .smp-compact-ticket-card__head {
    gap: .75rem;
    margin-bottom: .85rem;
  }

  .smp-compact-ticket-card__title {
    font-size: clamp(1.28rem, 6vw, 1.6rem);
  }

  .smp-compact-ticket-card__badge {
    padding: .5rem .72rem;
    font-size: .68rem;
    border-radius: 10px;
  }

  .smp-compact-ticket-card__desc {
    font-size: .98rem;
    line-height: 1.42;
  }

  .smp-compact-ticket-card__divider {
    margin: 1rem 0 .95rem;
  }

  .smp-compact-ticket-card__list {
    gap: .72rem;
    margin-bottom: 1.1rem;
  }

  .smp-compact-ticket-card__list li {
    gap: .7rem;
    font-size: .98rem;
  }

  .smp-compact-ticket-card__icon {
    width: 1.5rem;
    height: 1.5rem;
    flex-basis: 1.5rem;
  }

  .smp-compact-ticket-card__icon::before {
    font-size: .9rem;
  }

  .smp-compact-ticket-card__button {
    min-height: 54px;
    border-radius: 14px;
  }
}

@media (max-width: 390px) {
  .smp-compact-ticket-grid {
    grid-auto-columns: calc(100% - 2.25rem);
  }

  .smp-compact-ticket-card__head {
    gap: .55rem;
  }

  .smp-compact-ticket-card__title {
    font-size: 1.22rem;
  }

  .smp-compact-ticket-card__badge {
    font-size: .62rem;
    padding: .48rem .62rem;
  }
}

/* ==========================================================
   04. PROBLEM RECOGNITION / DIFFERENCE REVEAL
   ========================================================== */

.smp-special-difference {
  padding-top: clamp(2.25rem, 5vw, 3.5rem) !important;
  padding-bottom: clamp(2.25rem, 5vw, 3.5rem) !important;
}

.smp-special-difference .mirror-eyebrow {
  margin-bottom: 0.75rem !important;
}

.smp-special-difference .mirror-headline,
.smp-special-difference__headline {
  max-width: 20ch !important;
  margin-left: auto !important;
  margin-right: auto !important;
  margin-bottom: 1.35rem !important;
  text-align: center !important;
  text-wrap: balance !important;
}

.smp-special-difference .mirror-sub,
.smp-special-difference__sub {
  max-width: 24ch !important;
  margin-left: auto !important;
  margin-right: auto !important;
  margin-bottom: 0 !important;
  text-align: center !important;
  line-height: 1.65 !important;
}

.smp-special-difference .smp-reveal-fade,
.smp-special-difference .smp-reveal-title {
  opacity: 0;
  will-change: opacity, transform;
}

.smp-special-difference .smp-reveal-fade {
  transform: translateY(18px);
  transition:
    opacity .7s ease,
    transform .7s ease;
}

.smp-special-difference .smp-reveal-fade--delay {
  transition-delay: .14s;
}

.smp-special-difference .smp-reveal-title {
  transform: scale(.88);
  transition:
    opacity .85s ease,
    transform .85s cubic-bezier(.22, 1, .36, 1);
}

.smp-special-difference.is-visible .smp-reveal-fade,
.smp-special-difference.is-visible .smp-reveal-title {
  opacity: 1;
}

.smp-special-difference.is-visible .smp-reveal-fade {
  transform: translateY(0);
}

.smp-special-difference.is-visible .smp-reveal-title {
  transform: scale(1);
}

@media (max-width: 781px) {
  .smp-special-difference {
    padding-top: clamp(2rem, 6vw, 2.75rem) !important;
    padding-bottom: clamp(2rem, 6vw, 2.75rem) !important;
  }

  .smp-special-difference .mirror-eyebrow {
    margin-bottom: 0.6rem !important;
  }

  .smp-special-difference .mirror-headline,
  .smp-special-difference__headline {
    max-width: 18ch !important;
    margin-bottom: 1rem !important;
  }

  .smp-special-difference .mirror-sub,
  .smp-special-difference__sub {
    max-width: 22ch !important;
    line-height: 1.6 !important;
  }

  .smp-special-difference .smp-reveal-fade {
    transform: translateY(14px);
  }

  .smp-special-difference .smp-reveal-title {
    transform: scale(.9);
  }
}

/* ==========================================================
   05. HOW THE NIGHT UNFOLDS / FLIGHT STORY
   ========================================================== */

main,
.site,
.site-content,
.wp-site-blocks,
.entry-content,
.container,
.container.p-1.content {
  max-width: 100%;
  overflow-x: clip !important;
  overflow-y: visible !important;
}

@supports not (overflow: clip) {
  main,
  .site,
  .site-content,
  .wp-site-blocks,
  .entry-content,
  .container,
  .container.p-1.content {
    overflow-x: hidden !important;
  }
}

.smp-flight-story,
.smp-flight-story__stack-list {
  overflow-x: visible !important;
  overflow-y: visible !important;
}

.smp-flight-story,
.smp-flight-story * {
  box-sizing: border-box;
}

.smp-flight-story {
  --smp-stack-top: 72px;
  position: relative;
  width: 100vw;
  max-width: 100vw;
  margin-left: calc(50% - 50vw);
  margin-right: calc(50% - 50vw);
  background:
    radial-gradient(circle at 18% 0%, rgba(255, 89, 0, 0.10), transparent 34%),
    radial-gradient(circle at 84% 48%, rgba(0, 176, 188, 0.06), transparent 34%),
    var(--smp-bg-light, #f7f5ee);
  padding: clamp(3rem, 6vw, 4.6rem) 5vw clamp(4rem, 8vw, 6rem);
  isolation: isolate;
}

.smp-flight-story__intro,
.smp-flight-story__stack-list,
.smp-flight-story__final {
  position: relative;
  z-index: 2;
}

.smp-flight-story__intro {
  max-width: 780px;
  margin: 0 auto clamp(2rem, 4vw, 2.8rem);
  text-align: center;
}

.smp-flight-story__intro .mirror-headline {
  max-width: 18ch !important;
  margin-left: auto !important;
  margin-right: auto !important;
  margin-bottom: 1.15rem !important;
  font-size: clamp(2.2rem, 4.9vw, 3.65rem) !important;
  line-height: 1.02 !important;
  letter-spacing: -0.045em !important;
}

.smp-flight-story__intro .mirror-sub {
  max-width: 54ch !important;
  line-height: 1.65 !important;
}

.smp-flight-story__stack-list {
  position: sticky;
  top: var(--smp-stack-top);
  max-width: 980px;
  margin: 0 auto;
  min-height: var(--smp-flight-stage-height, 1100px);
  margin-bottom: var(--smp-flight-scroll-space, 900px);
}

.smp-flight-card {
  position: absolute;
  top: var(--smp-card-top, 0px);
  left: 0;
  width: 100%;
  display: grid;
  grid-template-columns: 280px minmax(0, 1fr);
  gap: clamp(1.4rem, 2.6vw, 2.1rem);
  align-items: start;
  min-height: clamp(270px, 34vh, 320px);
  margin: 0 !important;
  padding: clamp(1.3rem, 2.4vw, 1.8rem) clamp(1.35rem, 2.6vw, 2rem);
  background: #fff;
  border: 1px solid rgba(231, 236, 242, 0.96);
  border-radius: 30px;
  box-shadow:
    0 18px 48px rgba(5, 37, 64, 0.11),
    0 2px 0 rgba(255, 255, 255, 0.78) inset;
  overflow: visible !important;
}

.smp-flight-card::before {
  content: "";
  position: absolute;
  inset: 12px;
  border-radius: 24px;
  border: 1px dashed rgba(5, 37, 64, 0.10);
  pointer-events: none;
}

.smp-flight-card--1 { z-index: 40; --icon-scale: 1.10; }
.smp-flight-card--2 { z-index: 30; --icon-scale: 1.08; }
.smp-flight-card--3 { z-index: 20; --icon-scale: 1.08; }
.smp-flight-card--4 { z-index: 10; --icon-scale: 1.06; }

.smp-flight-card.is-flight-future .smp-flight-card__number {
  opacity: 0 !important;
  visibility: hidden !important;
  transform: scale(.8);
}

.smp-flight-card.is-flight-revealed .smp-flight-card__number,
.smp-flight-card.is-flight-current .smp-flight-card__number {
  opacity: 1 !important;
  visibility: visible !important;
  transform: scale(1);
}

.smp-flight-card__number {
  position: absolute;
  top: -1rem;
  left: -1rem;
  width: 4.3rem;
  height: 4.3rem;
  display: grid;
  place-items: center;
  border-radius: 999px;
  background: linear-gradient(135deg, var(--smp-orange, #ff5900), #d94700);
  color: #fff;
  font-size: 1.7rem;
  font-weight: 900;
  line-height: 1;
  box-shadow: 0 14px 28px rgba(255, 89, 0, 0.23);
  z-index: 3;
  transition:
    opacity .22s ease,
    visibility .22s ease,
    transform .22s ease;
}

.smp-flight-card__visual {
  width: 260px;
  height: 260px;
  display: grid;
  place-items: center;
  justify-self: center;
  align-self: start;
  margin-top: 0.35rem;
  border-radius: 28px;
  background: #fafafa;
  box-shadow: 0 10px 28px rgba(5, 37, 64, 0.05);
  overflow: hidden;
}

.smp-flight-card__visual img {
  display: block;
  width: 94%;
  height: 94%;
  object-fit: contain;
  transform: scale(var(--icon-scale, 1));
  transform-origin: center center;
  filter: drop-shadow(0 8px 14px rgba(5, 37, 64, 0.10));
}

.smp-flight-card__content {
  min-width: 0;
  max-width: 34rem;
  padding-top: 0.45rem;
}

.smp-flight-card__label {
  margin: 0 0 0.45rem !important;
  color: var(--smp-teal, #00b0bc);
  font-size: 0.78rem;
  font-weight: 900;
  line-height: 1.1;
  letter-spacing: 0.18em;
  text-transform: uppercase;
}

.smp-flight-card h3 {
  margin: 0 0 0.8rem !important;
  color: var(--smp-navy, #052540) !important;
  font-size: clamp(1.75rem, 3.4vw, 2.75rem) !important;
  font-weight: 900 !important;
  line-height: 0.98 !important;
  letter-spacing: -0.05em !important;
  text-wrap: balance;
}

.smp-flight-card p:not(.smp-flight-card__label) {
  max-width: 34ch;
  margin: 0 !important;
  color: #1f2430;
  font-size: clamp(1rem, 1.25vw, 1.15rem);
  font-weight: 500;
  line-height: 1.45;
}

.smp-flight-story__final {
  max-width: 760px;
  margin: clamp(2rem, 5vw, 3.5rem) auto 0;
  padding-top: clamp(0.5rem, 1.5vw, 1rem);
  padding-bottom: clamp(7rem, 14vw, 10rem);
  text-align: center;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: flex-start;
}

.smp-flight-story__final .mirror-eyebrow {
  margin-bottom: clamp(0.7rem, 1.5vw, 1rem) !important;
}

.smp-flight-story__final .mirror-headline {
  max-width: 14ch !important;
  margin-bottom: clamp(1.4rem, 3vw, 2rem) !important;
}

.smp-flight-story__actions {
  justify-content: center;
  margin-top: 0 !important;
  width: 100%;
}

.smp-flight-story__actions .wp-block-button {
  width: min(100%, 680px);
}

.smp-flight-story__actions .wp-block-button__link {
  width: 100%;
  background: var(--smp-navy, #052540) !important;
  color: #fff !important;
  border-radius: 13px !important;
  padding: 0.95rem 1.7rem !important;
  font-weight: 800 !important;
  box-shadow: var(--smp-shadow, 0 6px 20px rgba(0,0,0,.08));
  transition:
    transform var(--smp-duration, .22s) var(--smp-ease, cubic-bezier(.4,0,.2,1)),
    box-shadow var(--smp-duration, .22s) var(--smp-ease, cubic-bezier(.4,0,.2,1));
}

.smp-flight-story__actions .wp-block-button__link:hover {
  transform: translateY(-2px);
  box-shadow: 0 14px 34px rgba(5, 37, 64, 0.16);
}

@media (max-width: 980px) {
  .smp-flight-story {
    --smp-stack-top: 64px;
  }

  .smp-flight-story__intro .mirror-headline {
    max-width: 17ch !important;
    font-size: clamp(2rem, 5.6vw, 3.1rem) !important;
  }

  .smp-flight-card {
    grid-template-columns: 220px minmax(0, 1fr);
    min-height: 248px;
    gap: 1.15rem;
    padding: 1.15rem 1.2rem 1.25rem;
  }

  .smp-flight-card__number {
    width: 3.7rem;
    height: 3.7rem;
    font-size: 1.45rem;
  }

  .smp-flight-card__visual {
    width: 208px;
    height: 208px;
    border-radius: 24px;
  }

  .smp-flight-card__content {
    padding-top: 0.28rem;
  }

  .smp-flight-card h3 {
    font-size: clamp(1.55rem, 3.8vw, 2.25rem) !important;
  }

  .smp-flight-card p:not(.smp-flight-card__label) {
    font-size: 0.98rem;
    line-height: 1.42;
  }

  .smp-flight-story__final {
    padding-bottom: clamp(6rem, 15vw, 8.5rem);
  }
}

@media (max-width: 781px) {
  .smp-flight-story {
    --smp-stack-top: 56px;
    padding-top: clamp(2.4rem, 8vw, 3.2rem);
    padding-bottom: clamp(3rem, 8vw, 4.25rem);
  }

  .smp-flight-story__intro {
    margin-bottom: 1.5rem;
  }

  .smp-flight-story__intro .mirror-headline {
    max-width: 15ch !important;
    font-size: clamp(1.9rem, 8vw, 2.65rem) !important;
    line-height: 1.04 !important;
    margin-bottom: 0.95rem !important;
  }

  .smp-flight-story__intro .mirror-sub {
    max-width: 30ch !important;
    font-size: 0.98rem !important;
    line-height: 1.55 !important;
  }

  .smp-flight-card {
    grid-template-columns: 148px minmax(0, 1fr);
    min-height: 238px;
    gap: 0.95rem;
    border-radius: 24px;
    padding: 1rem 1rem 1.1rem;
  }

  .smp-flight-card::before {
    inset: 8px;
    border-radius: 18px;
  }

  .smp-flight-card__number {
    top: -0.78rem;
    left: -0.78rem;
    width: 3.15rem;
    height: 3.15rem;
    font-size: 1.18rem;
  }

  .smp-flight-card__visual {
    width: 140px;
    height: 140px;
    margin-top: 1.3rem;
    border-radius: 20px;
  }

  .smp-flight-card__content {
    padding-top: 1.2rem;
  }

  .smp-flight-card__label {
    font-size: 0.62rem !important;
    letter-spacing: 0.16em;
    margin-bottom: 0.32rem !important;
  }

  .smp-flight-card h3 {
    font-size: clamp(1.34rem, 6.2vw, 1.82rem) !important;
    line-height: 1 !important;
    margin-bottom: 0.42rem !important;
  }

  .smp-flight-card p:not(.smp-flight-card__label) {
    font-size: 0.88rem !important;
    line-height: 1.38 !important;
    max-width: 28ch;
  }

  .smp-flight-story__final {
    margin-top: clamp(1rem, 3vw, 1.5rem);
    padding-top: 0.35rem;
    padding-bottom: clamp(5.5rem, 18vw, 7.5rem);
  }

  .smp-flight-story__final .mirror-eyebrow {
    font-size: 0.76rem !important;
    margin-bottom: 0.7rem !important;
  }

  .smp-flight-story__final .mirror-headline {
    font-size: clamp(1.8rem, 7.8vw, 2.45rem) !important;
    line-height: 1.06 !important;
    margin-bottom: 1.35rem !important;
  }

  .smp-flight-story__actions .wp-block-button,
  .smp-flight-story__actions .wp-block-button__link {
    width: 100%;
  }
}

@media (max-width: 430px) {
  .smp-flight-story {
    --smp-stack-top: 52px;
  }

  .smp-flight-story__intro .mirror-headline {
    max-width: 14ch !important;
    font-size: clamp(1.75rem, 8.4vw, 2.28rem) !important;
  }

  .smp-flight-card {
    grid-template-columns: 116px minmax(0, 1fr);
    min-height: 222px;
    gap: 0.78rem;
    padding: 0.88rem 0.88rem 0.95rem;
  }

  .smp-flight-card__number {
    width: 2.95rem;
    height: 2.95rem;
    font-size: 1.12rem;
  }

  .smp-flight-card__visual {
    width: 116px;
    height: 116px;
    margin-top: 1.45rem;
    border-radius: 20px;
  }

  .smp-flight-card__content {
    padding-top: 1.45rem;
  }

  .smp-flight-card__label {
    font-size: 0.58rem !important;
  }

  .smp-flight-card h3 {
    font-size: clamp(1.15rem, 5.7vw, 1.48rem) !important;
    margin-bottom: 0.34rem !important;
  }

  .smp-flight-card p:not(.smp-flight-card__label) {
    font-size: 0.84rem !important;
    line-height: 1.36 !important;
  }

  .smp-flight-story__final {
    padding-bottom: clamp(5rem, 17vw, 6.5rem);
  }
}

/* ==========================================================
   06. TRUST / REVIEWS CAROUSEL
   ========================================================== */

.smp-proof-intro {
  max-width: 42ch;
  margin: 0 auto 1.5rem !important;
  color: rgba(255,255,255,.88) !important;
}

.smp-reviews-carousel {
  width: 100%;
  max-width: 820px;
  margin: 0 auto;
  overflow: hidden;
  position: relative;
}

.smp-reviews-track {
  display: flex;
  transition: transform .4s cubic-bezier(.4,0,.2,1);
  will-change: transform;
}

.smp-review-card {
  background: #efefef;
  border-radius: 12px;
  padding: 1.25rem 1.5rem;
  width: 100%;
  min-width: 100%;
  max-width: 100%;
  box-sizing: border-box;
  flex: 0 0 100%;
  flex-shrink: 0;
}

.smp-review-card__header {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  gap: 12px;
  margin-bottom: .75rem;
}

.smp-review-card__person {
  display: flex;
  align-items: center;
  gap: 12px;
  min-width: 0;
}

.smp-review-card__avatar-init {
  width: 44px;
  height: 44px;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  font-weight: 800;
  font-size: .95rem;
  color: #fff;
  flex-shrink: 0;
}

.smp-review-card__identity {
  min-width: 0;
}

.smp-review-card__name {
  font-size: 1rem;
  line-height: 1.15;
  font-weight: 700;
  color: #111;
}

.smp-review-card__meta {
  font-size: .8rem;
  color: #666;
  margin-top: 2px;
}

.smp-review-card__google {
  width: 22px;
  height: 22px;
  object-fit: contain;
  flex-shrink: 0;
  margin-top: 4px;
}

.smp-review-card__stars {
  font-size: 1.2rem;
  line-height: 1;
  color: #e5b53a;
  letter-spacing: 1px;
  margin-bottom: .75rem;
}

.smp-review-card__quote {
  font-size: clamp(.9rem,1.8vw,1rem);
  line-height: 1.5;
  font-weight: 400;
  color: #111;
  margin-left: 0;
  word-break: break-word;
}

.smp-reviews-nav {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 1rem;
  margin-top: 1.25rem;
}

.smp-reviews-btn {
  background: rgba(255,255,255,.5);
  border: 1px solid rgba(255,255,255,.6);
  color: #fff;
  width: 36px;
  height: 36px;
  border-radius: 50%;
  font-size: 1rem;
  cursor: pointer;
  transition: background .2s;
  display: flex;
  align-items: center;
  justify-content: center;
}

.smp-reviews-btn:hover {
  background: rgba(255,255,255,.7);
}

.smp-reviews-dots {
  display: flex;
  gap: 8px;
}

.smp-reviews-dot {
  width: 8px;
  height: 8px;
  border-radius: 50%;
  background: rgba(255,255,255,.4);
  cursor: pointer;
  transition: background .2s;
}

.smp-reviews-dot.active {
  background: #fff;
}

@media (max-width: 600px) {
  .smp-review-card {
    padding: .875rem 1rem;
  }

  .smp-review-card__quote {
    font-size: .9rem;
  }
}

/* ==========================================================
   07. FAQ
   ========================================================== */

.smp-cgn-faq {
  background: #fff !important;
}

.smp-cgn-faq__list {
  max-width: 860px;
  margin-left: auto;
  margin-right: auto;
  margin-top: clamp(1.75rem, 4vw, 2.5rem);
}

.smp-cgn-faq .wp-block-details.smp-cgn-faq__item {
  margin-bottom: 0.85rem;
  padding: 1rem 1.1rem;
  background: var(--smp-card-bg);
  border: 1px solid var(--smp-border);
  border-radius: 16px;
}

.smp-cgn-faq .wp-block-details summary {
  position: relative;
  list-style: none;
  cursor: pointer;
  color: var(--smp-navy);
  font-size: clamp(0.98rem, 1.2vw, 1.08rem);
  font-weight: 800;
  line-height: 1.35;
  padding-right: 1.75rem;
}

.smp-cgn-faq .wp-block-details summary::-webkit-details-marker {
  display: none;
}

.smp-cgn-faq .wp-block-details summary::after {
  content: "+";
  position: absolute;
  right: 0;
  top: 0;
  color: var(--smp-orange);
  font-size: 1.2rem;
  font-weight: 800;
  line-height: 1;
}

.smp-cgn-faq .wp-block-details[open] summary::after {
  content: "-";
}

.smp-cgn-faq .wp-block-details p {
  margin-top: 0.8rem !important;
  color: var(--smp-text);
  line-height: 1.6;
}

/* ==========================================================
   08. WHAT YOU GET / PHASE CAROUSELS
   ========================================================== */

.smp-night-phases {
  margin-top: clamp(1.5rem, 4vw, 2.25rem);
}

.smp-night-phases > .wp-block-column {
  display: flex;
}

.smp-night-phase {
  position: relative;
  width: 100%;
  min-height: clamp(420px, 52vw, 560px);
  border-radius: 22px;
  overflow: hidden;
  border: 1px solid var(--smp-border);
  isolation: isolate;
}

.smp-night-phase--social {
  box-shadow: 0 18px 38px rgba(255, 89, 0, 0.18);
}

.smp-night-phase--party {
  box-shadow: 0 8px 20px rgba(5, 37, 64, 0.08);
}

.smp-night-phase__slides {
  position: absolute;
  inset: 0;
}

.smp-night-phase__slide {
  position: absolute;
  inset: 0;
  opacity: 0;
  visibility: hidden;
  pointer-events: none;
  z-index: 1;
  will-change: opacity;
  backface-visibility: hidden;
  transition:
    opacity .9s ease-in-out,
    visibility 0s linear .9s;
}

.smp-night-phase__slide.is-active {
  opacity: 1;
  visibility: visible;
  pointer-events: auto;
  z-index: 2;
  transition:
    opacity .9s ease-in-out,
    visibility 0s linear 0s;
}

.smp-night-phase__slide--text {
  display: flex;
  align-items: stretch;
}

.smp-night-phase__slide--social {
  background: linear-gradient(180deg, #ff7a1a 0%, #ff5900 100%);
}

.smp-night-phase__slide--party {
  background: linear-gradient(180deg, #eef2f5 0%, #e4e9ef 100%);
}

.smp-night-phase__overlay {
  position: relative;
  z-index: 2;
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  justify-content: flex-start;
  width: 100%;
  height: 100%;
  padding: clamp(1.6rem, 3vw, 2rem);
}

.smp-night-phase__label {
  display: inline-flex;
  align-items: center;
  min-height: 44px;
  margin: 0 0 1rem !important;
  padding: .55rem .95rem;
  border-radius: 999px;
  font-size: .78rem;
  font-weight: 800;
  letter-spacing: .06em;
  text-transform: uppercase;
  line-height: 1.1;
}

.smp-night-phase__slide--social .smp-night-phase__label {
  background: rgba(255,255,255,.16);
  color: rgba(255,255,255,.98);
}

.smp-night-phase__slide--party .smp-night-phase__label {
  background: rgba(5,37,64,.08);
  color: var(--smp-navy);
}

.smp-night-phase__title {
  margin: 0 0 .7rem !important;
  font-size: clamp(2rem, 4vw, 3rem) !important;
  font-weight: 900 !important;
  line-height: .98 !important;
  letter-spacing: -.04em !important;
  max-width: 10ch;
}

.smp-night-phase__slide--social .smp-night-phase__title {
  color: #fff !important;
}

.smp-night-phase__slide--party .smp-night-phase__title {
  color: var(--smp-navy) !important;
}

.smp-night-phase__intro {
  margin: 0 !important;
  max-width: 22ch;
  font-size: clamp(1rem, 1.7vw, 1.2rem);
  line-height: 1.5;
  font-weight: 500;
}

.smp-night-phase__slide--social .smp-night-phase__intro {
  color: rgba(255,255,255,.96);
}

.smp-night-phase__slide--party .smp-night-phase__intro {
  color: rgba(5,37,64,.62);
}

.smp-night-phase__slide--image {
  background-size: cover;
  background-position: center center;
  background-repeat: no-repeat;
}

.smp-night-phase__chip-wrap {
  position: absolute;
  top: 1.1rem;
  left: 1.1rem;
  z-index: 3;
  width: auto;
  max-width: calc(100% - 2.2rem);
}

.smp-night-phase__chip {
  display: inline-flex !important;
  align-items: center;
  justify-content: center;
  width: fit-content !important;
  max-width: none;
  min-width: 0;
  min-height: 0;
  margin: 0 !important;
  padding: .58rem .95rem;
  border-radius: 999px;
  font-size: .78rem;
  font-weight: 800;
  letter-spacing: .04em;
  text-transform: uppercase;
  line-height: 1.1;
  white-space: nowrap;
  box-shadow: 0 8px 18px rgba(0,0,0,.12);
  backdrop-filter: blur(8px);
}

.smp-night-phase__chip--two-line {
  display: inline-flex !important;
  width: fit-content !important;
  max-width: 16rem;
  white-space: normal;
  line-height: 1.18;
}

.smp-night-phase__chip--social {
  background: rgba(255, 89, 0, .88);
  color: #fff;
}

.smp-night-phase__chip--party {
  background: rgba(5, 37, 64, .88);
  color: #fff;
}

.smp-night-phases__closing {
  margin-top: 1.25rem !important;
  font-size: clamp(1.05rem, 2vw, 1.2rem);
  font-weight: 800;
  color: var(--smp-navy);
}

@media (max-width: 781px) {
  .smp-night-phase {
    min-height: 360px;
    border-radius: 18px;
  }

  .smp-night-phase__overlay {
    padding: 1.2rem 1rem 1rem;
  }

  .smp-night-phase__label {
    min-height: 38px;
    margin-bottom: .85rem !important;
    padding: .48rem .8rem;
    font-size: .68rem;
  }

  .smp-night-phase__title {
    font-size: clamp(1.65rem, 7vw, 2.2rem) !important;
    max-width: 11ch;
    margin-bottom: .55rem !important;
  }

  .smp-night-phase__intro {
    max-width: 20ch;
    font-size: .95rem;
    line-height: 1.45;
  }

  .smp-night-phase__chip-wrap {
    top: .95rem;
    left: .95rem;
    max-width: calc(100% - 1.9rem);
  }

  .smp-night-phase__chip {
    width: fit-content !important;
    max-width: none;
    min-height: 0;
    padding: .5rem .82rem;
    font-size: .68rem;
    line-height: 1.08;
    white-space: nowrap;
  }

  .smp-night-phase__chip--two-line {
    width: fit-content !important;
    max-width: 13.5rem;
    white-space: normal;
    line-height: 1.16;
  }
}

/* ==========================================================
   09. MAIN TICKET DECISION
   ========================================================== */

.smp-ticket-swiper-wrap {
  overflow: hidden;
}

.smp-ticket-swipe-row {
  display: flex !important;
  flex-wrap: wrap !important;
  align-items: stretch !important;
  gap: 1rem !important;
  margin-left: 0 !important;
  margin-right: 0 !important;
}

.smp-ticket-swipe-row > .wp-block-column {
  display: flex !important;
  align-self: stretch !important;
  flex: 1 1 calc(25% - 0.75rem) !important;
  min-width: 0 !important;
}

.smp-ticket-swipe-row > .wp-block-column > * {
  width: 100% !important;
  min-width: 0 !important;
  min-height: 100% !important;
}

.smp-ticket-swipe-row .smp-card,
.smp-ticket-swipe-row .smp-ticket-text-slide {
  height: 100% !important;
  min-height: 100% !important;
  border-radius: 24px !important;
  overflow: hidden;
  background: #faf8ef !important;
  border: 1px solid #d9dee5 !important;
  box-shadow: 0 10px 24px rgba(5,37,64,.08) !important;
}

.smp-ticket-swipe-row .smp-card.smp-special {
  border: 1px solid #d9dee5 !important;
  box-shadow: 0 10px 24px rgba(5,37,64,.08) !important;
}

.smp-ticket-swipe-row .smp-card--offer {
  position: relative;
  box-shadow:
    0 16px 34px rgba(5,37,64,.12),
    0 0 0 1px rgba(200,63,91,.08) !important;
  transform: translateY(-4px);
}

.smp-ticket-swipe-row .smp-card,
.smp-ticket-swipe-row .smp-ticket-text-slide {
  cursor: pointer;
}

.smp-ticket-swipe-row .smp-card:focus-visible,
.smp-ticket-swipe-row .smp-ticket-text-slide:focus-visible {
  outline: 3px solid rgba(0, 176, 188, 0.45);
  outline-offset: 4px;
}

.smp-offer-badge {
  position: absolute;
  top: 42px;
  left: 50%;
  transform: translateX(-50%);
  z-index: 4;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 32px;
  padding: 0.42rem 0.78rem;
  border-radius: 999px;
  background: #052540;
  color: #fff;
  font-size: 0.68rem;
  font-weight: 900;
  letter-spacing: 0.05em;
  text-transform: uppercase;
  box-shadow: 0 10px 22px rgba(5,37,64,.18);
  white-space: nowrap;
}

.smp-ticket-swipe-row .smp-special-banner,
.smp-ticket-swipe-row .smp-soft-banner {
  min-height: 48px;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 0.82rem 1rem;
  text-align: center;
  font-size: 0.86rem;
  line-height: 1;
  font-weight: 900;
  letter-spacing: 0.04em;
  text-transform: uppercase;
}

.smp-ticket-swipe-row .smp-special-banner {
  background: linear-gradient(90deg, #c83f5b 0%, #d68735 100%);
  color: #fff;
}

.smp-ticket-swipe-row .smp-soft-banner {
  background: #eef2f5;
  color: #7a8792;
  border-bottom: 1px solid rgba(5,37,64,.06);
}

.smp-ticket-swipe-row .smp-card .card-content {
  display: flex;
  flex-direction: column;
  flex: 1 1 auto;
  padding: 1.05rem 1rem 0 !important;
}

.smp-ticket-swipe-row .smp-card--offer .card-content {
  padding-top: 2rem !important;
}

.smp-ticket-swipe-row .smp-title {
  min-height: auto !important;
  max-width: 14ch;
  margin: 0 auto 0.55rem !important;
  text-align: center !important;
  color: var(--smp-navy);
  font-size: clamp(1.55rem, 2vw, 1.9rem) !important;
  font-weight: 900 !important;
  line-height: 1.04 !important;
  letter-spacing: -0.04em !important;
  text-wrap: balance;
}

.smp-price-anchor {
  display: flex;
  justify-content: center;
  align-items: baseline;
  gap: 0.2rem;
  margin: 0 0 0.2rem;
}

.smp-price-anchor__value {
  color: var(--smp-navy);
  font-size: clamp(2.1rem, 4.2vw, 2.8rem);
  font-weight: 900;
  line-height: 1;
  letter-spacing: -0.05em;
  text-align: center;
}

.smp-price-anchor__sub {
  margin: 0 auto 0.8rem !important;
  text-align: center;
  color: #6d7688;
  font-size: 0.88rem;
  line-height: 1.25;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.04em;
}

.smp-ticket-swipe-row .smp-sub {
  min-height: auto !important;
  max-width: 18ch;
  margin: 0 auto 1rem !important;
  text-align: center !important;
  color: var(--smp-navy);
  font-size: 0.98rem;
  line-height: 1.5;
  font-weight: 400 !important;
  text-wrap: balance;
}

#events .smp-features,
#club-tickets .smp-features {
  margin: 0;
  padding: 0;
  list-style: none;
}

#events .smp-features li,
#club-tickets .smp-features li {
  display: grid;
  grid-template-columns: 44px minmax(0, 1fr);
  column-gap: .8rem;
  align-items: center;
  padding: 1rem 0;
  border-top: 1px solid rgba(5, 37, 64, 0.08);
  min-width: 0;
}

#events .smp-features li:last-child,
#club-tickets .smp-features li:last-child {
  padding-bottom: 0;
}

#events .smp-features strong,
#events .smp-value,
#club-tickets .smp-features strong,
#club-tickets .smp-value {
  grid-column: 2;
  min-width: 0;
}

#events .smp-features strong,
#club-tickets .smp-features strong {
  color: #000;
  font-size: clamp(.95rem, 1vw, 1rem);
  font-weight: 800;
  line-height: 1.15;
  margin-bottom: .18rem;
}

#events .smp-value,
#club-tickets .smp-value {
  color: var(--smp-navy);
  font-size: clamp(.95rem, 1vw, 1rem);
  font-weight: 500;
  line-height: 1.25;
  overflow-wrap: break-word;
}

#events .check,
#club-tickets .check {
  grid-column: 1;
  grid-row: 1 / span 2;
  position: relative;
  width: 38px;
  height: 38px;
  border: 3px solid rgba(0, 176, 188, 0.34);
  border-radius: 50%;
  justify-self: center;
  align-self: center;
  box-sizing: border-box;
}

#events .check::before,
#club-tickets .check::before {
  content: "";
  position: absolute;
  left: 11px;
  top: 5px;
  width: 7px;
  height: 14px;
  border-right: 3px solid rgba(0, 176, 188, 0.75);
  border-bottom: 3px solid rgba(0, 176, 188, 0.75);
  transform: rotate(40deg);
}

.smp-ticket-swipe-row .smp-features {
  width: 100%;
  max-width: 280px;
  margin: 0 auto !important;
  padding: 0.3rem 0.88rem !important;
  list-style: none;
  background: #e9edf2;
  border-radius: 14px;
}

.smp-ticket-swipe-row .smp-features li {
  display: grid !important;
  grid-template-columns: 30px minmax(0, 1fr) !important;
  gap: 0.12rem 0.62rem;
  align-items: center;
  padding: 0.72rem 0 !important;
  border-top: 1px solid rgba(5,37,64,.08);
}

.smp-ticket-swipe-row .smp-features li:first-child {
  border-top: 0;
}

.smp-ticket-swipe-row .smp-features strong,
.smp-ticket-swipe-row .smp-value {
  grid-column: 2;
  min-width: 0;
}

.smp-ticket-swipe-row .smp-features strong {
  color: #111;
  font-size: 0.95rem;
  font-weight: 900;
  line-height: 1.14;
  margin: 0 0 0.08rem !important;
}

.smp-ticket-swipe-row .smp-value {
  color: #1f2430;
  font-size: 0.92rem;
  font-weight: 400;
  line-height: 1.22;
  overflow-wrap: break-word;
}

.smp-ticket-swipe-row .check {
  grid-column: 1;
  grid-row: 1 / span 2;
  position: relative;
  width: 24px;
  height: 24px;
  border: 2px solid rgba(103,164,187,.75);
  border-radius: 50%;
  justify-self: center;
  align-self: center;
  background: transparent;
}

.smp-ticket-swipe-row .check::before {
  content: "";
  position: absolute;
  left: 6px;
  top: 2px;
  width: 4px;
  height: 9px;
  border-right: 2px solid rgba(103,164,187,.9);
  border-bottom: 2px solid rgba(103,164,187,.9);
  transform: rotate(40deg);
}

.smp-ticket-swipe-row .smp-band {
  margin-top: 0.9rem;
  padding: 0.9rem 1rem;
  background: #74aec3;
  color: #fff !important;
  text-align: center;
  font-size: 0.95rem;
  font-weight: 900;
  line-height: 1.1;
  text-decoration: none !important;
}

.smp-ticket-swipe-row .smp-card--offer .smp-band {
  background: var(--smp-orange) !important;
}

.smp-ticket-swipe-row .smp-band:hover {
  filter: brightness(.97);
}

.smp-ticket-text-slide {
  display: flex !important;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  text-align: center;
  padding: 1.35rem 1.1rem;
  background: #faf8ef !important;
}

.smp-ticket-text-slide .mirror-eyebrow,
.smp-ticket-text-slide .mirror-headline,
.smp-ticket-text-slide .mirror-sub {
  text-align: center !important;
  margin-left: auto !important;
  margin-right: auto !important;
}

.smp-ticket-text-slide .mirror-eyebrow {
  margin-bottom: 0.65rem !important;
}

.smp-ticket-text-slide .mirror-headline {
  max-width: 10ch !important;
  margin-bottom: 0.9rem !important;
  font-size: clamp(1.8rem, 2.3vw, 2.15rem) !important;
  line-height: 1.04 !important;
  letter-spacing: -0.04em !important;
}

.smp-ticket-text-slide .mirror-sub {
  max-width: 20ch !important;
  color: #6d7688 !important;
  font-size: 0.98rem !important;
  line-height: 1.52 !important;
  font-weight: 400 !important;
}

@media (max-width: 1100px) {
  .smp-ticket-swipe-row > .wp-block-column {
    flex: 1 1 calc(50% - 0.5rem) !important;
  }
}

@media (max-width: 781px) {
  .smp-ticket-swiper-wrap {
    padding-left: 1rem !important;
    padding-right: 1rem !important;
  }

  .smp-ticket-swipe-row {
    display: grid !important;
    grid-auto-flow: column;
    grid-auto-columns: calc(100% - 3.25rem);
    gap: 1rem !important;
    overflow-x: auto;
    overscroll-behavior-x: contain;
    scroll-snap-type: x mandatory;
    -webkit-overflow-scrolling: touch;
    scroll-padding-left: 1rem;
    padding: 0 1rem 0.5rem 1rem;
    margin: 0 -1rem !important;
    align-items: stretch !important;
  }

  .smp-ticket-swipe-row > .wp-block-column {
    display: flex !important;
    flex: none !important;
    width: auto !important;
    min-width: 0 !important;
    margin: 0 !important;
    align-self: stretch !important;
    scroll-snap-align: center;
  }

  .smp-ticket-swipe-row > .wp-block-column > * {
    width: 100% !important;
    min-height: 100% !important;
  }

  .smp-ticket-swipe-row .smp-card,
  .smp-ticket-swipe-row .smp-ticket-text-slide {
    min-height: 500px !important;
    border-radius: 22px !important;
  }

  .smp-offer-badge {
    top: 40px;
    min-height: 30px;
    padding: 0.38rem 0.7rem;
    font-size: 0.62rem;
  }

  .smp-ticket-swipe-row .smp-special-banner,
  .smp-ticket-swipe-row .smp-soft-banner {
    min-height: 44px;
    font-size: 0.8rem;
  }

  .smp-ticket-swipe-row .smp-card .card-content {
    padding: 0.95rem 0.95rem 0 !important;
  }

  .smp-ticket-swipe-row .smp-card--offer .card-content {
    padding-top: 1.9rem !important;
  }

  .smp-ticket-swipe-row .smp-title {
    max-width: 13ch;
    font-size: clamp(1.28rem, 5.8vw, 1.6rem) !important;
    margin-bottom: 0.48rem !important;
  }

  .smp-price-anchor__value {
    font-size: clamp(1.95rem, 8vw, 2.3rem);
  }

  .smp-price-anchor__sub {
    font-size: 0.8rem;
    margin-bottom: 0.75rem !important;
  }

  .smp-ticket-swipe-row .smp-sub {
    max-width: 17ch;
    font-size: 0.92rem;
    line-height: 1.48;
    margin-bottom: 0.9rem !important;
  }

  .smp-ticket-swipe-row .smp-features {
    max-width: 252px;
    padding: 0.25rem 0.78rem !important;
    border-radius: 13px;
  }

  .smp-ticket-swipe-row .smp-features li {
    grid-template-columns: 28px minmax(0, 1fr) !important;
    gap: 0.12rem 0.56rem;
    padding: 0.68rem 0 !important;
  }

  .smp-ticket-swipe-row .check {
    width: 22px;
    height: 22px;
  }

  .smp-ticket-swipe-row .check::before {
    left: 5px;
    top: 2px;
    width: 4px;
    height: 8px;
  }

  .smp-ticket-swipe-row .smp-features strong {
    font-size: 0.9rem;
  }

  .smp-ticket-swipe-row .smp-value {
    font-size: 0.88rem;
  }

  .smp-ticket-swipe-row .smp-band {
    margin-top: 0.82rem;
    padding: 0.86rem 1rem;
    font-size: 0.92rem;
  }

  .smp-ticket-text-slide {
    padding: 1.15rem 1rem;
  }

  .smp-ticket-text-slide .mirror-headline {
    font-size: clamp(1.6rem, 6.8vw, 1.9rem) !important;
    max-width: 10ch !important;
  }

  .smp-ticket-text-slide .mirror-sub {
    max-width: 19ch !important;
    font-size: 0.94rem !important;
  }

  .smp-ticket-swipe-row::-webkit-scrollbar {
    display: none;
  }
}

@media (max-width: 480px) {
  .smp-ticket-swipe-row .smp-card,
  .smp-ticket-swipe-row .smp-ticket-text-slide {
    min-height: 480px !important;
  }
}

/* ==========================================================
   10. INSTAGRAM REEL / ENERGY PREVIEW
   ========================================================== */

.smp-tanz-reel-block {
  background: #fcfaf1 !important;
}

.smp-tanz-reel-block__grid {
  align-items: center !important;
}

.smp-tanz-reel-block .mirror-eyebrow,
.smp-tanz-reel-block .mirror-headline,
.smp-tanz-reel-block .mirror-sub {
  text-align: left !important;
  margin-left: 0 !important;
  margin-right: 0 !important;
}

.smp-tanz-reel-block .mirror-headline {
  max-width: 12ch !important;
  margin-bottom: 1rem !important;
}

.smp-tanz-reel-block .mirror-sub {
  max-width: 38rem !important;
}

.smp-tanz-reel-block__actions {
  margin-top: 1.25rem !important;
}

.smp-tanz-reel-block__actions .wp-block-button__link {
  padding: 0.9rem 1.5rem !important;
  font-weight: 800 !important;
  border-radius: 13px !important;
  box-shadow: var(--smp-shadow) !important;
}

.smp-tanz-reel-embed {
  width: 100%;
  max-width: 520px;
  margin-left: auto;
  background: #fff;
  border: 1px solid var(--smp-border);
  border-radius: 22px;
  box-shadow: var(--smp-shadow);
  overflow: hidden;
  padding: 0.75rem;
}

.smp-tanz-reel-embed blockquote.instagram-media,
.smp-tanz-reel-embed iframe {
  width: 100% !important;
  max-width: 100% !important;
  min-width: 100% !important;
  margin: 0 !important;
}

@media (max-width: 781px) {
  .smp-tanz-reel-block {
    padding-left: 1rem !important;
    padding-right: 1rem !important;
  }

  .smp-tanz-reel-block__grid {
    flex-direction: column !important;
    gap: 1.25rem !important;
  }

  .smp-tanz-reel-block .mirror-headline {
    max-width: none !important;
  }

  .smp-tanz-reel-block__actions,
  .smp-tanz-reel-block__actions .wp-block-button,
  .smp-tanz-reel-block__actions .wp-block-button__link {
    width: 100%;
  }

  .smp-tanz-reel-embed {
    max-width: 100%;
    margin-left: 0;
    padding: 0.6rem;
    border-radius: 20px;
  }
}

/* ==========================================================
   11. AUDIENCE FIT / PERSONA CARDS
   ========================================================== */

.smp-persona-grid {
  margin-top: clamp(1.5rem, 4vw, 2.25rem);
}

.smp-persona-grid > .wp-block-column {
  display: flex;
}

.smp-persona-card {
  width: 100%;
  height: 100%;
  background: var(--smp-card-bg);
  border: 1px solid var(--smp-border);
  border-radius: 18px;
  box-shadow: var(--smp-shadow-sm);
  padding: 1.15rem 1rem 1rem;
  text-align: center;
}

.smp-persona-card__icon {
  margin: 0 0 .6rem !important;
  font-size: 1.8rem;
  line-height: 1;
}

.smp-persona-card__title {
  margin: 0 0 .45rem !important;
  font-size: clamp(1rem, 2.5vw, 1.2rem) !important;
  font-weight: 800 !important;
  line-height: 1.2 !important;
  color: var(--smp-navy) !important;
}

.smp-persona-card__text {
  margin: 0 !important;
  color: var(--smp-muted);
  line-height: 1.55;
  font-size: .95rem;
}

.smp-persona-grid__note {
  margin-top: 1.15rem !important;
  font-size: clamp(1rem, 2vw, 1.1rem);
  font-weight: 700;
  color: var(--smp-navy);
}

@media (max-width: 781px) {
  .smp-persona-card {
    padding: 1rem .9rem .95rem;
  }

  .smp-persona-card__icon {
    font-size: 1.7rem;
  }

  .smp-persona-card__text {
    font-size: .92rem;
  }
}

/* ==========================================================
   12. STICKY MOBILE CTA
   ========================================================== */

.smp-sticky-ticket-cta {
  position: fixed;
  left: 0;
  right: 0;
  bottom: 0;
  z-index: 40;
  transform: translateY(120%);
  transition: transform var(--smp-duration, .22s) var(--smp-ease, cubic-bezier(.4,0,.2,1));
  padding: .75rem 1rem calc(.75rem + env(safe-area-inset-bottom));
  background: rgba(5,37,64,.96);
  backdrop-filter: blur(10px);
  box-shadow: 0 -10px 30px rgba(0,0,0,.18);
}

.smp-sticky-ticket-cta.is-visible {
  transform: translateY(0);
}

.smp-sticky-ticket-cta__inner {
  max-width: 480px;
  margin: 0 auto;
  display: flex;
  flex-direction: column;
  gap: .45rem;
}

.smp-sticky-ticket-cta__eyebrow {
  color: rgba(255,255,255,.78);
  font-size: .72rem;
  font-weight: 700;
  letter-spacing: .08em;
  text-transform: uppercase;
  text-align: center;
}

.smp-sticky-ticket-cta .wp-element-button {
  display: block;
  width: 100%;
  text-align: center;
  text-decoration: none !important;
  padding: .9rem 1rem !important;
  border-radius: 13px !important;
  background: var(--smp-teal) !important;
  color: #fff !important;
  font-weight: 800 !important;
}

.smp-sticky-ticket-cta-spacer {
  display: none;
}

@media (min-width: 782px) {
  .smp-sticky-ticket-cta,
  .smp-sticky-ticket-cta-spacer {
    display: none !important;
  }
}

@media (max-width: 781px) {
  .smp-sticky-ticket-cta-spacer {
    display: block;
    height: 5.75rem;
  }
}

/* ==========================================================
   13. TICKET MODAL
   ========================================================== */

body.smp-ticket-modal-open {
  overflow: hidden;
}

.smp-ticket-modal {
  position: fixed;
  inset: 0;
  z-index: 99999;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 1.25rem;
  opacity: 0;
  visibility: hidden;
  pointer-events: none;
  transition:
    opacity .24s ease,
    visibility 0s linear .24s;
}

.smp-ticket-modal.is-open {
  opacity: 1;
  visibility: visible;
  pointer-events: auto;
  transition:
    opacity .24s ease,
    visibility 0s linear 0s;
}

.smp-ticket-modal__backdrop {
  position: absolute;
  inset: 0;
  background: rgba(5, 37, 64, 0.68);
  backdrop-filter: blur(6px);
}

.smp-ticket-modal__dialog {
  position: relative;
  z-index: 2;
  width: min(100%, 980px);
  max-height: min(88vh, 920px);
  overflow: auto;
  background: #fff;
  border-radius: 24px;
  box-shadow: 0 24px 70px rgba(5, 37, 64, 0.28);
}

.smp-ticket-modal__header {
  position: sticky;
  top: 0;
  z-index: 3;
  padding: 1rem 1.25rem .75rem;
  background: #fff;
  border-bottom: 1px solid rgba(5, 37, 64, 0.08);
}

.smp-ticket-modal__title {
  margin: 0 !important;
  color: var(--smp-navy);
  font-size: clamp(1.2rem, 2vw, 1.5rem) !important;
  font-weight: 900 !important;
  line-height: 1.1 !important;
  letter-spacing: -.03em !important;
}

.smp-ticket-modal__close {
  position: absolute;
  top: .8rem;
  right: .8rem;
  z-index: 4;
  width: 42px;
  height: 42px;
  border: 0;
  border-radius: 999px;
  background: rgba(5, 37, 64, 0.08);
  color: var(--smp-navy);
  font-size: 1.6rem;
  line-height: 1;
  cursor: pointer;
}

.smp-ticket-modal__close:hover {
  background: rgba(5, 37, 64, 0.14);
}

.smp-ticket-modal__body {
  padding: 1rem 1.25rem 1.25rem;
}

.smp-ticket-modal__widget {
  min-height: 320px;
}

@media (max-width: 781px) {
  .smp-ticket-modal {
    padding: .75rem;
  }

  .smp-ticket-modal__dialog {
    width: 100%;
    max-height: 92vh;
    border-radius: 18px;
  }

  .smp-ticket-modal__header {
    padding: .95rem 1rem .7rem;
  }

  .smp-ticket-modal__body {
    padding: .85rem 1rem 1rem;
  }

  .smp-ticket-modal__close {
    top: .65rem;
    right: .65rem;
    width: 40px;
    height: 40px;
  }
}

/* ==========================================================
   14. COOKIE / CONSENT REVISIT BUTTON
   ========================================================== */

@media (max-width: 781px) {
  .cky-btn-revisit-wrapper,
  .cky-revisit-bottom-left,
  #cookie-law-info-again,
  .cli_settings_button,
  .cmplz-manage-consent {
    left: 0.55rem !important;
    bottom: 0.55rem !important;
    transform: scale(0.72) !important;
    transform-origin: left bottom !important;
    z-index: 35 !important;
  }
}

/* ==========================================================
   15. ACCESSIBILITY / REDUCED MOTION
   ========================================================== */

@media (prefers-reduced-motion: reduce) {
  .smp-night-phase__slide,
  .smp-night-phase__slide.is-active,
  .smp-reviews-track,
  .smp-card,
  .smp-scroll-pill,
  .smp-scroll-pill__icon,
  .smp-special-event-hero__button .wp-block-button__link,
  .smp-flight-story__actions .wp-block-button__link {
    transition: none !important;
    animation: none !important;
  }
}
