.vip-life-scroll-section {
  --vip-life-viewport: 100vh;
  position: relative;
  height: var(--vip-scroll-height, 500vh);
  width: 100%;
  max-width: 100%;
  background: transparent;
  overflow-x: clip;
}

@supports (height: 100dvh) {
  .vip-life-scroll-section {
    --vip-life-viewport: 100dvh;
  }
}

html,
body {
  overflow-x: clip;
}

.vip-life-elementor-widget-host,
.vip-life-elementor-widget-host > .elementor-widget-container,
.vip-life-elementor-widget-container {
  width: 100% !important;
  max-width: none !important;
  overflow: visible !important;
}

.vip-life-elementor-widget-host {
  position: relative;
  overflow-x: clip !important;
}

.vip-life-elementor-scroll-host {
  overflow: visible !important;
  height: auto !important;
  min-height: 0 !important;
  max-height: none !important;
}

.vip-life-elementor-widget-host .vip-life-scroll-section {
  width: 100%;
  max-width: 100%;
  margin-left: 0;
  margin-right: 0;
}

.vip-life-sticky {
  position: sticky;
  top: 0;
  height: var(--vip-life-viewport);
  overflow: hidden;
  isolation: isolate;
}

.vip-life-bg {
  position: absolute;
  inset: 0;
  z-index: -1;
  background-size: cover;
  background-position: center;
  background-repeat: no-repeat;
}

.vip-life-bg-default {
  background: transparent;
}

.vip-life-bg-a {
  z-index: -3;
}

.vip-life-bg-b {
  z-index: -2;
}

.is-vip-life-bg-reveal .vip-life-bg-b,
.is-vip-life-bg-reveal .vip-life-bg-overlay-reveal {
  -webkit-mask-image: radial-gradient(
    circle at 100% 0%,
    #000 0,
    #000 var(--vip-bg-reveal-inner-size, 0vmax),
    rgba(0, 0, 0, 0) var(--vip-bg-reveal-size, 0vmax)
  );
  mask-image: radial-gradient(
    circle at 100% 0%,
    #000 0,
    #000 var(--vip-bg-reveal-inner-size, 0vmax),
    rgba(0, 0, 0, 0) var(--vip-bg-reveal-size, 0vmax)
  );
  -webkit-mask-repeat: no-repeat;
  mask-repeat: no-repeat;
  -webkit-mask-size: 100% 100%;
  mask-size: 100% 100%;
  will-change: mask-image, opacity;
  transform: translateZ(0);
}

.is-vip-life-bg-reveal .vip-life-bg-b {
  opacity: 1;
}

