/* =============================================================
   Lumi Security Elementor Pack – Main Stylesheet
   Version: 1.0.0
   ============================================================= */

/* ── Global Reset / Base ─────────────────────────────────── */
.lumi-section-title,
.lumi-premium-header,
.lumi-image-card,
.lumi-image-wrap,
.lumi-slider-wrapper,
.lumi-icon-box,
.lumi-cta,
.lumi-cta-hero,
.lumi-buttons-wrap,
.lumi-bg-anim-wrap,
.lumi-offcanvas-wrapper,
.lumi-image-box,
.lumi-testimonial-wrap,
.lumi-pricing,
.lumi-team-card,
.lumi-counter,
.lumi-progress-bars,
.lumi-logo-carousel,
.lumi-timeline,
.lumi-feature-grid,
.lumi-glass-card,
.lumi-hover-card,
.lumi-tabs,
.lumi-accordion,
.lumi-modal,
.lumi-section-wrapper {
  box-sizing: border-box;
}

/* Premium Video Gallery + Playlist refresh */
.lpp-video-gallery-cinematic,
.lpp-video-playlist-premium {
  --lpp-video-gallery-accent: #ff5c7a;
  --lpp-video-gallery-accent-2: #73f0ff;
  --lpp-video-gallery-hover-glow: rgba(255, 92, 122, 0.42);
  --lpp-video-gallery-blur: 18px;
  --lpp-video-gallery-speed: 560ms;
  --lpp-video-gallery-hover-lift: 12px;
  --lpp-video-playlist-accent: #7b68ff;
  --lpp-video-playlist-active: rgba(123, 104, 255, 0.22);
  --lpp-video-playlist-hover: rgba(115, 240, 255, 0.16);
  --lpp-video-playlist-blur: 16px;
  --lpp-video-playlist-speed: 520ms;
  --lpp-video-playlist-progress: linear-gradient(90deg, #ff5c7a 0%, #73f0ff 100%);
  --lpp-video-playlist-progress-track: rgba(255, 255, 255, 0.12);
  --lpp-video-playlist-progress-height: 4px;
  --lpp-video-playlist-progress-duration: 6s;
  position: relative;
}

.lpp-video-gallery-cinematic {
  display: grid;
  gap: 28px;
  min-width: 0;
}

.lpp-video-gallery-cinematic.no-glass .lpp-video-gallery-stage-btn,
.lpp-video-gallery-cinematic.no-glass .lpp-video-gallery-filter,
.lpp-video-gallery-cinematic.no-glass .lpp-video-gallery-nav-btn,
.lpp-video-playlist-premium.no-glass .lpp-video-playlist-action,
.lpp-video-playlist-premium.no-glass .lpp-video-mini-player,
.lpp-video-playlist-premium.no-glass .lpp-video-list,
.lpp-video-playlist-premium.no-glass .lpp-video-list-item {
  backdrop-filter: none;
}

.lpp-video-gallery-cinematic .lpp-video-gallery-stage,
.lpp-video-playlist-premium .lpp-video-stage {
  position: relative;
  overflow: hidden;
  isolation: isolate;
  border-radius: 36px;
}

.lpp-video-gallery-cinematic .lpp-video-gallery-stage::before,
.lpp-video-playlist-premium .lpp-video-stage::before {
  content: "";
  position: absolute;
  inset: 0;
  z-index: 0;
  pointer-events: none;
  background: linear-gradient(90deg, rgba(6, 10, 18, 0.9) 0%, rgba(6, 10, 18, 0.74) 52%, rgba(6, 10, 18, 0.2) 100%);
}

.lpp-video-gallery-cinematic .lpp-video-gallery-stage::after,
.lpp-video-playlist-premium .lpp-video-stage::after {
  content: "";
  position: absolute;
  inset: 0;
  z-index: 0;
  pointer-events: none;
  background:
    radial-gradient(circle at 14% 18%, rgba(115, 240, 255, 0.15), transparent 24%),
    radial-gradient(circle at 82% 14%, rgba(255, 92, 122, 0.14), transparent 24%),
    radial-gradient(circle at 58% 82%, rgba(123, 104, 255, 0.12), transparent 22%);
}

.lpp-video-gallery-cinematic .lpp-video-stage-backdrop,
.lpp-video-playlist-premium .lpp-video-stage-backdrop {
  opacity: 1;
  transform: none;
  filter: none;
}

.lpp-video-gallery-cinematic .lpp-video-stage-backdrop-media,
.lpp-video-playlist-premium .lpp-video-stage-backdrop-media {
  width: 100%;
  height: 100%;
  object-fit: cover;
  filter: saturate(1.12) contrast(1.02);
  transform: scale(1.08);
  animation: lppVideoKenBurns 24s ease-in-out infinite alternate;
}

.lpp-video-gallery-cinematic .lpp-video-gallery-stage-shell,
.lpp-video-playlist-premium .lpp-video-playlist-stage-shell {
  position: relative;
  z-index: 1;
  width: 100%;
  min-width: 0;
}

.lpp-video-gallery-cinematic .lpp-video-gallery-feature {
  display: grid;
  grid-template-columns: minmax(0, 1.06fr) minmax(320px, 0.94fr);
  gap: clamp(28px, 4vw, 52px);
  align-items: center;
}

.lpp-video-gallery-cinematic .lpp-video-gallery-stage-copy,
.lpp-video-playlist-premium .lpp-video-stage-copy {
  min-width: 0;
  gap: 18px;
}

.lpp-video-gallery-cinematic .lpp-video-gallery-hero-meta,
.lpp-video-playlist-premium .lpp-video-stage-meta {
  align-items: center;
  gap: 10px 12px;
  font-family: "Lato", var(--e-global-typography-text-font-family, sans-serif);
  letter-spacing: 0.01em;
}

.lpp-video-gallery-cinematic .lpp-video-gallery-hero-meta .lpp-widget-chip,
.lpp-video-playlist-premium .lpp-video-stage-meta .lpp-widget-chip {
  padding: 8px 14px;
  border-radius: 999px;
  background: linear-gradient(135deg, var(--lpp-video-gallery-accent), var(--lpp-video-gallery-accent-2));
  border: 0;
  color: #fff;
  box-shadow: 0 16px 28px rgba(13, 24, 48, 0.32);
}

.lpp-video-gallery-cinematic .lpp-video-stage-tag,
.lpp-video-playlist-premium .lpp-video-stage-tag {
  background: rgba(255, 255, 255, 0.08);
  border-color: rgba(255, 255, 255, 0.16);
  backdrop-filter: blur(var(--lpp-video-gallery-blur));
}

.lpp-video-gallery-cinematic .lpp-video-gallery-stage h3 {
  font-family: "Montserrat", var(--e-global-typography-primary-font-family, sans-serif);
  font-size: clamp(2.6rem, 5.4vw, 5.2rem);
  line-height: 0.92;
  letter-spacing: -0.07em;
  max-width: min(100%, 10.5ch);
}

.lpp-video-gallery-cinematic .lpp-video-gallery-hero-subtitle,
.lpp-video-playlist-premium .lpp-video-playlist-stage-subtitle {
  margin: -4px 0 0;
  font-family: "Lato", var(--e-global-typography-text-font-family, sans-serif);
  font-size: clamp(0.98rem, 1.5vw, 1.1rem);
  color: rgba(240, 244, 255, 0.74);
}

.lpp-video-gallery-cinematic .lpp-video-gallery-stage p,
.lpp-video-playlist-premium .lpp-video-stage p {
  max-width: 54ch;
  color: rgba(236, 242, 255, 0.78);
  line-height: 1.75;
  display: -webkit-box;
  overflow: hidden;
  -webkit-line-clamp: 3;
  -webkit-box-orient: vertical;
}

.lpp-video-gallery-cinematic .lpp-video-gallery-stage-actions,
.lpp-video-playlist-premium .lpp-video-playlist-stage-actions {
  display: flex;
  align-items: center;
  gap: 14px;
  flex-wrap: wrap;
}

.lpp-video-gallery-cinematic .lpp-video-gallery-stage-btn,
.lpp-video-playlist-premium .lpp-video-playlist-stage-btn {
  position: relative;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 54px;
  padding: 14px 26px;
  border-radius: 999px;
  border: 1px solid rgba(255, 255, 255, 0.14);
  background: rgba(255, 255, 255, 0.06);
  color: #fff;
  text-decoration: none;
  box-shadow: 0 18px 36px rgba(3, 11, 24, 0.22);
  backdrop-filter: blur(var(--lpp-video-gallery-blur));
  transition:
    transform var(--lpp-video-gallery-speed) ease,
    box-shadow var(--lpp-video-gallery-speed) ease,
    background-color var(--lpp-video-gallery-speed) ease,
    border-color var(--lpp-video-gallery-speed) ease;
}

.lpp-video-gallery-cinematic .lpp-video-gallery-stage-btn:hover,
.lpp-video-playlist-premium .lpp-video-playlist-stage-btn:hover {
  transform: translateY(-2px);
}

.lpp-video-gallery-cinematic .lpp-video-gallery-stage-btn.is-primary,
.lpp-video-playlist-premium .lpp-video-playlist-stage-btn.is-primary {
  background: linear-gradient(135deg, var(--lpp-video-gallery-accent) 0%, var(--lpp-video-gallery-accent-2) 100%);
  border-color: transparent;
  color: #04101f;
  font-weight: 800;
}

.lpp-video-gallery-cinematic .lpp-video-gallery-stage-btn.is-secondary {
  background: rgba(255, 255, 255, 0.04);
}

.lpp-video-gallery-cinematic .lpp-video-gallery-stage-visual,
.lpp-video-playlist-premium .lpp-video-playlist-stage-visual {
  position: relative;
  display: flex;
  align-items: flex-end;
  justify-content: flex-end;
  min-height: clamp(340px, 42vw, 540px);
  padding: clamp(18px, 2.4vw, 28px);
  overflow: hidden;
  border-radius: 32px;
  border: 1px solid rgba(255, 255, 255, 0.12);
  background: rgba(4, 9, 19, 0.74);
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, 0.05),
    0 34px 68px rgba(2, 8, 20, 0.34);
}

.lpp-video-gallery-cinematic .lpp-video-gallery-stage-poster,
.lpp-video-playlist-premium .lpp-video-playlist-stage-poster {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  transform: scale(1.04);
  filter: saturate(1.1);
  animation: lppVideoKenBurns 22s ease-in-out infinite alternate;
}

.lpp-video-gallery-cinematic .lpp-video-gallery-stage-visual::before,
.lpp-video-playlist-premium .lpp-video-playlist-stage-visual::before {
  content: "";
  position: absolute;
  inset: 0;
  background:
    linear-gradient(90deg, rgba(6, 10, 18, 0.18) 8%, rgba(6, 10, 18, 0.58) 58%, rgba(6, 10, 18, 0.84) 100%),
    linear-gradient(180deg, rgba(6, 10, 18, 0.04), rgba(6, 10, 18, 0.46));
}

.lpp-video-gallery-cinematic .lpp-video-stage-player,
.lpp-video-playlist-premium .lpp-video-stage-player {
  position: relative;
  z-index: 2;
  width: min(100%, 520px);
  margin-left: auto;
  border-radius: 26px;
  border: 1px solid rgba(255, 255, 255, 0.14);
  background:
    linear-gradient(145deg, rgba(8, 18, 38, 0.7), rgba(10, 22, 45, 0.38)),
    rgba(3, 10, 20, 0.76);
  box-shadow:
    0 24px 52px rgba(2, 8, 20, 0.4),
    inset 0 1px 0 rgba(255, 255, 255, 0.06);
  backdrop-filter: blur(var(--lpp-video-gallery-blur));
}

.lpp-video-gallery-cinematic .lpp-video-stage-player.is-empty,
.lpp-video-playlist-premium .lpp-video-stage-player.is-empty {
  min-height: 240px;
}

.lpp-video-gallery-cinematic .lpp-video-stage-play,
.lpp-video-playlist-premium .lpp-video-stage-play,
.lpp-video-playlist-premium .lpp-video-mini-player-toggle {
  position: absolute;
  right: 18px;
  bottom: 18px;
  z-index: 3;
  width: 64px;
  height: 64px;
  border: 0;
  border-radius: 999px;
  cursor: pointer;
  background:
    radial-gradient(circle at 30% 30%, rgba(255, 255, 255, 0.3), transparent 54%),
    linear-gradient(135deg, var(--lpp-video-gallery-accent) 0%, var(--lpp-video-gallery-accent-2) 100%);
  box-shadow: 0 20px 40px rgba(3, 11, 24, 0.34);
  transition: transform var(--lpp-video-gallery-speed) ease, box-shadow var(--lpp-video-gallery-speed) ease;
}

.lpp-video-gallery-cinematic .lpp-video-stage-play::before,
.lpp-video-playlist-premium .lpp-video-stage-play::before,
.lpp-video-playlist-premium .lpp-video-mini-player-toggle::before {
  content: "";
  position: absolute;
  left: 50%;
  top: 50%;
  transform: translate(-38%, -50%);
  border-style: solid;
  border-width: 10px 0 10px 16px;
  border-color: transparent transparent transparent #fff;
}

.lpp-video-gallery-cinematic.is-playing .lpp-video-stage-play::before,
.lpp-video-playlist-premium.is-playing .lpp-video-stage-play::before,
.lpp-video-playlist-premium.is-playing .lpp-video-mini-player-toggle::before {
  width: 14px;
  height: 18px;
  border: 0;
  background:
    linear-gradient(90deg, #fff 0 38%, transparent 38% 62%, #fff 62%);
  transform: translate(-50%, -50%);
}

.lpp-video-gallery-cinematic .lpp-video-stage-play:hover,
.lpp-video-playlist-premium .lpp-video-stage-play:hover,
.lpp-video-playlist-premium .lpp-video-mini-player-toggle:hover {
  transform: translateY(-2px) scale(1.03);
}

.lpp-video-gallery-cinematic .lpp-video-gallery-shelf,
.lpp-video-playlist-premium .lpp-video-list-shell {
  display: grid;
  gap: 16px;
  min-width: 0;
}

.lpp-video-gallery-cinematic .lpp-video-gallery-rail-head,
.lpp-video-playlist-premium .lpp-video-list-head {
  display: flex;
  align-items: flex-end;
  justify-content: space-between;
  gap: 18px;
}

.lpp-video-gallery-cinematic .lpp-video-gallery-rail-copy,
.lpp-video-playlist-premium .lpp-video-list-heading {
  display: grid;
  gap: 6px;
}

.lpp-video-gallery-cinematic .lpp-video-gallery-rail-actions {
  display: flex;
  align-items: center;
  justify-content: flex-end;
  gap: 14px;
  flex-wrap: wrap;
}

.lpp-video-gallery-cinematic .lpp-video-gallery-filters {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
}

.lpp-video-gallery-cinematic .lpp-video-gallery-filter,
.lpp-video-gallery-cinematic .lpp-video-gallery-nav-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 42px;
  padding: 10px 16px;
  border: 1px solid rgba(255, 255, 255, 0.1);
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.05);
  color: rgba(255, 255, 255, 0.92);
  font-size: 0.8rem;
  font-weight: 700;
  letter-spacing: 0.04em;
  cursor: pointer;
  backdrop-filter: blur(var(--lpp-video-gallery-blur));
  transition:
    transform var(--lpp-video-gallery-speed) ease,
    background-color var(--lpp-video-gallery-speed) ease,
    border-color var(--lpp-video-gallery-speed) ease,
    box-shadow var(--lpp-video-gallery-speed) ease;
}

.lpp-video-gallery-cinematic .lpp-video-gallery-filter.is-active {
  background: linear-gradient(135deg, var(--lpp-video-gallery-accent), var(--lpp-video-gallery-accent-2));
  border-color: transparent;
  color: #061120;
  box-shadow: 0 18px 32px rgba(12, 24, 48, 0.3);
}

.lpp-video-gallery-cinematic .lpp-video-gallery-nav {
  display: flex;
  gap: 10px;
}

.lpp-video-gallery-cinematic .lpp-video-gallery-nav-btn {
  width: 46px;
  padding: 0;
}

.lpp-video-gallery-cinematic .lpp-video-gallery-nav-btn::before {
  content: "";
  width: 10px;
  height: 10px;
  border-top: 2px solid currentColor;
  border-right: 2px solid currentColor;
  transform: rotate(225deg);
}

.lpp-video-gallery-cinematic .lpp-video-gallery-nav-btn[class*="next"]::before {
  transform: rotate(45deg);
}

.lpp-video-gallery-cinematic .lpp-video-gallery-grid {
  overflow: visible;
  padding: 4px 2px 12px;
}

.lpp-video-gallery-cinematic .lpp-video-gallery-grid .swiper-wrapper {
  align-items: stretch;
}

.lpp-video-gallery-cinematic .lpp-video-gallery-grid .swiper-slide {
  height: auto;
}

.lpp-video-gallery-cinematic .lpp-video-gallery-card {
  position: relative;
  display: block;
  width: 100%;
  height: 100%;
  padding: 0;
  border-radius: 26px;
  border: 1px solid rgba(255, 255, 255, 0.1);
  background: rgba(6, 10, 18, 0.74);
  box-shadow:
    0 24px 48px rgba(2, 8, 20, 0.32),
    inset 0 1px 0 rgba(255, 255, 255, 0.04);
  overflow: hidden;
  transition:
    transform var(--lpp-video-gallery-speed) ease,
    box-shadow var(--lpp-video-gallery-speed) ease,
    border-color var(--lpp-video-gallery-speed) ease;
}

.lpp-video-gallery-cinematic .lpp-video-gallery-card:hover,
.lpp-video-gallery-cinematic .lpp-video-gallery-card.is-active {
  transform: translateY(calc(var(--lpp-video-gallery-hover-lift) * -1));
}

.lpp-video-gallery-cinematic .lpp-video-gallery-card:hover {
  border-color: rgba(255, 255, 255, 0.22);
  box-shadow:
    0 30px 58px rgba(2, 8, 20, 0.42),
    0 0 0 1px var(--lpp-video-gallery-hover-glow);
}

.lpp-video-gallery-cinematic .lpp-video-gallery-card.is-active {
  border-color: var(--lpp-video-gallery-accent);
  box-shadow:
    0 34px 62px rgba(2, 8, 20, 0.48),
    0 0 0 1px var(--lpp-video-gallery-accent);
}

.lpp-video-gallery-cinematic .lpp-video-gallery-poster {
  min-height: 300px;
  height: 100%;
}

.lpp-video-gallery-cinematic .lpp-video-gallery-poster img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform var(--lpp-video-gallery-speed) ease, filter var(--lpp-video-gallery-speed) ease;
}

.lpp-video-gallery-cinematic .lpp-video-gallery-card:hover .lpp-video-gallery-poster img,
.lpp-video-gallery-cinematic .lpp-video-gallery-card.is-active .lpp-video-gallery-poster img {
  transform: scale(1.08);
  filter: saturate(1.16);
}

.lpp-video-gallery-cinematic .lpp-video-gallery-card-badge {
  top: 16px;
  left: 16px;
  background: rgba(5, 10, 20, 0.58);
  border: 1px solid rgba(255, 255, 255, 0.14);
  backdrop-filter: blur(var(--lpp-video-gallery-blur));
}

.lpp-video-gallery-cinematic .lpp-video-gallery-card-overlay {
  position: absolute;
  inset: 0;
  display: flex;
  flex-direction: column;
  justify-content: flex-end;
  gap: 12px;
  padding: 20px;
  background:
    linear-gradient(180deg, rgba(4, 8, 16, 0) 18%, rgba(4, 8, 16, 0.58) 58%, rgba(4, 8, 16, 0.96) 100%);
}

.lpp-video-gallery-cinematic .lpp-video-gallery-card-play {
  position: relative;
  display: block;
  width: 52px;
  height: 52px;
  border-radius: 999px;
  background:
    radial-gradient(circle at 30% 30%, rgba(255, 255, 255, 0.3), transparent 54%),
    linear-gradient(135deg, var(--lpp-video-gallery-accent), var(--lpp-video-gallery-accent-2));
  box-shadow: 0 16px 28px rgba(3, 11, 24, 0.34);
}

.lpp-video-gallery-cinematic .lpp-video-gallery-card-play::before {
  content: "";
  position: absolute;
  left: 50%;
  top: 50%;
  transform: translate(-36%, -50%);
  border-style: solid;
  border-width: 8px 0 8px 13px;
  border-color: transparent transparent transparent #fff;
}

.lpp-video-gallery-cinematic .lpp-video-gallery-card-copy {
  position: static;
  gap: 6px;
  padding: 0;
  background: none;
}

.lpp-video-gallery-cinematic .lpp-video-gallery-card-copy strong,
.lpp-video-playlist-premium .lpp-video-copy strong,
.lpp-video-playlist-premium .lpp-video-mini-player strong {
  font-family: "Montserrat", var(--e-global-typography-primary-font-family, sans-serif);
  font-weight: 700;
  letter-spacing: -0.03em;
}

.lpp-video-gallery-cinematic .lpp-video-gallery-card-meta {
  gap: 6px 10px;
}

.lpp-video-playlist-premium {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(260px, var(--lpp-video-sidebar-width, 320px));
  gap: var(--lpp-video-sidebar-gap, 22px);
  align-items: stretch;
}

.lpp-video-playlist-premium .lpp-video-stage {
  padding: clamp(22px, 3.2vw, 34px);
}

.lpp-video-playlist-premium .lpp-video-playlist-stage-shell {
  display: grid;
  grid-template-columns: minmax(0, 0.94fr) minmax(300px, 1.06fr);
  gap: clamp(24px, 3vw, 40px);
  align-items: center;
}

.lpp-video-playlist-premium .lpp-video-playlist-stage-visual {
  min-height: clamp(320px, 38vw, 460px);
}

.lpp-video-playlist-premium .lpp-video-playlist-stage-actions {
  padding-top: 2px;
}

.lpp-video-playlist-premium .lpp-video-playlist-action {
  position: relative;
  width: 48px;
  height: 48px;
  padding: 0;
  border: 1px solid rgba(255, 255, 255, 0.14);
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.05);
  color: #fff;
  cursor: pointer;
  backdrop-filter: blur(var(--lpp-video-playlist-blur));
  transition:
    transform var(--lpp-video-playlist-speed) ease,
    box-shadow var(--lpp-video-playlist-speed) ease,
    background-color var(--lpp-video-playlist-speed) ease;
}

.lpp-video-playlist-premium .lpp-video-playlist-action:hover,
.lpp-video-playlist-premium .lpp-video-playlist-action.is-active,
.lpp-video-playlist-premium .lpp-video-playlist-action.is-shared {
  transform: translateY(-2px);
  background: rgba(255, 255, 255, 0.12);
  box-shadow: 0 16px 28px rgba(3, 11, 24, 0.28);
}

.lpp-video-playlist-premium .lpp-video-playlist-action.is-like::before {
  content: "+";
  display: block;
  font-size: 24px;
  line-height: 1;
  font-weight: 300;
}

.lpp-video-playlist-premium .lpp-video-playlist-action.is-share::before,
.lpp-video-playlist-premium .lpp-video-playlist-action.is-share::after {
  content: "";
  position: absolute;
}

.lpp-video-playlist-premium .lpp-video-playlist-action.is-share::before {
  width: 12px;
  height: 12px;
  left: 17px;
  top: 13px;
  border-top: 2px solid currentColor;
  border-right: 2px solid currentColor;
  transform: rotate(45deg);
}

.lpp-video-playlist-premium .lpp-video-playlist-action.is-share::after {
  width: 15px;
  height: 2px;
  left: 15px;
  top: 24px;
  background: currentColor;
  transform: rotate(-45deg);
  transform-origin: left center;
}

.lpp-video-playlist-premium .lpp-video-mini-player {
  position: relative;
  z-index: 1;
  display: grid;
  grid-template-columns: auto minmax(0, 1fr) auto;
  align-items: center;
  gap: 16px;
  margin-top: 20px;
  padding: 16px 18px 18px;
  border: 1px solid rgba(255, 255, 255, 0.12);
  border-radius: 22px;
  background: rgba(8, 16, 30, 0.52);
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.04);
  backdrop-filter: blur(var(--lpp-video-playlist-blur));
}

.lpp-video-playlist-premium .lpp-video-mini-player-toggle {
  position: relative;
  right: auto;
  bottom: auto;
  width: 48px;
  height: 48px;
  margin: 0;
}

.lpp-video-playlist-premium .lpp-video-mini-player-copy {
  min-width: 0;
}

.lpp-video-playlist-premium .lpp-video-mini-player-copy small {
  display: block;
  margin-bottom: 4px;
  color: rgba(236, 242, 255, 0.56);
}

.lpp-video-playlist-premium .lpp-video-mini-player-duration {
  color: rgba(236, 242, 255, 0.66);
  font-size: 0.82rem;
  font-weight: 700;
}

.lpp-video-playlist-premium .lpp-video-mini-player-progress,
.lpp-video-playlist-premium .lpp-video-list-progress {
  position: relative;
  overflow: hidden;
  background: var(--lpp-video-playlist-progress-track);
  border-radius: 999px;
}

.lpp-video-playlist-premium .lpp-video-mini-player-progress {
  grid-column: 1 / -1;
  height: var(--lpp-video-playlist-progress-height);
}

.lpp-video-playlist-premium .lpp-video-mini-player-progress span,
.lpp-video-playlist-premium .lpp-video-list-progress span {
  display: block;
  width: 100%;
  height: 100%;
  transform: scaleX(0);
  transform-origin: left center;
  background: var(--lpp-video-playlist-progress);
}

.lpp-video-playlist-premium .lpp-video-mini-player-progress.is-progressing span,
.lpp-video-playlist-premium .lpp-video-list-item.is-progressing .lpp-video-list-progress span {
  animation: lppVideoProgress var(--lpp-video-playlist-progress-duration) linear forwards;
}

.lpp-video-playlist-premium .lpp-video-list-head p {
  margin: 0;
  color: rgba(236, 242, 255, 0.62);
  line-height: 1.6;
}

.lpp-video-playlist-premium .lpp-video-list-count {
  display: inline-flex;
  align-items: center;
  min-height: 34px;
  padding: 8px 12px;
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.06);
  color: rgba(255, 255, 255, 0.78);
  font-size: 0.76rem;
  font-weight: 700;
  letter-spacing: 0.06em;
  text-transform: uppercase;
}

.lpp-video-playlist-premium .lpp-video-list {
  gap: 12px;
  padding: 12px;
  border-radius: 28px;
  background:
    linear-gradient(145deg, rgba(8, 18, 38, 0.38), rgba(10, 22, 45, 0.18)),
    linear-gradient(135deg, rgba(123, 104, 255, 0.08), transparent 44%);
  border: 1px solid rgba(255, 255, 255, 0.08);
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.04);
  backdrop-filter: blur(var(--lpp-video-playlist-blur));
}

.lpp-video-playlist-premium .lpp-video-list-item {
  position: relative;
  grid-template-columns: 92px 42px minmax(0, 1fr);
  gap: 14px;
  padding: 14px;
  border-radius: 22px;
  border: 1px solid rgba(255, 255, 255, 0.1);
  background: rgba(6, 10, 18, 0.48);
  transition:
    transform var(--lpp-video-playlist-speed) ease,
    background-color var(--lpp-video-playlist-speed) ease,
    border-color var(--lpp-video-playlist-speed) ease,
    box-shadow var(--lpp-video-playlist-speed) ease;
}

.lpp-video-playlist-premium .lpp-video-list-item:hover,
.lpp-video-playlist-premium .lpp-video-list-item.is-active {
  transform: translateY(-3px);
  border-color: rgba(255, 255, 255, 0.2);
  box-shadow: 0 24px 40px rgba(2, 8, 20, 0.28);
}

.lpp-video-playlist-premium .lpp-video-list-item.is-active {
  background: linear-gradient(135deg, var(--lpp-video-playlist-active), rgba(255, 255, 255, 0.06));
  box-shadow:
    0 26px 42px rgba(2, 8, 20, 0.34),
    0 0 0 1px rgba(255, 255, 255, 0.12);
}

.lpp-video-playlist-premium .lpp-video-list-thumb {
  min-height: 72px;
  border-radius: 18px;
  border-color: rgba(255, 255, 255, 0.12);
}

.lpp-video-playlist-premium .lpp-video-list-thumb::after {
  width: 34px;
  height: 34px;
}

.lpp-video-playlist-premium .lpp-video-copy {
  gap: 6px;
}

.lpp-video-playlist-premium .lpp-video-copy strong {
  font-size: 1rem;
  line-height: 1.22;
}

.lpp-video-playlist-premium .lpp-video-copy small {
  font-size: 0.78rem;
  color: rgba(236, 242, 255, 0.62);
  -webkit-line-clamp: 2;
}

.lpp-video-playlist-premium .lpp-video-index {
  width: 36px;
  height: 36px;
  border-radius: 14px;
  background: linear-gradient(135deg, var(--lpp-video-playlist-accent), var(--lpp-video-gallery-accent-2));
  color: #071425;
}

.lpp-video-playlist-premium .lpp-video-list-progress {
  position: absolute;
  left: 18px;
  right: 18px;
  bottom: 12px;
  height: var(--lpp-video-playlist-progress-height);
}

.lpp-video-gallery-cinematic .lpp-video-gallery-filter:hover,
.lpp-video-gallery-cinematic .lpp-video-gallery-nav-btn:hover {
  transform: translateY(-2px);
  box-shadow: 0 14px 26px rgba(2, 8, 20, 0.26);
}

