[x-cloak] {
  display: none !important;
}

/* Travel package content spacing */
.travel-package-content > * + * {
  margin-top: 1rem;
}

.travel-package-content h2,
.travel-package-content h3,
.travel-package-content h4 {
  margin-top: 1.75rem;
  margin-bottom: 0.75rem;
  font-family: "Outfit", sans-serif;
  font-weight: 700;
  line-height: 1.2;
  color: #111111;
}

.travel-package-content h2 {
  font-size: clamp(1.5rem, 3vw, 2rem);
}

.travel-package-content h3 {
  font-size: clamp(1.25rem, 2.4vw, 1.5rem);
}

.travel-package-content h4 {
  font-size: 1.125rem;
}

.travel-package-content p {
  margin-top: 0.75rem;
  margin-bottom: 0.75rem;
  line-height: 1.8;
}

.travel-package-content ul,
.travel-package-content ol {
  margin-top: 0.75rem;
  margin-bottom: 1.5rem;
  padding-left: 1.4rem;
}

.travel-package-content li {
  margin-top: 0.45rem;
  line-height: 1.75;
}

.travel-package-content ul li {
  list-style: disc;
}

.travel-package-content figure {
  margin-top: 0;
  margin-bottom: 1.75rem;
}

.travel-package-content figcaption {
  margin-top: 0.75rem;
  color: #4b5563;
  font-size: 0.95rem;
}

.travel-package-content img {
  border-radius: 1.25rem;
}

html.mobile-menu-open,
body.mobile-menu-open {
  overflow: hidden;
  overscroll-behavior: none;
}

body.mobile-menu-open {
  position: fixed;
  inset: 0;
  width: 100%;
}

.mobile-menu-panel {
  max-height: calc(100vh - 7.5rem);
  padding-bottom: max(5rem, calc(1.25rem + env(safe-area-inset-bottom, 0px)));
  overflow-y: auto;
  overscroll-behavior: contain;
  -webkit-overflow-scrolling: touch;
  scroll-padding-bottom: max(5rem, calc(1.25rem + env(safe-area-inset-bottom, 0px)));
}

@supports (height: 100svh) {
  .mobile-menu-panel {
    max-height: calc(100svh - 7.5rem);
  }
}

@supports (height: 100dvh) {
  .mobile-menu-panel {
    max-height: calc(100dvh - 7.5rem);
  }
}

/* WhatsApp FAB */
.wa-fab-wrap {
  position: fixed;
  bottom: max(1.5rem, env(safe-area-inset-bottom, 1.5rem));
  right: max(1.5rem, env(safe-area-inset-right, 1.5rem));
  z-index: 90;
  transition:
    opacity 0.2s ease,
    visibility 0.2s ease,
    transform 0.2s ease;
}

body.mobile-menu-open .wa-fab-wrap {
  opacity: 0;
  visibility: hidden;
  pointer-events: none;
  transform: translateY(0.5rem);
}

.wa-fab {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 3.5rem;
  height: 3.5rem;
  padding: 0;
  border: 0;
  background-color: #25d366;
  color: white;
  border-radius: 9999px;
  box-shadow: 0 4px 12px rgba(0, 0, 0, 0.15);
  cursor: pointer;
  transition:
    transform 0.3s cubic-bezier(0.175, 0.885, 0.32, 1.275),
    box-shadow 0.3s ease;
  animation: wa-fab-appear 0.6s cubic-bezier(0.175, 0.885, 0.32, 1.275) backwards;
  animation-delay: 0.5s;
}

.wa-fab-menu {
  position: absolute;
  right: 0;
  bottom: calc(100% + 0.75rem);
  display: flex;
  flex-direction: column;
  gap: 0.5rem;
  min-width: 12rem;
}

.wa-fab-menu a {
  display: flex;
  align-items: center;
  justify-content: flex-start;
  padding: 0.75rem 1rem;
  border-radius: 0.875rem;
  background: #fff;
  color: #111;
  text-decoration: none;
  font-weight: 700;
  box-shadow: 0 8px 24px rgba(0, 0, 0, 0.14);
  transition:
    transform 0.2s ease,
    background-color 0.2s ease,
    box-shadow 0.2s ease;
}

