/* Azmy Travels — Custom CSS (supplements Tailwind CDN) */

body { font-family: 'Inter', sans-serif; }

/* ── Navbar hover underline */
.nav-link { position: relative; }
.nav-link::after {
  content: '';
  position: absolute;
  bottom: -4px; left: 0; right: 0;
  height: 2px;
  background: #B8923A;
  transform: scaleX(0);
  transition: transform .3s ease;
}
.nav-link:hover::after,
.nav-link.active::after { transform: scaleX(1); }

/* ── Mobile nav link underline */
.mobile-nav-link { position: relative; }
.mobile-nav-link::after {
  content: '';
  position: absolute;
  bottom: -4px; left: 0;
  width: 0; height: 2px;
  background: #B8923A;
  transition: width .3s ease;
}
.mobile-nav-link:hover::after { width: 100%; }

/* ── Hero Swiper */
.hero-swiper { width: 100%; height: 100vh; min-height: 620px; }
.hero-slide  { position: relative; display: flex; align-items: center; overflow: hidden; }
.hero-slide__bg {
  position: absolute; inset: 0;
  background-size: cover; background-position: center;
  transform: scale(1.08);
  transition: transform 8s ease;
}
.swiper-slide-active .hero-slide__bg { transform: scale(1); }

/* ── Hero slide-in animations */
.slide-anim         { opacity: 0; transform: translateY(16px); transition: opacity .8s ease, transform .8s ease; }
.slide-anim--badge  { transition-delay: .2s; }
.slide-anim--title1 { transition-delay: .4s; }
.slide-anim--title2 { transition-delay: .55s; }
.slide-anim--divider {
  opacity: 0; transform: scaleX(0); transform-origin: left;
  transition: opacity .6s ease .7s, transform .6s ease .7s;
}
.slide-anim--desc { transition-delay: .75s; }
.slide-anim--cta  { transition-delay: .95s; }
.swiper-slide-active .slide-anim         { opacity: 1; transform: translateY(0); }
.swiper-slide-active .slide-anim--divider { opacity: 1; transform: scaleX(1); }

/* ── Swiper pagination bullets */
.hero-pagination { position: absolute !important; bottom: 84px !important; left: 0 !important; right: 0 !important; display: flex !important; justify-content: center !important; gap: 8px !important; z-index: 10 !important; }
.hero-pagination .swiper-pagination-bullet { width: 28px; height: 3px; border-radius: 2px; background: rgba(255,255,255,.35) !important; opacity: 1 !important; transition: all .4s; cursor: pointer; }
.hero-pagination .swiper-pagination-bullet-active { background: #B8923A !important; width: 52px; }

/* ── Service / value card top-border reveal */
.service-card,
.value-card { position: relative; overflow: hidden; }
.service-card::before,
.value-card::before {
  content: '';
  position: absolute; top: 0; left: 0; right: 0;
  height: 3px;
  background: linear-gradient(90deg, #B8923A, #1A5468);
  transform: scaleX(0);
  transition: transform .4s ease;
}
.service-card:hover::before,
.value-card:hover::before { transform: scaleX(1); }

/* ── Scroll indicator */
.scroll-line { width: 1px; height: 50px; background: linear-gradient(to bottom, rgba(255,255,255,.4), transparent); animation: scrollPulse 2s ease-in-out infinite; }
@keyframes scrollPulse { 0%,100%{opacity:1;transform:scaleY(1)} 50%{opacity:.3;transform:scaleY(.5)} }

/* ── Destination card image zoom */
.dest-card img { transition: transform .6s ease; }
.dest-card:hover img { transform: scale(1.07); }
.dest-card:first-child { grid-row: 1 / 3; }

/* ── Why-item hover slide */
.why-item { transition: box-shadow .3s, transform .3s; }
.why-item:hover { box-shadow: 0 4px 24px rgba(27,47,82,.10); transform: translateX(6px); }

/* ── Gallery masonry */
.gallery-grid { columns: 4; column-gap: 1rem; }
@media (max-width: 1024px) { .gallery-grid { columns: 3; } }
@media (max-width: 640px)  { .gallery-grid { columns: 2; } }
.gallery-item { break-inside: avoid; margin-bottom: 1rem; display: block; }
.gallery-item img { transition: transform .5s ease; }
.gallery-item:hover img { transform: scale(1.06); }
.gallery-item .gallery-overlay {
  position: absolute; inset: 0;
  background: linear-gradient(to top, rgba(13,33,55,.85) 0%, transparent 55%);
  opacity: 0; transition: opacity .35s ease;
}
.gallery-item:hover .gallery-overlay { opacity: 1; }

/* ── Lightbox */
#lightbox { display:none; position:fixed; inset:0; z-index:1300; background:rgba(0,0,0,.92); align-items:center; justify-content:center; }
#lightbox.open { display:flex; }
#lightbox img { max-width:90vw; max-height:85vh; object-fit:contain; border-radius:4px; transition:opacity .2s ease; }
#lightbox img.fading { opacity:0; }

/* ── WhatsApp pulse ring */
@keyframes wa-pulse { 0%,100%{transform:scale(1);opacity:.5} 60%{transform:scale(1.55);opacity:0} }
.wa-btn::after {
  content: '';
  position: absolute; inset: 0;
  border-radius: 9999px;
  background: #25D366;
  animation: wa-pulse 2.2s ease-out infinite;
  z-index: -1;
}

/* ── Blog post sticky sidebar */
@media (min-width: 1024px) {
  .blog-sidebar { position: sticky; top: 6rem; }
}

/* ── FAQ accordion arrow */
details summary::-webkit-details-marker { display: none; }