.lpp-video-gallery-cinematic .lpp-video-gallery-stage.is-stage-hidden {
  display: none;
}

@keyframes lppVideoKenBurns {
  0% {
    transform: scale(1.04) translate3d(0, 0, 0);
  }
  100% {
    transform: scale(1.14) translate3d(-2%, -2%, 0);
  }
}

@keyframes lppVideoProgress {
  0% {
    transform: scaleX(0);
  }
  100% {
    transform: scaleX(1);
  }
}

@media (max-width: 1024px) {
  .lpp-video-gallery-cinematic .lpp-video-gallery-feature,
  .lpp-video-playlist-premium {
    grid-template-columns: 1fr;
  }

  .lpp-video-playlist-premium .lpp-video-playlist-stage-shell {
    grid-template-columns: 1fr;
  }

  .lpp-video-playlist-premium .lpp-video-list-shell {
    order: 2;
  }
}

@media (max-width: 767px) {
  .lpp-video-gallery-cinematic {
    gap: 20px;
  }

  .lpp-video-gallery-cinematic .lpp-video-gallery-stage,
  .lpp-video-playlist-premium .lpp-video-stage {
    border-radius: 28px;
    padding: 18px;
  }

  .lpp-video-gallery-cinematic .lpp-video-gallery-stage h3 {
    max-width: 100%;
    font-size: clamp(2rem, 11vw, 3.2rem);
  }

  .lpp-video-gallery-cinematic .lpp-video-gallery-stage-visual,
  .lpp-video-playlist-premium .lpp-video-playlist-stage-visual {
    min-height: clamp(260px, 70vw, 360px);
    padding: 14px;
  }

  .lpp-video-gallery-cinematic .lpp-video-gallery-rail-head,
  .lpp-video-playlist-premium .lpp-video-list-head {
    align-items: flex-start;
    flex-direction: column;
  }

  .lpp-video-gallery-cinematic .lpp-video-gallery-rail-actions {
    width: 100%;
    justify-content: space-between;
  }

  .lpp-video-gallery-cinematic .lpp-video-gallery-filters {
    flex-wrap: nowrap;
    overflow-x: auto;
    padding-bottom: 4px;
  }

  .lpp-video-gallery-cinematic .lpp-video-gallery-filter {
    white-space: nowrap;
  }

  .lpp-video-gallery-cinematic .lpp-video-gallery-card {
    border-radius: 22px;
  }

  .lpp-video-gallery-cinematic .lpp-video-gallery-poster {
    min-height: 240px;
  }

  .lpp-video-playlist-premium .lpp-video-mini-player {
    grid-template-columns: auto minmax(0, 1fr);
  }

  .lpp-video-playlist-premium .lpp-video-mini-player-duration {
    grid-column: 2;
    justify-self: end;
  }

  .lpp-video-playlist-premium .lpp-video-list {
    display: grid;
    grid-auto-flow: column;
    grid-auto-columns: minmax(220px, 76%);
    overflow-x: auto;
    overflow-y: hidden;
    scroll-snap-type: x proximity;
    padding-bottom: 14px;
  }

  .lpp-video-playlist-premium .lpp-video-list-item {
    min-height: 100%;
    scroll-snap-align: start;
  }
}

