@import url('https://fonts.googleapis.com/css2?family=Sora:wght@400;500;600;700;800&family=Source+Serif+4:wght@600;700&display=swap');

:root {
  --brand-primary: #0f4c5c;
  --brand-secondary: #1f7a8c;
  --brand-accent: #e07a5f;
  --brand-gold: #f2cc8f;
  --ink-dark: #1d2d35;
  --ink-muted: #5f6f76;
  --bg-soft: #f8fbfc;
  --bg-sand: #fff8ef;
  --white: #ffffff;
  --radius-md: 12px;
  --radius-lg: 20px;
  --shadow-soft: 0 12px 30px rgba(8, 40, 48, 0.1);
}

* {
  box-sizing: border-box;
}

html {
  scroll-behavior: smooth;
}

body {
  margin: 0;
  font-family: 'Sora', sans-serif;
  color: var(--ink-dark);
  background: linear-gradient(180deg, #fdfefe 0%, #f7fafb 100%);
}

h1,
h2,
h3,
h4,
h5 {
  font-family: 'Source Serif 4', serif;
  letter-spacing: 0.2px;
}

a {
  text-decoration: none;
}

.section-title {
  font-size: clamp(1.8rem, 2.5vw, 2.4rem);
  color: var(--brand-primary);
}

.section-subtitle {
  color: var(--ink-muted);
  max-width: 680px;
}

.top-strip {
  background: var(--brand-primary);
  color: var(--white);
  font-size: 0.85rem;
}

.top-strip a {
  color: var(--white);
}

.navbar {
  transition: all 0.3s ease;
}

.navbar-brand img {
  width: 170px;
  height: auto;
}

.navbar-nav .nav-link {
  color: var(--ink-dark);
  font-weight: 600;
  padding: 0.9rem 0.95rem;
}

.navbar-nav .nav-link.active,
.navbar-nav .nav-link:hover,
.dropdown-item:hover {
  color: var(--brand-secondary);
}

.dropdown-menu {
  border: 0;
  border-radius: var(--radius-md);
  box-shadow: var(--shadow-soft);
}

.scrolled {
  box-shadow: 0 8px 25px rgba(12, 54, 63, 0.18);
}

.hero-section {
  position: relative;
}

.hero-slide {
  min-height: 78vh;
  position: relative;
  background-size: cover;
  background-position: center;
}

.hero-slide::before {
  content: '';
  position: absolute;
  inset: 0;
  background: linear-gradient(100deg, rgba(10, 37, 44, 0.82) 0%, rgba(20, 98, 114, 0.42) 100%);
}

.hero-content {
  position: relative;
  z-index: 2;
  min-height: 78vh;
  display: flex;
  align-items: center;
}

.hero-content h1 {
  font-size: clamp(2rem, 4vw, 3.7rem);
  color: var(--white);
}

.hero-content p {
  color: #d6e6eb;
  max-width: 640px;
}

.btn-brand {
  background: var(--brand-accent);
  color: var(--white);
  border-radius: 999px;
  padding: 0.72rem 1.3rem;
  border: none;
  font-weight: 600;
}

.btn-brand:hover {
  background: #cf6b51;
  color: var(--white);
}

.btn-outline-brand {
  color: var(--white);
  border: 1px solid rgba(255, 255, 255, 0.8);
  border-radius: 999px;
  padding: 0.72rem 1.3rem;
  font-weight: 600;
}

.btn-outline-brand:hover {
  background: rgba(255, 255, 255, 0.15);
  color: var(--white);
}

.btn-outline-brand .bi-whatsapp {
  color: #25d366;
}

.section-pad {
  padding: 82px 0;
}

.about-card,
.info-card,
.package-card,
.destination-card,
.review-card,
.gallery-card,
.form-wrap,
.blog-card {
  border: 0;
  border-radius: var(--radius-lg);
  box-shadow: var(--shadow-soft);
  overflow: hidden;
  background: var(--white);
}

.about-highlight {
  background: linear-gradient(145deg, var(--bg-sand), #fffefc);
}

.icon-badge {
  width: 54px;
  height: 54px;
  border-radius: 14px;
  background: #e8f3f6;
  color: var(--brand-secondary);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-size: 1.3rem;
}

.package-card img,
.destination-card img,
.gallery-card img,
.blog-card img {
  height: 230px;
  object-fit: cover;
}

.package-card .btn,
.destination-card .btn,
.blog-card .btn {
  border-radius: 999px;
}

.choose-strip {
  background: linear-gradient(130deg, #0f4c5c 0%, #1f7a8c 100%);
  color: var(--white);
  position: relative;
  overflow: hidden;
}

.choose-strip::after {
  content: '';
  position: absolute;
  width: 360px;
  height: 360px;
  border-radius: 50%;
  right: -120px;
  top: -120px;
  background: rgba(255, 255, 255, 0.08);
}

.choose-item {
  position: relative;
  z-index: 1;
}

.rating-stars {
  color: #ffb703;
  letter-spacing: 2px;
}

.form-wrap {
  background: linear-gradient(180deg, #ffffff 0%, #f7fbfc 100%);
  padding: 2rem;
}

.form-control,
.form-select {
  border-radius: 10px;
  border-color: #d8e5e9;
  padding: 0.72rem 0.9rem;
}

.footer-main {
  background: #102b33;
  color: #d2dde1;
}

.footer-main h5 {
  color: var(--white);
}

.footer-main a {
  color: #d2dde1;
}

.footer-main a:hover {
  color: #ffffff;
}

.footer-bottom {
  background: #0a1a1f;
  color: #bfd3da;
}

.page-hero {
  padding: 100px 0 70px;
  background: linear-gradient(120deg, rgba(15, 76, 92, 0.96), rgba(31, 122, 140, 0.9)),
    url('https://images.unsplash.com/photo-1469474968028-56623f02e42e?auto=format&fit=crop&w=1400&q=80') center/cover;
  color: var(--white);
}

.reveal {
  opacity: 0;
  transform: translateY(24px);
  transition: opacity 0.6s ease, transform 0.6s ease;
}

.reveal.show {
  opacity: 1;
  transform: translateY(0);
}

.floating-cta {
  position: fixed;
  right: 16px;
  bottom: 16px;
  z-index: 1100;
  display: flex;
  flex-direction: column;
  gap: 10px;
}

.floating-cta__btn {
  width: 52px;
  height: 52px;
  border-radius: 50%;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  color: #ffffff;
  box-shadow: 0 10px 22px rgba(0, 0, 0, 0.2);
  transition: transform 0.2s ease, box-shadow 0.2s ease;
}

.floating-cta__btn:hover {
  transform: translateY(-2px);
  box-shadow: 0 12px 26px rgba(0, 0, 0, 0.26);
  color: #ffffff;
}

.floating-cta__btn--whatsapp {
  background: #25d366;
}

.floating-cta__btn--call {
  background: var(--brand-accent);
}

@media (max-width: 991px) {
  .hero-slide,
  .hero-content {
    min-height: 70vh;
  }

  .navbar-nav .nav-link {
    padding: 0.55rem 0;
  }
}

@media (max-width: 767px) {
  .section-pad {
    padding: 64px 0;
  }

  .hero-content h1 {
    font-size: 2rem;
  }

  .package-card img,
  .destination-card img,
  .gallery-card img,
  .blog-card img {
    height: 190px;
  }

  .floating-cta {
    right: 12px;
    bottom: 12px;
  }

  .floating-cta__btn {
    width: 48px;
    height: 48px;
  }
}