.wa-fab-menu a:hover {
  transform: translateY(-1px);
  background-color: #f7f7f7;
  box-shadow: 0 10px 26px rgba(0, 0, 0, 0.18);
}

.wa-fab-menu a:focus-visible {
  outline: 2px solid #128c7e;
  outline-offset: 2px;
}

.wa-fab:hover {
  transform: scale(1.1);
  box-shadow: 0 6px 16px rgba(0, 0, 0, 0.2);
}

.wa-fab:focus-visible {
  outline: 2px solid #128c7e;
  outline-offset: 2px;
}

@keyframes wa-fab-appear {
  from {
    transform: scale(0) rotate(-15deg);
    opacity: 0;
  }
  to {
    transform: scale(1) rotate(0);
    opacity: 1;
  }
}

/* Navigation Force Dark */
.site-header-nav {
  border-bottom: 1px solid rgba(255, 255, 255, 0.1);
  background-color: rgba(17, 17, 17, 0.72);
  box-shadow: 0 8px 30px rgba(17, 17, 17, 0.18);
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
}

.site-header-nav.is-scrolled {
  background-color: rgba(17, 17, 17, 0.9);
  box-shadow: 0 10px 30px rgba(0, 0, 0, 0.24);
}

.nav-force-dark {
  background-color: rgba(17, 17, 17, 0.9) !important;
  backdrop-filter: blur(12px) !important;
  -webkit-backdrop-filter: blur(12px) !important;
  padding-top: 1rem !important;
  padding-bottom: 1rem !important;
  box-shadow: 0 4px 6px -1px rgba(0, 0, 0, 0.1), 0 2px 4px -1px rgba(0, 0, 0, 0.06) !important;
}

/* Zunaz Logo Animation */
.zunaz-logo-link {
  position: relative;
  border-radius: 9999px;
  transform: translateZ(0);
  transition:
    transform 0.2s ease,
    filter 0.2s ease;
}

.zunaz-logo-link:hover,
.zunaz-logo-link:focus-visible {
  transform: translateY(-1px) scale(1.02);
  filter: drop-shadow(0 0 12px rgba(255, 209, 0, 0.42));
}

.zunaz-logo-link:focus-visible {
  outline: 2px solid #ffd100;
  outline-offset: 0.35rem;
}

.zunaz-logo-img {
  display: block;
  transform: translateZ(0);
}

.zunaz-splash-intro {
  position: fixed;
  inset: 0;
  z-index: 9999;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: max(1.25rem, env(safe-area-inset-top, 0px)) max(1.25rem, env(safe-area-inset-right, 0px)) max(1.25rem, env(safe-area-inset-bottom, 0px)) max(1.25rem, env(safe-area-inset-left, 0px));
  background:
    radial-gradient(circle at center, rgba(255, 209, 0, 0.08), transparent min(34rem, 90vw)),
    #111111;
  opacity: 1;
  visibility: visible;
  pointer-events: auto;
  transition:
    opacity 0.5s ease,
    visibility 0.5s ease;
}

.zunaz-splash-intro.is-hidden {
  opacity: 0;
  visibility: hidden;
  pointer-events: none;
}

.zunaz-splash-logo {
  position: relative;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: clamp(11rem, 68vw, 26rem);
  max-width: calc(100vw - 2.5rem);
  max-height: calc(100svh - 2.5rem);
  padding: clamp(0.5rem, 2.6vw, 1rem);
  border-radius: clamp(1.25rem, 5vw, 2rem);
  overflow: hidden;
  isolation: isolate;
  animation: zunaz-splash-logo-reveal 0.9s ease-out 0.2s both;
}

.zunaz-splash-logo::before {
  content: "";
  position: absolute;
  inset: 18%;
  z-index: 0;
  border-radius: 9999px;
  background: rgba(255, 209, 0, 0.16);
  filter: blur(2rem);
  animation: zunaz-splash-gold-pulse 1.4s ease-out 0.35s both;
}