.lumi-split-slider {
  position: relative;
  isolation: isolate;
  overflow: hidden;
  background: #08101d;
  box-shadow: 0 28px 70px rgba(4, 12, 26, 0.22);
}
.lumi-split-slider .swiper,
.lumi-split-slider .swiper-wrapper,
.lumi-split-slider .swiper-slide {
  height: 100%;
}
.lumi-split-slide {
  position: relative;
  background-size: cover;
  background-position: center;
  overflow: hidden;
}
.lumi-split-slide::before {
  content: "";
  position: absolute;
  inset: 0;
  background:
    radial-gradient(circle at 16% 16%, rgba(79,195,247,0.14), transparent 34%),
    radial-gradient(circle at 86% 18%, rgba(225,184,102,0.14), transparent 28%);
  pointer-events: none;
  z-index: 0;
}
.lumi-split-slide-overlay {
  position: absolute;
  inset: 0;
  background:
    linear-gradient(135deg, rgba(2,8,18,0.54) 0%, rgba(5,13,29,0.2) 42%, rgba(7,14,29,0.56) 100%),
    linear-gradient(180deg, rgba(2,8,18,0.08) 0%, rgba(2,8,18,0.62) 100%);
  z-index: 1;
}
.lumi-split-slide-shell {
  position: relative;
  z-index: 2;
  display: flex;
  min-height: 100%;
  padding: clamp(28px, 5vw, 64px) clamp(18px, 4vw, 54px) clamp(132px, 15vw, 170px);
}
.lumi-split-slider-no-status .lumi-split-slide-shell {
  padding-bottom: clamp(104px, 13vw, 132px);
}
.lumi-split-slider-no-nav .lumi-split-slide-shell {
  padding-bottom: clamp(88px, 11vw, 112px);
}
.lumi-split-slider-no-status.lumi-split-slider-no-nav .lumi-split-slide-shell {
  padding-bottom: clamp(44px, 7vw, 72px);
}
.lumi-split-slider-boxed .lumi-split-slide-shell {
  max-width: min(1380px, calc(100% - 28px));
  margin: 0 auto;
}
.lumi-split-slider-full .lumi-split-slide-shell {
  max-width: calc(100% - 28px);
  margin: 0 auto;
}
.lumi-split-v-top { align-items: flex-start; }
.lumi-split-v-middle { align-items: center; }
.lumi-split-v-bottom { align-items: flex-end; }
.lumi-split-slide-grid {
  display: grid;
  grid-template-columns: minmax(0, 1.02fr) minmax(0, 0.98fr);
  gap: 28px;
  align-items: center;
  width: 100%;
}
.lumi-split-no-media .lumi-split-slide-grid {
  grid-template-columns: minmax(0, 1fr);
}
.lumi-split-slide-copy-wrap { width: 100%; }
.lumi-split-slide-copy {
  position: relative;
  display: flex;
  flex-direction: column;
  gap: 18px;
  max-width: 640px;
  padding: 30px 32px;
  border-radius: 28px;
  background: rgba(8,16,34,0.72);
  border: 1px solid rgba(255,255,255,0.12);
  box-shadow: 0 24px 60px rgba(4, 12, 26, 0.24), inset 0 1px 0 rgba(255,255,255,0.08);
  backdrop-filter: blur(14px);
  -webkit-backdrop-filter: blur(14px);
  overflow: hidden;
}
.lumi-split-no-media .lumi-split-slide-copy {
  max-width: min(780px, 100%);
}
.lumi-split-slide-copy::before {
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(140deg, rgba(255,255,255,0.1), transparent 42%);
  pointer-events: none;
}
.lumi-split-slide-copy > * {
  position: relative;
  z-index: 1;
  opacity: 0;
  transform: var(--lumi-split-content-transform, translate3d(0, 24px, 0));
  filter: var(--lumi-split-content-filter, none);
  transition:
    opacity 0.55s ease,
    transform 0.7s cubic-bezier(0.22, 1, 0.36, 1),
    filter 0.55s ease;
}
.swiper-slide-active .lumi-split-slide-copy > * {
  opacity: 1;
  transform: none;
  filter: none;
}
.lumi-split-slider .swiper:not(.swiper-initialized) .swiper-slide:first-child .lumi-split-slide-copy > * {
  opacity: 1;
  transform: none;
  filter: none;
}
.swiper-slide-active .lumi-split-slide-copy > *:nth-child(1) { transition-delay: 0.06s; }
.swiper-slide-active .lumi-split-slide-copy > *:nth-child(2) { transition-delay: 0.12s; }
.swiper-slide-active .lumi-split-slide-copy > *:nth-child(3) { transition-delay: 0.18s; }
.swiper-slide-active .lumi-split-slide-copy > *:nth-child(4) { transition-delay: 0.24s; }
.swiper-slide-active .lumi-split-slide-copy > *:nth-child(5) { transition-delay: 0.3s; }
.lumi-split-anim-rise .lumi-split-slide-copy > * { --lumi-split-content-transform: translate3d(0, 24px, 0); }
.lumi-split-anim-zoom .lumi-split-slide-copy > * { --lumi-split-content-transform: translate3d(0, 14px, 0) scale(0.94); --lumi-split-content-filter: blur(1.4px); }
.lumi-split-anim-sweep-left .lumi-split-slide-copy > * { --lumi-split-content-transform: translate3d(-36px, 0, 0); }
.lumi-split-anim-sweep-right .lumi-split-slide-copy > * { --lumi-split-content-transform: translate3d(36px, 0, 0); }
.lumi-split-anim-none .lumi-split-slide-copy > * { opacity: 1; transform: none; filter: none; transition: none; }
.lumi-split-align-center { text-align: center; align-items: center; margin-left: auto; margin-right: auto; }
.lumi-split-align-right { text-align: right; align-items: flex-end; margin-left: auto; margin-right: 0; }
.lumi-split-align-left { text-align: left; align-items: flex-start; margin-left: 0; margin-right: auto; }
.lumi-split-slide-label {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  align-self: flex-start;
  width: fit-content;
  padding: 7px 18px;
  border-radius: 999px;
  font-size: 12px;
  font-weight: 700;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  background: rgba(255,255,255,0.12);
  border: 1px solid rgba(255,255,255,0.22);
}
.lumi-split-align-center .lumi-split-slide-label { align-self: center; }
.lumi-split-align-right .lumi-split-slide-label { align-self: flex-end; }
.lumi-split-slide-label::before {
  content: "";
  width: 8px;
  height: 8px;
  border-radius: 50%;
  background: linear-gradient(135deg, #4fc3f7, #e1b866);
  box-shadow: 0 0 16px rgba(79,195,247,0.45);
}
.lumi-split-slide-title {
  margin: 0;
  font-size: clamp(2.2rem, 4.5vw, 4.4rem);
  font-weight: 800;
  line-height: 1.02;
  letter-spacing: -0.04em;
  color: #fff;
}
.lumi-split-slide-desc {
  margin: 0;
  font-size: 1.05rem;
  line-height: 1.75;
  color: rgba(242,246,255,0.86);
  max-width: 52ch;
}
.lumi-split-slide-highlights,
.lumi-split-slide-buttons {
  display: flex;
  flex-wrap: wrap;
  gap: 14px;
  align-items: center;
}
.lumi-split-highlight {
  display: inline-flex;
  align-items: center;
  padding: 10px 16px;
  border-radius: 999px;
  background: rgba(255,255,255,0.08);
  border: 1px solid rgba(255,255,255,0.16);
  color: #fff;
  font-size: 0.84rem;
  font-weight: 600;
}
.lumi-split-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 56px;
  padding: 14px 28px;
  border-radius: 999px;
  text-decoration: none;
  font-size: 0.95rem;
  font-weight: 700;
  line-height: 1;
  max-width: 100%;
  flex: 0 1 auto;
  transition: transform 0.3s ease, box-shadow 0.3s ease, background 0.3s ease, border-color 0.3s ease, color 0.3s ease;
}
.lumi-split-btn:hover { transform: translateY(-3px); }
.lumi-split-btn-primary {
  background: #1d6ce3;
  color: #fff;
  border: 1px solid rgba(255,255,255,0.14);
  box-shadow: 0 24px 46px rgba(10, 33, 72, 0.34);
}
.lumi-split-btn-secondary {
  background: rgba(10,20,39,0.72);
  color: #fff;
  border: 1px solid rgba(255,255,255,0.18);
  box-shadow: 0 18px 34px rgba(3, 11, 24, 0.16);
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
}
.lumi-split-slide-media { width: 100%; }
.lumi-split-media-card {
  position: relative;
  min-height: 420px;
  border-radius: 28px;
  overflow: hidden;
  background: rgba(255,255,255,0.04);
  border: 1px solid rgba(255,255,255,0.12);
  box-shadow: 0 24px 56px rgba(3, 11, 24, 0.2);
}
.lumi-split-media-card img {
  display: block;
  width: 100%;
  height: 100%;
  min-height: inherit;
  object-fit: cover;
}
.lumi-split-slider-pagination {
  position: absolute;
  left: 50% !important;
  right: auto;
  bottom: clamp(24px, 3vw, 34px);
  width: auto !important;
  display: flex;
  gap: 8px;
  transform: translateX(-50%);
  z-index: 3;
}
.lumi-split-slider .swiper-pagination-bullet {
  width: 10px;
  height: 10px;
  margin: 0 !important;
  border-radius: 999px;
  background: rgba(255,255,255,0.34);
  opacity: 1;
  transition: width 0.3s ease, background 0.3s ease;
}
.lumi-split-slider .swiper-pagination-bullet-active {
  width: 30px;
  background: linear-gradient(90deg, #4fc3f7, #e1b866);
  box-shadow: 0 10px 24px rgba(79,195,247,0.22);
}
.lumi-split-slider-chrome {
  position: absolute;
  inset: 0;
  z-index: 3;
  pointer-events: none;
}
.lumi-split-slider-status {
  position: absolute;
  left: clamp(18px, 4vw, 54px);
  bottom: clamp(18px, 3vw, 28px);
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 9px 14px;
  border-radius: 999px;
  background: rgba(10,20,39,0.52);
  border: 1px solid rgba(255,255,255,0.12);
  font-size: 0.74rem;
  font-weight: 700;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: #fff;
  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);
  pointer-events: auto;
}
.lumi-split-slider-nav {
  position: absolute;
  inset: 0;
  pointer-events: none;
}
.lumi-split-slider-nav-btn {
  position: absolute;
  top: 50%;
  width: 46px;
  height: 46px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border-radius: 50%;
  border: 1px solid rgba(255,255,255,0.14);
  background: rgba(10,20,39,0.44);
  color: #fff;
  transform: translateY(-50%);
  box-shadow: 0 14px 28px rgba(3, 11, 24, 0.16);
  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);
  pointer-events: auto;
  transition: transform 0.3s ease, background 0.3s ease, border-color 0.3s ease;
}
.lumi-split-slider-nav-btn:hover {
  transform: translateY(-50%) scale(1.03);
  background: rgba(15,36,72,0.8);
  border-color: rgba(255,255,255,0.22);
}
.lumi-split-slider-nav-btn:first-child { left: clamp(14px, 2vw, 22px); }
.lumi-split-slider-nav-btn:last-child { right: clamp(14px, 2vw, 22px); }
.lumi-split-slider-nav-btn span { font-size: 0.95rem; font-weight: 700; }
.lumi-split-slider-progress-wrap {
  position: absolute;
  left: 0;
  right: 0;
  z-index: 3;
}
.lumi-split-slider-progress-top { top: 0; }
.lumi-split-slider-progress-bottom { bottom: 0; }
.lumi-split-slider-progress {
  position: relative;
  height: 3px;
  background: rgba(255,255,255,0.14);
  overflow: hidden;
}
.lumi-split-slider-progress-fill {
  display: block;
  width: 33.333%;
  height: 100%;
  background: linear-gradient(90deg, #4fc3f7, #e1b866);
  box-shadow: 0 0 18px rgba(79,195,247,0.28);
  transition: width 0.45s ease;
}
@media ( max-width: 1024px ) {
  .lumi-split-slide-title {
    font-size: clamp(2rem, 6vw, 3.4rem);
  }
  .lumi-split-media-card {
    min-height: 360px;
  }
}
@media ( max-width: 768px ) {
  .lumi-split-slide-shell {
    padding: 20px 16px 148px;
  }
  .lumi-split-slider-no-status .lumi-split-slide-shell {
    padding-bottom: 118px;
  }
  .lumi-split-slider-no-nav .lumi-split-slide-shell {
    padding-bottom: 86px;
  }
  .lumi-split-slider-no-status.lumi-split-slider-no-nav .lumi-split-slide-shell {
    padding-bottom: 44px;
  }
  .lumi-split-slider-boxed .lumi-split-slide-shell,
  .lumi-split-slider-full .lumi-split-slide-shell {
    max-width: calc(100% - 18px);
  }
  .lumi-split-slide-grid {
    grid-template-columns: 1fr;
  }
  .lumi-split-slide-copy-wrap {
    order: 1;
  }
  .lumi-split-slide-media {
    order: 2;
  }
  .lumi-split-slide-copy {
    max-width: none;
    padding: 24px 20px;
    gap: 16px;
  }
  .lumi-split-slide-title {
    font-size: clamp(1.85rem, 9vw, 3rem);
  }
  .lumi-split-slide-desc {
    font-size: 0.98rem;
    max-width: none;
  }
  .lumi-split-media-card {
    min-height: 260px;
  }
  .lumi-split-btn {
    min-height: 48px;
    padding: 12px 20px;
    font-size: 0.9rem;
  }
  .lumi-split-slider-pagination {
    bottom: 72px;
  }
  .lumi-split-slider-status {
    left: 16px;
    bottom: 104px;
    padding: 8px 11px;
    font-size: 0.68rem;
    letter-spacing: 0.1em;
  }
  .lumi-split-slider-no-nav .lumi-split-slider-status {
    bottom: 18px;
  }
  .lumi-split-slider-nav {
    inset: auto;
    left: 50%;
    bottom: 18px;
    display: inline-flex;
    gap: 12px;
    transform: translateX(-50%);
    pointer-events: auto;
  }
  .lumi-split-slider-nav-btn {
    position: relative;
    top: auto;
    left: auto;
    right: auto;
    width: 40px;
    height: 40px;
    transform: none;
  }
  .lumi-split-slider-nav-btn:hover {
    transform: translateY(-2px);
  }
}
@media ( max-width: 480px ) {
  .lumi-split-slide-shell {
    padding-bottom: 164px;
  }
  .lumi-split-slider-no-status .lumi-split-slide-shell {
    padding-bottom: 126px;
  }
  .lumi-split-slider-no-nav .lumi-split-slide-shell {
    padding-bottom: 98px;
  }
  .lumi-split-slider-no-status.lumi-split-slider-no-nav .lumi-split-slide-shell {
    padding-bottom: 44px;
  }
  .lumi-split-slide-highlights,
  .lumi-split-slide-buttons {
    width: 100%;
  }
  .lumi-split-slider-status {
    left: 16px;
    right: 16px;
    width: auto;
    justify-content: center;
  }
  .lumi-split-slider-nav {
    gap: 10px;
  }
  .lumi-split-slider-nav-btn {
    width: 38px;
    height: 38px;
  }
}

/* ── 1. ADVANCED SECTION TITLE ──────────────────────────── */
.lumi-section-title {
  width: 100%;
}
.lumi-st-badge-wrap {
  display: block;
}
.lumi-st-badge {
  display: inline-block;
  padding: 6px 18px;
  border-radius: 50px;
  font-size: 12px;
  font-weight: 700;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  background: linear-gradient(135deg, #1a73e8 0%, #4fc3f7 100%);
  color: #fff;
}
.lumi-st-title {
  margin: 0;
  line-height: 1.2;
}
.lumi-st-description {
  margin: 0;
  line-height: 1.6;
}

.lumi-premium-header {
  position: relative;
  display: flex;
  flex-direction: column;
  gap: 16px;
  width: 100%;
  max-width: 760px;
  padding: 0;
  border-radius: 0;
  overflow: visible;
  isolation: auto;
  background: none;
  border: none;
  box-shadow: none;
  backdrop-filter: none;
  -webkit-backdrop-filter: none;
}
.lumi-premium-header::before {
  display: none;
}
.lumi-premium-header > * {
  position: relative;
  z-index: 1;
}
.lumi-ph-align-left .lumi-premium-header {
  text-align: left;
  align-items: flex-start;
}
.lumi-ph-align-center .lumi-premium-header {
  text-align: center;
  align-items: center;
}
.lumi-ph-align-right .lumi-premium-header {
  text-align: right;
  align-items: flex-end;
}
.lumi-ph-eyebrow {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  width: fit-content;
  padding: 8px 16px;
  border-radius: 999px;
  background-color: rgba(11,22,44,0.42);
  border: 1px solid rgba(255,255,255,0.14);
  color: #f7f2e7;
  font-size: 12px;
  font-weight: 700;
  letter-spacing: 0.12em;
  text-transform: uppercase;
}
.lumi-ph-eyebrow::before {
  content: "";
  width: 8px;
  height: 8px;
  border-radius: 50%;
  background: linear-gradient(135deg, #4fc3f7, #e1b866);
  box-shadow: 0 0 18px rgba(79,195,247,0.5);
}
.lumi-ph-title {
  margin: 0;
  font-size: clamp(2rem, 4.8vw, 3.65rem);
  font-weight: 800;
  line-height: 1.08;
  letter-spacing: -0.035em;
  color: #fff;
  text-wrap: balance;
  text-shadow: 0 14px 32px rgba(0,0,0,0.16);
}
.lumi-ph-description {
  margin: 0;
  max-width: 58ch;
  color: rgba(235,242,255,0.78);
  font-size: 1rem;
  line-height: 1.75;
}
.lumi-ph-divider {
  display: inline-flex;
  align-items: center;
  gap: 12px;
  width: var(--lumi-ph-divider-width, 180px);
  max-width: 100%;
  margin-top: 8px;
}
.lumi-ph-divider-line {
  flex: 1;
  height: 1px;
  border-radius: 999px;
  background: rgba(255,255,255,0.22);
}
.lumi-ph-divider-accent {
  width: 12px;
  height: 12px;
  border-radius: 50%;
  background: #e1b866;
  box-shadow: 0 0 0 6px rgba(225,184,102,0.12), 0 10px 24px rgba(225,184,102,0.28);
}

/* ── 2. IMAGE CARD ───────────────────────────────────────── */
.lumi-image-card {
  position: relative;
  overflow: hidden;
  background-size: cover;
  background-position: center;
  display: flex;
  align-items: flex-end;
  transition: transform 0.4s ease;
}
.lumi-image-card:hover {
  transform: scale(1.01);
}
.lumi-ic-overlay {
  position: absolute;
  inset: 0;
  background: linear-gradient(to top, rgba(0,0,0,0.85) 0%, rgba(0,0,0,0.2) 100%);
  transition: opacity 0.4s ease;
  z-index: 1;
}
.lumi-ic-body {
  position: relative;
  z-index: 2;
  padding: 32px;
  width: 100%;
}
.lumi-ic-category {
  display: block;
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  margin-bottom: 8px;
}
.lumi-ic-title {
  margin: 0 0 0;
  font-size: 1.3rem;
  color: #fff;
  transition: margin-bottom 0.3s ease;
}
.lumi-ic-hover-content {
  max-height: 0;
  overflow: hidden;
  transition: max-height 0.4s ease, opacity 0.4s ease;
  opacity: 0;
}
.lumi-image-card:hover .lumi-ic-hover-content {
  max-height: 300px;
  opacity: 1;
}
.lumi-image-card:hover .lumi-ic-title {
  margin-bottom: 12px;
}
.lumi-ic-desc {
  margin: 0 0 16px;
  font-size: 0.9rem;
  line-height: 1.6;
}
.lumi-ic-btn {
  display: inline-block;
  padding: 10px 24px;
  border-radius: 6px;
  font-size: 14px;
  font-weight: 600;
  text-decoration: none;
  background: rgba(255,255,255,0.2);
  border: 1px solid rgba(255,255,255,0.4);
  color: #fff;
  transition: background 0.3s ease;
  backdrop-filter: blur(4px);
}
.lumi-ic-btn:hover {
  background: rgba(255,255,255,0.3);
}

/* ── 3. IMAGE WIDGET ─────────────────────────────────────── */
.lumi-image-wrap {
  position: relative;
  display: block;
  width: 100%;
}
.lumi-image-stage {
  position: relative;
  display: block;
  overflow: hidden;
  border-radius: 28px;
  isolation: isolate;
  background:
    linear-gradient(150deg, rgba(11,22,43,0.96), rgba(7,16,30,0.92)),
    linear-gradient(135deg, rgba(79,195,247,0.12), transparent 45%);
  border: 1px solid rgba(255,255,255,0.12);
  box-shadow:
    0 22px 58px rgba(3, 12, 28, 0.28),
    inset 0 1px 0 rgba(255,255,255,0.08);
}
.lumi-image-stage::before,
.lumi-image-stage::after {
  content: "";
  position: absolute;
  pointer-events: none;
}
.lumi-image-stage::before {
  inset: 14px;
  border: 1px solid rgba(255,255,255,0.14);
  border-radius: 22px;
  z-index: 2;
}
.lumi-image-stage::after {
  inset: auto auto -22% -10%;
  width: 44%;
  aspect-ratio: 1;
  border-radius: 50%;
  background: radial-gradient(circle, rgba(225,184,102,0.22), transparent 70%);
  filter: blur(14px);
  z-index: 0;
}
.lumi-image-stage-glow {
  position: absolute;
  inset: -10% auto auto 52%;
  width: 40%;
  aspect-ratio: 1;
  border-radius: 50%;
  background: radial-gradient(circle, rgba(79,195,247,0.18), transparent 72%);
  filter: blur(18px);
  z-index: 0;
  pointer-events: none;
}
.lumi-image-media {
  position: relative;
  z-index: 1;
  display: block;
  overflow: hidden;
}
.lumi-image-wrap img {
  display: block;
  width: 100%;
  max-width: 100%;
  transform: scale(1.01);
  transition: transform 0.55s ease, filter 0.35s ease, opacity 0.3s ease;
}
.lumi-image-stage:hover img,
.lumi-image-stage:focus-within img {
  transform: scale(1.06);
  filter: saturate(1.08) contrast(1.03);
}
.lumi-image-caption {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  margin-top: 18px;
  padding: 10px 16px;
  border-radius: 999px;
  font-size: 0.82rem;
  font-weight: 700;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: rgba(246,248,255,0.92);
  background: linear-gradient(140deg, rgba(10,19,38,0.78), rgba(10,19,38,0.52));
  border: 1px solid rgba(255,255,255,0.1);
  box-shadow: 0 16px 34px rgba(3, 12, 28, 0.2);
}
.lumi-image-caption::before {
  content: "";
  width: 8px;
  height: 8px;
  border-radius: 50%;
  background: linear-gradient(135deg, #4fc3f7, #e1b866);
  box-shadow: 0 0 16px rgba(79,195,247,0.45);
}

/* ── 4. SLIDER ───────────────────────────────────────────── */
.lumi-slider-wrapper {
  position: relative;
  isolation: isolate;
  width: 100%;
  overflow: hidden;
  border-radius: clamp(18px, 2vw, 32px);
  background: #050b16;
  box-shadow: 0 24px 70px rgba(5, 12, 27, 0.28);
}
.lumi-slider-wrapper::after {
  content: "";
  position: absolute;
  inset: 0;
  background:
    linear-gradient(120deg, rgba(11,25,56,0.18), transparent 42%),
    radial-gradient(circle at top right, rgba(225,184,102,0.14), transparent 32%);
  pointer-events: none;
  z-index: 1;
}
.lumi-slider-wrap {
  width: 100%;
  height: 100%;
  overflow: hidden;
}
.lumi-slider-wrap .swiper-wrapper,
.lumi-slider-wrap .swiper-slide {
  height: 100%;
}
.lumi-slide {
  position: relative;
  min-height: 100%;
  background-size: cover;
  background-position: center;
  overflow: hidden;
}
.lumi-slide::before {
  content: "";
  position: absolute;
  inset: -15%;
  background:
    radial-gradient(circle at 18% 20%, rgba(79,195,247,0.18), transparent 32%),
    radial-gradient(circle at 88% 18%, rgba(225,184,102,0.16), transparent 28%),
    linear-gradient(135deg, rgba(0,0,0,0.16), transparent 45%);
  z-index: 0;
  pointer-events: none;
}
.lumi-slide-overlay {
  position: absolute;
  inset: 0;
  background:
    linear-gradient(90deg, rgba(4,10,22,0.82) 0%, rgba(5,13,29,0.58) 38%, rgba(7,14,29,0.34) 100%),
    linear-gradient(180deg, rgba(2,8,18,0.12) 0%, rgba(2,8,18,0.62) 100%);
  z-index: 1;
}
.lumi-slide-inner {
  position: relative;
  z-index: 2;
  display: flex;
  width: 100%;
  min-height: 100%;
  padding: clamp(32px, 5vw, 72px);
}
.lumi-content-v-top { align-items: flex-start; }
.lumi-content-v-middle { align-items: center; }
.lumi-content-v-bottom { align-items: flex-end; }
.lumi-slide-content {
  position: relative;
  z-index: 2;
  display: flex;
  flex-direction: column;
  gap: 16px;
  width: 100%;
  max-width: 760px;
  padding: 32px;
  border-radius: 24px;
  background-color: rgba(8,16,34,0.72);
  border: 1px solid rgba(255,255,255,0.14);
  box-shadow: 0 20px 60px rgba(4, 12, 26, 0.28), inset 0 1px 0 rgba(255,255,255,0.08);
  backdrop-filter: blur(14px);
  -webkit-backdrop-filter: blur(14px);
  overflow: hidden;
}
.lumi-slide-content::before {
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(130deg, rgba(255,255,255,0.12), transparent 38%);
  pointer-events: none;
  z-index: 0;
}
.lumi-slide-content > * {
  position: relative;
  z-index: 1;
  opacity: 0;
  transform: var(--lumi-slider-content-transform, translate3d(0, 24px, 0));
  filter: var(--lumi-slider-content-filter, none);
  transition:
    opacity 0.55s ease,
    transform 0.7s cubic-bezier(0.22, 1, 0.36, 1),
    filter 0.55s ease;
  will-change: opacity, transform;
}
.swiper-slide-active .lumi-slide-content > * {
  opacity: 1;
  transform: none;
  filter: none;
}
.lumi-slider-wrapper .swiper:not(.swiper-initialized) .swiper-slide:first-child .lumi-slide-content > * {
  opacity: 1;
  transform: none;
  filter: none;
}
.swiper-slide-active .lumi-slide-content > *:nth-child(1) { transition-delay: 0.06s; }
.swiper-slide-active .lumi-slide-content > *:nth-child(2) { transition-delay: 0.12s; }
.swiper-slide-active .lumi-slide-content > *:nth-child(3) { transition-delay: 0.18s; }
.swiper-slide-active .lumi-slide-content > *:nth-child(4) { transition-delay: 0.24s; }
.swiper-slide-active .lumi-slide-content > *:nth-child(5) { transition-delay: 0.3s; }
.lumi-slider-anim-rise .lumi-slide-content > * {
  --lumi-slider-content-transform: translate3d(0, 24px, 0);
}
.lumi-slider-anim-zoom .lumi-slide-content > * {
  --lumi-slider-content-transform: translate3d(0, 14px, 0) scale(0.94);
  --lumi-slider-content-filter: blur(1.5px);
}
.lumi-slider-anim-sweep-left .lumi-slide-content > * {
  --lumi-slider-content-transform: translate3d(-36px, 0, 0);
}
.lumi-slider-anim-sweep-right .lumi-slide-content > * {
  --lumi-slider-content-transform: translate3d(36px, 0, 0);
}
.lumi-slider-anim-none .lumi-slide-content > * {
  opacity: 1;
  transform: none;
  filter: none;
  transition: none;
}
.lumi-content-center { text-align: center; margin: 0 auto; }
.lumi-content-left   { text-align: left;   margin-right: auto; }
.lumi-content-right  { text-align: right;  margin-left: auto; }

.lumi-slide-label {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  align-self: flex-start;
  width: fit-content;
  padding: 7px 18px;
  border-radius: 50px;
  font-size: 12px;
  font-weight: 700;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  background: rgba(255,255,255,0.12);
  border: 1px solid rgba(255,255,255,0.22);
  box-shadow: inset 0 1px 0 rgba(255,255,255,0.12);
  backdrop-filter: blur(8px);
  -webkit-backdrop-filter: blur(8px);
  margin-bottom: 4px;
}
.lumi-content-center .lumi-slide-label { align-self: center; }
.lumi-content-right .lumi-slide-label  { align-self: flex-end; }
.lumi-slide-label::before {
  content: "";
  width: 8px;
  height: 8px;
  border-radius: 50%;
  background: linear-gradient(135deg, #4fc3f7, #e1b866);
  box-shadow: 0 0 18px rgba(79,195,247,0.55);
}
.lumi-slide-title {
  font-size: clamp(2rem, 5vw, 4rem);
  font-weight: 800;
  line-height: 1.1;
  letter-spacing: -0.03em;
  margin: 0;
  color: #fff;
  text-shadow: 0 16px 40px rgba(0,0,0,0.28);
}
.lumi-slide-desc {
  font-size: 1.1rem;
  line-height: 1.75;
  margin: 0;
  max-width: 52ch;
  color: rgba(236,242,255,0.88);
}
.lumi-slide-buttons {
  display: flex;
  flex-wrap: wrap;
  gap: 14px;
  align-items: center;
  margin-top: 8px;
}
.lumi-content-center .lumi-slide-buttons { justify-content: center; }
.lumi-content-right  .lumi-slide-buttons { justify-content: flex-end; }

.lumi-slider-wrapper .lumi-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  text-decoration: none;
  cursor: pointer;
  border: none;
  font-weight: 600;
  min-height: 48px;
  max-width: 100%;
  flex: 0 1 auto;
  transition: all 0.3s ease;
}
.lumi-slider-wrapper .lumi-btn-primary {
  padding: 14px 32px;
  border-radius: 999px;
  background-color: #1a73e8;
  color: #fff;
  font-size: 15px;
  box-shadow: 0 18px 32px rgba(10, 35, 78, 0.32);
}
.lumi-slider-wrapper .lumi-btn-primary:hover {
  transform: translateY(-2px);
  box-shadow: 0 18px 36px rgba(10, 35, 78, 0.4);
}
.lumi-slider-wrapper .lumi-btn-secondary {
  padding: 13px 32px;
  border-radius: 999px;
  background-color: rgba(255,255,255,0.06);
  color: #fff;
  border: 1px solid rgba(255,255,255,0.24);
  backdrop-filter: blur(8px);
  -webkit-backdrop-filter: blur(8px);
  font-size: 15px;
}
.lumi-slider-wrapper .lumi-btn-secondary:hover {
  background: rgba(255,255,255,0.14);
  border-color: rgba(255,255,255,0.36);
}
.lumi-btn-text {
  padding: 0;
  background: none;
  color: #4fc3f7;
  font-size: 14px;
}
.lumi-btn-text:hover { gap: 12px; }
.lumi-arrow { transition: transform 0.2s ease; }
.lumi-btn-text:hover .lumi-arrow { transform: translateX(4px); }

/* Swiper Custom Arrows */
.lumi-slider-wrapper .swiper-button-next,
.lumi-slider-wrapper .swiper-button-prev {
  top: 50%;
  margin-top: 0;
  transform: translateY(-50%);
  color: #fff;
  background: rgba(8,18,36,0.42);
  width: 46px !important;
  height: 46px !important;
  border-radius: 50%;
  border: 1px solid rgba(255,255,255,0.14);
  box-shadow: 0 14px 28px rgba(2,8,18,0.18);
  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);
  transition: transform 0.3s ease, background 0.3s ease, border-color 0.3s ease, box-shadow 0.3s ease;
  z-index: 4;
}
.lumi-slider-wrapper .swiper-button-next:hover,
.lumi-slider-wrapper .swiper-button-prev:hover {
  transform: translateY(-50%) scale(1.03);
  background: rgba(16,36,68,0.78);
  border-color: rgba(255,255,255,0.22);
  box-shadow: 0 18px 30px rgba(2,8,18,0.22);
}
.lumi-slider-wrapper .swiper-button-prev {
  left: clamp(14px, 2vw, 22px);
}
.lumi-slider-wrapper .swiper-button-next {
  right: clamp(14px, 2vw, 22px);
}
.lumi-slider-wrapper .swiper-button-next::after,
.lumi-slider-wrapper .swiper-button-prev::after {
  font-size: 14px !important;
  font-weight: 700;
}
.lumi-slider-wrapper .swiper-pagination {
  left: 50% !important;
  right: auto !important;
  bottom: clamp(24px, 3vw, 34px) !important;
  width: auto !important;
  transform: translateX(-50%);
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  z-index: 4;
}
.lumi-slider-wrapper .swiper-pagination-bullet {
  margin: 0 !important;
  width: 10px;
  height: 10px;
  border-radius: 999px;
  background: rgba(255,255,255,0.34) !important;
  opacity: 1;
  transition: width 0.3s ease, transform 0.3s ease, background 0.3s ease;
}
.lumi-slider-wrapper .swiper-pagination-bullet-active {
  width: 30px;
  height: 10px;
  border-radius: 999px;
  background: linear-gradient(90deg, #4fc3f7, #e1b866) !important;
  box-shadow: 0 10px 24px rgba(79,195,247,0.22);
}

/* Progress bar variant */
.lumi-slider-progress {
  position: absolute;
  left: 0;
  right: 0;
  height: 3px;
  background: rgba(255,255,255,0.12);
  z-index: 10;
  overflow: hidden;
}
.lumi-slider-progress-top {
  top: 0;
  bottom: auto;
}
.lumi-slider-progress-bottom {
  top: auto;
  bottom: 0;
}
.lumi-slider-progress-bar {
  height: 100%;
  background: linear-gradient(90deg, #0f3e81 0%, #4fc3f7 55%, #e1b866 100%);
  box-shadow: 0 0 16px rgba(79,195,247,0.3);
}

/* ── 5. ICON BOX ─────────────────────────────────────────── */
.lumi-icon-box {
  display: flex;
  transition: all 0.35s ease;
}
.lumi-ib-pos-top {
  flex-direction: column;
}
.lumi-ib-pos-left {
  flex-direction: row;
  align-items: flex-start;
  gap: 24px;
}
.lumi-ib-pos-right {
  flex-direction: row-reverse;
  align-items: flex-start;
  gap: 24px;
}
.lumi-ib-icon-wrap {
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
  border-radius: 12px;
  transition: transform 0.3s ease;
}
.lumi-icon-box:hover .lumi-ib-icon-wrap {
  transform: scale(1.08);
}
.lumi-ib-icon {
  display: flex;
  align-items: center;
  justify-content: center;
}
.lumi-ib-text {
  flex: 1;
}
.lumi-ib-title {
  margin: 0 0 10px;
  font-size: 1.1rem;
  font-weight: 700;
}
.lumi-ib-desc {
  margin: 0 0 16px;
  line-height: 1.65;
  font-size: 0.93rem;
}

/* ── 6. CTA ──────────────────────────────────────────────── */
.lumi-cta {
  position: relative;
  overflow: hidden;
  display: flex;
  align-items: center;
  justify-content: center;
  min-height: 100vh;
  background-color: #071321;
  background-size: cover;
  background-position: center;
  background-repeat: no-repeat;
  isolation: isolate;
  box-shadow: 0 24px 70px rgba(5, 12, 27, 0.26);
}
.lumi-cta-overlay {
  position: absolute;
  inset: 0;
  background-color: rgba(6, 13, 27, 0.72);
  background-image: none;
  z-index: 0;
}
.lumi-cta-glow {
  position: absolute;
  border-radius: 999px;
  filter: blur(16px);
  opacity: 0.65;
  pointer-events: none;
  z-index: 0;
}
.lumi-cta-glow-blue {
  width: 280px;
  height: 280px;
  top: -80px;
  left: -60px;
  background: radial-gradient(circle, rgba(79,195,247,0.32), transparent 70%);
}
.lumi-cta-glow-gold {
  width: 260px;
  height: 260px;
  right: -60px;
  bottom: -80px;
  background: radial-gradient(circle, rgba(225,184,102,0.28), transparent 70%);
}
.lumi-cta-inner {
  position: relative;
  z-index: 1;
  width: min(100%, 1440px);
  min-height: inherit;
  display: flex;
  align-items: center;
}
.lumi-cta-panel {
  position: relative;
  width: 100%;
  display: flex;
  flex-direction: column;
  gap: 28px;
  padding: clamp(34px, 5vw, 56px);
  border-radius: 32px;
  overflow: hidden;
  background: linear-gradient(145deg, rgba(8,18,38,0.74), rgba(8,16,31,0.42));
  border: 1px solid rgba(255,255,255,0.12);
  box-shadow: 0 24px 60px rgba(4, 12, 26, 0.24), inset 0 1px 0 rgba(255,255,255,0.08);
  backdrop-filter: blur(14px);
  -webkit-backdrop-filter: blur(14px);
}
.lumi-cta-panel::before {
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(130deg, rgba(255,255,255,0.12), transparent 36%);
  pointer-events: none;
  z-index: 0;
}
.lumi-cta-panel > * {
  position: relative;
  z-index: 1;
}
.lumi-cta-layout-center .lumi-cta-panel {
  text-align: center;
  align-items: center;
}
.lumi-cta-layout-center .lumi-cta-text {
  max-width: 820px;
}
.lumi-cta-layout-left-right .lumi-cta-panel {
  flex-direction: row;
  align-items: center;
  justify-content: space-between;
  gap: 48px;
}
.lumi-cta-layout-left-right .lumi-cta-text {
  flex: 1;
  min-width: 300px;
  max-width: 760px;
}
.lumi-cta-layout-left-right .lumi-cta-buttons {
  flex-shrink: 0;
  justify-content: flex-end;
}

.lumi-cta-subtitle {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  width: fit-content;
  padding: 8px 18px;
  border-radius: 999px;
  border: 1px solid rgba(255,255,255,0.16);
  background: linear-gradient(135deg, rgba(255,255,255,0.1), rgba(255,255,255,0.04));
  box-shadow: inset 0 1px 0 rgba(255,255,255,0.1);
  font-size: 0.82rem;
  font-weight: 700;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  margin-bottom: 16px;
}
.lumi-cta-subtitle::before {
  content: "";
  width: 8px;
  height: 8px;
  border-radius: 50%;
  background: linear-gradient(135deg, #4fc3f7, #e1b866);
  box-shadow: 0 0 18px rgba(79,195,247,0.5);
}
.lumi-cta-layout-center .lumi-cta-subtitle {
  margin-left: auto;
  margin-right: auto;
}
.lumi-cta-title {
  font-size: clamp(2.2rem, 4.5vw, 4.4rem);
  font-weight: 800;
  line-height: 1.06;
  letter-spacing: -0.04em;
  margin: 0 0 18px;
  text-wrap: balance;
  text-shadow: 0 18px 40px rgba(0,0,0,0.18);
}
.lumi-cta-desc {
  margin: 0;
  max-width: 58ch;
  line-height: 1.75;
  font-size: 1.05rem;
  color: rgba(236,242,255,0.84);
}
.lumi-cta-layout-center .lumi-cta-desc {
  margin-left: auto;
  margin-right: auto;
}
.lumi-cta-buttons {
  display: flex;
  flex-direction: row;
  gap: 16px;
  flex-wrap: wrap;
  align-items: center;
}
.lumi-cta-buttons > a {
  flex: 0 0 auto;
  width: auto;
  max-width: 100%;
}
.lumi-cta-layout-center .lumi-cta-buttons {
  justify-content: center;
}
.lumi-cta-btn-primary {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: min(180px, 100%);
  padding: 16px 34px;
  border-radius: 999px;
  font-size: 15px;
  font-weight: 700;
  text-decoration: none;
  text-align: center;
  background-color: #1a73e8;
  background-image: none;
  color: #fff;
  box-shadow: 0 18px 36px rgba(8, 27, 58, 0.32);
  transition: transform 0.3s ease, box-shadow 0.3s ease, filter 0.3s ease;
}
.lumi-cta-btn-primary:hover {
  transform: translateY(-2px);
  box-shadow: 0 22px 40px rgba(8, 27, 58, 0.4);
  filter: brightness(1.03);
}
.lumi-cta-btn-secondary {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: min(180px, 100%);
  padding: 15px 34px;
  border-radius: 999px;
  font-size: 15px;
  font-weight: 700;
  text-decoration: none;
  text-align: center;
  background-color: rgba(255,255,255,0.06);
  background-image: none;
  border: 1px solid rgba(255,255,255,0.22);
  color: #fff;
  backdrop-filter: blur(8px);
  -webkit-backdrop-filter: blur(8px);
  transition: transform 0.3s ease, background 0.3s ease, border-color 0.3s ease;
}
.lumi-cta-btn-secondary:hover {
  transform: translateY(-2px);
  background: rgba(255,255,255,0.12);
  border-color: rgba(255,255,255,0.34);
}

.lumi-cta-hero {
  position: relative;
  display: flex;
  align-items: center;
  min-height: 100vh;
  overflow: hidden;
  isolation: isolate;
  background-color: #071321;
  background-size: cover;
  background-position: center;
  background-repeat: no-repeat;
  box-shadow: 0 24px 70px rgba(5, 12, 27, 0.24);
}
.lumi-cta-hero-overlay {
  position: absolute;
  inset: 0;
  background-color: rgba(6, 13, 27, 0.7);
  background-image: none;
  z-index: 0;
}
.lumi-cta-hero-glow {
  position: absolute;
  border-radius: 999px;
  filter: blur(16px);
  opacity: 0.68;
  pointer-events: none;
  z-index: 0;
}
.lumi-cta-hero-glow-blue {
  width: 320px;
  height: 320px;
  top: -110px;
  left: -60px;
  background: radial-gradient(circle, rgba(79,195,247,0.32), transparent 70%);
}
.lumi-cta-hero-glow-gold {
  width: 280px;
  height: 280px;
  right: -70px;
  bottom: -100px;
  background: radial-gradient(circle, rgba(225,184,102,0.28), transparent 70%);
}
.lumi-cta-hero-inner {
  position: relative;
  z-index: 1;
  width: 100%;
}
.lumi-cta-hero-boxed .lumi-cta-hero-inner {
  width: min(100%, 1240px);
  margin-left: auto;
  margin-right: auto;
}
.lumi-cta-hero-full .lumi-cta-hero-inner {
  max-width: none;
}
.lumi-cta-hero-content {
  display: flex;
  flex-direction: column;
  gap: 18px;
  max-width: 760px;
}
.lumi-cta-hero-align-left .lumi-cta-hero-content {
  margin-right: auto;
  text-align: left;
  align-items: flex-start;
}
.lumi-cta-hero-align-center .lumi-cta-hero-content {
  margin-left: auto;
  margin-right: auto;
  text-align: center;
  align-items: center;
}
.lumi-cta-hero-align-right .lumi-cta-hero-content {
  margin-left: auto;
  text-align: right;
  align-items: flex-end;
}
.lumi-cta-hero-subtitle {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  width: fit-content;
  padding: 8px 18px;
  border-radius: 999px;
  background: linear-gradient(135deg, rgba(255,255,255,0.12), rgba(255,255,255,0.05));
  border: 1px solid rgba(255,255,255,0.14);
  box-shadow: inset 0 1px 0 rgba(255,255,255,0.12);
  color: #f7f2e7;
  font-size: 0.82rem;
  font-weight: 700;
  letter-spacing: 0.14em;
  text-transform: uppercase;
}
.lumi-cta-hero-subtitle::before {
  content: "";
  width: 8px;
  height: 8px;
  border-radius: 50%;
  background: linear-gradient(135deg, #4fc3f7, #e1b866);
  box-shadow: 0 0 18px rgba(79,195,247,0.5);
}
.lumi-cta-hero-title {
  margin: 0;
  font-size: clamp(2.6rem, 5vw, 4.9rem);
  font-weight: 800;
  line-height: 1.04;
  letter-spacing: -0.045em;
  color: #fff;
  text-wrap: balance;
  text-shadow: 0 18px 44px rgba(0,0,0,0.2);
}
.lumi-cta-hero-divider {
  display: inline-flex;
  align-items: center;
  gap: 12px;
  width: 180px;
}
.lumi-cta-hero-divider-line {
  flex: 1;
  height: 1px;
  border-radius: 999px;
  background: rgba(255,255,255,0.24);
}
.lumi-cta-hero-divider-accent {
  width: 12px;
  height: 12px;
  border-radius: 50%;
  background: #e1b866;
  box-shadow: 0 0 0 6px rgba(225,184,102,0.12), 0 10px 24px rgba(225,184,102,0.28);
}
.lumi-cta-hero-desc {
  margin: 0;
  max-width: 58ch;
  color: rgba(236,242,255,0.86);
  font-size: 1.05rem;
  line-height: 1.78;
}
.lumi-cta-hero-buttons {
  display: flex;
  flex-direction: row;
  flex-wrap: wrap;
  gap: 16px;
  align-items: center;
  justify-content: flex-start;
  width: 100%;
  max-width: 100%;
  align-self: stretch;
  margin-top: 8px;
}
.lumi-cta-hero-buttons > a {
  flex: 0 0 auto;
  width: auto;
  max-width: 100%;
}
.lumi-cta-hero-align-center .lumi-cta-hero-buttons {
  justify-content: center;
}
.lumi-cta-hero-align-right .lumi-cta-hero-buttons {
  justify-content: flex-end;
}
.lumi-cta-hero-btn-primary,
.lumi-cta-hero-btn-secondary {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: min(180px, 100%);
  padding: 16px 34px;
  font-size: 15px;
  font-weight: 700;
  text-decoration: none;
  text-align: center;
  transition: transform 0.3s ease, box-shadow 0.3s ease, filter 0.3s ease, background 0.3s ease, border-color 0.3s ease;
}
.lumi-cta-hero-btn-primary {
  border-radius: 999px;
  background-color: #1a73e8;
  background-image: none;
  color: #fff;
  box-shadow: 0 18px 36px rgba(8, 27, 58, 0.34);
}
.lumi-cta-hero-btn-primary:hover {
  transform: translateY(-2px);
  box-shadow: 0 22px 40px rgba(8, 27, 58, 0.42);
  filter: brightness(1.03);
}
.lumi-cta-hero-btn-secondary {
  border-radius: 999px;
  background-color: rgba(255,255,255,0.06);
  background-image: none;
  border: 1px solid rgba(255,255,255,0.22);
  color: #fff;
  backdrop-filter: blur(8px);
  -webkit-backdrop-filter: blur(8px);
}
.lumi-cta-hero-btn-secondary:hover {
  transform: translateY(-2px);
  background: rgba(255,255,255,0.12);
  border-color: rgba(255,255,255,0.34);
}

/* ── 7. BUTTONS ──────────────────────────────────────────── */
.lumi-buttons-wrap {
  display: flex;
  flex-wrap: wrap;
  gap: 16px;
  align-items: center;
}
.lumi-btn-item {
  --lumi-btn-shadow: 0 18px 34px rgba(3, 11, 24, 0.16);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  text-decoration: none;
  cursor: pointer;
  font-weight: 700;
  transition: transform 0.3s ease, box-shadow 0.3s ease, background 0.3s ease, border-color 0.3s ease, color 0.3s ease, filter 0.3s ease;
  border-radius: 999px;
  padding: 14px 32px;
  font-size: 15px;
  line-height: 1;
  border: 1px solid transparent;
  position: relative;
  overflow: hidden;
  isolation: isolate;
  box-shadow: var(--lumi-btn-shadow);
  letter-spacing: 0.01em;
}
.lumi-btn-item.lumi-btn-full { width: 100%; }
.lumi-btn-item::before {
  content: "";
  position: absolute;
  inset: 1px;
  border-radius: inherit;
  background: linear-gradient(180deg, rgba(255,255,255,0.12), rgba(255,255,255,0.02));
  opacity: 0.8;
  z-index: 0;
}
.lumi-btn-content {
  position: relative;
  z-index: 2;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 10px;
}
.lumi-btn-sheen {
  position: absolute;
  top: -28%;
  left: -36%;
  width: 34%;
  height: 160%;
  transform: translateX(-140%) rotate(22deg);
  background: linear-gradient(90deg, rgba(255,255,255,0), rgba(255,255,255,0.38), rgba(255,255,255,0));
  opacity: 0;
  transition: transform 0.6s ease, opacity 0.3s ease;
  z-index: 1;
}
.lumi-btn-icon {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-size: 0.95em;
  transition: transform 0.3s ease;
}
.lumi-btn-copy {
  position: relative;
  top: -0.02em;
}
.lumi-btn-item:hover {
  transform: translateY(-3px);
  filter: brightness(1.02);
}
.lumi-btn-item:hover .lumi-btn-sheen {
  transform: translateX(420%) rotate(22deg);
  opacity: 1;
}
.lumi-btn-item:hover .lumi-btn-icon-before {
  transform: translateX(-2px);
}
.lumi-btn-item:hover .lumi-btn-icon-after {
  transform: translateX(4px);
}
.lumi-btn-style-primary {
  background: linear-gradient(135deg, #0f3e81 0%, #1d6ce3 52%, #e1b866 100%);
  color: #fff;
  border-color: rgba(255,255,255,0.14);
  box-shadow: 0 22px 44px rgba(10, 33, 72, 0.34);
}
.lumi-btn-style-primary:hover {
  box-shadow: 0 26px 52px rgba(10, 33, 72, 0.42);
}
.lumi-btn-style-secondary {
  background: linear-gradient(145deg, rgba(10,20,39,0.8), rgba(10,20,39,0.52));
  color: #fff;
  border-color: rgba(255,255,255,0.26);
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
}
.lumi-btn-style-secondary:hover {
  background: linear-gradient(145deg, rgba(13,28,54,0.9), rgba(13,28,54,0.6));
  border-color: rgba(255,255,255,0.4);
}
.lumi-btn-style-ghost {
  background: rgba(255,255,255,0.08);
  color: #fff;
  border-color: rgba(255,255,255,0.14);
  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);
  box-shadow: 0 14px 28px rgba(3, 11, 24, 0.14);
}
.lumi-btn-style-ghost:hover {
  background: rgba(255,255,255,0.14);
  border-color: rgba(255,255,255,0.22);
}
.lumi-btn-style-text-link {
  background: none;
  color: #cfe5ff;
  padding: 6px 0;
  border: none;
  border-radius: 0;
  box-shadow: none;
  overflow: visible;
}
.lumi-btn-style-text-link::before,
.lumi-btn-style-text-link .lumi-btn-sheen {
  display: none;
}
.lumi-btn-style-text-link .lumi-btn-content {
  gap: 12px;
}
.lumi-btn-style-text-link .lumi-btn-copy::after {
  content: "";
  position: absolute;
  left: 0;
  right: 0;
  bottom: -6px;
  height: 2px;
  border-radius: 999px;
  background: linear-gradient(90deg, #4fc3f7, #e1b866);
  transform-origin: left center;
  transform: scaleX(0.35);
  transition: transform 0.3s ease;
}
.lumi-btn-style-text-link:hover {
  transform: none;
  opacity: 1;
}
.lumi-btn-style-text-link:hover .lumi-btn-copy::after {
  transform: scaleX(1);
}

/* ── 8. BACKGROUND ANIMATION ─────────────────────────────── */
.lumi-bg-anim-wrap {
  --prolink-motion-primary: rgba(79,195,247,0.62);
  --prolink-motion-secondary: rgba(26,115,232,0.38);
  --prolink-motion-accent: rgba(225,184,102,0.32);
  position: relative;
  overflow: hidden;
  display: flex;
  align-items: center;
  justify-content: center;
}
.lumi-bg-anim-wrap canvas {
  display: block;
  width: 100%;
  height: 100%;
}
.lumi-bg-anim-wrap.lumi-bg-anim-as-background {
  width: 100%;
  height: 100%;
  min-height: 0 !important;
  pointer-events: none;
}
.elementor-widget-lumi-background-animation.lumi-bg-anim-layer {
  position: absolute !important;
  inset: 0;
  width: 100% !important;
  max-width: none !important;
  height: 100%;
  margin: 0 !important;
  z-index: 0 !important;
  pointer-events: none;
}
.elementor-widget-lumi-background-animation.lumi-bg-anim-layer > .elementor-widget-container,
.elementor-widget-lumi-background-animation.lumi-bg-anim-layer .lumi-bg-anim-wrap {
  height: 100%;
}
.lumi-bg-anim-host {
  position: relative;
}
.lumi-bg-anim-host.lumi-bg-anim-clip {
  overflow: hidden;
}
.lumi-bg-anim-host > .elementor-element {
  position: relative;
  z-index: 1;
}
.lumi-bg-anim-host > .elementor-widget-lumi-background-animation.lumi-bg-anim-layer {
  z-index: 0 !important;
}
.prolink-motion-host {
  position: relative;
  isolation: isolate;
}
.prolink-motion-host.prolink-motion-clip {
  overflow: hidden;
}
.prolink-motion-host > * {
  position: relative;
  z-index: 2;
}
.prolink-motion-host > .elementor-background-overlay {
  z-index: 0;
}
.prolink-motion-host > .prolink-motion-surface {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  min-height: 0 !important;
  margin: 0 !important;
  z-index: 1 !important;
  pointer-events: none;
  background-color: rgba(5, 13, 27, 0.22);
}
.prolink-motion-host > .prolink-motion-surface > * {
  position: absolute;
  inset: 0;
}
.prolink-motion-host > .prolink-motion-surface > .prolink-motion-overlay {
  z-index: 0;
}
.prolink-motion-host > .prolink-motion-surface > .lumi-grid-pulse,
.prolink-motion-host > .prolink-motion-surface > .lumi-mesh-grid,
.prolink-motion-host > .prolink-motion-surface > .lumi-scanlines,
.prolink-motion-host > .prolink-motion-surface > .lumi-scan-glow,
.prolink-motion-host > .prolink-motion-surface > .lumi-wave-container,
.prolink-motion-host > .prolink-motion-surface > .lumi-shape,
.prolink-motion-host > .prolink-motion-surface > .lumi-gradient-orb,
.prolink-motion-host > .prolink-motion-surface > .lumi-aurora-band,
.prolink-motion-host > .prolink-motion-surface > .lumi-mesh-orb,
.prolink-motion-host > .prolink-motion-surface > .lumi-spotlight,
.prolink-motion-host > .prolink-motion-surface > .lumi-particles-canvas {
  z-index: 1;
}
/* Floating Shapes */
.lumi-shape {
  position: absolute;
  border-radius: 50%;
  animation: lumiFloat 8s ease-in-out infinite;
}
.lumi-shape-1 {
  width: 500px; height: 500px;
  top: -150px; left: -100px;
  animation-delay: 0s;
  background: radial-gradient(circle, rgba(79,195,247,0.15), transparent 70%);
}
.lumi-shape-2 {
  width: 400px; height: 400px;
  bottom: -100px; right: -80px;
  animation-delay: 3s;
  background: radial-gradient(circle, rgba(100,60,200,0.12), transparent 70%);
}
.lumi-shape-3 {
  width: 300px; height: 300px;
  top: 50%; left: 50%;
  transform: translate(-50%, -50%);
  animation-delay: 6s;
  background: radial-gradient(circle, rgba(0,230,160,0.1), transparent 70%);
}
@keyframes lumiFloat {
  0%, 100% { transform: translateY(0) scale(1); }
  50%       { transform: translateY(-30px) scale(1.05); }
}

/* Gradient Orbs */
.lumi-gradient-orb {
  position: absolute;
  border-radius: 50%;
  filter: blur(80px);
  animation: lumiOrb 12s ease-in-out infinite;
}
.lumi-orb-1 {
  width: 600px; height: 600px;
  background: rgba(79,195,247,0.25);
  top: -200px; left: -200px;
  animation-delay: 0s;
}
.lumi-orb-2 {
  width: 500px; height: 500px;
  background: rgba(100,60,220,0.2);
  bottom: -150px; right: -150px;
  animation-delay: 4s;
}
.lumi-orb-3 {
  width: 350px; height: 350px;
  background: rgba(0,230,160,0.15);
  top: 50%; left: 50%;
  transform: translate(-50%, -50%);
  animation-delay: 8s;
}
@keyframes lumiOrb {
  0%, 100% { transform: scale(1) translate(0, 0); opacity: 1; }
  33%       { transform: scale(1.15) translate(30px, -20px); opacity: 0.8; }
  66%       { transform: scale(0.9)  translate(-20px, 30px); opacity: 0.9; }
}

/* Grid Pulse */
.lumi-grid-pulse {
  position: absolute;
  inset: 0;
  background-image:
    linear-gradient(color-mix(in srgb, var(--prolink-motion-primary) 55%, transparent) 1px, transparent 1px),
    linear-gradient(90deg, color-mix(in srgb, var(--prolink-motion-primary) 55%, transparent) 1px, transparent 1px);
  background-size: 60px 60px;
  animation: lumiPulse 4s ease-in-out infinite;
}
@keyframes lumiPulse {
  0%, 100% { opacity: 1; }
  50%       { opacity: 0.4; }
}

/* Wave */
.lumi-wave-container {
  position: absolute;
  bottom: 0;
  left: 0;
  right: 0;
}
.lumi-wave {
  width: 100%;
  display: block;
  animation: lumiWave 6s ease-in-out infinite;
  color: #4fc3f7;
}
.lumi-wave-2 {
  animation-delay: -3s;
  animation-duration: 9s;
  margin-top: -60px;
}
.lumi-aurora-band {
  position: absolute;
  width: 72%;
  height: 44%;
  border-radius: 999px;
  filter: blur(42px);
  opacity: 0.72;
  mix-blend-mode: screen;
  animation: lumiAuroraDrift 12s ease-in-out infinite alternate;
}
.lumi-aurora-band-1 {
  top: -6%;
  left: -10%;
  background: linear-gradient(135deg, color-mix(in srgb, var(--prolink-motion-primary) 80%, transparent), transparent 72%);
}
.lumi-aurora-band-2 {
  right: -8%;
  bottom: 8%;
  animation-delay: -4s;
  background: linear-gradient(135deg, color-mix(in srgb, var(--prolink-motion-secondary) 78%, transparent), transparent 72%);
}
.lumi-aurora-band-3 {
  left: 18%;
  top: 28%;
  animation-delay: -8s;
  background: linear-gradient(135deg, color-mix(in srgb, var(--prolink-motion-accent) 80%, transparent), transparent 76%);
}
@keyframes lumiAuroraDrift {
  0% { transform: translate3d(-3%, 0, 0) rotate(-10deg) scale(1); }
  50% { transform: translate3d(4%, -8%, 0) rotate(-2deg) scale(1.08); }
  100% { transform: translate3d(-2%, 6%, 0) rotate(6deg) scale(0.96); }
}
.lumi-mesh-orb {
  position: absolute;
  border-radius: 50%;
  filter: blur(42px);
  opacity: 0.8;
  animation: lumiOrb 11s ease-in-out infinite;
}
.lumi-mesh-orb-1 {
  width: 380px;
  height: 380px;
  top: -80px;
  left: -40px;
  background: radial-gradient(circle, color-mix(in srgb, var(--prolink-motion-primary) 88%, transparent), transparent 70%);
}
.lumi-mesh-orb-2 {
  width: 320px;
  height: 320px;
  right: -60px;
  bottom: -50px;
  animation-delay: -4s;
  background: radial-gradient(circle, color-mix(in srgb, var(--prolink-motion-secondary) 82%, transparent), transparent 70%);
}
.lumi-mesh-orb-3 {
  width: 260px;
  height: 260px;
  left: 34%;
  top: 22%;
  animation-delay: -7s;
  background: radial-gradient(circle, color-mix(in srgb, var(--prolink-motion-accent) 84%, transparent), transparent 70%);
}
.lumi-mesh-grid {
  position: absolute;
  inset: 0;
  background-image:
    linear-gradient(color-mix(in srgb, var(--prolink-motion-primary) 22%, transparent) 1px, transparent 1px),
    linear-gradient(90deg, color-mix(in srgb, var(--prolink-motion-secondary) 18%, transparent) 1px, transparent 1px);
  background-size: 34px 34px;
  opacity: 0.5;
  mask-image: radial-gradient(circle at center, rgba(0,0,0,0.9), transparent 78%);
}
.lumi-spotlight {
  position: absolute;
  width: 48%;
  height: 140%;
  top: -20%;
  filter: blur(10px);
  transform-origin: top center;
  opacity: 0.54;
  animation: lumiSpotSweep 14s ease-in-out infinite alternate;
}
.lumi-spotlight-1 {
  left: -8%;
  background: linear-gradient(180deg, color-mix(in srgb, var(--prolink-motion-primary) 85%, transparent), transparent 72%);
}
.lumi-spotlight-2 {
  right: -8%;
  animation-delay: -6s;
  background: linear-gradient(180deg, color-mix(in srgb, var(--prolink-motion-accent) 80%, transparent), transparent 72%);
}
@keyframes lumiSpotSweep {
  0% { transform: rotate(-10deg) translateY(-2%); }
  50% { transform: rotate(3deg) translateY(4%); }
  100% { transform: rotate(12deg) translateY(-4%); }
}
.lumi-scanlines {
  position: absolute;
  inset: 0;
  background-image:
    linear-gradient(180deg, transparent 0%, color-mix(in srgb, var(--prolink-motion-primary) 14%, transparent) 48%, transparent 100%),
    repeating-linear-gradient(180deg, rgba(255,255,255,0.04) 0px, rgba(255,255,255,0.04) 1px, transparent 1px, transparent 6px);
  opacity: 0.48;
}
.lumi-scan-glow {
  position: absolute;
  inset: -25% 0 auto;
  height: 34%;
  background: linear-gradient(180deg, transparent, color-mix(in srgb, var(--prolink-motion-accent) 46%, transparent), transparent);
  filter: blur(18px);
  animation: lumiScanSweep 8s linear infinite;
}
@keyframes lumiScanSweep {
  0% { transform: translateY(-90%); }
  100% { transform: translateY(320%); }
}
@keyframes lumiWave {
  0%, 100% { transform: translateX(0); }
  50%       { transform: translateX(-30px); }
}

/* Particles Canvas */
.lumi-particles-canvas {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
}

/* ── 9. OFF CANVAS ───────────────────────────────────────── */
.lumi-oc-trigger {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  cursor: pointer;
  padding: 12px 24px;
  border-radius: 8px;
  font-size: 15px;
  font-weight: 600;
  border: none;
  background-color: #1a73e8;
  color: #fff;
  transition: transform 0.3s ease, box-shadow 0.3s ease, background-color 0.3s ease;
}
.lumi-oc-trigger:hover {
  transform: translateY(-2px);
  box-shadow: 0 6px 20px rgba(79,195,247,0.35);
}
.lumi-oc-overlay {
  position: fixed;
  inset: 0;
  background: rgba(0,0,0,0.6);
  z-index: 9998;
  opacity: 0;
  pointer-events: none;
  transition: opacity 0.35s ease;
}
.lumi-oc-overlay.lumi-oc-blur {
  backdrop-filter: blur(6px);
  -webkit-backdrop-filter: blur(6px);
}
.lumi-oc-overlay.lumi-open {
  opacity: 1;
  pointer-events: all;
}
.lumi-oc-panel {
  position: fixed;
  top: 0;
  bottom: 0;
  z-index: 9999;
  background-color: #0a0f1e;
  width: 360px;
  max-width: 90vw;
  overflow-y: auto;
  transition: transform 0.4s cubic-bezier(0.4, 0, 0.2, 1);
  display: flex;
  flex-direction: column;
}
.lumi-oc-left  { left: 0;  transform: translateX(-100%); }
.lumi-oc-right { right: 0; transform: translateX(100%); }
.lumi-oc-top   { top: 0; left: 0; right: 0; width: 100%; height: auto; max-height: 70vh; transform: translateY(-100%); }

.lumi-oc-left.lumi-open,
.lumi-oc-right.lumi-open { transform: translateX(0); }
.lumi-oc-top.lumi-open   { transform: translateY(0); }

.lumi-oc-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 24px 28px;
  border-bottom: 1px solid rgba(255,255,255,0.08);
}
.lumi-oc-title {
  margin: 0;
  font-size: 1.2rem;
  color: #fff;
}
.lumi-oc-close {
  background: rgba(255,255,255,0.08);
  border: none;
  border-radius: 50%;
  width: 36px;
  height: 36px;
  display: flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  color: rgba(255,255,255,0.7);
  transition: all 0.2s ease;
}
.lumi-oc-close:hover { background: rgba(255,255,255,0.16); color: #fff; }
.lumi-oc-body {
  padding: 28px;
  flex: 1;
  color: rgba(255,255,255,0.75);
  line-height: 1.65;
}
.lumi-oc-headerless .lumi-oc-body {
  padding-top: 32px;
}
.lumi-oc-close-floating {
  position: sticky;
  top: 18px;
  margin: 18px 18px 0 auto;
  z-index: 2;
}
.lumi-oc-body-template {
  padding: 0;
  color: inherit;
}
.lumi-oc-body-template > .elementor,
.lumi-oc-body-template .elementor-section-wrap,
.lumi-oc-body-template .e-con,
.lumi-oc-body-template .elementor-element {
  width: 100%;
  max-width: 100%;
}

/* ── 10. IMAGE BOX ───────────────────────────────────────── */
.lumi-image-box {
  transition: all 0.3s ease;
  text-decoration: none;
  display: block;
}
.lumi-image-box-img {
  overflow: hidden;
  border-radius: 12px 12px 0 0;
}
.lumi-image-box-img img {
  width: 100%;
  height: auto;
  display: block;
  transition: transform 0.5s ease;
}
.lumi-image-box:hover .lumi-image-box-img img {
  transform: scale(1.05);
}
.lumi-image-box-content { padding: 24px 0 0; }
.lumi-image-box-content h3 {
  margin: 0 0 10px;
  font-size: 1.1rem;
  font-weight: 700;
}
.lumi-image-box-content p { margin: 0 0 14px; line-height: 1.6; }
.lumi-image-box-link {
  color: #4fc3f7;
  text-decoration: none;
  font-weight: 600;
  font-size: 14px;
  transition: gap 0.2s ease;
}
.lumi-image-box-link:hover { opacity: 0.8; }

/* ── 11. TESTIMONIAL ─────────────────────────────────────── */
.lumi-testimonial-stage {
  display: flex;
  flex-direction: column;
  gap: 28px;
}
.lumi-testimonial-header {
  display: flex;
  align-items: flex-end;
  justify-content: space-between;
  gap: 18px;
}
.lumi-testimonial-heading {
  margin: 0;
  max-width: 16ch;
  font-size: clamp(2rem, 4.4vw, 3.4rem);
  line-height: 1.05;
  letter-spacing: -0.04em;
  text-wrap: balance;
}
.lumi-testimonial-slider-shell {
  display: flex;
  align-items: center;
  gap: 16px;
}
.lumi-testimonial-slider-shell .swiper {
  flex: 1;
  overflow: visible;
}
.lumi-testimonial-slider-shell .swiper-wrapper {
  align-items: stretch;
}
.lumi-testimonial-slider-shell .swiper-slide {
  height: auto;
}
.lumi-testi-nav {
  flex-shrink: 0;
  width: 48px;
  height: 48px;
  border: 1px solid rgba(255,255,255,0.14);
  border-radius: 50%;
  background: rgba(10,20,39,0.48);
  color: #fff;
  box-shadow: 0 18px 38px rgba(3,11,24,0.18);
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
  cursor: pointer;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  transition: transform .25s ease, background .25s ease, border-color .25s ease;
}
.lumi-testi-nav:hover {
  transform: scale(1.04);
  background: var(--lumi-testi-accent, #e1b866);
  border-color: transparent;
}
.lumi-testimonial-wrap .swiper-pagination {
  position: static;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  margin-top: 26px;
}
.lumi-testimonial-wrap .swiper-pagination-bullet {
  width: 8px;
  height: 8px;
  margin: 0 !important;
  opacity: 1;
  border-radius: 999px;
  background: rgba(255,255,255,0.24);
  transition: width .25s ease, background .25s ease;
}
.lumi-testimonial-wrap .swiper-pagination-bullet-active {
  width: 26px;
  background: linear-gradient(90deg, #4fc3f7, #e1b866);
}
.lumi-testimonial-item {
  --lumi-testi-accent: #e1b866;
  position: relative;
  display: flex;
  flex-direction: column;
  gap: 22px;
  min-height: 100%;
  overflow: hidden;
  border-radius: 28px;
  background: linear-gradient(145deg, rgba(11,19,37,0.96), rgba(14,24,47,0.72));
  border: 1px solid rgba(255,255,255,0.1);
  box-shadow: 0 26px 58px rgba(3,11,24,0.2), inset 0 1px 0 rgba(255,255,255,0.08);
  transition: transform .3s ease, box-shadow .3s ease, border-color .3s ease;
}
.lumi-testimonial-item:hover {
  transform: translateY(-4px);
  border-color: rgba(255,255,255,0.16);
  box-shadow: 0 30px 62px rgba(3,11,24,0.24), inset 0 1px 0 rgba(255,255,255,0.08);
}
.lumi-testi-split-shell {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(220px, 270px);
  align-items: stretch;
  min-height: 420px;
}
.lumi-testi-light-shell {
  background: linear-gradient(145deg, rgba(255,255,255,0.94), rgba(247,249,255,0.88));
  color: #102036;
}
.lumi-testi-light-shell .lumi-testi-quote,
.lumi-testi-light-shell .lumi-testi-position {
  color: rgba(16,32,54,0.72);
}
.lumi-testi-light-shell .lumi-testi-name {
  color: #102036;
}
.lumi-testi-light-shell .lumi-testi-tag {
  border-color: rgba(16,32,54,0.08);
}
.lumi-testi-magazine-shell {
  grid-template-columns: repeat(2, minmax(0, 1fr));
  min-height: 460px;
}
.lumi-testi-image-left {
  grid-template-columns: minmax(220px, 270px) minmax(0, 1fr);
}
.lumi-testi-image-left .lumi-testi-image-side {
  order: -1;
}
.lumi-testi-image-bottom {
  grid-template-columns: 1fr;
}
.lumi-testi-image-bottom .lumi-testi-image-side {
  min-height: 240px;
}
.lumi-testi-content-side {
  position: relative;
  display: flex;
  flex-direction: column;
  justify-content: center;
  gap: 14px;
  padding: 42px 44px;
}
.lumi-testi-image-side {
  position: relative;
  min-height: 100%;
  background: linear-gradient(180deg, color-mix(in srgb, var(--lumi-testi-accent) 78%, #0b1326), #0a1224);
}
.lumi-testi-image-side::before {
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(180deg, rgba(255,255,255,0.02), rgba(0,0,0,0.18));
  z-index: 1;
}
.lumi-testi-image-frame,
.lumi-testi-image-frame img {
  width: 100%;
  height: 100%;
}
.lumi-testi-image-frame img {
  display: block;
  object-fit: cover;
  object-position: top center;
  transition: transform .55s ease;
}
.lumi-testimonial-item:hover .lumi-testi-image-frame img {
  transform: scale(1.04);
}
.lumi-testi-featured-shell,
.lumi-testi-minimal-shell,
.lumi-testi-bubble-shell {
  padding: 40px;
}
.lumi-testi-featured-shell {
  text-align: center;
  background: radial-gradient(circle at top, rgba(79,195,247,0.12), transparent 36%), linear-gradient(145deg, rgba(11,19,37,0.96), rgba(10,17,34,0.78));
}
.lumi-testi-featured-inner {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 16px;
  margin: auto;
  max-width: 760px;
}
.lumi-testi-minimal-shell {
  border-top: 3px solid color-mix(in srgb, var(--lumi-testi-accent) 82%, transparent);
  background: linear-gradient(180deg, rgba(10,18,35,0.86), rgba(10,18,35,0.58));
}
.lumi-testi-bubble-shell {
  background: transparent;
  border: 0;
  box-shadow: none;
  padding: 8px 0 0;
}
.lumi-testi-bubble-head {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 0 8px;
}
.lumi-testi-bubble {
  position: relative;
  display: flex;
  flex-direction: column;
  gap: 12px;
  padding: 28px;
  border-radius: 0 24px 24px 24px;
  background: linear-gradient(145deg, rgba(18,31,58,0.96), rgba(11,22,42,0.84));
  border: 1px solid rgba(255,255,255,0.08);
  box-shadow: 0 22px 50px rgba(3,11,24,0.18);
}
.lumi-testi-bubble::before {
  content: "";
  position: absolute;
  top: 0;
  left: -12px;
  border-style: solid;
  border-width: 10px 12px 0 0;
  border-color: color-mix(in srgb, var(--lumi-testi-accent) 55%, #162c54) transparent transparent transparent;
}
.lumi-testi-tag {
  display: inline-flex;
  align-items: center;
  width: fit-content;
  min-height: 34px;
  padding: 7px 14px;
  border-radius: 999px;
  background: rgba(79,195,247,0.12);
  border: 1px solid rgba(255,255,255,0.12);
  color: #e9f1ff;
  font-size: .72rem;
  font-weight: 800;
  letter-spacing: .12em;
  text-transform: uppercase;
}
.lumi-testi-stars {
  margin: 0;
  display: flex;
  gap: 4px;
}
.lumi-testi-stars i {
  font-size: 14px;
  color: #ffc95a;
}
.lumi-testi-quote-mark {
  font-family: Georgia, serif;
  font-size: 86px;
  line-height: .48;
  color: var(--lumi-testi-accent);
  opacity: .9;
}
.lumi-testi-quote-mark-large {
  font-size: 124px;
}
.lumi-testi-quote {
  margin: 0;
  font-size: 1rem;
  line-height: 1.8;
  color: rgba(255,255,255,0.88);
}
.lumi-testi-quote-featured {
  max-width: 34ch;
  font-size: clamp(1.18rem, 2.4vw, 1.58rem);
  line-height: 1.55;
}
.lumi-testi-author-row {
  display: flex;
  align-items: center;
  gap: 14px;
  flex-wrap: wrap;
}
.lumi-testi-author-row-centered {
  justify-content: center;
}
.lumi-testi-avatar {
  width: 58px;
  height: 58px;
  border-radius: 50%;
  object-fit: cover;
  border: 2px solid color-mix(in srgb, var(--lumi-testi-accent) 42%, rgba(255,255,255,0.16));
  flex-shrink: 0;
}
.lumi-testi-avatar-sm {
  width: 44px;
  height: 44px;
}
.lumi-testi-info {
  display: flex;
  flex-direction: column;
  gap: 4px;
  min-width: 0;
}
.lumi-testi-name {
  font-size: .98rem;
  font-weight: 700;
  color: #fff;
}
.lumi-testi-position {
  font-size: .84rem;
  color: rgba(233,241,255,0.62);
}
.lumi-testi-company-logo {
  margin-left: auto;
  height: 28px;
  max-width: 120px;
  width: auto;
  object-fit: contain;
  opacity: .72;
}
.lumi-testi-video-link {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  width: fit-content;
  color: #fff;
  text-decoration: none;
  font-size: .78rem;
  font-weight: 800;
  letter-spacing: .12em;
  text-transform: uppercase;
}
.lumi-testi-video-link:hover {
  gap: 12px;
}

@media (max-width: 1024px) {
  .lumi-testi-split-shell,
  .lumi-testi-magazine-shell,
  .lumi-testi-image-left {
    grid-template-columns: 1fr;
  }
  .lumi-testi-image-left .lumi-testi-image-side {
    order: 0;
  }
  .lumi-testi-image-side {
    min-height: 280px;
  }
}

@media (max-width: 767px) {
  .lumi-testimonial-slider-shell {
    display: block;
  }
  .lumi-testi-nav {
    display: none;
  }
  .lumi-testimonial-heading {
    max-width: none;
    font-size: clamp(1.8rem, 7vw, 2.5rem);
  }
  .lumi-testi-content-side,
  .lumi-testi-featured-shell,
  .lumi-testi-minimal-shell,
  .lumi-testi-bubble-shell {
    padding: 26px 22px;
  }
  .lumi-testi-bubble {
    padding: 22px 20px;
  }
  .lumi-testi-quote-mark {
    font-size: 64px;
  }
  .lumi-testi-quote-mark-large {
    font-size: 88px;
  }
  .lumi-testi-quote {
    font-size: .96rem;
  }
  .lumi-testi-company-logo {
    margin-left: 0;
  }
}

/* ── 12. PRICING ─────────────────────────────────────────── */
.lumi-pricing {
  position: relative;
  text-align: center;
  transition: transform 0.3s ease;
}
.lumi-pricing-featured {
  transform: scale(1.03);
}
.lumi-pricing-badge {
  position: absolute;
  top: -14px;
  left: 50%;
  transform: translateX(-50%);
  background: linear-gradient(135deg, #1a73e8, #4fc3f7);
  color: #fff;
  font-size: 12px;
  font-weight: 700;
  padding: 5px 18px;
  border-radius: 50px;
  white-space: nowrap;
}
.lumi-pricing-header { margin-bottom: 24px; }
.lumi-plan-name {
  margin: 0 0 8px;
  font-size: 1.3rem;
  font-weight: 700;
}
.lumi-plan-desc { margin: 0; font-size: 0.88rem; opacity: 0.65; }
.lumi-pricing-price {
  margin-bottom: 24px;
}
.lumi-price-original {
  text-decoration: line-through;
  opacity: 0.45;
  font-size: 1rem;
  display: block;
  margin-bottom: 4px;
}
.lumi-price-amount-wrap {
  display: flex;
  align-items: flex-start;
  justify-content: center;
  gap: 4px;
}
.lumi-price-currency { font-size: 1.4rem; font-weight: 700; margin-top: 8px; }
.lumi-price-amount   { font-size: 3.5rem; font-weight: 800; line-height: 1; }
.lumi-price-period   { font-size: 0.9rem; opacity: 0.6; align-self: flex-end; margin-bottom: 8px; }
.lumi-pricing-divider {
  height: 1px;
  background: rgba(255,255,255,0.1);
  margin: 0 0 24px;
}
.lumi-features-list {
  list-style: none;
  padding: 0;
  margin: 0 0 32px;
  text-align: left;
}
.lumi-feature-item {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 10px 0;
  border-bottom: 1px solid rgba(255,255,255,0.06);
  font-size: 0.9rem;
}
.lumi-feature-item:last-child { border-bottom: none; }
.lumi-feature-item.excluded { opacity: 0.4; }
.lumi-feature-item i { flex-shrink: 0; font-size: 13px; }
.lumi-pricing-footer { display: flex; flex-direction: column; align-items: center; gap: 12px; }
.lumi-pricing-btn {
  display: block;
  width: 100%;
  text-align: center;
  text-decoration: none;
  font-weight: 700;
  transition: all 0.3s ease;
}
.lumi-pricing-btn:hover { transform: translateY(-2px); }
.lumi-pricing-note { margin: 0; font-size: 0.82rem; opacity: 0.5; }

/* ── 13. TEAM ────────────────────────────────────────────── */
.lumi-team-card {
  overflow: hidden;
  text-decoration: none;
  display: block;
  transition: transform 0.3s ease;
}
.lumi-team-card:hover { transform: translateY(-6px); }
.lumi-team-classic .lumi-team-photo { border-radius: 12px 12px 0 0; overflow: hidden; }
.lumi-team-circle  .lumi-team-photo { display: flex; justify-content: center; padding-top: 30px; }
.lumi-team-circle  .lumi-team-photo img {
  width: 120px;
  height: 120px;
  border-radius: 50%;
  object-fit: cover;
  border: 3px solid rgba(79,195,247,0.4);
}
.lumi-team-overlay .lumi-team-photo { position: relative; overflow: hidden; }
.lumi-team-overlay .lumi-team-photo img { width: 100%; display: block; }
.lumi-team-overlay .lumi-team-overlay {
  position: absolute;
  inset: 0;
  background: rgba(0,0,0,0.7);
  display: flex;
  align-items: center;
  justify-content: center;
  opacity: 0;
  transition: opacity 0.35s ease;
}
.lumi-team-card:hover .lumi-team-overlay { opacity: 1; }
.lumi-team-info { padding: 20px; }
.lumi-team-name { margin: 0 0 4px; font-size: 1rem; font-weight: 700; }
.lumi-team-role { display: block; font-size: 0.82rem; font-weight: 600; margin-bottom: 10px; }
.lumi-team-bio  { font-size: 0.88rem; line-height: 1.6; margin: 0 0 14px; }
.lumi-team-social { display: flex; gap: 12px; justify-content: center; }
.lumi-team-social a {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 32px;
  height: 32px;
  border-radius: 50%;
  background: rgba(255,255,255,0.08);
  text-decoration: none;
  transition: all 0.3s ease;
}
.lumi-team-social a:hover { background: rgba(79,195,247,0.2); }

/* ── 14. COUNTER ─────────────────────────────────────────── */
.lumi-counter {
  position: relative;
  display: flex;
  flex-direction: column;
  gap: 12px;
  overflow: hidden;
  isolation: isolate;
  background: linear-gradient(180deg, rgba(7,17,35,0.9), rgba(8,13,26,0.78));
  border: 1px solid rgba(255,255,255,0.1);
  box-shadow: 0 18px 44px rgba(4, 12, 26, 0.22);
}
.lumi-counter::before {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  height: 4px;
  background: linear-gradient(90deg, #1a73e8 0%, #4fc3f7 55%, #e1b866 100%);
  z-index: 0;
}
.lumi-counter::after {
  content: "";
  position: absolute;
  width: 180px;
  height: 180px;
  top: -68px;
  right: -68px;
  background: radial-gradient(circle, rgba(79,195,247,0.16), transparent 72%);
  pointer-events: none;
  z-index: 0;
}
.lumi-counter > * {
  position: relative;
  z-index: 1;
}
.lumi-counter-icon {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 72px;
  height: 72px;
  border-radius: 20px;
  background: linear-gradient(135deg, rgba(18,38,76,0.88), rgba(9,19,38,0.56));
  border: 1px solid rgba(255,255,255,0.14);
  box-shadow: inset 0 1px 0 rgba(255,255,255,0.14), 0 16px 34px rgba(4,12,26,0.22);
}
.lumi-counter-icon svg {
  width: 1em;
  height: 1em;
}
.lumi-counter-number-wrap {
  display: inline-flex;
  align-items: flex-end;
  gap: 6px;
  width: fit-content;
  max-width: 100%;
}
.lumi-counter-number {
  font-size: clamp(2.6rem, 5vw, 4rem);
  font-weight: 800;
  line-height: 0.92;
  letter-spacing: -0.04em;
  text-shadow: 0 10px 30px rgba(0,0,0,0.18);
}
.lumi-counter-prefix,
.lumi-counter-suffix {
  font-size: clamp(1.1rem, 2.2vw, 1.75rem);
  font-weight: 700;
  line-height: 1;
  margin-bottom: 0.24em;
}
.lumi-counter-title {
  margin: 4px 0 0;
  font-size: 1.05rem;
  font-weight: 700;
  letter-spacing: -0.01em;
}
.lumi-counter-desc  {
  margin: 0;
  max-width: 28ch;
  font-size: 0.92rem;
  line-height: 1.65;
  opacity: 0.68;
}

/* ── 15. PROGRESS ────────────────────────────────────────── */
.lumi-progress-bars {
  width: 100%;
}
.lumi-progress-item {
  position: relative;
  overflow: hidden;
  padding: 20px 22px 22px;
  border-radius: 24px;
  background: linear-gradient(150deg, rgba(9,18,34,0.94), rgba(8,17,31,0.82));
  border: 1px solid rgba(255,255,255,0.08);
  box-shadow:
    0 20px 46px rgba(3, 11, 24, 0.18),
    inset 0 1px 0 rgba(255,255,255,0.05);
}
.lumi-progress-item::before {
  content: "";
  position: absolute;
  inset: auto -8% -36% auto;
  width: 42%;
  aspect-ratio: 1;
  border-radius: 50%;
  background: radial-gradient(circle, rgba(79,195,247,0.16), transparent 72%);
  filter: blur(12px);
  pointer-events: none;
}
.lumi-progress-header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 14px;
  margin-bottom: 16px;
}
.lumi-progress-label {
  font-size: 0.98rem;
  font-weight: 700;
  letter-spacing: 0.01em;
}
.lumi-progress-pct {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 62px;
  padding: 7px 12px;
  border-radius: 999px;
  font-size: 0.82rem;
  font-weight: 800;
  background: rgba(255,255,255,0.08);
  border: 1px solid rgba(255,255,255,0.12);
  box-shadow: inset 0 1px 0 rgba(255,255,255,0.08);
}
.lumi-progress-track {
  position: relative;
  overflow: hidden;
  border-radius: 999px;
  height: 10px;
  background: linear-gradient(90deg, rgba(255,255,255,0.08), rgba(255,255,255,0.03));
  border: 1px solid rgba(255,255,255,0.06);
  box-shadow: inset 0 1px 4px rgba(0,0,0,0.22);
}
.lumi-progress-track::after {
  content: "";
  position: absolute;
  inset: 0;
  background: repeating-linear-gradient(
    90deg,
    rgba(255,255,255,0.06) 0,
    rgba(255,255,255,0.06) 1px,
    transparent 1px,
    transparent 18%
  );
  opacity: 0.45;
  pointer-events: none;
}
.lumi-progress-fill {
  position: relative;
  height: 100%;
  border-radius: 999px;
  background: linear-gradient(90deg, #1a73e8, #4fc3f7);
  width: 0;
  transition: width 1.2s cubic-bezier(0.4, 0, 0.2, 1);
  box-shadow: 0 0 20px rgba(79,195,247,0.35);
}
.lumi-progress-fill::before {
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(180deg, rgba(255,255,255,0.3), rgba(255,255,255,0));
  opacity: 0.7;
}
.lumi-progress-fill-cap {
  position: absolute;
  top: 50%;
  right: 6px;
  width: 16px;
  height: 16px;
  border-radius: 50%;
  background: radial-gradient(circle at 35% 35%, #ffffff, #9fdfff 48%, rgba(255,255,255,0.18) 100%);
  transform: translateY(-50%);
  box-shadow:
    0 0 0 4px rgba(255,255,255,0.14),
    0 0 18px rgba(79,195,247,0.48);
}
.lumi-progress-flat  .lumi-progress-track,
.lumi-progress-flat  .lumi-progress-fill { border-radius: 0; }
.lumi-progress-striped .lumi-progress-fill {
  background-image:
    linear-gradient(90deg, #1a73e8, #4fc3f7),
    repeating-linear-gradient(
    45deg,
    transparent,
    transparent 8px,
    rgba(255,255,255,0.12) 8px,
    rgba(255,255,255,0.12) 16px
  );
}

/* ── 16. LOGO CAROUSEL ───────────────────────────────────── */
.lumi-logo-carousel {
  position: relative;
  overflow: hidden;
  padding: 6px 0;
}
.lumi-logo-carousel .swiper {
  -webkit-mask-image: linear-gradient(90deg, transparent 0%, #000 10%, #000 90%, transparent 100%);
  mask-image: linear-gradient(90deg, transparent 0%, #000 10%, #000 90%, transparent 100%);
}
.lumi-logo-carousel .swiper-slide {
  height: auto;
}
.lumi-logo-item {
  position: relative;
  display: flex;
  align-items: center;
  justify-content: center;
  cursor: default;
  min-height: 122px;
  padding: 24px 28px;
  border-radius: 24px;
  background: linear-gradient(145deg, rgba(9,18,34,0.92), rgba(8,16,30,0.74));
  border: 1px solid rgba(255,255,255,0.08);
  box-shadow:
    0 18px 40px rgba(3, 11, 24, 0.16),
    inset 0 1px 0 rgba(255,255,255,0.06);
  transition: transform 0.3s ease, box-shadow 0.3s ease, border-color 0.3s ease, background 0.3s ease, filter 0.3s ease;
}
.lumi-logo-item::before {
  content: "";
  position: absolute;
  inset: 1px;
  border-radius: inherit;
  background: linear-gradient(180deg, rgba(255,255,255,0.08), rgba(255,255,255,0));
  opacity: 0.8;
  pointer-events: none;
}
.lumi-logo-item a {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 100%;
  height: 100%;
}
.lumi-logo-item img {
  display: block;
  max-height: 60px;
  width: auto;
  object-fit: contain;
  opacity: 0.78;
  filter: grayscale(100%) brightness(1.1);
  transition: transform 0.35s ease, filter 0.35s ease, opacity 0.35s ease;
}
.lumi-logo-item:hover {
  transform: translateY(-4px);
  border-color: rgba(255,255,255,0.16);
  box-shadow:
    0 24px 44px rgba(3, 11, 24, 0.22),
    inset 0 1px 0 rgba(255,255,255,0.08);
}
.lumi-logo-item:hover img {
  opacity: 1;
  filter: grayscale(0%) brightness(1);
  transform: scale(1.04);
}

/* ── 17. TIMELINE ────────────────────────────────────────── */
.lumi-timeline {
  position: relative;
  padding-left: 60px;
}
.lumi-timeline.lumi-tl-center { padding: 0 40px; }
.lumi-tl-line {
  position: absolute;
  left: 20px;
  top: 0;
  bottom: 0;
  width: 2px;
  background: rgba(255,255,255,0.15);
}
.lumi-tl-center .lumi-tl-line { left: 50%; transform: translateX(-50%); }
.lumi-tl-right .lumi-tl-line  { left: auto; right: 20px; }

.lumi-tl-item {
  position: relative;
  margin-bottom: 40px;
  display: flex;
  align-items: flex-start;
  gap: 20px;
}
.lumi-tl-left  .lumi-tl-item { flex-direction: row; }
.lumi-tl-right .lumi-tl-item { flex-direction: row-reverse; }

.lumi-tl-dot {
  position: relative;
  z-index: 2;
  flex-shrink: 0;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  background: #1a73e8;
  font-size: 16px;
  margin-left: -40px;
}
.lumi-tl-date {
  display: block;
  font-size: 0.8rem;
  font-weight: 700;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  margin-bottom: 6px;
}
.lumi-tl-title { margin: 0 0 8px; font-size: 1rem; font-weight: 700; }
.lumi-tl-desc  { margin: 0; font-size: 0.88rem; line-height: 1.65; }

/* Horizontal Timeline */
.lumi-tl-horizontal {
  padding: 0;
  display: flex;
  overflow-x: auto;
  gap: 0;
}
.lumi-tl-horizontal .lumi-tl-line { display: none; }
.lumi-tl-horizontal .lumi-tl-item {
  flex-direction: column;
  flex: 1;
  min-width: 200px;
  padding-top: 24px;
  padding-right: 20px;
  border-top: 2px solid rgba(255,255,255,0.15);
}
.lumi-tl-horizontal .lumi-tl-dot {
  margin: -36px 0 16px;
  width: 24px !important;
  height: 24px !important;
  line-height: 24px !important;
  font-size: 10px !important;
}

/* ── 18. FEATURE GRID ────────────────────────────────────── */
.lumi-feature-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 28px;
}
.lumi-fg-item {
  display: flex;
  flex-direction: column;
  text-decoration: none;
  transition: all 0.35s ease;
}
.lumi-fg-icon-wrap {
  display: inline-flex;
  margin-bottom: 20px;
}
.lumi-fg-icon { display: flex; align-items: center; justify-content: center; }
.lumi-fg-title { margin: 0 0 10px; font-size: 1.05rem; font-weight: 700; }
.lumi-fg-desc  { margin: 0; font-size: 0.9rem; line-height: 1.65; }

/* ── 19. GLASS CARD ──────────────────────────────────────── */
.lumi-glass-card {
  display: block;
  text-decoration: none;
  transition: all 0.3s ease;
}
.lumi-glass-card:hover { transform: translateY(-6px); }
.lumi-gc-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: 20px;
}
.lumi-gc-icon-wrap { display: flex; align-items: center; }
.lumi-gc-icon { font-size: 36px; display: flex; }
.lumi-gc-tag {
  font-size: 11px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  padding: 4px 12px;
  border-radius: 50px;
  border: 1px solid currentColor;
}
.lumi-gc-title { margin: 0 0 12px; font-size: 1.1rem; font-weight: 700; }
.lumi-gc-desc  { margin: 0 0 20px; font-size: 0.9rem; line-height: 1.65; }
.lumi-gc-stats {
  display: flex;
  align-items: center;
  gap: 20px;
  padding-top: 20px;
  border-top: 1px solid rgba(255,255,255,0.1);
}
.lumi-gc-stat { display: flex; flex-direction: column; gap: 3px; }
.lumi-gc-stat strong { font-size: 1.3rem; font-weight: 800; color: #fff; }
.lumi-gc-stat span   { font-size: 0.8rem; opacity: 0.6; }
.lumi-gc-stat-divider { width: 1px; height: 40px; background: rgba(255,255,255,0.12); flex-shrink: 0; }

/* ── 20. HOVER CARD ──────────────────────────────────────── */
.lumi-hover-card {
  position: relative;
  perspective: 1200px;
}
.lumi-hc-inner {
  position: relative;
  width: 100%;
  height: 100%;
  transition: transform 0.65s cubic-bezier(0.4, 0.2, 0.2, 1);
  transform-style: preserve-3d;
}
.lumi-hover-card.lumi-hc-flip-right:hover .lumi-hc-inner { transform: rotateY(180deg); }
.lumi-hover-card.lumi-hc-flip-left:hover  .lumi-hc-inner { transform: rotateY(-180deg); }
.lumi-hover-card.lumi-hc-flip-up:hover    .lumi-hc-inner { transform: rotateX(-180deg); }
.lumi-hover-card.lumi-hc-flip-down:hover  .lumi-hc-inner { transform: rotateX(180deg); }

.lumi-hc-front,
.lumi-hc-back {
  position: absolute;
  inset: 0;
  backface-visibility: hidden;
  -webkit-backface-visibility: hidden;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  padding: 40px 32px;
  text-align: center;
}
.lumi-hc-back { transform: rotateY(180deg); }
.lumi-hc-flip-left  .lumi-hc-back { transform: rotateY(-180deg); }
.lumi-hc-flip-up    .lumi-hc-back { transform: rotateX(-180deg); }
.lumi-hc-flip-down  .lumi-hc-back { transform: rotateX(180deg); }

/* Push (slide-up) variant */
.lumi-hover-card.lumi-hc-push .lumi-hc-inner { transform-style: flat; }
.lumi-hover-card.lumi-hc-push .lumi-hc-front,
.lumi-hover-card.lumi-hc-push .lumi-hc-back { backface-visibility: visible; -webkit-backface-visibility: visible; transition: transform 0.5s ease, opacity 0.5s ease; }
.lumi-hover-card.lumi-hc-push .lumi-hc-back { transform: translateY(100%); opacity: 0; }
.lumi-hover-card.lumi-hc-push:hover .lumi-hc-front { transform: translateY(-100%); opacity: 0; }
.lumi-hover-card.lumi-hc-push:hover .lumi-hc-back  { transform: translateY(0); opacity: 1; }

.lumi-hc-front-icon-wrap { margin-bottom: 20px; }
.lumi-hc-front-icon { font-size: 40px; display: flex; }
.lumi-hc-front-title { margin: 0 0 8px; font-size: 1.1rem; font-weight: 700; }
.lumi-hc-front-subtitle { margin: 0; font-size: 0.88rem; }
.lumi-hc-back-title { margin: 0 0 12px; font-size: 1rem; font-weight: 700; }
.lumi-hc-back-desc  { margin: 0 0 20px; font-size: 0.88rem; line-height: 1.65; }
.lumi-hc-back-btn {
  display: inline-block;
  padding: 10px 24px;
  border-radius: 8px;
  font-size: 13px;
  font-weight: 700;
  text-decoration: none;
  border: 2px solid rgba(255,255,255,0.4);
  color: #fff;
  transition: all 0.3s ease;
}
.lumi-hc-back-btn:hover { background: rgba(255,255,255,0.1); }

/* ── 21. TABS ────────────────────────────────────────────── */
.lumi-tabs {
  width: 100%;
  position: relative;
}
.lumi-tabs-pos-top    { display: flex; flex-direction: column; gap: 18px; }
.lumi-tabs-pos-bottom { display: flex; flex-direction: column-reverse; gap: 18px; }
.lumi-tabs-pos-left   { display: flex; flex-direction: row; gap: 18px; }
.lumi-tabs-pos-right  { display: flex; flex-direction: row-reverse; gap: 18px; }

.lumi-tabs-nav {
  display: flex;
  flex-wrap: wrap;
  gap: 12px;
  margin: 0;
  padding: 10px;
  border-radius: 28px;
  background-color: rgba(9,18,34,0.88);
  border: 1px solid rgba(255,255,255,0.08);
  box-shadow:
    0 18px 38px rgba(3, 11, 24, 0.14),
    inset 0 1px 0 rgba(255,255,255,0.05);
}
.lumi-tabs-pos-left  .lumi-tabs-nav,
.lumi-tabs-pos-right .lumi-tabs-nav {
  flex-direction: column;
  min-width: 240px;
}
.lumi-tab-btn {
  position: relative;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 10px;
  padding: 14px 22px;
  border-radius: 18px;
  font-size: 14px;
  font-weight: 700;
  cursor: pointer;
  border: 1px solid transparent;
  background-color: rgba(255,255,255,0.05);
  color: rgba(241,245,255,0.74);
  transition: transform 0.25s ease, background 0.25s ease, color 0.25s ease, border-color 0.25s ease, box-shadow 0.25s ease;
  white-space: nowrap;
  overflow: hidden;
  isolation: isolate;
  box-shadow: inset 0 1px 0 rgba(255,255,255,0.05);
}
.lumi-tab-btn::before,
.lumi-tab-btn::after {
  content: "";
  position: absolute;
  transition: transform 0.25s ease, opacity 0.25s ease;
}
.lumi-tab-btn::before {
  inset: 1px;
  border-radius: inherit;
  background: linear-gradient(180deg, rgba(255,255,255,0.08), rgba(255,255,255,0));
  opacity: 0.7;
}
.lumi-tab-btn::after {
  left: 18px;
  right: 18px;
  bottom: 10px;
  height: 3px;
  border-radius: 999px;
  background: linear-gradient(90deg, #4fc3f7, #e1b866);
  transform: scaleX(0.2);
  opacity: 0;
}
.lumi-tab-btn.active,
.lumi-tab-btn:hover {
  background-color: rgba(13,31,61,0.96);
  color: #fff;
  border-color: rgba(255,255,255,0.12);
  transform: translateY(-1px);
  box-shadow: 0 16px 30px rgba(5, 16, 34, 0.22);
}
.lumi-tab-btn.active::after,
.lumi-tab-btn:hover::after {
  transform: scaleX(1);
  opacity: 1;
}
.lumi-tab-icon {
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 14px;
}

.lumi-tabs-content { flex: 1; min-width: 0; }
.lumi-tab-panel {
  display: none;
  position: relative;
  overflow: hidden;
  animation: lumiTabFade 0.35s ease;
  line-height: 1.75;
  padding: 34px 36px;
  border-radius: 28px;
  background-color: rgba(9,18,34,0.94);
  border: 1px solid rgba(255,255,255,0.08);
  box-shadow:
    0 22px 48px rgba(3, 11, 24, 0.16),
    inset 0 1px 0 rgba(255,255,255,0.05);
  color: rgba(240,244,255,0.82);
}
.lumi-tab-panel::before {
  content: "";
  position: absolute;
  inset: auto -8% -40% auto;
  width: 44%;
  aspect-ratio: 1;
  border-radius: 50%;
  background: radial-gradient(circle, rgba(79,195,247,0.15), transparent 72%);
  filter: blur(16px);
  pointer-events: none;
}
.lumi-tab-panel.active { display: block; }
.lumi-tab-panel > *:last-child {
  margin-bottom: 0;
}
@keyframes lumiTabFade {
  from { opacity: 0; transform: translateY(8px); }
  to   { opacity: 1; transform: translateY(0); }
}

/* ── 22. ACCORDION ───────────────────────────────────────── */
.lumi-accordion {
  display: grid;
  gap: 14px;
}
.lumi-acc-item {
  position: relative;
  overflow: hidden;
  border-radius: 24px;
  background: linear-gradient(150deg, rgba(9,18,34,0.94), rgba(8,17,31,0.82));
  border: 1px solid rgba(255,255,255,0.08);
  box-shadow:
    0 20px 44px rgba(3, 11, 24, 0.15),
    inset 0 1px 0 rgba(255,255,255,0.05);
  transition: border-color 0.25s ease, box-shadow 0.25s ease, transform 0.25s ease;
}
.lumi-acc-item::before {
  content: "";
  position: absolute;
  inset: auto -6% -36% auto;
  width: 38%;
  aspect-ratio: 1;
  border-radius: 50%;
  background: radial-gradient(circle, rgba(225,184,102,0.12), transparent 72%);
  filter: blur(16px);
  pointer-events: none;
}
.lumi-acc-item.active {
  border-color: rgba(79,195,247,0.26);
  box-shadow:
    0 24px 48px rgba(3, 11, 24, 0.2),
    0 0 0 1px rgba(79,195,247,0.1),
    inset 0 1px 0 rgba(255,255,255,0.07);
}
.lumi-acc-header {
  width: 100%;
  display: flex;
  align-items: center;
  justify-content: space-between;
  cursor: pointer;
  border: none;
  background: transparent;
  text-align: left;
  transition: all 0.25s ease;
  padding: 22px 26px;
  position: relative;
  z-index: 1;
}
.lumi-acc-title-wrap {
  display: flex;
  align-items: center;
  gap: 16px;
  flex: 1;
  min-width: 0;
}
.lumi-acc-item-icon {
  flex-shrink: 0;
  width: 44px;
  height: 44px;
  border-radius: 14px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  background: rgba(255,255,255,0.08);
  border: 1px solid rgba(255,255,255,0.12);
  box-shadow: inset 0 1px 0 rgba(255,255,255,0.06);
}
.lumi-acc-title {
  font-size: 1rem;
  font-weight: 700;
  letter-spacing: -0.01em;
}
.lumi-acc-toggle {
  flex-shrink: 0;
  margin-left: 16px;
  width: 48px;
  height: 48px;
  border-radius: 16px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  background: rgba(255,255,255,0.06);
  border: 1px solid rgba(255,255,255,0.1);
  box-shadow: inset 0 1px 0 rgba(255,255,255,0.06);
  transition: transform 0.25s ease, background 0.25s ease, border-color 0.25s ease, box-shadow 0.25s ease;
}
.lumi-acc-toggle > span {
  display: inline-flex;
  align-items: center;
  justify-content: center;
}
.lumi-acc-icon-open  { display: none; }
.lumi-acc-item.active .lumi-acc-icon-closed { display: none; }
.lumi-acc-item.active .lumi-acc-icon-open   { display: inline-flex; }
.lumi-acc-item.active .lumi-acc-toggle {
  background: linear-gradient(135deg, #4fc3f7, #e1b866);
  border-color: rgba(255,255,255,0.22);
  color: #06111f;
  transform: translateY(-2px);
  box-shadow: 0 14px 26px rgba(79,195,247,0.22);
}
.lumi-acc-collapse { overflow: hidden; }
.lumi-acc-body {
  position: relative;
  z-index: 1;
  padding: 0 26px 26px;
  line-height: 1.75;
  font-size: 0.95rem;
  color: rgba(240,244,255,0.8);
}
.lumi-acc-body > *:last-child {
  margin-bottom: 0;
}

/* ── 23. MODAL ───────────────────────────────────────────── */
.lumi-modal-trigger { cursor: pointer; }
.lumi-modal {
  position: fixed;
  inset: 0;
  z-index: 99999;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 20px;
  opacity: 0;
  pointer-events: none;
  transition: opacity 0.3s ease;
}
.lumi-modal.lumi-open {
  opacity: 1;
  pointer-events: all;
}
.lumi-modal-overlay {
  position: absolute;
  inset: 0;
  background: rgba(0,0,0,0.65);
  cursor: pointer;
}
.lumi-modal-blur .lumi-modal-overlay {
  backdrop-filter: blur(8px);
  -webkit-backdrop-filter: blur(8px);
}
.lumi-modal-box {
  position: relative;
  z-index: 1;
  max-width: 680px;
  width: 100%;
  max-height: 90vh;
  overflow-y: auto;
  background: #0d1829;
  border-radius: 20px;
  transition: transform 0.35s cubic-bezier(0.34, 1.56, 0.64, 1), opacity 0.3s ease;
}
/* Animations */
.lumi-modal-anim-fade    .lumi-modal-box { transform: none; }
.lumi-modal-anim-slide-up.lumi-modal:not(.lumi-open)   .lumi-modal-box { transform: translateY(60px); opacity: 0; }
.lumi-modal-anim-slide-down.lumi-modal:not(.lumi-open) .lumi-modal-box { transform: translateY(-60px); opacity: 0; }
.lumi-modal-anim-zoom.lumi-modal:not(.lumi-open)       .lumi-modal-box { transform: scale(0.8); opacity: 0; }

.lumi-modal-close {
  position: absolute;
  top: 20px;
  right: 20px;
  background: rgba(255,255,255,0.08);
  border: none;
  border-radius: 50%;
  width: 36px;
  height: 36px;
  display: flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  color: rgba(255,255,255,0.7);
  transition: all 0.2s ease;
  z-index: 2;
}
.lumi-modal-close:hover { background: rgba(255,255,255,0.18); color: #fff; }
.lumi-modal-title {
  margin: 0 50px 16px 0;
  font-size: 1.4rem;
  font-weight: 800;
}
.lumi-modal-content { line-height: 1.7; }
.lumi-modal-content iframe,
.lumi-modal-content video,
.lumi-modal-content embed,
.lumi-modal-content object {
  display: block;
  width: 100%;
  max-width: 100%;
  min-height: 240px;
  aspect-ratio: 16 / 9;
  border: 0;
  background: #000;
  border-radius: 16px;
}

/* ── 24. SECTION WRAPPER ─────────────────────────────────── */
.lumi-section-wrapper {
  position: relative;
  display: flex;
  flex-direction: column;
  justify-content: center;
  overflow: hidden;
}
.lumi-sw-overlay {
  position: absolute;
  inset: 0;
  z-index: 0;
}
.lumi-sw-inner {
  position: relative;
  z-index: 1;
  margin-left: auto;
  margin-right: auto;
  width: 100%;
}
.lumi-sw-boxed   .lumi-sw-inner { max-width: 1200px; }
.lumi-sw-wide    .lumi-sw-inner { max-width: 1600px; }
.lumi-sw-narrow  .lumi-sw-inner { max-width: 800px; }
.lumi-sw-full    .lumi-sw-inner { max-width: 100%; }

/* â”€â”€ 25. PREMIUM CINEMATIC SLIDER â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */
.lumi-premium-slider {
  position: relative;
  isolation: isolate;
  overflow: hidden;
  min-height: 100vh;
  border-radius: clamp(22px, 2.4vw, 34px);
  background: #050b16;
  box-shadow: 0 30px 80px rgba(4, 12, 26, 0.3);
}
.lumi-premium-slider::before,
.lumi-premium-slider::after {
  content: "";
  position: absolute;
  inset: auto;
  border-radius: 50%;
  pointer-events: none;
  z-index: 0;
}
.lumi-premium-slider::before {
  top: -14%;
  right: -8%;
  width: 34%;
  aspect-ratio: 1;
  background: radial-gradient(circle, rgba(79,195,247,0.18), transparent 72%);
  filter: blur(20px);
}
.lumi-premium-slider::after {
  bottom: -22%;
  left: -10%;
  width: 36%;
  aspect-ratio: 1;
  background: radial-gradient(circle, rgba(225,184,102,0.18), transparent 72%);
  filter: blur(18px);
}
.lumi-premium-slider .swiper,
.lumi-premium-slider .swiper-wrapper,
.lumi-premium-slider .swiper-slide {
  height: 100%;
  min-height: inherit;
}
.lumi-premium-slide {
  position: relative;
  min-height: inherit;
  overflow: hidden;
}
.lumi-premium-slide-media {
  position: absolute;
  inset: 0;
  background-size: cover;
  background-position: center;
  transform: scale(1.14);
  transition: transform 1.3s cubic-bezier(0.22, 1, 0.36, 1), filter 0.6s ease;
  filter: saturate(1.04) contrast(1.02);
}
.swiper-slide-active .lumi-premium-slide-media {
  transform: scale(1);
}
.lumi-premium-slide-overlay {
  position: absolute;
  inset: 0;
  background:
    linear-gradient(112deg, rgba(4,10,20,0.92) 0%, rgba(6,14,28,0.7) 42%, rgba(8,16,30,0.36) 100%),
    linear-gradient(180deg, rgba(3,9,17,0.18), rgba(3,9,17,0.68));
  z-index: 1;
}
.lumi-premium-slide-noise {
  position: absolute;
  inset: 0;
  background:
    radial-gradient(circle at 16% 20%, rgba(79,195,247,0.22), transparent 24%),
    radial-gradient(circle at 84% 18%, rgba(225,184,102,0.18), transparent 26%),
    linear-gradient(125deg, rgba(255,255,255,0.08), transparent 18%);
  mix-blend-mode: screen;
  opacity: 0.7;
  z-index: 1;
  pointer-events: none;
}
.lumi-premium-slide-shell {
  position: relative;
  z-index: 2;
  display: flex;
  width: 100%;
  min-height: inherit;
  padding: clamp(28px, 5vw, 68px) clamp(18px, 4vw, 54px) clamp(132px, 16vw, 170px);
}
.lumi-premium-slider-no-status .lumi-premium-slide-shell {
  padding-bottom: clamp(104px, 13vw, 132px);
}
.lumi-premium-slider-no-nav .lumi-premium-slide-shell {
  padding-bottom: clamp(88px, 11vw, 112px);
}
.lumi-premium-slider-no-status.lumi-premium-slider-no-nav .lumi-premium-slide-shell {
  padding-bottom: clamp(52px, 7vw, 76px);
}
.lumi-premium-slider-boxed .lumi-premium-slide-shell {
  max-width: min(1380px, calc(100% - 28px));
  margin: 0 auto;
}
.lumi-premium-slider-full .lumi-premium-slide-shell {
  max-width: calc(100% - 28px);
  margin: 0 auto;
}
.lumi-premium-v-top { align-items: flex-start; }
.lumi-premium-v-middle { align-items: center; }
.lumi-premium-v-bottom { align-items: flex-end; }
.lumi-premium-slide-content {
  position: relative;
  display: flex;
  flex-direction: column;
  gap: 18px;
  width: 100%;
  max-width: 760px;
}
.lumi-premium-slide-content::before {
  content: "";
  position: absolute;
  inset: auto auto -18% -10%;
  width: 72%;
  height: 52%;
  border-radius: 32px;
  background: linear-gradient(135deg, rgba(10,34,68,0.34), rgba(10,34,68,0));
  filter: blur(14px);
  pointer-events: none;
  z-index: 0;
}
.lumi-premium-slide-content > * {
  position: relative;
  z-index: 1;
  opacity: 0;
  transform: var(--lumi-premium-content-transform, translate3d(0, 24px, 0));
  filter: var(--lumi-premium-content-filter, none);
  transition:
    opacity 0.55s ease,
    transform 0.72s cubic-bezier(0.22, 1, 0.36, 1),
    filter 0.6s ease;
  will-change: opacity, transform;
}
.swiper-slide-active .lumi-premium-slide-content > * {
  opacity: 1;
  transform: none;
  filter: none;
}
.lumi-premium-slider .swiper:not(.swiper-initialized) .swiper-slide:first-child .lumi-premium-slide-content > *,
.lumi-premium-slider .swiper:not(.swiper-initialized) .swiper-slide:first-child .lumi-premium-slide-media {
  opacity: 1;
  transform: none;
  filter: none;
}
.lumi-premium-slider .swiper:not(.swiper-initialized) .swiper-slide:first-child .lumi-premium-slide-media {
  transform: scale(1);
}
.swiper-slide-active .lumi-premium-slide-content > *:nth-child(1) { transition-delay: 0.08s; }
.swiper-slide-active .lumi-premium-slide-content > *:nth-child(2) { transition-delay: 0.14s; }
.swiper-slide-active .lumi-premium-slide-content > *:nth-child(3) { transition-delay: 0.2s; }
.swiper-slide-active .lumi-premium-slide-content > *:nth-child(4) { transition-delay: 0.26s; }
.swiper-slide-active .lumi-premium-slide-content > *:nth-child(5) { transition-delay: 0.32s; }
.lumi-premium-anim-rise .lumi-premium-slide-content > * {
  --lumi-premium-content-transform: translate3d(0, 24px, 0);
}
.lumi-premium-anim-zoom .lumi-premium-slide-content > * {
  --lumi-premium-content-transform: translate3d(0, 14px, 0) scale(0.94);
  --lumi-premium-content-filter: blur(1.8px);
}
.lumi-premium-anim-sweep-left .lumi-premium-slide-content > * {
  --lumi-premium-content-transform: translate3d(-40px, 0, 0);
}
.lumi-premium-anim-sweep-right .lumi-premium-slide-content > * {
  --lumi-premium-content-transform: translate3d(40px, 0, 0);
}
.lumi-premium-anim-none .lumi-premium-slide-content > * {
  opacity: 1;
  transform: none;
  filter: none;
  transition: none;
}
.lumi-premium-align-left {
  margin-right: auto;
  text-align: left;
  align-items: flex-start;
}
.lumi-premium-align-center {
  margin: 0 auto;
  text-align: center;
  align-items: center;
}
.lumi-premium-align-right {
  margin-left: auto;
  text-align: right;
  align-items: flex-end;
}
.lumi-premium-slide-label {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  width: fit-content;
  padding: 8px 18px;
  border-radius: 999px;
  background-color: rgba(10,22,44,0.72);
  border: 1px solid rgba(255,255,255,0.18);
  box-shadow: inset 0 1px 0 rgba(255,255,255,0.08);
  color: #fff;
  font-size: 0.78rem;
  font-weight: 800;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
}
.lumi-premium-slide-label::before {
  content: "";
  width: 8px;
  height: 8px;
  border-radius: 50%;
  background: linear-gradient(135deg, #4fc3f7, #e1b866);
  box-shadow: 0 0 18px rgba(79,195,247,0.4);
}
.lumi-premium-slide-title {
  margin: 0;
  font-size: clamp(2.6rem, 5.8vw, 5.5rem);
  line-height: 0.97;
  letter-spacing: -0.05em;
  font-weight: 800;
  color: #fff;
  text-wrap: balance;
  text-shadow: 0 18px 44px rgba(0,0,0,0.3);
}
.lumi-premium-slide-desc {
  margin: 0;
  max-width: 56ch;
  font-size: clamp(1rem, 1.4vw, 1.15rem);
  line-height: 1.8;
  color: rgba(242,246,255,0.84);
}
.lumi-premium-slide-highlights {
  display: flex;
  flex-wrap: wrap;
  gap: 12px;
}
.lumi-premium-align-center .lumi-premium-slide-highlights {
  justify-content: center;
}
.lumi-premium-align-right .lumi-premium-slide-highlights {
  justify-content: flex-end;
}
.lumi-premium-highlight {
  position: relative;
  display: inline-flex;
  align-items: center;
  gap: 10px;
  padding: 10px 16px;
  border-radius: 999px;
  background: rgba(255,255,255,0.08);
  border: 1px solid rgba(255,255,255,0.12);
  color: #fff;
  font-size: 0.84rem;
  font-weight: 700;
  line-height: 1;
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
}
.lumi-premium-highlight::before {
  content: "";
  width: 8px;
  height: 8px;
  border-radius: 50%;
  background: linear-gradient(135deg, #4fc3f7, #e1b866);
}
.lumi-premium-slide-buttons {
  display: flex;
  flex-wrap: wrap;
  gap: 14px;
  align-items: center;
  padding-top: 6px;
}
.lumi-premium-align-center .lumi-premium-slide-buttons {
  justify-content: center;
}
.lumi-premium-align-right .lumi-premium-slide-buttons {
  justify-content: flex-end;
}
.lumi-premium-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 56px;
  padding: 14px 28px;
  border-radius: 999px;
  text-decoration: none;
  font-size: 0.95rem;
  font-weight: 700;
  line-height: 1;
  max-width: 100%;
  flex: 0 1 auto;
  transition: transform 0.3s ease, box-shadow 0.3s ease, background 0.3s ease, border-color 0.3s ease, color 0.3s ease;
}
.lumi-premium-btn:hover {
  transform: translateY(-3px);
}
.lumi-premium-btn-primary {
  background-color: #1d6ce3;
  color: #fff;
  border: 1px solid rgba(255,255,255,0.14);
  box-shadow: 0 24px 46px rgba(10, 33, 72, 0.34);
}
.lumi-premium-btn-primary:hover {
  box-shadow: 0 28px 54px rgba(10, 33, 72, 0.42);
}
.lumi-premium-btn-secondary {
  background-color: rgba(10,20,39,0.72);
  color: #fff;
  border: 1px solid rgba(255,255,255,0.18);
  box-shadow: 0 18px 34px rgba(3, 11, 24, 0.16);
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
}
.lumi-premium-btn-secondary:hover {
  background-color: rgba(13,28,54,0.88);
}
.lumi-premium-slider-pagination {
  position: absolute;
  left: 50% !important;
  right: auto;
  bottom: clamp(24px, 3vw, 34px);
  width: auto !important;
  display: flex;
  align-items: center;
  gap: 8px;
  z-index: 3;
  transform: translateX(-50%);
}
.lumi-premium-slider-no-nav .lumi-premium-slider-pagination {
  bottom: clamp(24px, 3vw, 34px);
}
.lumi-premium-slider .swiper-pagination-bullet {
  width: 10px;
  height: 10px;
  margin: 0 !important;
  border-radius: 999px;
  background: rgba(255,255,255,0.34);
  opacity: 1;
  transition: width 0.3s ease, transform 0.3s ease, background 0.3s ease;
}
.lumi-premium-slider .swiper-pagination-bullet-active {
  width: 30px;
  background: linear-gradient(90deg, #4fc3f7, #e1b866);
  transform: none;
  box-shadow: 0 10px 24px rgba(79,195,247,0.22);
}
.lumi-premium-slider-chrome {
  position: absolute;
  inset: 0;
  z-index: 3;
  pointer-events: none;
}
.lumi-premium-slider-status {
  position: absolute;
  left: clamp(18px, 4vw, 54px);
  bottom: clamp(18px, 3vw, 28px);
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 9px 14px;
  border-radius: 999px;
  background-color: rgba(10,20,39,0.52);
  border: 1px solid rgba(255,255,255,0.12);
  color: #fff;
  font-size: 0.74rem;
  font-weight: 700;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  font-variant-numeric: tabular-nums;
  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);
  box-shadow: 0 12px 28px rgba(3, 11, 24, 0.16);
  pointer-events: auto;
}
.lumi-premium-slider-progress-wrap {
  position: absolute;
  left: 0;
  right: 0;
  z-index: 3;
}
.lumi-premium-slider-progress-top {
  top: 0;
  bottom: auto;
}
.lumi-premium-slider-progress-bottom {
  top: auto;
  bottom: 0;
}
.lumi-premium-slider-no-nav .lumi-premium-slider-progress-bottom {
  bottom: 0;
}
.lumi-premium-slider-progress {
  position: relative;
  height: 3px;
  border-radius: 0;
  background: rgba(255,255,255,0.14);
  overflow: hidden;
}
.lumi-premium-slider-progress-fill {
  display: block;
  width: 33.333%;
  height: 100%;
  border-radius: inherit;
  background: linear-gradient(90deg, #4fc3f7, #e1b866);
  box-shadow: 0 0 18px rgba(79,195,247,0.28);
  transition: width 0.45s ease;
}
.lumi-premium-slider-nav {
  position: absolute;
  inset: 0;
  pointer-events: none;
}
.lumi-premium-slider-nav-btn {
  position: absolute;
  top: 50%;
  width: 46px;
  height: 46px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border-radius: 50%;
  border: 1px solid rgba(255,255,255,0.14);
  background-color: rgba(10,20,39,0.44);
  color: #fff;
  cursor: pointer;
  box-shadow: 0 14px 28px rgba(3, 11, 24, 0.16);
  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);
  transition: transform 0.3s ease, background 0.3s ease, border-color 0.3s ease, box-shadow 0.3s ease;
  transform: translateY(-50%);
  pointer-events: auto;
}
.lumi-premium-slider-nav-btn:hover {
  transform: translateY(-50%) scale(1.03);
  background-color: rgba(15,36,72,0.8);
  border-color: rgba(255,255,255,0.22);
  box-shadow: 0 18px 30px rgba(3, 11, 24, 0.22);
}
.lumi-premium-slider-nav-btn:first-child {
  left: clamp(14px, 2vw, 22px);
}
.lumi-premium-slider-nav-btn:last-child {
  right: clamp(14px, 2vw, 22px);
}
.lumi-premium-slider-nav-btn span {
  font-size: 0.95rem;
  font-weight: 700;
  line-height: 1;
}
@media ( max-width: 1024px ) {
  .lumi-premium-slide-title {
    font-size: clamp(2.4rem, 6vw, 4.6rem);
  }
}
@media ( max-width: 768px ) {
  .lumi-premium-slide-shell {
    padding: 20px 16px 142px;
  }
  .lumi-premium-slider-no-status .lumi-premium-slide-shell {
    padding-bottom: 118px;
  }
  .lumi-premium-slider-no-nav .lumi-premium-slide-shell {
    padding-bottom: 86px;
  }
  .lumi-premium-slider-no-status.lumi-premium-slider-no-nav .lumi-premium-slide-shell {
    padding-bottom: 44px;
  }
  .lumi-premium-slider-boxed .lumi-premium-slide-shell,
  .lumi-premium-slider-full .lumi-premium-slide-shell {
    max-width: calc(100% - 18px);
  }
  .lumi-premium-slide-title {
    font-size: clamp(2.05rem, 10vw, 3.2rem);
  }
  .lumi-premium-slide-desc {
    max-width: none;
    font-size: 0.98rem;
  }
  .lumi-premium-slide-content {
    gap: 14px;
  }
  .lumi-premium-slide-highlights {
    gap: 10px;
  }
  .lumi-premium-highlight {
    padding: 9px 14px;
    font-size: 0.78rem;
  }
  .lumi-premium-btn {
    min-height: 48px;
    padding: 12px 20px;
    font-size: 0.9rem;
  }
  .lumi-premium-slider-pagination {
    left: 50% !important;
    right: auto;
    bottom: 72px;
  }
  .lumi-premium-slider-no-nav .lumi-premium-slider-pagination {
    bottom: 72px;
  }
  .lumi-premium-slider-chrome {
    inset: 0;
  }
  .lumi-premium-slider-progress-wrap {
    left: 0;
    right: 0;
  }
  .lumi-premium-slider-progress-bottom {
    bottom: 0;
  }
  .lumi-premium-slider-no-nav .lumi-premium-slider-progress-bottom {
    bottom: 0;
  }
  .lumi-premium-slider-progress {
    height: 3px;
  }
  .lumi-premium-slider-status {
    left: 16px;
    bottom: 104px;
    padding: 8px 11px;
    font-size: 0.68rem;
    letter-spacing: 0.1em;
  }
  .lumi-premium-slider-no-nav .lumi-premium-slider-status {
    bottom: 18px;
  }
  .lumi-premium-slider-nav {
    inset: auto;
    left: 50%;
    bottom: 18px;
    display: inline-flex;
    align-items: center;
    gap: 12px;
    transform: translateX(-50%);
    pointer-events: auto;
  }
  .lumi-premium-slider-nav-btn {
    position: relative;
    top: auto;
    left: auto;
    right: auto;
    width: 40px;
    height: 40px;
    transform: none;
  }
  .lumi-premium-slider-nav-btn:hover {
    transform: translateY(-2px);
  }
  .lumi-premium-slider-nav-btn span {
    font-size: 0.9rem;
  }
}
@media ( max-width: 480px ) {
  .lumi-premium-slide-shell {
    padding-bottom: 156px;
  }
  .lumi-premium-slider-no-status .lumi-premium-slide-shell {
    padding-bottom: 126px;
  }
  .lumi-premium-slider-no-nav .lumi-premium-slide-shell {
    padding-bottom: 98px;
  }
  .lumi-premium-slider-no-status.lumi-premium-slider-no-nav .lumi-premium-slide-shell {
    padding-bottom: 44px;
  }
  .lumi-premium-slide-highlights {
    width: 100%;
  }
  .lumi-premium-slider-status {
    left: 16px;
    right: 16px;
    width: auto;
    justify-content: center;
  }
  .lumi-premium-slider-nav {
    width: auto;
    justify-content: center;
    gap: 10px;
    margin-left: 0;
  }
  .lumi-premium-slider-nav-btn {
    width: 38px;
    height: 38px;
  }
}

/* ── RESPONSIVE ──────────────────────────────────────────── */
@media ( max-width: 1024px ) {
  .lumi-feature-grid { grid-template-columns: repeat(2, 1fr); }
}
@media ( max-width: 768px ) {
  .lumi-feature-grid { grid-template-columns: 1fr; }
  .lumi-slide-title  { font-size: 2rem; }
  .lumi-slide-desc   { font-size: 0.97rem; }
  .lumi-slide-inner { padding: 20px 16px 110px; }
  .lumi-slide-content {
    width: 100%;
    max-width: none;
    padding: 22px 18px;
  }
  .lumi-slider-wrapper .swiper-button-next,
  .lumi-slider-wrapper .swiper-button-prev {
    top: auto;
    bottom: 18px;
    transform: none;
    width: 40px !important;
    height: 40px !important;
  }
  .lumi-slider-wrapper .swiper-button-prev {
    left: calc(50% - 50px);
  }
  .lumi-slider-wrapper .swiper-button-next {
    right: calc(50% - 50px);
  }
  .lumi-slider-wrapper .swiper-button-next:hover,
  .lumi-slider-wrapper .swiper-button-prev:hover {
    transform: translateY(-2px) scale(1.03);
  }
  .lumi-slider-wrapper .swiper-pagination {
    bottom: 66px !important;
  }
  .lumi-slider-wrapper .swiper-button-next::after,
  .lumi-slider-wrapper .swiper-button-prev::after {
    font-size: 13px !important;
  }
  .lumi-slider-wrapper .lumi-btn-primary,
  .lumi-slider-wrapper .lumi-btn-secondary {
    padding: 12px 20px;
    font-size: 14px;
  }
  .lumi-slider-progress {
    height: 3px;
  }
  .lumi-cta-layout-left-right .lumi-cta-panel {
    flex-direction: column;
    align-items: flex-start;
  }
  .lumi-cta-layout-left-right .lumi-cta-buttons {
    justify-content: flex-start;
  }
  .lumi-cta-buttons,
  .lumi-cta-hero-buttons {
    width: 100%;
  }
  .lumi-cta-buttons > a,
  .lumi-cta-hero-buttons > a {
    flex: 1 1 100%;
    width: 100%;
  }
  .lumi-cta-hero-title {
    font-size: 2.2rem;
  }
  .lumi-cta-hero-boxed .lumi-cta-hero-inner,
  .lumi-cta-hero-full .lumi-cta-hero-inner {
    max-width: none;
  }
  .lumi-tabs-pos-left,
  .lumi-tabs-pos-right { flex-direction: column; }
  .lumi-tabs-pos-left  .lumi-tabs-nav,
  .lumi-tabs-pos-right .lumi-tabs-nav { flex-direction: row; }
  .lumi-pricing-featured { transform: scale(1); }
  .lumi-oc-panel { max-width: 85vw; }
}
@media ( max-width: 480px ) {
  .lumi-ph-title {
    font-size: 1.8rem;
  }
  .lumi-ph-description {
    font-size: 0.94rem;
  }
  .lumi-cta-hero-content {
    max-width: 100%;
  }
  .lumi-cta-hero-title {
    font-size: 1.95rem;
  }
  .lumi-cta-hero-desc {
    font-size: 0.96rem;
  }
  .lumi-cta-hero-btn-primary,
  .lumi-cta-hero-btn-secondary {
    max-width: 100%;
  }
  .lumi-cta-panel {
    padding: 26px;
    border-radius: 24px;
    gap: 24px;
  }
  .lumi-cta-title {
    font-size: 1.95rem;
  }
  .lumi-cta-desc {
    font-size: 0.96rem;
  }
  .lumi-cta-btn-primary,
  .lumi-cta-btn-secondary {
    max-width: 100%;
  }
  .lumi-buttons-wrap { flex-direction: column; }
  .lumi-btn-item { width: 100%; justify-content: center; }
  .lumi-slide-content {
    padding: 20px;
  }
  .lumi-slide-buttons {
    gap: 12px;
  }
  .lumi-slider-wrapper .swiper-button-next,
  .lumi-slider-wrapper .swiper-button-prev {
    width: 40px !important;
    height: 40px !important;
  }
  .lumi-slider-wrapper .swiper-pagination {
    bottom: 68px !important;
  }
  .lumi-counter-icon {
    width: 64px;
    height: 64px;
    border-radius: 18px;
  }
}

/* 26. PROLINK PREMIUM SHARED */
@keyframes lppProgressFlow {
  0% { background-position: 0 0; }
  100% { background-position: 200% 0; }
}
@keyframes lppFloatGlow {
  0%, 100% { transform: translateY(0); opacity: .7; }
  50% { transform: translateY(-6px); opacity: 1; }
}
.lpp-empty-state {
  padding: 22px 24px;
  border-radius: 20px;
  background: linear-gradient(145deg, rgba(8,18,38,.76), rgba(10,22,45,.42));
  border: 1px solid rgba(255,255,255,.08);
  color: rgba(240,244,255,.72);
}
.lpp-widget-chip,
.lpp-post-meta-card span,
.lpp-breadcrumbs span,
.lpp-breadcrumbs a {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  width: fit-content;
  padding: 7px 14px;
  border-radius: 999px;
  background-color: rgba(10,20,39,.74);
  border: 1px solid rgba(255,255,255,.12);
  color: #f5f8ff;
  font-size: .78rem;
  font-weight: 700;
  letter-spacing: .08em;
  text-transform: uppercase;
  box-shadow: inset 0 1px 0 rgba(255,255,255,.08);
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
}
.lpp-widget-chip::before {
  content: "";
  width: 8px;
  height: 8px;
  border-radius: 50%;
  background: linear-gradient(135deg, #4fc3f7, #e1b866);
  box-shadow: 0 0 18px rgba(79,195,247,.35);
}
.lpp-button,
.lpp-share-btn,
.lpp-bio-link,
.lpp-filter-btn,
.lpp-copy-btn,
.lpp-carousel-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 50px;
  padding: 12px 22px;
  border-radius: 999px;
  border: 1px solid rgba(255,255,255,.14);
  background-color: rgba(9,20,39,.92);
  color: #f7f9ff;
  text-decoration: none;
  font-size: .92rem;
  font-weight: 700;
  cursor: pointer;
  transition: transform .3s ease, box-shadow .3s ease, border-color .3s ease, background .3s ease;
  box-shadow: 0 18px 36px rgba(3, 11, 24, .18);
}
.lpp-button-primary,
.lpp-share-btn:hover,
.lpp-bio-link:hover,
.lpp-filter-btn.is-active {
  background-color: #1b73e8;
  border-color: rgba(255,255,255,.16);
  color: #fff;
  box-shadow: 0 20px 40px rgba(10, 33, 72, .32);
}
.lpp-button:hover,
.lpp-share-btn:hover,
.lpp-bio-link:hover,
.lpp-filter-btn:hover,
.lpp-copy-btn:hover,
.lpp-carousel-btn:hover {
  transform: translateY(-2px);
}
.lpp-link-arrow {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  color: #9ed9ff;
  font-weight: 700;
  text-decoration: none;
}
.lpp-link-arrow::after {
  content: "->";
  transition: transform .25s ease;
}
.lpp-link-arrow:hover::after {
  transform: translateX(4px);
}

.lumi-progress-item {
  background:
    linear-gradient(150deg, rgba(8,18,38,.98), rgba(8,17,31,.88)),
    radial-gradient(circle at top right, rgba(225,184,102,.1), transparent 32%);
  border-color: rgba(255,255,255,.1);
  box-shadow:
    0 26px 52px rgba(3, 11, 24, .22),
    inset 0 1px 0 rgba(255,255,255,.06);
}
.lumi-progress-item::after {
  content: "";
  position: absolute;
  inset: 12px;
  border: 1px solid rgba(255,255,255,.06);
  border-radius: 18px;
  pointer-events: none;
}
.lumi-progress-pct {
  background: linear-gradient(140deg, rgba(10,22,44,.72), rgba(10,22,44,.42));
  border-color: rgba(255,255,255,.16);
  box-shadow: inset 0 1px 0 rgba(255,255,255,.1), 0 8px 18px rgba(3, 11, 24, .14);
}
.lumi-progress-track {
  height: 12px;
  background:
    linear-gradient(90deg, rgba(255,255,255,.08), rgba(255,255,255,.025)),
    linear-gradient(180deg, rgba(4,10,18,.32), rgba(4,10,18,.18));
  border-color: rgba(255,255,255,.08);
}
.lumi-progress-track::before {
  content: "";
  position: absolute;
  left: 12px;
  right: 12px;
  top: 50%;
  height: 3px;
  transform: translateY(-50%);
  background: repeating-linear-gradient(90deg, rgba(255,255,255,.18) 0 2px, transparent 2px 18%);
  opacity: .35;
  pointer-events: none;
}
.lumi-progress-fill {
  background: linear-gradient(90deg, #143f80 0%, #4fc3f7 52%, #e1b866 100%);
  background-size: 200% 100%;
  animation: lppProgressFlow 5s linear infinite;
  box-shadow: 0 0 24px rgba(79,195,247,.3), 0 0 48px rgba(79,195,247,.18);
}
.lumi-progress-fill-cap {
  right: 1px;
  width: 18px;
  height: 18px;
  box-shadow: 0 0 0 5px rgba(255,255,255,.12), 0 0 22px rgba(79,195,247,.52);
}

.lpp-form-card,
.lpp-code-card,
.lpp-blockquote,
.lpp-bio-card,
.lpp-review-card,
.lpp-comments-box,
.lpp-toc,
.lpp-dynamic-card,
.lpp-lottie-card,
.lpp-featured-image-wrap,
.lpp-author-box,
.lpp-post-nav-link,
.lpp-content-card,
.lpp-media-slide,
.lpp-album-card,
.lpp-album-panel,
.lpp-video-gallery-stage,
.lpp-video-gallery-card,
.lpp-video-playlist,
.lpp-price-list,
.lpp-post-card,
.lpp-post-meta-card {
  position: relative;
  overflow: hidden;
  border-radius: 24px;
  padding: 28px;
  background-color: rgba(8,18,38,.84);
  border: 1px solid rgba(255,255,255,.1);
  box-shadow: 0 22px 48px rgba(4, 12, 26, .22), inset 0 1px 0 rgba(255,255,255,.06);
  backdrop-filter: blur(14px);
  -webkit-backdrop-filter: blur(14px);
}
.lpp-form-header {
  display: flex;
  flex-direction: column;
  gap: 12px;
  margin-bottom: 24px;
}
.lpp-form-header > * {
  margin-top: 0;
  margin-bottom: 0;
}
.lpp-surface-mode-none {
  background-image: none;
  background-color: transparent;
  border-color: transparent;
  box-shadow: none;
  backdrop-filter: none;
  -webkit-backdrop-filter: none;
}
.lpp-surface-mode-none::before,
.lpp-surface-mode-none::after {
  display: none;
}
.lpp-surface-mode-minimal {
  background-color: rgba(8,18,38,.3);
  border-color: rgba(255,255,255,.08);
  box-shadow: 0 16px 34px rgba(4, 12, 26, .12), inset 0 1px 0 rgba(255,255,255,.05);
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
}
.lpp-surface-mode-premium {
  background-color: rgba(8,18,38,.88);
  border-color: rgba(255,255,255,.12);
  box-shadow: 0 22px 48px rgba(4, 12, 26, .22), inset 0 1px 0 rgba(255,255,255,.08);
}
.lpp-form-card::before,
.lpp-code-card::before,
.lpp-bio-card::before,
.lpp-review-card::before,
.lpp-post-card::before,
.lpp-content-card::before,
.lpp-media-slide::before {
  content: "";
  position: absolute;
  inset: auto auto -20% -10%;
  width: 42%;
  aspect-ratio: 1;
  border-radius: 50%;
  background: radial-gradient(circle, rgba(79,195,247,.18), transparent 72%);
  filter: blur(14px);
  pointer-events: none;
}
.lpp-form-title,
.lpp-page-title,
.lpp-code-card strong,
.lpp-media-slide-body h3,
.lpp-content-card h3,
.lpp-video-stage-copy h3,
.lpp-bio-card h3,
.lpp-blockquote p,
.lpp-toc-title {
  margin: 0 0 12px;
  color: #fff;
  font-weight: 800;
  letter-spacing: -.03em;
}
.lpp-form-title,
.lpp-page-title {
  font-size: clamp(2rem, 4.4vw, 3.6rem);
  line-height: 1.05;
}
.lpp-form-desc,
.lpp-media-slide-body p,
.lpp-content-card p,
.lpp-video-stage-copy p,
.lpp-post-excerpt,
.lpp-prose,
.lpp-bio-card p,
.lpp-review-card p,
.lpp-comments-box p,
.lpp-price-item p,
.lpp-progress-step p {
  margin: 0;
  color: rgba(236,242,255,.78);
  line-height: 1.75;
}
.lpp-form-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 16px;
  margin-top: 24px;
}
.lpp-form-field {
  display: flex;
  flex-direction: column;
  gap: 8px;
}
.lpp-form-field-full {
  grid-column: 1 / -1;
}
.lpp-form-field label {
  font-size: .84rem;
  font-weight: 700;
  color: rgba(240,244,255,.72);
}
.lpp-form-field input,
.lpp-form-field textarea,
.lpp-search-form input,
.lpp-login-form-wrap input[type="text"],
.lpp-login-form-wrap input[type="password"] {
  width: 100%;
  padding: 14px 16px;
  border-radius: 16px;
  border: 1px solid rgba(255,255,255,.12);
  background-color: rgba(4,12,24,.42);
  color: #fff;
  box-shadow: inset 0 1px 0 rgba(255,255,255,.05);
}
.lpp-form-field input:focus,
.lpp-form-field textarea:focus,
.lpp-search-form input:focus,
.lpp-login-form-wrap input:focus {
  outline: none;
  border-color: rgba(79,195,247,.6);
  box-shadow: 0 0 0 4px rgba(79,195,247,.12);
}
.lpp-form-notice {
  margin-top: 18px;
  padding: 14px 16px;
  border-radius: 16px;
  font-weight: 700;
}
.lpp-form-notice-success { background: rgba(46, 204, 113, .16); color: #baf7d1; }
.lpp-form-notice-invalid,
.lpp-form-notice-error { background: rgba(231, 76, 60, .16); color: #ffd2ca; }
.lpp-form-actions {
  display: flex;
  gap: 14px;
  flex-wrap: wrap;
  align-items: center;
  margin-top: 18px;
}
.lpp-link-action {
  color: #9ed9ff;
  font-weight: 700;
  text-decoration: none;
}
.lpp-login-form-wrap form {
  display: grid;
  gap: 14px;
}
.lpp-login-form-wrap label {
  display: block;
  margin-bottom: 8px;
  color: rgba(240,244,255,.74);
  font-size: .84rem;
  font-weight: 700;
}
.lpp-login-form-wrap .login-remember {
  display: flex;
  align-items: center;
  gap: 10px;
  color: rgba(236,242,255,.74);
}
.lpp-login-form-wrap .login-remember label {
  margin: 0;
}
.lpp-login-form-wrap .login-remember input {
  width: auto;
  margin: 0;
}
.lpp-login-form-wrap .login-submit input {
  width: auto;
  min-width: 180px;
}
.lpp-post-grid {
  display: grid;
  gap: 24px;
}
.lpp-grid-cols-1 { grid-template-columns: 1fr; }
.lpp-grid-cols-2 { grid-template-columns: repeat(2, minmax(0, 1fr)); }
.lpp-grid-cols-3 { grid-template-columns: repeat(3, minmax(0, 1fr)); }
.lpp-grid-cols-4 { grid-template-columns: repeat(4, minmax(0, 1fr)); }
.lpp-post-card {
  display: flex;
  flex-direction: column;
  gap: 18px;
  padding: 0;
}
.lpp-post-card-featured {
  grid-column: span 2;
}
.lpp-post-media,
.lpp-portfolio-media {
  display: block;
  position: relative;
  overflow: hidden;
  min-height: 220px;
}
.lpp-post-media img,
.lpp-album-stack-layer img,
.lpp-gallery-item img,
.lpp-content-card img,
.lpp-portfolio-media img,
.lpp-media-slide-visual img,
.lpp-video-gallery-poster img,
.lpp-featured-image-wrap img,
.lpp-bio-avatar {
  display: block;
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform .55s ease, filter .35s ease;
}
.lpp-post-card:hover .lpp-post-media img,
.lpp-album-card:hover .lpp-album-stack-layer-1 img,
.lpp-gallery-item:hover img,
.lpp-content-card:hover img,
.lpp-video-gallery-card:hover .lpp-video-gallery-poster img,
.lpp-portfolio-card:hover img {
  transform: scale(1.06);
  filter: saturate(1.06);
}
.lpp-post-media-fallback {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 100%;
  min-height: 220px;
  background: linear-gradient(135deg, #0f3e81, #13243f);
  color: #fff;
  font-size: 3rem;
  font-weight: 800;
}
.lpp-post-body {
  display: flex;
  flex-direction: column;
  gap: 14px;
  padding: 0 26px 26px;
}
.lpp-post-title,
.lpp-post-title a,
.lpp-content-card h3,
.lpp-price-item strong,
.lpp-video-copy strong,
.lpp-bio-link strong,
.lpp-comment-item strong,
.lpp-post-nav-link strong {
  color: #fff;
  text-decoration: none;
  font-size: 1.18rem;
  line-height: 1.2;
}
.lpp-post-meta,
.lpp-video-copy small,
.lpp-bio-link span,
.lpp-comment-item span,
.lpp-blockquote footer span {
  display: flex;
  flex-wrap: wrap;
  gap: 12px;
  color: rgba(240,244,255,.54);
  font-size: .82rem;
}
.lpp-carousel-shell,
.lpp-media-carousel-shell {
  position: relative;
  --lpp-carousel-pagination-gap: 18px;
}
.lpp-carousel-shell .swiper,
.lpp-media-carousel-shell .swiper {
  overflow: hidden;
}
.lpp-carousel-shell .swiper-pagination,
.lpp-media-carousel-shell .swiper-pagination {
  position: static;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 10px;
  margin-top: var(--lpp-carousel-pagination-gap);
}
.lpp-carousel-shell .swiper-pagination-bullet,
.lpp-media-carousel-shell .swiper-pagination-bullet {
  width: 10px;
  height: 10px;
  margin: 0 !important;
  opacity: 1;
  background-color: rgba(255,255,255,.28);
  transition: transform .25s ease, background-color .25s ease, width .25s ease;
}
.lpp-carousel-shell .swiper-pagination-bullet-active,
.lpp-media-carousel-shell .swiper-pagination-bullet-active {
  width: 32px;
  border-radius: 999px;
  background: linear-gradient(90deg, #4fc3f7, #e1b866);
  transform: translateY(-1px);
}
.lpp-carousel-shell.lpp-carousel-pagination-inside-bottom,
.lpp-carousel-shell.lpp-carousel-pagination-inside-top,
.lpp-media-carousel-shell.lpp-carousel-pagination-inside-bottom,
.lpp-media-carousel-shell.lpp-carousel-pagination-inside-top {
  padding-bottom: 0;
}
.lpp-carousel-shell.lpp-carousel-pagination-inside-bottom .swiper-pagination,
.lpp-carousel-shell.lpp-carousel-pagination-inside-top .swiper-pagination,
.lpp-media-carousel-shell.lpp-carousel-pagination-inside-bottom .swiper-pagination,
.lpp-media-carousel-shell.lpp-carousel-pagination-inside-top .swiper-pagination {
  position: absolute;
  left: 0;
  right: 0;
  z-index: 3;
  margin-top: 0;
}
.lpp-carousel-shell.lpp-carousel-pagination-inside-bottom .swiper-pagination,
.lpp-media-carousel-shell.lpp-carousel-pagination-inside-bottom .swiper-pagination {
  bottom: 14px;
}
.lpp-carousel-shell.lpp-carousel-pagination-inside-top .swiper-pagination,
.lpp-media-carousel-shell.lpp-carousel-pagination-inside-top .swiper-pagination {
  top: 14px;
}
.lpp-carousel-shell.lpp-carousel-pagination-hidden .swiper-pagination,
.lpp-media-carousel-shell.lpp-carousel-pagination-hidden .swiper-pagination {
  display: none !important;
}
.lpp-carousel-nav {
  display: flex;
  justify-content: flex-end;
  gap: 10px;
  margin-top: 16px;
}
.lpp-media-slide {
  display: grid;
  grid-template-columns: minmax(0, 1.15fr) minmax(280px, .85fr);
  gap: 26px;
  align-items: stretch;
}
.lpp-media-slide-visual,
.lpp-video-stage,
.lpp-video-gallery-stage {
  position: relative;
  overflow: hidden;
  border-radius: 20px;
  min-height: 320px;
  background: transparent;
  border: 1px solid rgba(255,255,255,.08);
  box-shadow: inset 0 1px 0 rgba(255,255,255,.05);
}
.lpp-media-slide-visual iframe,
.lpp-video-stage iframe,
.lpp-video-gallery-stage iframe {
  width: 100%;
  height: 100%;
  min-height: 320px;
  border: 0;
}
.lpp-media-slide-body,
.lpp-video-stage-copy {
  display: flex;
  flex-direction: column;
  justify-content: center;
  gap: 14px;
}
.lpp-gallery-grid {
  display: grid;
  gap: 18px;
}
.lpp-album-gallery {
  --lpp-album-stack-offset: 16px;
  display: flex;
  flex-direction: column;
  gap: 24px;
}
.lpp-gallery-albums,
.lpp-gallery-stack-panels {
  display: grid;
  gap: 22px;
}
.lpp-album-card {
  display: flex;
  flex-direction: column;
  gap: 18px;
  width: 100%;
  text-align: left;
  cursor: pointer;
  transition: transform .3s ease, box-shadow .3s ease, border-color .3s ease;
}
.lpp-album-card:hover,
.lpp-album-card.is-active {
  transform: translateY(-4px);
  border-color: rgba(79,195,247,.28);
  box-shadow: 0 28px 52px rgba(3, 11, 24, .24);
}
.lpp-album-stack {
  position: relative;
  display: block;
  min-height: 280px;
  padding: 0 calc(var(--lpp-album-stack-offset) * 1.8) calc(var(--lpp-album-stack-offset) * 1.8) 0;
}
.lpp-album-stack-layer {
  position: absolute;
  inset: 0;
  display: block;
  overflow: hidden;
  border-radius: 24px;
  border: 1px solid rgba(255,255,255,.12);
  box-shadow: 0 22px 44px rgba(3, 11, 24, .24);
  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);
}
.lpp-album-stack-layer-1 { z-index: 4; transform: rotate(-2deg); }
.lpp-album-stack-layer-2 {
  z-index: 3;
  transform: translate(calc(var(--lpp-album-stack-offset) * .5), calc(var(--lpp-album-stack-offset) * .5)) rotate(2.5deg);
  opacity: .92;
}
.lpp-album-stack-layer-3 {
  z-index: 2;
  transform: translate(calc(var(--lpp-album-stack-offset) * 1), calc(var(--lpp-album-stack-offset) * 1)) rotate(-3.5deg);
  opacity: .84;
}
.lpp-album-stack-layer-4 {
  z-index: 1;
  transform: translate(calc(var(--lpp-album-stack-offset) * 1.5), calc(var(--lpp-album-stack-offset) * 1.5)) rotate(4.5deg);
  opacity: .74;
}
.lpp-album-count {
  position: absolute;
  right: 12px;
  bottom: 12px;
  z-index: 5;
  display: inline-flex;
  align-items: center;
  min-height: 42px;
  padding: 10px 14px;
  border-radius: 999px;
  background: linear-gradient(145deg, rgba(8,18,38,.88), rgba(10,22,45,.62));
  border: 1px solid rgba(255,255,255,.12);
  color: #fff;
  font-size: .78rem;
  font-weight: 800;
  letter-spacing: .06em;
  text-transform: uppercase;
  box-shadow: 0 18px 36px rgba(3, 11, 24, .24);
  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);
}
.lpp-album-card-copy,
.lpp-album-panel-head,
.lpp-video-gallery-card-copy {
  display: flex;
  flex-direction: column;
  gap: 10px;
}
.lpp-album-title,
.lpp-album-panel-title,
.lpp-gallery-item-title,
.lpp-video-gallery-card-copy strong {
  color: #fff;
  font-size: 1.22rem;
  line-height: 1.15;
}
.lpp-album-meta,
.lpp-album-text,
.lpp-album-panel-meta,
.lpp-album-panel-desc,
.lpp-gallery-item-location,
.lpp-video-gallery-card-copy small {
  color: rgba(236,242,255,.72);
  line-height: 1.7;
}
.lpp-album-panel[hidden] {
  display: none !important;
}
.lpp-album-panel {
  scroll-margin-top: 24px;
}
.lpp-gallery-item {
  display: block;
  position: relative;
  overflow: hidden;
  min-height: 220px;
  border-radius: 22px;
  border: 1px solid rgba(255,255,255,.08);
  box-shadow: 0 18px 36px rgba(3, 11, 24, .16);
}
.lpp-gallery-item-copy {
  position: absolute;
  left: 16px;
  right: 16px;
  bottom: 16px;
  display: flex;
  flex-direction: column;
  gap: 6px;
  padding: 14px 16px;
  border-radius: 18px;
  background: linear-gradient(145deg, rgba(8,18,38,.88), rgba(10,22,45,.54));
  border: 1px solid rgba(255,255,255,.1);
  box-shadow: 0 18px 36px rgba(3, 11, 24, .2);
  opacity: 0;
  transform: translateY(10px);
  transition: opacity .3s ease, transform .3s ease;
  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);
}
.lpp-gallery-item:hover .lpp-gallery-item-copy {
  opacity: 1;
  transform: translateY(0);
}
.lpp-content-card {
  display: flex;
  flex-direction: column;
  gap: 14px;
}
.lpp-content-card img {
  min-height: 220px;
  border-radius: 18px;
}
.lpp-filter-nav,
.lpp-share-buttons {
  display: flex;
  flex-wrap: wrap;
  gap: 12px;
  margin-bottom: 20px;
}
.lpp-portfolio-card {
  position: relative;
  overflow: hidden;
  border-radius: 24px;
  min-height: 320px;
  border: 1px solid rgba(255,255,255,.08);
  box-shadow: 0 20px 42px rgba(3, 11, 24, .18);
}
.lpp-portfolio-media,
.lpp-portfolio-media img {
  min-height: 320px;
}
.lpp-portfolio-overlay {
  position: absolute;
  inset: 0;
  background: linear-gradient(180deg, rgba(4,10,18,.1), rgba(4,10,18,.82));
}
.lpp-portfolio-content {
  position: absolute;
  left: 20px;
  right: 20px;
  bottom: 20px;
  display: flex;
  flex-direction: column;
  gap: 10px;
  z-index: 1;
  color: #fff;
}
.lpp-hotspot-wrap {
  position: relative;
  overflow: hidden;
  border-radius: 24px;
  border: 1px solid rgba(255,255,255,.08);
  box-shadow: 0 20px 42px rgba(3, 11, 24, .18);
}
.lpp-hotspot-wrap > img {
  display: block;
  width: 100%;
}
.lpp-hotspot-pin {
  position: absolute;
  width: 24px;
  height: 24px;
  padding: 0;
  border: 0;
  background: transparent;
  transform: translate(-50%, -50%);
  cursor: pointer;
}
.lpp-hotspot-dot {
  display: block;
  width: 24px;
  height: 24px;
  border-radius: 50%;
  background-color: #1b73e8;
  box-shadow: 0 0 0 8px rgba(79,195,247,.14);
  animation: lppFloatGlow 2.8s ease-in-out infinite;
}
.lpp-hotspot-card {
  position: absolute;
  left: 32px;
  top: 50%;
  width: 240px;
  display: flex;
  flex-direction: column;
  gap: 8px;
  padding: 16px 18px;
  border-radius: 18px;
  background-color: rgba(8,18,38,.96);
  border: 1px solid rgba(255,255,255,.1);
  color: #fff;
  transform: translateY(-50%) scale(.92);
  opacity: 0;
  pointer-events: none;
  transition: opacity .25s ease, transform .25s ease;
}
.lpp-hotspot-pin:hover .lpp-hotspot-card,
.lpp-hotspot-pin.is-active .lpp-hotspot-card {
  opacity: 1;
  transform: translateY(-50%) scale(1);
}
.lpp-video-playlist {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(180px, var(--lpp-video-sidebar-width, 220px));
  gap: var(--lpp-video-sidebar-gap, 20px);
  align-items: stretch;
}
.lpp-video-gallery {
  display: grid;
  gap: 24px;
}
.lpp-video-gallery-stage {
  display: flex;
  flex-direction: column;
  gap: 22px;
  align-items: stretch;
}
.lpp-video-gallery-grid {
  display: grid;
  gap: 18px;
}
.lpp-video-stage,
.lpp-video-gallery-stage {
  padding: 24px;
  border-radius: 30px;
  background:
    linear-gradient(140deg, rgba(8,18,38,.92), rgba(7,14,29,.76)),
    linear-gradient(180deg, rgba(79,195,247,.06), transparent 34%);
  border: 1px solid rgba(255,255,255,.08);
  box-shadow: 0 28px 64px rgba(3, 11, 24, .24), inset 0 1px 0 rgba(255,255,255,.05);
  isolation: isolate;
}
.lpp-video-stage {
  display: flex;
  flex-direction: column;
  gap: 18px;
}
.lpp-video-stage-backdrop {
  position: absolute;
  inset: 0;
  z-index: 0;
  border-radius: inherit;
  background-position: center;
  background-size: cover;
  opacity: .28;
  filter: saturate(1.05) blur(0px);
  transform: scale(1.06);
}
.lpp-video-stage-backdrop::after {
  content: "";
  position: absolute;
  inset: 0;
  border-radius: inherit;
  background:
    linear-gradient(180deg, rgba(4,10,20,.18), rgba(4,10,20,.82)),
    radial-gradient(circle at 15% 22%, rgba(79,195,247,.24), transparent 28%),
    radial-gradient(circle at 84% 18%, rgba(225,184,102,.22), transparent 26%);
}
.lpp-video-stage-player {
  position: relative;
  overflow: hidden;
  z-index: 1;
  border-radius: 24px;
  min-height: 0;
  background-color: rgba(3,10,20,.78);
  border: 1px solid rgba(255,255,255,.08);
  box-shadow: 0 24px 48px rgba(3, 11, 24, .2);
  aspect-ratio: 16 / 9;
}
.lpp-video-stage iframe,
.lpp-video-gallery-stage iframe {
  min-height: 0;
  height: 100%;
}
.lpp-video-stage-play {
  position: absolute;
  right: 18px;
  bottom: 18px;
  width: 66px;
  height: 66px;
  border-radius: 50%;
  pointer-events: none;
  background:
    radial-gradient(circle at 30% 30%, rgba(255,255,255,.32), transparent 52%),
    linear-gradient(135deg, rgba(15,62,129,.96), rgba(225,184,102,.88));
  box-shadow: 0 18px 36px rgba(3, 11, 24, .3);
}
.lpp-video-stage-play::before {
  content: "";
  position: absolute;
  left: 28px;
  top: 22px;
  border-style: solid;
  border-width: 11px 0 11px 18px;
  border-color: transparent transparent transparent #fff;
}
.lpp-video-stage-copy,
.lpp-video-gallery-stage-copy {
  position: relative;
  z-index: 1;
  display: flex;
  flex-direction: column;
  gap: 16px;
}
.lpp-video-gallery-stage-copy {
  width: 100%;
  max-width: 980px;
  margin: 0;
}
.lpp-video-stage-copy-centered {
  align-items: flex-start;
  text-align: left;
}
.lpp-video-stage-head {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 12px;
}
.lpp-video-stage-head-center {
  justify-content: center;
  text-align: center;
}
.lpp-video-stage-head-center + h3,
.lpp-video-stage-head-center + p,
.lpp-video-stage-head-center ~ .lpp-video-stage-meta {
  text-align: center;
}
.lpp-video-stage-tag {
  display: inline-flex;
  align-items: center;
  min-height: 38px;
  padding: 8px 14px;
  border-radius: 999px;
  background-color: rgba(255,255,255,.08);
  border: 1px solid rgba(255,255,255,.12);
  color: rgba(240,244,255,.9);
  font-size: .8rem;
  font-weight: 700;
  line-height: 1;
}
.lpp-video-stage-meta,
.lpp-video-card-meta {
  display: flex;
  flex-wrap: wrap;
  gap: 10px 14px;
  color: rgba(236,242,255,.68);
  font-size: .82rem;
  line-height: 1.5;
}
.lpp-video-stage-head-center ~ .lpp-video-stage-meta {
  justify-content: center;
}
.lpp-video-stage-meta > span:not(.lpp-widget-chip):not(.lpp-video-stage-tag),
.lpp-video-card-meta span {
  display: inline-flex;
  align-items: center;
  gap: 8px;
}
.lpp-video-stage-meta-rich {
  align-items: center;
}
.lpp-video-stage-copy-centered .lpp-video-stage-meta-rich {
  justify-content: flex-start;
}
.lpp-video-stage-meta > span:not(.lpp-widget-chip):not(.lpp-video-stage-tag)::before,
.lpp-video-card-meta span::before {
  content: "";
  width: 6px;
  height: 6px;
  border-radius: 50%;
  background: linear-gradient(135deg, #4fc3f7, #e1b866);
  box-shadow: 0 0 14px rgba(79,195,247,.4);
}
.lpp-video-gallery-card {
  position: relative;
  display: flex;
  flex-direction: column;
  gap: 12px;
  width: 100%;
  min-width: 0;
  padding: 12px;
  text-align: left;
  cursor: pointer;
  overflow: hidden;
  transition: transform .28s ease, border-color .28s ease, box-shadow .28s ease, background-color .28s ease;
}
.lpp-video-gallery-card:hover,
.lpp-video-gallery-card.is-active {
  transform: translateY(-3px);
  border-color: rgba(79,195,247,.28);
  box-shadow: 0 24px 48px rgba(3, 11, 24, .24);
  background-color: rgba(10,22,44,.52);
}
.lpp-video-gallery-poster {
  display: block;
  position: relative;
  overflow: hidden;
  min-height: 210px;
  border-radius: 20px;
}
.lpp-video-gallery-stage .lpp-video-stage-player {
  min-height: 420px;
}
.lpp-video-gallery-card,
.lpp-video-gallery-card-copy,
.lpp-video-gallery-card-copy strong,
.lpp-video-gallery-card-copy small,
.lpp-video-gallery-card-copy .lpp-video-card-meta {
  min-width: 0;
  max-width: 100%;
}
.lpp-video-gallery-card-copy {
  width: 100%;
  padding: 4px 4px 6px;
  box-sizing: border-box;
}
.lpp-video-gallery-card-copy strong,
.lpp-video-gallery-card-copy small {
  display: block;
  overflow-wrap: anywhere;
  word-break: break-word;
}
.lpp-video-gallery-stage-copy h3,
.lpp-video-gallery-stage-copy p {
  max-width: 100%;
}
.lpp-video-gallery-poster::after {
  content: "";
  position: absolute;
  inset: auto auto 12px 12px;
  width: 52px;
  height: 52px;
  border-radius: 50%;
  background:
    radial-gradient(circle at 30% 30%, rgba(255,255,255,.28), transparent 55%),
    linear-gradient(135deg, rgba(15,62,129,.92), rgba(225,184,102,.82));
  box-shadow: 0 18px 36px rgba(3, 11, 24, .28);
}
.lpp-video-gallery-poster::before {
  content: "";
  position: absolute;
  left: 31px;
  bottom: 26px;
  z-index: 1;
  border-style: solid;
  border-width: 8px 0 8px 14px;
  border-color: transparent transparent transparent #fff;
}
.lpp-video-list {
  display: flex;
  flex-direction: column;
  gap: 10px;
  max-height: 540px;
  overflow-y: auto;
  padding: 8px;
  scrollbar-width: thin;
  border-radius: 24px;
  background:
    linear-gradient(145deg, rgba(8,18,38,.34), rgba(10,22,45,.18)),
    linear-gradient(135deg, rgba(79,195,247,.06), transparent 40%);
  border: 1px solid rgba(255,255,255,.07);
  box-shadow: inset 0 1px 0 rgba(255,255,255,.04);
}
.lpp-video-list-item {
  display: grid;
  grid-template-columns: 58px minmax(0, 1fr) 32px;
  gap: 10px;
  align-items: center;
  padding: 12px;
  border-radius: 18px;
  border: 1px solid rgba(255,255,255,.1);
  background-color: rgba(4,12,24,.28);
  color: #fff;
  cursor: pointer;
  transition: transform .25s ease, border-color .25s ease, background-color .25s ease;
}
.lpp-video-list-item.is-active,
.lpp-video-list-item:hover {
  transform: translateY(-2px);
  border-color: rgba(79,195,247,.34);
  background-color: rgba(10,22,44,.48);
}
.lpp-video-list-thumb {
  order: 1;
  grid-column: 1;
  position: relative;
  display: block;
  overflow: hidden;
  min-height: 58px;
  border-radius: 14px;
  border: 1px solid rgba(255,255,255,.08);
}
.lpp-video-list-thumb::after {
  content: "";
  position: absolute;
  left: 50%;
  top: 50%;
  width: 42px;
  height: 42px;
  border-radius: 50%;
  transform: translate(-50%, -50%);
  background: linear-gradient(135deg, rgba(15,62,129,.94), rgba(225,184,102,.82));
  box-shadow: 0 12px 24px rgba(3, 11, 24, .26);
}
.lpp-video-list-thumb::before {
  content: "";
  position: absolute;
  left: 50%;
  top: 50%;
  z-index: 1;
  transform: translate(-36%, -50%);
  border-style: solid;
  border-width: 7px 0 7px 11px;
  border-color: transparent transparent transparent #fff;
}
.lpp-video-copy {
  order: 2;
  grid-column: 2;
  display: flex;
  flex-direction: column;
  gap: 4px;
  min-width: 0;
}
.lpp-video-copy strong {
  display: -webkit-box;
  overflow: hidden;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  font-size: .9rem;
  line-height: 1.35;
}
.lpp-video-copy small {
  display: -webkit-box;
  overflow: hidden;
  -webkit-line-clamp: 1;
  -webkit-box-orient: vertical;
  font-size: .72rem;
  color: rgba(240,244,255,.48);
}
.lpp-video-index {
  order: 3;
  grid-column: 3;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 32px;
  height: 32px;
  border-radius: 12px;
  background-color: rgba(15,62,129,.7);
  color: #fff;
  font-weight: 800;
  font-size: .76rem;
}
.lpp-video-card-meta {
  gap: 6px 10px;
  font-size: .72rem;
}
.lpp-video-card-meta span {
  white-space: nowrap;
}
.lpp-video-card-meta span::before {
  width: 5px;
  height: 5px;
}
.lpp-video-gallery-rail-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  margin-top: 4px;
}
.lpp-video-rail-label {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  color: rgba(255,255,255,.92);
  font-size: .82rem;
  font-weight: 800;
  letter-spacing: .12em;
  text-transform: uppercase;
}
.lpp-video-rail-label::before {
  content: "";
  width: 9px;
  height: 9px;
  border-radius: 50%;
  background: linear-gradient(135deg, #4fc3f7, #e1b866);
  box-shadow: 0 0 14px rgba(79,195,247,.42);
}
.lpp-video-gallery-stage h3,
.lpp-video-stage h3 {
  margin: 0;
  color: #fff;
  text-wrap: balance;
}
.lpp-video-gallery-stage h3 {
  font-size: clamp(1.9rem, 4.2vw, 3.5rem);
  line-height: 1.02;
  letter-spacing: -.045em;
  max-width: 100%;
}
.lpp-video-stage h3 {
  font-size: clamp(1.4rem, 2.8vw, 2.05rem);
  line-height: 1.06;
  letter-spacing: -.03em;
}
.lpp-video-gallery-stage p,
.lpp-video-stage p {
  margin: 0;
  color: rgba(236,242,255,.74);
  line-height: 1.7;
}
.lpp-video-gallery-stage p {
  max-width: 100%;
}
.lpp-video-gallery-stage {
  position: relative;
  overflow: hidden;
  padding: clamp(22px, 3.5vw, 34px);
  border-radius: 34px;
  background:
    linear-gradient(150deg, rgba(6,12,24,.98), rgba(7,14,28,.78)),
    radial-gradient(circle at 18% 18%, rgba(84,127,255,.12), transparent 30%),
    radial-gradient(circle at 82% 14%, rgba(97,229,197,.08), transparent 24%);
  box-shadow:
    0 42px 84px rgba(2, 8, 20, .34),
    inset 0 1px 0 rgba(255,255,255,.05);
}
.lpp-video-gallery-stage-shell {
  position: relative;
  z-index: 1;
  display: grid;
  gap: clamp(24px, 3vw, 34px);
  width: 100%;
  min-width: 0;
}
.lpp-video-gallery-topbar {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
  padding: 8px 0 0;
}
.lpp-video-gallery-topbar-nav {
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  gap: 10px 18px;
  min-width: 0;
}
.lpp-video-gallery-topbar-label,
.lpp-video-gallery-topbar-item {
  display: inline-flex;
  align-items: center;
  min-height: 30px;
  color: rgba(255,255,255,.86);
  font-size: .72rem;
  font-weight: 700;
  letter-spacing: .12em;
  text-transform: uppercase;
}
.lpp-video-gallery-topbar-label {
  color: #fff;
}
.lpp-video-gallery-topbar-item {
  color: rgba(233,238,255,.62);
}
.lpp-video-gallery-topbar-tools {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  flex-shrink: 0;
}
.lpp-video-gallery-topbar-tools span {
  position: relative;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 38px;
  height: 38px;
  border-radius: 999px;
  border: 1px solid rgba(255,255,255,.1);
  background: rgba(255,255,255,.05);
  box-shadow: inset 0 1px 0 rgba(255,255,255,.05);
}
.lpp-video-gallery-topbar-tools span:first-child::before {
  content: "";
  display: block;
  width: 11px;
  height: 11px;
  border: 1.8px solid rgba(255,255,255,.9);
  border-radius: 50%;
}
.lpp-video-gallery-topbar-tools span:first-child::after {
  content: "";
  position: absolute;
  right: 10px;
  bottom: 10px;
  width: 7px;
  height: 2px;
  border-radius: 999px;
  background: rgba(255,255,255,.9);
  transform: rotate(45deg);
  transform-origin: center;
}
.lpp-video-gallery-topbar-tools span:last-child {
  overflow: hidden;
  background:
    radial-gradient(circle at 35% 35%, rgba(255,255,255,.38), transparent 42%),
    linear-gradient(135deg, #8f58ff, #3d89ff 60%, #76f2ce);
}
.lpp-video-gallery-feature {
  display: grid;
  grid-template-columns: minmax(0, 1.02fr) minmax(0, .98fr);
  gap: clamp(24px, 4vw, 48px);
  align-items: end;
  width: 100%;
  min-width: 0;
}
.lpp-video-gallery-stage-copy {
  align-self: center;
  padding: clamp(8px, 1vw, 14px) 0;
  min-width: 0;
}
.lpp-video-gallery-stage-copy .lpp-video-stage-meta-rich {
  gap: 10px 12px;
  margin-bottom: 2px;
}
.lpp-video-gallery-stage-copy .lpp-widget-chip {
  padding: 8px 14px;
  border-radius: 999px;
  background:
    linear-gradient(135deg, rgba(118,57,255,.28), rgba(61,137,255,.18)),
    rgba(255,255,255,.04);
  border: 1px solid rgba(156,119,255,.32);
  color: #fff;
  box-shadow: 0 12px 28px rgba(61, 79, 180, .18);
}
.lpp-video-gallery-stage h3 {
  font-size: clamp(2.35rem, 5vw, 4.7rem);
  line-height: .95;
  letter-spacing: -.06em;
  max-width: min(100%, 12ch);
  overflow-wrap: anywhere;
}
.lpp-video-gallery-stage p {
  max-width: min(100%, 52ch);
  font-size: clamp(1rem, 1.4vw, 1.08rem);
  color: rgba(236,242,255,.78);
}
.lpp-video-gallery-stage-actions {
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  gap: 14px;
  padding-top: 6px;
}
.lpp-video-gallery-stage-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 52px;
  padding: 14px 26px;
  border-radius: 999px;
  border: 1px solid rgba(255,255,255,.16);
  color: #fff;
  font-size: .92rem;
  font-weight: 700;
  letter-spacing: .01em;
  text-decoration: none;
  transition: transform .3s ease, box-shadow .3s ease, border-color .3s ease, background-color .3s ease;
}
.lpp-video-gallery-stage-btn:hover {
  transform: translateY(-2px);
}
.lpp-video-gallery-stage-btn.is-primary {
  background: linear-gradient(135deg, #7c33ff, #3a7bff);
  border-color: transparent;
  box-shadow: 0 18px 32px rgba(76, 70, 214, .3);
}
.lpp-video-gallery-stage-btn.is-secondary {
  background: rgba(255,255,255,.03);
  box-shadow: inset 0 1px 0 rgba(255,255,255,.05);
}
.lpp-video-gallery-stage-btn.is-secondary:hover {
  border-color: rgba(255,255,255,.28);
  background: rgba(255,255,255,.07);
}
.lpp-video-gallery-stage-btn[hidden] {
  display: none;
}
.lpp-video-gallery-stage-visual {
  position: relative;
  display: flex;
  align-items: flex-end;
  justify-content: flex-end;
  min-height: clamp(340px, 42vw, 520px);
  padding: clamp(18px, 2vw, 24px);
  overflow: hidden;
  border-radius: 30px;
  border: 1px solid rgba(255,255,255,.1);
  background-color: rgba(4,9,19,.72);
  background-position: center;
  background-size: cover;
  box-shadow:
    inset 0 1px 0 rgba(255,255,255,.07),
    0 28px 56px rgba(2, 8, 20, .28);
  width: 100%;
  min-width: 0;
  max-width: 100%;
}
.lpp-video-gallery-stage-visual::before {
  content: "";
  position: absolute;
  inset: 0;
  background:
    linear-gradient(90deg, rgba(6,12,24,.2) 8%, rgba(6,12,24,.58) 55%, rgba(6,12,24,.8) 100%),
    linear-gradient(180deg, rgba(6,12,24,.08), rgba(6,12,24,.54) 100%);
}
.lpp-video-gallery-stage-visual::after {
  content: "";
  position: absolute;
  inset: auto auto -18% -8%;
  width: 46%;
  aspect-ratio: 1;
  border-radius: 50%;
  background: radial-gradient(circle, rgba(124,51,255,.18), transparent 72%);
  pointer-events: none;
}
.lpp-video-gallery-stage-visual .lpp-video-stage-player {
  position: relative;
  z-index: 1;
  width: 100%;
  max-width: 520px;
  margin-left: auto;
  border-radius: 24px;
  border: 1px solid rgba(255,255,255,.14);
  background:
    linear-gradient(145deg, rgba(8,18,38,.72), rgba(10,22,45,.42)),
    rgba(3,10,20,.7);
  box-shadow:
    0 26px 54px rgba(2, 8, 20, .38),
    inset 0 1px 0 rgba(255,255,255,.06);
  backdrop-filter: blur(14px);
}
.lpp-video-gallery-stage .lpp-video-stage-play {
  right: 16px;
  bottom: 16px;
  width: 58px;
  height: 58px;
}
.lpp-video-gallery-stage .lpp-video-stage-play::before {
  left: 25px;
  top: 19px;
  border-width: 10px 0 10px 16px;
}
.lpp-video-gallery-rail-head {
  position: relative;
  z-index: 1;
  margin-top: 2px;
}
.lpp-video-gallery-rail-meta {
  color: rgba(233,238,255,.58);
  font-size: .76rem;
  letter-spacing: .04em;
  text-transform: uppercase;
}
.lpp-video-gallery-grid {
  position: relative;
  z-index: 1;
  display: flex;
  gap: 18px;
  overflow-x: auto;
  overflow-y: hidden;
  padding: 4px 2px 10px;
  scrollbar-width: thin;
  scroll-snap-type: x proximity;
  width: 100%;
  max-width: 100%;
  min-width: 0;
}
.lpp-video-gallery-card {
  position: relative;
  display: block;
  flex: 0 0 calc((100% - ((var(--lpp-video-gallery-columns, 3) - 1) * 18px)) / var(--lpp-video-gallery-columns, 3));
  width: calc((100% - ((var(--lpp-video-gallery-columns, 3) - 1) * 18px)) / var(--lpp-video-gallery-columns, 3));
  min-width: 158px;
  max-width: 100%;
  padding: 0;
  border: 0;
  background: transparent;
  box-shadow: none;
  overflow: visible;
  scroll-snap-align: start;
}
.lpp-video-gallery-card:hover,
.lpp-video-gallery-card.is-active {
  background: transparent;
  box-shadow: none;
}
.lpp-video-gallery-card:hover {
  transform: translateY(-6px) scale(1.01);
}
.lpp-video-gallery-card.is-active {
  transform: translateY(-4px);
}
.lpp-video-gallery-poster {
  position: relative;
  min-height: 250px;
  border-radius: 22px;
  border: 1px solid rgba(255,255,255,.08);
  background: rgba(5,10,20,.54);
  box-shadow:
    0 22px 44px rgba(2, 8, 20, .28),
    inset 0 1px 0 rgba(255,255,255,.04);
}
.lpp-video-gallery-card.is-active .lpp-video-gallery-poster {
  border-color: rgba(124,51,255,.44);
  box-shadow:
    0 24px 50px rgba(2, 8, 20, .36),
    0 0 0 1px rgba(124,51,255,.22);
}
.lpp-video-gallery-poster img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  filter: saturate(1.08);
}
.lpp-video-gallery-poster::after {
  inset: auto auto 12px 12px;
  width: 42px;
  height: 42px;
  background:
    radial-gradient(circle at 30% 30%, rgba(255,255,255,.3), transparent 55%),
    linear-gradient(135deg, #7c33ff, #3a7bff);
  box-shadow: 0 14px 28px rgba(32, 24, 110, .3);
}
.lpp-video-gallery-poster::before {
  left: 28px;
  bottom: 23px;
  border-width: 7px 0 7px 12px;
}
.lpp-video-gallery-card-badge {
  position: absolute;
  top: 12px;
  left: 12px;
  z-index: 1;
  display: inline-flex;
  align-items: center;
  min-height: 28px;
  padding: 6px 10px;
  border-radius: 999px;
  background: rgba(4,10,20,.56);
  border: 1px solid rgba(255,255,255,.14);
  color: rgba(255,255,255,.9);
  font-size: .66rem;
  font-weight: 700;
  letter-spacing: .08em;
  text-transform: uppercase;
  backdrop-filter: blur(10px);
}
.lpp-video-gallery-card-copy {
  position: absolute;
  inset: auto 0 0;
  display: flex;
  flex-direction: column;
  gap: 4px;
  padding: 52px 16px 16px;
  background: linear-gradient(180deg, rgba(3,8,18,0), rgba(3,8,18,.96) 62%);
}
.lpp-video-gallery-card-copy strong {
  font-size: .94rem;
  line-height: 1.3;
  color: #fff;
}
.lpp-video-gallery-card-copy small {
  font-size: .72rem;
  line-height: 1.4;
  color: rgba(236,242,255,.64);
}
.lpp-video-popup-wrap {
  position: relative;
}
.lpp-video-popup-thumb-shell {
  position: relative;
  overflow: hidden;
  border-radius: 28px;
  background:
    linear-gradient(145deg, rgba(8,18,38,.92), rgba(10,22,45,.58)),
    radial-gradient(circle at 18% 18%, rgba(79,195,247,.16), transparent 30%);
  border: 1px solid rgba(255,255,255,.1);
  box-shadow: 0 28px 62px rgba(3,11,24,.22), inset 0 1px 0 rgba(255,255,255,.06);
}
.lpp-video-popup-trigger {
  position: relative;
  display: grid;
  width: 100%;
  padding: 0;
  text-align: left;
  border: 0;
  background: transparent;
  color: inherit;
  cursor: pointer;
  overflow: hidden;
}
.lpp-video-popup-trigger:hover .lpp-video-popup-thumb img {
  transform: scale(1.04);
}
.lpp-video-popup-thumb {
  position: relative;
  display: block;
  min-height: 420px;
  overflow: hidden;
}
.lpp-video-popup-thumb img {
  width: 100%;
  height: 100%;
  display: block;
  object-fit: cover;
  transition: transform .45s ease;
}
.lpp-video-popup-overlay {
  position: absolute;
  inset: 0;
  background:
    linear-gradient(180deg, rgba(4,9,16,.14), rgba(4,9,16,.84)),
    radial-gradient(circle at 18% 18%, rgba(79,195,247,.2), transparent 30%),
    radial-gradient(circle at 82% 20%, rgba(225,184,102,.18), transparent 24%);
}
.lpp-video-popup-copy {
  position: absolute;
  left: clamp(20px, 4vw, 42px);
  right: clamp(20px, 4vw, 42px);
  bottom: clamp(22px, 4vw, 42px);
  z-index: 1;
  display: flex;
  flex-direction: column;
  gap: 10px;
  max-width: min(100%, 640px);
}
.lpp-video-popup-copy h3 {
  margin: 0;
  color: #fff;
  font-size: clamp(1.7rem, 4vw, 3.3rem);
  line-height: 1.02;
  letter-spacing: -.04em;
  overflow-wrap: anywhere;
}
.lpp-video-popup-copy p {
  margin: 0;
  color: rgba(236,242,255,.8);
  line-height: 1.7;
  overflow-wrap: anywhere;
}
.lpp-video-popup-action {
  position: absolute;
  left: clamp(20px, 4vw, 42px);
  top: clamp(20px, 4vw, 42px);
  z-index: 1;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 12px;
  min-height: 58px;
  padding: 14px 24px;
  border-radius: 999px;
  background: linear-gradient(135deg, #0f3e81, #e1b866);
  color: #fff;
  border: 1px solid rgba(255,255,255,.14);
  box-shadow: 0 18px 36px rgba(3,11,24,.28);
  transition: transform .28s ease, box-shadow .28s ease, background-color .28s ease;
}
.lpp-video-popup-trigger:hover .lpp-video-popup-action {
  transform: translateY(-2px);
  box-shadow: 0 22px 42px rgba(3,11,24,.34);
}
.lpp-video-popup-trigger-circle .lpp-video-popup-action {
  width: 72px;
  min-width: 72px;
  height: 72px;
  padding: 0;
  border-radius: 50%;
}
.lpp-video-popup-trigger-circle .lpp-video-popup-label {
  display: none;
}
.lpp-video-popup-trigger-outline .lpp-video-popup-action {
  background: rgba(4,10,20,.18);
  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);
}
.lpp-video-popup-icon {
  position: relative;
  width: 18px;
  height: 18px;
  flex-shrink: 0;
}
.lpp-video-popup-icon::before {
  content: "";
  position: absolute;
  left: 3px;
  top: 0;
  border-style: solid;
  border-width: 9px 0 9px 14px;
  border-color: transparent transparent transparent currentColor;
}
.lpp-video-popup-label {
  font-size: .96rem;
  font-weight: 700;
  line-height: 1;
}
.lpp-video-popup-modal {
  position: fixed;
  inset: 0;
  z-index: 100000;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 20px;
}
.lpp-video-popup-modal[hidden] {
  display: none !important;
}
.lpp-video-popup-backdrop {
  position: absolute;
  inset: 0;
  background: rgba(2,6,12,.88);
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
}
.lpp-video-popup-dialog {
  position: relative;
  z-index: 1;
  width: min(100%, 980px);
  border-radius: 26px;
  background:
    linear-gradient(140deg, rgba(8,18,38,.94), rgba(7,14,29,.84)),
    radial-gradient(circle at 18% 18%, rgba(79,195,247,.12), transparent 28%);
  border: 1px solid rgba(255,255,255,.08);
  box-shadow: 0 30px 70px rgba(3,11,24,.34);
  padding: 24px;
}
.lpp-video-popup-frame-wrap {
  position: relative;
  overflow: hidden;
  border-radius: 18px;
  aspect-ratio: 16 / 9;
  background: #000;
}
.lpp-video-popup-frame-wrap iframe,
.lpp-video-popup-frame-wrap video {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  border: 0;
}
.lpp-video-popup-close {
  position: absolute;
  top: 14px;
  right: 14px;
  z-index: 2;
  width: 44px;
  height: 44px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border: 0;
  border-radius: 50%;
  background: rgba(255,255,255,.1);
  color: #fff;
  cursor: pointer;
  transition: transform .24s ease, background-color .24s ease;
}
.lpp-video-popup-close:hover {
  transform: scale(1.04);
  background: rgba(255,255,255,.18);
}
.lpp-video-popup-close span,
.lpp-video-popup-close span::before {
  position: absolute;
  width: 18px;
  height: 2px;
  background: currentColor;
  border-radius: 999px;
  content: "";
}
.lpp-video-popup-close span {
  transform: rotate(45deg);
}
.lpp-video-popup-close span::before {
  transform: rotate(90deg);
}
.lpp-lottie {
  width: 100%;
  min-height: 240px;
}
.lpp-code-header {
  display: flex;
  align-items: center;
  gap: 12px;
  flex-wrap: wrap;
  margin-bottom: 16px;
}
.lpp-code-header strong {
  margin-right: auto;
}
.lpp-code-card pre {
  margin: 0;
  padding: 22px;
  border-radius: 20px;
  background-color: rgba(4,12,24,.6);
  border: 1px solid rgba(255,255,255,.08);
  color: #e9f1ff;
  overflow: auto;
}
.lpp-animated-headline {
  display: flex;
  flex-wrap: wrap;
  gap: 12px;
  align-items: center;
  font-size: clamp(2.2rem, 5vw, 4.6rem);
  line-height: 1;
  color: #fff;
  letter-spacing: -.05em;
}
.lpp-animated-word {
  color: #9ed9ff;
  transition: opacity .18s ease, transform .18s ease;
}
.lpp-animated-word.is-switching {
  opacity: .2;
  transform: translateY(6px);
}
.lpp-price-list {
  display: flex;
  flex-direction: column;
  gap: 16px;
}
.lpp-price-item {
  position: relative;
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 18px;
  padding: 18px 0;
  border-bottom: 1px solid rgba(255,255,255,.08);
}
.lpp-price-item:last-child {
  border-bottom: 0;
  padding-bottom: 0;
}
.lpp-price-item span:last-child {
  font-size: 1.35rem;
  font-weight: 800;
  color: #fff;
}
.lpp-flip-box {
  perspective: 1200px;
}
.lpp-flip-box-inner {
  position: relative;
  min-height: 340px;
  transform-style: preserve-3d;
  transition: transform .7s cubic-bezier(.22, 1, .36, 1);
}
.lpp-flip-box:hover .lpp-flip-box-inner {
  transform: rotateY(180deg);
}
.lpp-flip-side {
  position: absolute;
  inset: 0;
  display: flex;
  flex-direction: column;
  justify-content: center;
  gap: 14px;
  padding: 28px;
  border-radius: 24px;
  backface-visibility: hidden;
  background-color: rgba(8,18,38,.86);
  border: 1px solid rgba(255,255,255,.1);
  color: #fff;
}
.lpp-flip-back {
  transform: rotateY(180deg);
  background-color: rgba(14,30,58,.9);
}
.lpp-review-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 20px;
}
.lpp-review-card {
  display: flex;
  flex-direction: column;
  gap: 14px;
}
.lpp-review-stars {
  color: #f4c24e;
  font-size: 1.1rem;
  letter-spacing: .16em;
}
.lpp-toc {
  display: flex;
  flex-direction: column;
  gap: 16px;
}
.lpp-toc-list {
  display: flex;
  flex-direction: column;
  gap: 10px;
  margin: 0;
  padding: 0;
  list-style: none;
}
.lpp-toc-list a {
  color: rgba(240,244,255,.82);
  text-decoration: none;
  transition: color .25s ease, transform .25s ease;
}
.lpp-toc-list a:hover {
  transform: translateX(4px);
}
.lpp-toc-level-h3 { padding-left: 16px; }
.lpp-toc-level-h4 { padding-left: 30px; }
.lpp-countdown {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 18px;
}
.lpp-countdown-item {
  position: relative;
  overflow: hidden;
  padding: 22px;
  border-radius: 22px;
  text-align: center;
  background-color: rgba(8,18,38,.84);
  border: 1px solid rgba(255,255,255,.1);
}
.lpp-countdown-item::before {
  content: "";
  position: absolute;
  inset: auto auto -30% -12%;
  width: 44%;
  aspect-ratio: 1;
  border-radius: 50%;
  background: radial-gradient(circle, rgba(79,195,247,.18), transparent 72%);
  filter: blur(12px);
  pointer-events: none;
}
.lpp-countdown-item strong {
  display: block;
  font-size: clamp(2rem, 4vw, 3.4rem);
  line-height: 1;
  color: #fff;
}
.lpp-countdown-item span {
  display: block;
  margin-top: 8px;
  color: rgba(240,244,255,.58);
  font-size: .8rem;
  text-transform: uppercase;
  letter-spacing: .08em;
}
.lpp-countdown-expired {
  padding: 24px;
  border-radius: 18px;
  background: rgba(225,184,102,.16);
  color: #fff2d8;
  text-align: center;
  font-weight: 700;
}
.lpp-blockquote p {
  font-size: clamp(1.5rem, 2.4vw, 2.3rem);
  line-height: 1.35;
}
.lpp-blockquote footer {
  display: flex;
  flex-direction: column;
  gap: 6px;
  margin-top: 20px;
}
.lpp-blockquote footer strong {
  color: #fff;
}
.lpp-progress-tracker {
  display: flex;
  flex-direction: column;
  gap: 18px;
}
.lpp-progress-tracker-horizontal {
  flex-direction: row;
  flex-wrap: wrap;
}
.lpp-progress-step {
  position: relative;
  overflow: hidden;
  display: flex;
  align-items: flex-start;
  gap: 16px;
  padding: 18px 20px;
  border-radius: 20px;
  background-color: rgba(8,18,38,.78);
  border: 1px solid rgba(255,255,255,.08);
  transition: transform .3s ease, border-color .3s ease, box-shadow .3s ease;
}
.lpp-progress-step::before {
  content: "";
  position: absolute;
  inset: auto -8% -34% auto;
  width: 34%;
  aspect-ratio: 1;
  border-radius: 50%;
  background: radial-gradient(circle, rgba(225,184,102,.16), transparent 72%);
  filter: blur(14px);
  pointer-events: none;
}
.lpp-progress-step:hover {
  transform: translateY(-2px);
  border-color: rgba(255,255,255,.16);
  box-shadow: 0 20px 42px rgba(3, 11, 24, .18);
}
.lpp-progress-step-index {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 46px;
  height: 46px;
  border-radius: 16px;
  background: rgba(255,255,255,.08);
  color: #fff;
  font-weight: 800;
}
.lpp-progress-step.is-done .lpp-progress-step-index,
.lpp-progress-step.is-current .lpp-progress-step-index {
  background-color: #0f3e81;
}
.lpp-progress-step.is-current {
  border-color: rgba(79,195,247,.28);
  box-shadow: 0 22px 44px rgba(3, 11, 24, .2), 0 0 0 1px rgba(79,195,247,.1);
}
.lpp-progress-step.is-done {
  border-color: rgba(225,184,102,.24);
}
.lpp-bio-card {
  text-align: center;
}
.lpp-bio-avatar {
  width: 112px;
  height: 112px;
  margin: 0 auto 18px;
  border-radius: 28px;
  border: 1px solid rgba(255,255,255,.12);
}
.lpp-bio-links {
  display: flex;
  flex-direction: column;
  gap: 12px;
  margin-top: 22px;
}
.lpp-bio-link {
  flex-direction: column;
  align-items: flex-start;
  text-align: left;
  border-radius: 20px;
  min-height: 0;
}
.lpp-dynamic-title,
.lpp-site-mark,
.lpp-menu a,
.lpp-comment-item strong,
.lpp-breadcrumbs a,
.lpp-breadcrumbs span {
  color: #fff;
  text-decoration: none;
}
.lpp-menu {
  display: flex;
  gap: 14px;
  padding: 0;
  margin: 0;
  list-style: none;
}
.lpp-menu-column,
.lpp-menu-classic {
  flex-direction: column;
}
.lpp-menu li {
  list-style: none;
}
.lpp-menu a {
  display: inline-flex;
  align-items: center;
  min-height: 46px;
  padding: 10px 16px;
  border-radius: 16px;
  background-color: rgba(10,20,39,.68);
  border: 1px solid rgba(255,255,255,.08);
}
.lpp-sitemap-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 24px;
}
.lpp-sitemap-grid ul {
  display: flex;
  flex-direction: column;
  gap: 10px;
  margin: 14px 0 0;
  padding-left: 18px;
}
.lpp-prose > *:first-child { margin-top: 0; }
.lpp-prose > *:last-child { margin-bottom: 0; }
.lpp-author-box {
  display: grid;
  grid-template-columns: auto 1fr;
  gap: 20px;
  align-items: center;
}
.lpp-author-box img {
  border-radius: 22px;
}
.lpp-comment-list {
  display: flex;
  flex-direction: column;
  gap: 14px;
  margin: 18px 0 0;
  padding: 0;
  list-style: none;
}
.lpp-comment-item {
  padding: 18px;
  border-radius: 18px;
  background: rgba(4,12,24,.26);
  border: 1px solid rgba(255,255,255,.08);
}
.lpp-comment-form {
  margin-top: 20px;
}
.lpp-comment-form input,
.lpp-comment-form textarea {
  width: 100%;
  padding: 14px 16px;
  border-radius: 16px;
  border: 1px solid rgba(255,255,255,.12);
  background-color: rgba(4,12,24,.42);
  color: #fff;
}
.lpp-comment-form input[type="submit"] {
  width: auto;
  min-width: 180px;
  background-color: #1b73e8;
  border-radius: 999px;
  border: 0;
  font-weight: 800;
}
.lpp-post-nav {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 18px;
}
.lpp-post-nav-link {
  display: flex;
  flex-direction: column;
  gap: 8px;
  text-decoration: none;
}
.lpp-post-nav-link span {
  color: rgba(240,244,255,.52);
  font-size: .8rem;
  text-transform: uppercase;
  letter-spacing: .08em;
}
.lpp-post-meta-card {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
}
.lpp-search-form {
  display: flex;
  gap: 12px;
}
.lpp-sidebar-area {
  --lpp-sidebar-gap: 18px;
  display: flex;
  flex-direction: column;
  gap: var(--lpp-sidebar-gap);
}
.lpp-sidebar-area .widget,
.lpp-sidebar-area .wp-block-group,
.lpp-sidebar-area .wp-block-search,
.lpp-sidebar-area .wp-block-latest-posts,
.lpp-sidebar-area .wp-block-categories,
.lpp-sidebar-area .wp-block-archives {
  position: relative;
  overflow: hidden;
  padding: 22px;
  border-radius: 24px;
  background:
    linear-gradient(145deg, rgba(8,18,38,.84), rgba(10,22,45,.46)),
    linear-gradient(135deg, rgba(79,195,247,.08), transparent 44%);
  border: 1px solid rgba(255,255,255,.08);
  box-shadow: 0 22px 46px rgba(3, 11, 24, .18), inset 0 1px 0 rgba(255,255,255,.06);
  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);
}
.lpp-sidebar-area .widget > :first-child,
.lpp-sidebar-area .wp-block-group > :first-child {
  margin-top: 0;
}
.lpp-sidebar-area .widget > :last-child,
.lpp-sidebar-area .wp-block-group > :last-child {
  margin-bottom: 0;
}
.lpp-sidebar-area .widget-title,
.lpp-sidebar-area .wp-block-heading,
.lpp-sidebar-area h1,
.lpp-sidebar-area h2,
.lpp-sidebar-area h3,
.lpp-sidebar-area h4 {
  margin: 0 0 14px;
  color: #fff;
  font-weight: 800;
  letter-spacing: -.02em;
}
.lpp-sidebar-area p,
.lpp-sidebar-area li,
.lpp-sidebar-area span,
.lpp-sidebar-area label {
  color: rgba(236,242,255,.74);
  line-height: 1.7;
}
.lpp-sidebar-area ul,
.lpp-sidebar-area ol {
  display: flex;
  flex-direction: column;
  gap: 12px;
  margin: 14px 0 0;
  padding-left: 18px;
}
.lpp-sidebar-area a {
  text-decoration: none;
  transition: color .25s ease, transform .25s ease;
}
.lpp-sidebar-area a:hover {
  transform: translateX(4px);
}
.lpp-sidebar-area input,
.lpp-sidebar-area select,
.lpp-sidebar-area textarea {
  width: 100%;
}
.lpp-sidebar-area .wp-block-search__inside-wrapper,
.lpp-sidebar-area .search-form,
.lpp-sidebar-area form {
  display: flex;
  gap: 10px;
  flex-wrap: wrap;
}
.lpp-sidebar-area button,
.lpp-sidebar-area input[type="submit"],
.lpp-sidebar-area .wp-block-search__button {
  cursor: pointer;
}
.lpp-breadcrumbs {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 10px;
}
.lpp-breadcrumb-separator {
  color: rgba(240,244,255,.42);
}

@media ( max-width: 1024px ) {
  .lpp-grid-cols-4 { grid-template-columns: repeat(2, minmax(0, 1fr)); }
  .lpp-grid-cols-3 { grid-template-columns: repeat(2, minmax(0, 1fr)); }
  .lpp-review-grid,
  .lpp-countdown,
  .lpp-video-playlist,
  .lpp-video-gallery-stage,
  .lpp-media-slide,
  .lpp-sitemap-grid,
  .lpp-post-nav {
    grid-template-columns: 1fr;
  }
  .lpp-video-list {
    max-height: none;
    overflow: visible;
    padding-right: 8px;
  }
  .lpp-video-gallery-feature {
    grid-template-columns: 1fr;
  }
  .lpp-video-gallery-stage-visual {
    min-height: clamp(300px, 56vw, 440px);
  }
  .lpp-video-gallery-stage-visual .lpp-video-stage-player {
    width: 100%;
    max-width: 100%;
  }
}
@media ( max-width: 767px ) {
  .lpp-form-grid,
  .lpp-grid-cols-2,
  .lpp-grid-cols-3,
  .lpp-grid-cols-4 {
    grid-template-columns: 1fr;
  }
  .lpp-post-card-featured {
    grid-column: auto;
  }
  .lpp-share-buttons,
  .lpp-filter-nav,
  .lpp-menu {
    flex-direction: column;
    align-items: stretch;
  }
  .lpp-countdown {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
  .lpp-author-box {
    grid-template-columns: 1fr;
    text-align: center;
  }
  .lpp-search-form {
    flex-direction: column;
  }
  .lpp-sidebar-area .wp-block-search__inside-wrapper,
  .lpp-sidebar-area .search-form,
  .lpp-sidebar-area form {
    flex-direction: column;
  }
  .lpp-album-stack,
  .lpp-video-gallery-poster {
    min-height: 220px;
  }
  .lpp-video-stage,
  .lpp-video-gallery-stage {
    padding: 16px;
    gap: 18px;
  }
  .lpp-video-gallery-topbar {
    align-items: flex-start;
  }
  .lpp-video-gallery-topbar-nav {
    gap: 8px 12px;
  }
  .lpp-video-gallery-topbar-label,
  .lpp-video-gallery-topbar-item {
    font-size: .64rem;
    letter-spacing: .1em;
  }
  .lpp-video-gallery-stage-shell {
    gap: 20px;
  }
  .lpp-video-gallery-stage-visual {
    order: -1;
    min-height: clamp(250px, 70vw, 360px);
    padding: 12px;
  }
  .lpp-video-gallery-stage-copy {
    padding: 0;
  }
  .lpp-video-gallery-stage h3 {
    max-width: 100%;
    font-size: clamp(1.8rem, 10vw, 2.9rem);
  }
  .lpp-video-gallery-stage p {
    max-width: 100%;
    font-size: .95rem;
  }
  .lpp-video-gallery-stage-actions {
    gap: 10px;
  }
  .lpp-video-gallery-stage-btn {
    flex: 1 1 100%;
    min-height: 48px;
    padding: 12px 18px;
    font-size: .88rem;
  }
  .lpp-video-stage-player,
  .lpp-video-gallery-stage .lpp-video-stage-player {
    min-height: clamp(240px, 64vw, 340px);
    aspect-ratio: 16 / 10;
  }
  .lpp-video-gallery-grid.lpp-video-gallery-mobile-cols-1 {
    display: flex;
  }
  .lpp-video-gallery-grid.lpp-video-gallery-mobile-cols-2 {
    display: flex;
  }
  .lpp-video-gallery-grid.lpp-video-gallery-mobile-cols-3 {
    display: flex;
  }
  .lpp-video-gallery-card {
    padding: 0;
    gap: 0;
  }
  .lpp-video-gallery-grid.lpp-video-gallery-mobile-cols-1 .lpp-video-gallery-card {
    flex-basis: 82%;
    width: 82%;
  }
  .lpp-video-gallery-grid.lpp-video-gallery-mobile-cols-2 .lpp-video-gallery-card {
    flex-basis: calc((100% - 12px) / 2);
    width: calc((100% - 12px) / 2);
  }
  .lpp-video-gallery-grid.lpp-video-gallery-mobile-cols-3 .lpp-video-gallery-card {
    flex-basis: calc((100% - 24px) / 3);
    width: calc((100% - 24px) / 3);
    min-width: 132px;
  }
  .lpp-video-gallery-card-copy {
    gap: 5px;
    padding: 44px 12px 12px;
  }
  .lpp-video-gallery-card-copy strong {
    font-size: .82rem;
    line-height: 1.35;
  }
  .lpp-video-gallery-card-copy small {
    display: block;
    font-size: .68rem;
  }
  .lpp-video-popup-thumb {
    min-height: 320px;
  }
  .lpp-video-popup-copy {
    left: 18px;
    right: 18px;
    bottom: 18px;
    max-width: none;
  }
  .lpp-video-popup-copy h3 {
    font-size: clamp(1.4rem, 8vw, 2.3rem);
  }
  .lpp-video-popup-action {
    left: 18px;
    top: 18px;
    min-height: 50px;
    padding: 12px 18px;
  }
  .lpp-video-popup-trigger-circle .lpp-video-popup-action {
    width: 58px;
    min-width: 58px;
    height: 58px;
  }
  .lpp-video-popup-dialog {
    padding: 14px;
    border-radius: 20px;
  }
  .lpp-video-list-item {
    grid-template-columns: 1fr;
    gap: 10px;
    padding: 10px;
    align-content: start;
    min-width: 0;
    scroll-snap-align: start;
  }
  .lpp-video-list-thumb,
  .lpp-video-copy,
  .lpp-video-index {
    grid-column: auto;
  }
  .lpp-video-list-thumb {
    min-height: 88px;
  }
  .lpp-video-list {
    display: grid;
    grid-auto-flow: column;
    grid-auto-columns: minmax(140px, calc((100% - 24px) / 3));
    gap: 12px;
    overflow-x: auto;
    overflow-y: hidden;
    padding: 6px 2px 10px;
    scrollbar-width: thin;
    scroll-snap-type: x proximity;
  }
  .lpp-video-copy {
    gap: 4px;
  }
  .lpp-video-copy strong {
    font-size: .88rem;
  }
  .lpp-video-copy .lpp-widget-chip {
    font-size: .66rem;
    padding: 5px 10px;
  }
  .lpp-video-index {
    width: 28px;
    height: 28px;
    border-radius: 10px;
    font-size: .72rem;
  }
  .lpp-video-stage-play {
    width: 60px;
    height: 60px;
  }
  .lpp-video-stage-play::before {
    left: 26px;
    top: 20px;
    border-width: 10px 0 10px 16px;
  }
  .lpp-video-stage-head,
  .lpp-video-stage-meta,
  .lpp-video-card-meta {
    justify-content: flex-start;
  }
  .lpp-video-card-meta {
    gap: 4px 8px;
  }
  .lpp-carousel-shell .swiper-pagination,
  .lpp-media-carousel-shell .swiper-pagination {
    margin-top: 14px;
  }
  .lpp-carousel-shell.lpp-carousel-pagination-inside-bottom .swiper-pagination,
  .lpp-carousel-shell.lpp-carousel-pagination-inside-top .swiper-pagination,
  .lpp-media-carousel-shell.lpp-carousel-pagination-inside-bottom .swiper-pagination,
  .lpp-media-carousel-shell.lpp-carousel-pagination-inside-top .swiper-pagination {
    left: 10px;
    right: 10px;
  }
}