.vip-life-bg-video {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.vip-life-bg-overlay {
  position: absolute;
  inset: 0;
  z-index: -1;
  background: #000;
  pointer-events: none;
}

.vip-life-content {
  width: min(var(--vip-life-content-width, 100%), 100%);
  height: 100%;
  margin-inline: auto;
  display: grid;
  grid-template-columns: minmax(0, 0.9fr) minmax(0, 1.1fr);
  column-gap: clamp(28px, 5vw, 88px);
}

.vip-life-copy {
  width: min(620px, 86%);
  margin: auto 0 auto clamp(34px, 9.5vw, 132px);
  padding-block: 7vh;
  color: #f5d980;
  min-width: 0;
}

.vip-life-template {
  width: 100%;
}

.vip-life-kicker {
  margin: 0 0 clamp(48px, 9vh, 112px);
  color: #ffe89b;
  font-family: "Noto Serif TC", "Songti TC", Georgia, serif;
  font-size: clamp(38px, 4.7vw, 74px);
  font-weight: 500;
  line-height: 0.95;
  max-width: 100%;
  overflow-wrap: anywhere;
}

.vip-life-copy h2 {
  margin: 0 0 clamp(58px, 9vh, 104px);
  color: #f5d980;
  font-size: clamp(24px, 2.3vw, 36px);
  font-weight: 500;
  line-height: 1.35;
}

.vip-life-lead {
  margin: 0 0 9vh;
  max-width: 520px;
  color: #ffe38f;
  font-size: clamp(20px, 1.55vw, 28px);
  line-height: 1.65;
  font-weight: 600;
}

.vip-life-body {
  max-width: 520px;
  color: rgba(255, 229, 157, 0.84);
  font-family: "Microsoft JhengHei", "Noto Sans TC", sans-serif;
  font-size: clamp(12px, 0.92vw, 15px);
  line-height: 1.9;
}

.vip-life-button {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 160px;
  min-height: 48px;
  margin-top: clamp(30px, 6vh, 70px);
  padding: 0 24px;
  color: #f5d980;
  border: 1px solid rgba(245, 217, 128, 0.54);
  background: rgba(10, 0, 0, 0.18);
  text-decoration: none;
  font-family: "Microsoft JhengHei", "Noto Sans TC", sans-serif;
  font-size: 16px;
}

.is-vip-life-bg-reveal .vip-life-copy,
.is-vip-life-bg-reveal .vip-life-copy :where(h1, h2, h3, h4, h5, h6, p, span, div, a),
.is-vip-life-bg-reveal .vip-life-count,
.is-vip-life-bg-reveal .vip-life-kicker,
.is-vip-life-bg-reveal .vip-life-copy h2,
.is-vip-life-bg-reveal .vip-life-lead,
.is-vip-life-bg-reveal .vip-life-body,
.is-vip-life-bg-reveal .vip-life-button,
.is-vip-life-bg-reveal .vip-life-template .elementor-heading-title,
.is-vip-life-bg-reveal .vip-life-template .elementor-widget-container,
.is-vip-life-bg-reveal .vip-life-template .elementor-icon-list-text,
.is-vip-life-bg-reveal .vip-life-template .elementor-button,
.is-vip-life-bg-reveal .vip-life-template .elementor-button-text {
  color: var(--vip-life-current-text-color, var(--vip-life-text-color-a, #f5d980)) !important;
}

.is-vip-life-bg-reveal .vip-life-button {
  border-color: var(--vip-life-current-text-color, var(--vip-life-text-color-a, #f5d980));
}

.vip-life-gallery {
  position: relative;
  height: var(--vip-life-viewport);
  min-width: 0;
  overflow: hidden;
  contain: layout paint;
}

.vip-life-count {
  position: absolute;
  top: clamp(22px, 4.5vh, 56px);
  right: clamp(22px, 4vw, 64px);
  z-index: 5;
  display: flex;
  align-items: center;
  gap: 14px;
  color: #f5d980;
  font-family: "Microsoft JhengHei", "Noto Sans TC", sans-serif;
  font-size: 13px;
}

.vip-life-count span:nth-child(2) {
  width: 58px;
  height: 1px;
  background: currentColor;
  opacity: 0.72;
}

.vip-life-gallery-window {
  height: 100%;
  overflow: hidden;
  padding-right: clamp(24px, 4.7vw, 74px);
  -webkit-mask-image: linear-gradient(to bottom, transparent 0%, #000 14%, #000 86%, transparent 100%);
  mask-image: linear-gradient(to bottom, transparent 0%, #000 14%, #000 86%, transparent 100%);
}

.vip-life-track {
  display: grid;
  gap: clamp(28px, 6vh, 70px);
  transform: translate3d(0, var(--vip-life-track-y, 0px), 0);
  transition: transform 520ms cubic-bezier(0.22, 0.8, 0.18, 1);
  will-change: transform;
  contain: layout paint;
}

.vip-life-card {
  position: relative;
  width: min(860px, 96%);
  height: min(62vh, 620px);
  margin: 0 0 0 auto;
  overflow: hidden;
  background: transparent;
  box-shadow: 0 18px 42px rgba(0, 0, 0, 0.28);
  opacity: 0.18;
  transform: scale(0.94);
  transition: opacity 360ms ease, transform 520ms cubic-bezier(0.22, 0.8, 0.18, 1);
  contain: paint;
}

.vip-life-card.is-active {
  opacity: 1;
  transform: scale(1);
}

.vip-life-card:nth-child(2n) {
  width: min(760px, 92%);
}

.vip-life-card img {
  display: block;
  width: 100%;
  height: 100%;
  object-fit: cover;
}

@media (max-width: 1280px) {
  .vip-life-content {
    grid-template-columns: minmax(0, 0.82fr) minmax(0, 1.18fr);
    column-gap: clamp(20px, 3.5vw, 48px);
  }

  .vip-life-copy {
    width: min(520px, 88%);
    margin-left: clamp(28px, 6vw, 82px);
  }

  .vip-life-kicker {
    font-size: clamp(34px, 4.2vw, 58px);
  }
}

@media (max-width: 767px) {
  .vip-life-scroll-section {
    height: auto !important;
    min-height: var(--vip-life-viewport);
    overflow: hidden;
  }

  .vip-life-sticky {
    position: relative;
    top: auto;
    display: flex;
    align-items: center;
    height: auto;
    min-height: inherit;
    overflow: hidden;
    padding: max(18px, env(safe-area-inset-top)) 0 max(18px, env(safe-area-inset-bottom));
  }

  .vip-life-content {
    display: block;
    grid-template-columns: 1fr;
    width: 100%;
    height: auto;
    overflow: visible;
  }

  .vip-life-copy {
    width: 100%;
    margin: 0;
    padding: 0 clamp(18px, 5.6vw, 28px) clamp(16px, 3dvh, 22px);
    max-height: none;
    overflow: visible;
  }

  .vip-life-kicker {
    margin-bottom: 16px;
    font-size: clamp(30px, 10.5vw, 48px);
    line-height: 1.02;
  }

  .vip-life-copy h2 {
    margin-bottom: 12px;
    font-size: clamp(18px, 4.8vw, 22px);
    line-height: 1.35;
  }

  .vip-life-lead {
    display: -webkit-box;
    margin-bottom: 0;
    max-width: none;
    overflow: hidden;
    color: rgba(255, 227, 143, 0.92);
    font-size: clamp(14px, 3.85vw, 16px);
    line-height: 1.5;
    -webkit-box-orient: vertical;
    -webkit-line-clamp: 3;
  }

  .vip-life-body {
    display: none;
  }

  .vip-life-button {
    min-width: 128px;
    min-height: 40px;
    margin-top: 14px;
    padding: 0 18px;
    font-size: 14px;
  }

  .vip-life-template {
    max-height: 100%;
    overflow: hidden;
  }

  .vip-life-template img {
    max-width: 100%;
    height: auto;
  }

  .vip-life-gallery {
    height: auto;
    min-height: 0;
    overflow: visible;
    contain: none;
  }

  .vip-life-count {
    display: none;
  }

  .vip-life-gallery-window {
    height: auto;
    overflow-x: auto;
    overflow-y: hidden;
    padding: 4px clamp(18px, 5.6vw, 28px) 8px;
    scroll-padding-inline: clamp(18px, 5.6vw, 28px);
    scroll-snap-type: x mandatory;
    scrollbar-width: none;
    -webkit-mask-image: none;
    mask-image: none;
    -webkit-overflow-scrolling: touch;
  }

  .vip-life-gallery-window::-webkit-scrollbar {
    display: none;
  }

  .vip-life-track {
    display: flex;
    gap: 14px;
    width: max-content;
    transform: none !important;
    transition: none;
    will-change: auto;
    contain: none;
  }

  .vip-life-card,
  .vip-life-card:nth-child(2n) {
    flex: 0 0 min(82vw, 420px);
    width: min(82vw, 420px);
    height: clamp(260px, 58vw, 380px);
    margin: 0;
    scroll-snap-align: center;
    box-shadow: 0 12px 28px rgba(0, 0, 0, 0.26);
    opacity: 1;
    transform: none;
    transition: none;
  }
}

@media (max-width: 480px) {
  .vip-life-copy {
    padding-inline: 16px;
    padding-bottom: 18px;
  }

  .vip-life-kicker {
    margin-bottom: 12px;
    font-size: clamp(26px, 9.2vw, 38px);
  }

  .vip-life-copy h2 {
    margin-bottom: 8px;
    font-size: clamp(17px, 4.65vw, 20px);
  }

  .vip-life-lead {
    -webkit-line-clamp: 2;
  }

  .vip-life-gallery-window {
    padding-inline: 16px;
    scroll-padding-inline: 16px;
  }

  .vip-life-card,
  .vip-life-card:nth-child(2n) {
    flex-basis: min(84vw, 360px);
    width: min(84vw, 360px);
    height: clamp(230px, 62vw, 330px);
  }
}

@media (max-width: 900px) and (orientation: landscape) {
  .vip-life-scroll-section {
    height: auto !important;
    min-height: var(--vip-life-viewport);
  }

  .vip-life-sticky {
    position: relative;
    height: auto;
    min-height: inherit;
    display: flex;
    align-items: center;
    padding: 28px 0;
  }

  .vip-life-content {
    display: grid;
    grid-template-columns: minmax(0, 0.84fr) minmax(0, 1.16fr);
    column-gap: clamp(14px, 3vw, 28px);
    align-items: center;
  }

  .vip-life-copy {
    align-self: center;
    width: min(430px, 92%);
    margin: 0 0 0 clamp(18px, 4vw, 42px);
    padding: 18px 0;
  }

  .vip-life-kicker {
    margin-bottom: 12px;
    font-size: clamp(24px, 5vw, 38px);
  }

  .vip-life-copy h2 {
    margin-bottom: 8px;
    font-size: clamp(16px, 2.7vw, 20px);
  }

  .vip-life-lead {
    font-size: clamp(13px, 2vw, 15px);
    -webkit-line-clamp: 2;
  }

  .vip-life-gallery {
    height: auto;
  }

  .vip-life-gallery-window {
    padding: 4px clamp(14px, 3vw, 24px) 8px 0;
  }

  .vip-life-card,
  .vip-life-card:nth-child(2n) {
    flex-basis: min(54vw, 440px);
    width: min(54vw, 440px);
    height: min(66dvh, 330px);
  }
}