.zunaz-splash-logo::after {
  content: "";
  position: absolute;
  inset: -35%;
  z-index: 2;
  pointer-events: none;
  background: linear-gradient(
    110deg,
    transparent 30%,
    rgba(255, 209, 0, 0.08) 42%,
    rgba(255, 209, 0, 0.78) 50%,
    rgba(255, 255, 255, 0.3) 56%,
    transparent 70%
  );
  transform: translateX(-125%) rotate(8deg);
  animation: zunaz-splash-shimmer 1.05s ease-out 0.65s both;
}

.zunaz-splash-logo img {
  position: relative;
  z-index: 1;
  display: block;
  width: 100%;
  height: auto;
  max-height: min(38vh, 18rem);
  object-fit: contain;
  filter: drop-shadow(0 16px 36px rgba(0, 0, 0, 0.5));
}

@media (max-width: 480px) {
  .zunaz-splash-intro {
    padding: max(1rem, env(safe-area-inset-top, 0px)) max(1rem, env(safe-area-inset-right, 0px)) max(1rem, env(safe-area-inset-bottom, 0px)) max(1rem, env(safe-area-inset-left, 0px));
  }

  .zunaz-splash-logo {
    width: clamp(10rem, 74vw, 18rem);
  }

  .zunaz-splash-logo img {
    max-height: 28vh;
  }
}

@keyframes zunaz-splash-logo-reveal {
  from {
    opacity: 0;
    transform: translateY(10px) scale(0.96);
  }
  to {
    opacity: 1;
    transform: translateY(0) scale(1);
  }
}

@keyframes zunaz-splash-gold-pulse {
  from {
    opacity: 0;
    transform: scale(0.78);
  }
  45% {
    opacity: 1;
    transform: scale(1.08);
  }
  to {
    opacity: 0.32;
    transform: scale(1);
  }
}

@keyframes zunaz-splash-shimmer {
  from {
    opacity: 0;
    transform: translateX(-125%) rotate(8deg);
  }
  20% {
    opacity: 1;
  }
  to {
    opacity: 0;
    transform: translateX(125%) rotate(8deg);
  }
}

@media (prefers-reduced-motion: reduce) {
  .zunaz-logo-link,
  .zunaz-splash-intro,
  .zunaz-splash-logo,
  .zunaz-splash-logo::before,
  .zunaz-splash-logo::after {
    animation: none !important;
    transition: none !important;
  }

  .zunaz-logo-link:hover,
  .zunaz-logo-link:focus-visible {
    transform: none;
  }

  .zunaz-splash-logo::before,
  .zunaz-splash-logo::after {
    display: none;
  }
}

/* Glass Panels */
.glass-panel {
  background: rgba(255, 255, 255, 0.15);
  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);
  border: 1px solid rgba(255, 255, 255, 0.3);
}

.glass-dark {
  background: rgba(17, 17, 17, 0.6);
  backdrop-filter: blur(16px);
  -webkit-backdrop-filter: blur(16px);
  border: 1px solid rgba(255, 255, 255, 0.1);
}

/* Subtle Animations */
.hover-lift {
  transition:
    transform 0.3s cubic-bezier(0.4, 0, 0.2, 1),
    box-shadow 0.3s ease;
}
.hover-lift:hover {
  transform: translateY(-4px);
  box-shadow: 0 12px 40px rgba(17, 17, 17, 0.12);
}

.hover-zoom img {
  transition: transform 0.6s cubic-bezier(0.25, 0.46, 0.45, 0.94);
}
.hover-zoom:hover img {
  transform: scale(1.05);
}

.clip-swoosh {
  clip-path: polygon(0 0, 100% 0, 100% 85%, 0 100%);
}
.clip-swoosh-reverse {
  clip-path: polygon(0 15%, 100% 0, 100% 100%, 0 100%);
}

.about-story-parallax {
  --parallax-scale: 1.05;
  object-position: center 70%;
}
