/*********************************************
  STANDARDIZED SPACING VARIABLES
**********************************************/

:root {
  /* Card Grid Spacing - Standardized across all pages */
  --card-gap-standard: clamp(1.8rem, 4vw, 2.5rem);
  --card-gap-compact: clamp(1.5rem, 3.5vw, 2rem);
  --card-gap-small: clamp(1rem, 3vw, 1.75rem);
  
  /* Section Margins - Consistent spacing between sections */
  --section-margin-top: clamp(2rem, 4vw, 3rem);
  --section-margin-compact: clamp(1.5rem, 3vw, 2rem);
  
  /* Internal Card Spacing */
  --card-internal-gap: clamp(0.85rem, 2vw, 1.25rem);
  --card-internal-gap-small: clamp(0.65rem, 1.5vw, 1rem);
}

/*********************************************
  ABOUT US PAGE STYLES
**********************************************/

/* Hero styling */
.page-hero--about .page-hero__overlay {
  background: linear-gradient(118deg, rgba(14, 28, 26, 0.92) 12%, rgba(43, 66, 58, 0.78) 52%, rgba(204, 125, 58, 0.6) 100%);
}

.page-hero--about .page-hero__content {
  text-align: left;
}

/* Promise grid */
.promise-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
  gap: var(--card-gap-standard);
  margin-top: var(--section-margin-top);
}

.promise-card {
  background: rgba(255, 255, 255, 0.96);
  border: 1px solid rgba(139, 69, 19, 0.12);
  border-radius: 18px;
  box-shadow: 0 20px 44px rgba(12, 24, 21, 0.08);
  padding: clamp(2rem, 3vw, 2.5rem);
  display: grid;
  gap: 1rem;
}

.promise-card h3 {
  font-size: 1.1rem;
  color: var(--deep-green);
  margin: 0;
}

.promise-card p {
  margin: 0;
  line-height: 1.7;
  color: rgba(47, 79, 79, 0.85);
}

/* Offerings */
.offering-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
  gap: var(--card-gap-standard);
  margin-top: var(--section-margin-top);
}

.offering-card {
  background: rgba(255, 255, 255, 0.96);
  border: 1px solid rgba(139, 69, 19, 0.12);
  border-radius: 18px;
  box-shadow: 0 20px 44px rgba(12, 24, 21, 0.08);
  padding: clamp(1.5rem, 2.5vw, 2rem);
  display: grid;
  gap: 0.75rem;
  height: 100%;
}

.offering-card h3 {
  font-size: 1.15rem;
  color: var(--deep-green);
  margin: 0;
}

.offering-card p {
  margin: 0;
  line-height: 1.7;
  color: rgba(47, 79, 79, 0.85);
}

.offering-card__link {
  font-weight: 600;
  color: var(--burnt-orange);
  text-decoration: none;
  display: inline-flex;
  align-items: center;
  gap: 0.35rem;
  transition: color 0.25s ease, transform 0.25s ease;
}

.offering-card__link::after {
  content: "→";
  transition: transform 0.25s ease;
}

.offering-card__link:hover,
.offering-card__link:focus {
  color: var(--deep-green);
}

.offering-card__link:hover::after,
.offering-card__link:focus::after {
  transform: translateX(4px);
}

/* Responsive tweaks */
@media (max-width: 768px) {
  .page-hero--about .page-hero__content {
    text-align: center;
  }

  .section-header.section-header--left {
    text-align: center;
  }

  .section-header.section-header--left .section-heading {
    text-align: center;
  }

  .section-header.section-header--left .section-intro {
    margin-left: auto;
    margin-right: auto;
    text-align: center;
  }

  .section-header.section-header--left .section-eyebrow {
    text-align: center;
  }
}

@media (max-width: 540px) {
  .promise-grid,
  .offering-grid,
  .link-card-grid {
    grid-template-columns: 1fr;
  }
}
/*********************************************
  ARUSHA NATIONAL PARK PAGE STYLES
**********************************************/

/* HERO SECTION */
.arusha-hero {
    position: relative;
    height: 80vh;
    overflow: hidden;
  }
  .arusha-hero-image {
    width: 100%;
    height: 100%;
    object-fit: cover;
  }
  .arusha-hero-overlay {
    position: absolute;
    inset: 0;
    background: rgba(0,0,0,0.3);
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    color: #fff;
    text-align: center;
    padding: 1rem;
  }
  .arusha-hero-overlay h1 {
    font-size: 2.5rem;
    margin-bottom: 0.5rem;
  }
  .arusha-hero-overlay p {
    font-size: 1.2rem;
  }
  
  /* AT A GLANCE SECTION */
  .arusha-glance {
    padding: 2rem 5%;
    background: var(--beige);
    text-align: center;
  }
  .arusha-glance h2 {
    margin-bottom: 1rem;
    color: var(--brown);
  }
  .glance-grid {
    max-width: 700px;
    margin: 0 auto;
    display: flex;
    gap: 1.5rem;
    flex-wrap: wrap;
    justify-content: center;
  }
  .glance-item {
    flex: 1 1 200px;
    background: #fff;
    border-radius: 6px;
    box-shadow: 0 2px 5px rgba(0,0,0,0.1);
    padding: 1rem;
    text-align: center;
  }
  .glance-item strong {
    display: block;
    margin-bottom: 0.5rem;
    color: var(--brown);
  }
  
  /* INTRO SECTION */
  .arusha-intro {
    padding: 2rem 5%;
    background: #fff;
    text-align: center;
  }
  .arusha-intro h2 {
    margin-bottom: 1rem;
    color: var(--brown);
  }
  .arusha-intro p {
    max-width: 900px;
    margin: 0 auto;
    line-height: 1.8;
  }
  
  /* WHAT TO SEE SECTION */
  .arusha-what-to-see {
    padding: 2rem 5%;
    background: var(--beige);
    text-align: center;
  }
  .arusha-what-to-see h2 {
    margin-bottom: 1rem;
    color: var(--brown);
  }
  .arusha-what-to-see p {
    max-width: 900px;
    margin: 0 auto 1rem auto;
    line-height: 1.8;
    text-align: left;
  }
  
  /* ACTIVITIES SECTION */
  .arusha-activities {
    padding: 2rem 5%;
    background: #fff;
    text-align: center;
  }
  .arusha-activities h2 {
    margin-bottom: 1rem;
    color: var(--brown);
  }
  .arusha-activities p {
    max-width: 900px;
    margin: 0 auto;
    line-height: 1.8;
    text-align: left;
  }
  
  /* MOMELLA LAKES SECTION */
  .arusha-momella {
    padding: 2rem 5%;
    background: var(--beige);
    text-align: center;
  }
  .arusha-momella h2 {
    margin-bottom: 1rem;
    color: var(--brown);
  }
  .arusha-momella p {
    max-width: 900px;
    margin: 0 auto;
    line-height: 1.8;
    text-align: left;
  }
  
  /* BEST TIME SECTION */
  .arusha-best-time {
    padding: 2rem 5%;
    background: #fff;
    text-align: center;
  }
  .arusha-best-time h2 {
    margin-bottom: 1rem;
    color: var(--brown);
  }
  .arusha-best-time p {
    max-width: 900px;
    margin: 0 auto;
    line-height: 1.8;
    text-align: left;
  }
  .arusha-best-time-grid {
    display: flex;
    gap: 2rem;
    max-width: 700px;
    margin: 1rem auto;
    flex-wrap: wrap;
    justify-content: center;
  }
  .best-time-item {
    flex: 1 1 220px;
    background: var(--beige);
    padding: 1rem;
    text-align: center;
    border: 1px solid #ddd;
    border-radius: 6px;
    box-shadow: 0 2px 3px rgba(0,0,0,0.1);
    margin-bottom: 1rem;
  }
  
  /* WHY GO SECTION */
  .arusha-why-go {
    padding: 2rem 5%;
    background: var(--beige);
    text-align: center;
  }
  .arusha-why-go h2 {
    margin-bottom: 1rem;
    color: var(--brown);
  }
  .arusha-why-go p {
    max-width: 900px;
    margin: 0 auto 1rem auto;
    line-height: 1.8;
    text-align: left;
  }
  .testimonials {
    max-width: 900px;
    margin: 1rem auto;
    text-align: left;
  }
  .testimonials blockquote {
    background: #fff;
    border-left: 4px solid var(--brown);
    padding: 1rem;
    border-radius: 4px;
    margin: 0.5rem 0;
  }
  .testimonials cite {
    display: block;
    text-align: right;
    margin-top: 0.5rem;
    color: #555;
    font-style: italic;
  }
  
  /* WILDLIFE SECTION */
  .arusha-wildlife {
    padding: 2rem 5%;
    background: #fff;
    text-align: center;
  }
  .arusha-wildlife h2 {
    margin-bottom: 1rem;
    color: var(--brown);
  }
  .arusha-wildlife p {
    max-width: 900px;
    margin: 0 auto 1rem auto;
    line-height: 1.8;
    text-align: left;
  }
  
  /* WHERE TO STAY / LOCATION */
  .arusha-where {
    padding: 2rem 5%;
    background: var(--beige);
    text-align: center;
  }
  .arusha-where h2 {
    margin-bottom: 1rem;
    color: var(--brown);
  }
  .arusha-where p {
    max-width: 900px;
    margin: 0 auto 1rem auto;
    line-height: 1.8;
    text-align: left;
  }
  
  /* FINAL CTA */
  .arusha-final-cta {
    padding: 2rem 5%;
    background: #fff;
    text-align: center;
  }
  .arusha-final-cta h2 {
    margin-bottom: 1rem;
    color: var(--brown);
  }
  .arusha-final-cta p {
    max-width: 900px;
    margin: 0 auto 1.5rem auto;
    line-height: 1.8;
    text-align: left;
  }
  .final-cta-buttons {
    display: flex;
    flex-wrap: wrap;
    gap: 1rem;
    justify-content: center;
  }
  
  /* RESPONSIVE MEDIA QUERIES */
  @media (max-width: 768px) {
    .arusha-best-time-grid {
      flex-direction: column;
      align-items: center;
    }
  }/*********************************************
  BALLOON SAFARIS PAGE STYLES
**********************************************/

  /* INTRO SECTION */
  .balloon-intro {
    padding: 2rem 5%;
    background: #fff;
    text-align: center;
  }
  .balloon-intro h2 {
    margin-bottom: 1rem;
    color: var(--brown);
  }
  .balloon-intro p {
    max-width: 900px;
    margin: 0 auto;
    line-height: 1.8;
    text-align: left;
  }
  
  /* GALLERY SECTION */
  .balloon-gallery {
    padding: 2rem 5%;
    background: var(--beige);
    text-align: center;
  }
  .balloon-gallery h2 {
    margin-bottom: 1rem;
    color: var(--brown);
  }
  .gallery-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
    gap: var(--card-gap-standard);
    max-width: 1200px;
    margin: var(--section-margin-top) auto;
  }
  .gallery-grid img {
    width: 100%;
    height: auto;
    border-radius: 6px;
    object-fit: cover;
    box-shadow: 0 2px 5px rgba(0,0,0,0.1);
  }
  
  /* WHO SHOULD GO SECTION */
  .balloon-whoshouldgo {
    padding: clamp(2rem, 4vw, 3rem) 5%;
    background: #fff;
  }
  .balloon-whoshouldgo h2 {
    margin-bottom: clamp(1rem, 2vw, 1.5rem);
    color: var(--brown);
    text-align: center;
    font-size: clamp(1.8rem, 3vw, 2.2rem);
  }
  .balloon-whoshouldgo p {
    max-width: 900px;
    margin: 0 auto clamp(1rem, 2vw, 1.5rem) auto;
    line-height: 1.8;
    text-align: left;
  }
  .balloon-whoshouldgo ul {
    max-width: 600px;
    margin: clamp(1rem, 2vw, 1.5rem) auto;
    text-align: left;
    line-height: 1.8;
    list-style: disc outside;
    padding-left: 1.2rem;
  }
  
  /* WHERE TO EXPERIENCE SECTION */
  .balloon-where {
    padding: 2rem 5%;
    background: var(--beige);
    text-align: center;
  }
  .balloon-where h2 {
    margin-bottom: 1rem;
    color: var(--brown);
  }
  .balloon-where p {
    max-width: 900px;
    margin: 0 auto;
    line-height: 1.8;
    text-align: left;
  }
  
  /* WHEN TO GO SECTION */
  .balloon-besttime {
    padding: 2rem 5%;
    background: #fff;
    text-align: center;
  }
  .balloon-besttime h2 {
    margin-bottom: 1rem;
    color: var(--brown);
  }
  .balloon-besttime p {
    max-width: 900px;
    margin: 0 auto 1rem auto;
    line-height: 1.8;
    text-align: left;
  }
  .balloon-besttime-grid {
    display: flex;
    flex-wrap: wrap;
    gap: 1.5rem;
    max-width: 700px;
    margin: 1rem auto;
    justify-content: center;
    text-align: center;
  }
  .besttime-item {
    flex: 1 1 220px;
    background: var(--beige);
    border-radius: 6px;
    box-shadow: 0 2px 5px rgba(0,0,0,0.1);
    padding: 1rem;
  }
  
  /* CTA BANNER */
  .cta-banner-content {
    max-width: 900px;
    margin: 0 auto;
  }
  .cta-banner-content h2 {
    margin-bottom: 1rem;
    font-size: 2rem;
  }
  
  /* ACCOMMODATIONS SECTION */
  .balloon-accommodations {
    padding: 2rem 5%;
    background: #fff;
    text-align: center;
  }
  .balloon-accommodations h2 {
    margin-bottom: 1rem;
    color: var(--brown);
  }
.balloon-accommodations p {
    max-width: 900px;
    margin: 0 auto;
    line-height: 1.8;
    text-align: left;
  }
  
  /* ADDITIONAL INFO SECTION */
  .balloon-additional {
    padding: 2rem 5%;
    background: var(--beige);
    text-align: center;
  }
  .balloon-additional h2 {
    margin-bottom: 1rem;
    color: var(--brown);
  }
  .balloon-additional p {
    max-width: 900px;
    margin: 0 auto 1rem auto;
    line-height: 1.8;
    text-align: left;
  }
  /* FINAL CTA SECTION */
  .balloon-final-cta {
    padding: 2rem 5%;
    background: #fff;
    text-align: center;
  }
  .balloon-final-cta h2 {
    margin-bottom: 1rem;
    color: var(--brown);
  }
  .balloon-final-cta p {
    max-width: 900px;
    margin: 0 auto 1.5rem auto;
    line-height: 1.8;
    text-align: left;
  }
  .final-cta-buttons {
    display: flex;
    gap: 1rem;
    flex-wrap: wrap;
    justify-content: center;
  }
  
  /* RESPONSIVE BREAKPOINTS */
  @media (max-width: 768px) {
    .balloon-besttime-grid {
      flex-direction: column;
      align-items: center;
    }
    .gallery-grid {
      grid-template-columns: 1fr 1fr;
    }
    .balloon-whoshouldgo ul {
      list-style-position: outside;
      padding-left: 1.5rem;
    }
  }
/*********************************************
  BEACHES PAGE STYLES
**********************************************/

/* HERO CUSTOMIZATION */
.page-hero--beaches .page-hero__overlay {
  background: linear-gradient(120deg, rgba(9, 30, 36, 0.86) 0%, rgba(23, 64, 81, 0.72) 48%, rgba(206, 138, 74, 0.58) 100%);
}

.page-hero--beaches .page-hero__overlay::after {
  content: "";
  position: absolute;
  inset: 0;
  background: radial-gradient(circle at 18% 18%, rgba(255, 215, 0, 0.24) 0%, transparent 55%),
              radial-gradient(circle at 80% 82%, rgba(204, 136, 74, 0.3) 0%, transparent 60%);
  pointer-events: none;
}

.page-hero--beaches .page-hero__content {
  background: linear-gradient(132deg, rgba(16, 29, 32, 0.9) 0%, rgba(25, 58, 70, 0.75) 55%, rgba(206, 138, 74, 0.6) 100%);
}

.page-hero--beaches .page-hero__subtitle {
  color: rgba(255, 255, 255, 0.9);
}

/* INTRO */
.beaches-intro {
  width: min(1100px, 92%);
  margin: clamp(3rem, 6vw, 4.2rem) auto;
  padding: clamp(2.2rem, 5vw, 3.4rem);
  background: #fff;
  border-radius: 28px;
  border: 1px solid rgba(32, 74, 80, 0.08);
  box-shadow: 0 28px 60px rgba(11, 28, 36, 0.14);
  text-align: center;
  display: grid;
  gap: 1.1rem;
}

.beaches-intro h2 {
  margin: 0;
  color: var(--brown);
}

.beaches-intro p {
  margin: 0 auto;
  max-width: 850px;
  line-height: 1.78;
  color: rgba(47, 79, 79, 0.88);
}

/* DESTINATION SPOTLIGHTS */
.beach-destination {
  display: grid;
  grid-template-columns: minmax(280px, 0.95fr) minmax(0, 1.05fr);
  align-items: stretch;
  background: #fff;
  border-radius: 28px;
  border: 1px solid rgba(139, 69, 19, 0.12);
  box-shadow: 0 28px 60px rgba(15, 29, 26, 0.12);
  overflow: hidden;
  margin: var(--section-margin-top) auto;
  max-width: 1200px;
  width: min(94%, 1200px);
}

.feature-card {
  background: #fff;
  border-radius: 28px;
  border: 1px solid rgba(139, 69, 19, 0.12);
  box-shadow: 0 28px 60px rgba(15, 29, 26, 0.12);
  overflow: hidden;
  box-shadow: 0 32px 70px rgba(15, 29, 26, 0.16);
}

.beach-text-col {
  padding: clamp(1.8rem, 3.5vw, 3.1rem);
  display: flex;
  flex-direction: column;
  gap: clamp(0.85rem, 2vw, 1.25rem);
  justify-content: center;
}

.beach-text-col h3 {
  margin: 0;
  font-size: clamp(1.3rem, 2.2vw, 1.6rem);
  color: var(--brown);
}

.beach-text-col p {
  margin: 0;
  line-height: 1.75;
  color: rgba(47, 79, 79, 0.88);
}

.beach-text-col .btn {
  align-self: flex-start;
  margin-top: 0.5rem;
}

.beach-image-col {
  position: relative;
  min-height: 260px;
}

.beach-image-col::after {
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(170deg, rgba(8, 22, 23, 0.3) 0%, rgba(8, 22, 23, 0) 55%);
  pointer-events: none;
}

.beach-image {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}

.beach-destination--reverse {
  grid-template-columns: minmax(260px, 0.95fr) minmax(0, 1.05fr);
}

.beach-destination--reverse .beach-text-col {
  order: 2;
}

.beach-destination--reverse .beach-image-col {
  order: 1;
}

/* CROSS-PROMO SECTION */
.combine-cta {
  width: min(1100px, 92%);
  margin: var(--section-margin-top) auto;
  padding: clamp(2.4rem, 5vw, 3.6rem);
  text-align: center;
  background: linear-gradient(130deg, rgba(17, 29, 26, 0.92) 0%, rgba(204, 85, 0, 0.72) 100%);
  border-radius: 30px;
  position: relative;
  overflow: hidden;
  color: #fff;
}

.combine-cta::before {
  content: "";
  position: absolute;
  inset: 0;
  background: radial-gradient(circle at 20% 20%, rgba(255, 255, 255, 0.22) 0%, transparent 60%),
              radial-gradient(circle at 80% 80%, rgba(255, 215, 0, 0.28) 0%, transparent 65%);
  opacity: 0.6;
  pointer-events: none;
}

.combine-cta h2 {
  margin-bottom: 1rem;
  color: #fff;
}

.combine-cta p {
  margin: 0 auto clamp(2rem, 4vw, 2.6rem);
  max-width: 750px;
  line-height: 1.8;
  color: rgba(255, 255, 255, 0.88);
}

.combine-cta .cta-buttons .btn-outline {
  color: #fff;
  border-color: rgba(255, 255, 255, 0.6);
}

.combine-cta .cta-buttons .btn-outline:hover {
  background: rgba(255, 255, 255, 0.18);
  color: #fff;
}

.island-list {
  list-style: none;
  padding-left: 0;
  margin: 0;
  display: grid;
  gap: clamp(0.75rem, 2.4vw, 1.1rem);
}

.island-list li {
  position: relative;
  padding-left: 1.6rem;
  line-height: 1.8;
  color: rgba(18, 37, 32, 0.9);
}

.island-list li::before {
  content: "";
  position: absolute;
  left: 0;
  top: 0.65rem;
  width: 0.6rem;
  height: 0.6rem;
  border-radius: 50%;
  background: var(--burnt-orange);
  box-shadow: 0 0 0 4px rgba(204, 85, 0, 0.18);
}

/* WRAP-UP SECTION */
.beaches-wrap {
  width: min(1100px, 92%);
  margin: var(--section-margin-top) auto;
  padding: clamp(2.2rem, 5vw, 3.4rem);
  background: #fff;
  border-radius: 28px;
  border: 1px solid rgba(32, 74, 80, 0.08);
  box-shadow: 0 24px 55px rgba(11, 28, 36, 0.12);
  text-align: center;
  display: grid;
  gap: 1rem;
}

.beaches-wrap h2 {
  margin: 0;
  color: var(--brown);
}

.beaches-wrap p {
  margin: 0 auto;
  max-width: 820px;
  line-height: 1.78;
  color: rgba(47, 79, 79, 0.9);
}

/* RESPONSIVE ADJUSTMENTS */
@media (max-width: 980px) {
  .beach-destination {
    grid-template-columns: 1fr;
  }

  .beach-destination--reverse {
    grid-template-columns: 1fr;
  }

  .beach-image-col {
    min-height: 220px;
  }

  .beach-text-col {
    padding: clamp(1.6rem, 4vw, 2.2rem);
  }
}

@media (max-width: 640px) {
  .beaches-hero-overlay {
    padding: 2rem;
  }

  .beach-text-col .btn,
  .combine-cta .cta-buttons .btn {
    width: 100%;
    justify-content: center;
  }
}
/*********************************************
  BIRDING SAFARIS PAGE STYLES
**********************************************/

  /* INTRO SECTION */
  .birding-intro {
    padding: 2rem 5%;
    background: #fff;
    text-align: center;
  }
  .birding-intro h2 {
    margin-bottom: 1rem;
    color: var(--brown);
  }
  .birding-intro p {
    max-width: 900px;
    margin: 0 auto;
    line-height: 1.8;
    text-align: left;
  }
  
  /* GALLERY SECTION */
  .birding-gallery {
    padding: 2rem 5%;
    background: var(--beige);
    text-align: center;
  }
  .birding-gallery h2 {
    margin-bottom: 1rem;
    color: var(--brown);
  }
  .gallery-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
    gap: var(--card-gap-standard);
    max-width: 1200px;
    margin: var(--section-margin-top) auto;
  }
  .gallery-grid img {
    width: 100%;
    height: auto;
    border-radius: 6px;
    object-fit: cover;
    box-shadow: 0 2px 5px rgba(0,0,0,0.1);
  }
  
  /* WHO SHOULD GO SECTION */
  .birding-whoshouldgo {
    padding: clamp(2rem, 4vw, 3rem) 5%;
    background: #fff;
  }
  .birding-whoshouldgo h2 {
    margin-bottom: clamp(1rem, 2vw, 1.5rem);
    color: var(--brown);
    text-align: center;
    font-size: clamp(1.8rem, 3vw, 2.2rem);
  }
  .birding-whoshouldgo p {
    max-width: 900px;
    margin: 0 auto clamp(1rem, 2vw, 1.5rem) auto;
    line-height: 1.8;
    text-align: left;
  }
  .birding-whoshouldgo ul {
    max-width: 600px;
    margin: clamp(1rem, 2vw, 1.5rem) auto;
    text-align: left;
    line-height: 1.8;
    list-style: disc outside;
    padding-left: 1.2rem;
  }
  
  /* WHERE TO EXPERIENCE SECTION */
  .birding-where {
    padding: 2rem 5%;
    background: var(--beige);
    text-align: center;
  }
  .birding-where h2 {
    margin-bottom: 1rem;
    color: var(--brown);
  }
  .birding-where p {
    max-width: 900px;
    margin: 0 auto;
    line-height: 1.8;
    text-align: left;
  }
  
  /* WHEN TO GO SECTION */
  .birding-besttime {
    padding: 2rem 5%;
    background: #fff;
    text-align: center;
  }
  .birding-besttime h2 {
    margin-bottom: 1rem;
    color: var(--brown);
  }
  .birding-besttime p {
    max-width: 900px;
    margin: 0 auto 1rem auto;
    line-height: 1.8;
    text-align: left;
  }
  .birding-besttime-grid {
    display: flex;
    flex-wrap: wrap;
    gap: 2rem;
    max-width: 700px;
    margin: 1rem auto;
    justify-content: center;
    text-align: center;
  }
  .besttime-item {
    flex: 1 1 220px;
    background: var(--beige);
    border-radius: 6px;
    box-shadow: 0 2px 5px rgba(0,0,0,0.1);
    padding: 1rem;
  }
  
  /* CTA BANNER */
  .cta-banner-content {
    max-width: 900px;
    margin: 0 auto;
  }
  .cta-banner-content h2 {
    margin-bottom: 1rem;
    font-size: 2rem;
  }
  
  /* ACCOMMODATIONS SECTION */
  .birding-accommodations {
    padding: 2rem 5%;
    background: #fff;
    text-align: center;
  }
  .birding-accommodations h2 {
    margin-bottom: 1rem;
    color: var(--brown);
  }
  .birding-accommodations p {
    max-width: 900px;
    margin: 0 auto;
    line-height: 1.8;
    text-align: left;
  }
  
  /* HIGHLIGHTS SECTION */
  .birding-highlights {
    padding: 2rem 5%;
    background: var(--beige);
    text-align: center;
  }
  .birding-highlights h2 {
    margin-bottom: 1rem;
    color: var(--brown);
  }
  .birding-highlights p {
    max-width: 900px;
    margin: 0 auto;
    line-height: 1.8;
    text-align: left;
  }
  
  /* PACKING TIPS SECTION */
  .birding-packing {
    padding: 2rem 5%;
    background: #fff;
    text-align: center;
  }
  .birding-packing h2 {
    margin-bottom: 1rem;
    color: var(--brown);
  }
  .birding-packing ul {
    max-width: 600px;
    margin: 0 auto;
    text-align: left;
    line-height: 1.8;
    list-style: disc inside;
  }
  
  /* FINAL CTA SECTION */
  .birding-final-cta {
    padding: 2rem 5%;
    background: var(--beige);
    text-align: center;
  }
  .birding-final-cta h2 {
    margin-bottom: 1rem;
    color: var(--brown);
  }
  .birding-final-cta p {
    max-width: 900px;
    margin: 0 auto 1.5rem auto;
    line-height: 1.8;
    text-align: left;
  }
  .final-cta-buttons {
    display: flex;
    gap: 1rem;
    flex-wrap: wrap;
    justify-content: center;
  }
  
  /* RESPONSIVE BREAKPOINTS */
  @media (max-width: 768px) {
    .birding-besttime-grid {
      flex-direction: column;
      align-items: center;
    }
    .gallery-grid {
      grid-template-columns: 1fr 1fr;
    }
    .birding-whoshouldgo ul {
      list-style-position: outside;
      padding-left: 1.5rem;
    }
  }
/*********************************************
  BLOG PAGE STYLES
**********************************************/

.page-hero--blog .page-hero__overlay {
  background: linear-gradient(118deg, rgba(14, 28, 26, 0.92) 12%, rgba(43, 66, 58, 0.78) 52%, rgba(204, 125, 58, 0.6) 100%);
}
/*********************************************
  CAMPING SAFARIS DETAIL STYLES
**********************************************/

.page-hero--camping .page-hero__overlay {
  background: linear-gradient(118deg, rgba(10, 26, 24, 0.88) 0%, rgba(38, 63, 54, 0.78) 48%, rgba(204, 120, 58, 0.58) 100%);
}

.page-hero--camping .page-hero__content {
  background: linear-gradient(132deg, rgba(16, 29, 26, 0.92) 0%, rgba(28, 51, 44, 0.78) 55%, rgba(204, 120, 58, 0.62) 100%);
}

.page-hero--camping .page-hero__subtitle {
  color: rgba(255, 255, 255, 0.9);
}

.feature-card img {
  height: clamp(160px, 26vw, 200px);
}

.link-card-grid .link-card__body {
  gap: 0.65rem;
}

@media (max-width: 720px) {
  .feature-card img {
    height: 180px;
  }
}
/*********************************************
  CONTACT PAGE STYLES
**********************************************/

/* Hero styling */
.page-hero--contact .page-hero__overlay {
  background: linear-gradient(118deg, rgba(16, 28, 30, 0.9) 10%, rgba(34, 60, 54, 0.78) 52%, rgba(204, 120, 58, 0.58) 100%);
}

.page-hero--contact .page-hero__content {
  text-align: left;
}

/* Contact methods */
.contact-touch-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
  gap: var(--card-gap-standard);
  margin-top: var(--section-margin-top);
}

.contact-card {
  background: rgba(255, 255, 255, 0.96);
  border: 1px solid rgba(139, 69, 19, 0.12);
  border-radius: 18px;
  box-shadow: 0 20px 44px rgba(12, 24, 21, 0.08);
  padding: clamp(1.5rem, 2.4vw, 2rem);
  display: grid;
  gap: 0.65rem;
  height: 100%;
}

.contact-card__icon {
  width: 44px;
  height: 44px;
  border-radius: 12px;
  background: rgba(204, 120, 58, 0.14);
  display: inline-flex;
  align-items: center;
  justify-content: center;
}

.contact-card__icon img {
  width: 28px;
  height: 28px;
}

.contact-card h3 {
  margin: 0;
  font-size: 1.1rem;
  color: var(--deep-green);
}

.contact-card p {
  margin: 0;
  line-height: 1.65;
  color: rgba(47, 79, 79, 0.85);
}

.contact-card a {
  color: var(--burnt-orange);
  font-weight: 600;
  text-decoration: none;
}

.contact-card a:hover,
.contact-card a:focus {
  color: var(--deep-green);
}

.contact-card__note {
  font-size: 0.9rem;
  color: rgba(47, 79, 79, 0.7);
}

/* Planning guidance */
.contact-guidance {
  background: rgba(255, 255, 255, 0.96);
  border: 1px solid rgba(139, 69, 19, 0.12);
  border-radius: 20px;
  box-shadow: 0 22px 48px rgba(12, 24, 21, 0.1);
  padding: clamp(1.8rem, 2.8vw, 2.4rem);
}

.contact-guidance h3 {
  margin-top: 0;
  font-size: 1.35rem;
  color: var(--deep-green);
}

/* Enquiry form */
.form-card {
  background: rgba(255, 255, 255, 0.96);
  border: 1px solid rgba(139, 69, 19, 0.12);
  border-radius: 22px;
  box-shadow: 0 24px 56px rgba(12, 24, 21, 0.1);
  padding: clamp(1.9rem, 3vw, 2.5rem);
}

.form-card__hint {
  margin-bottom: 1.2rem;
  text-align: center;
  color: rgba(47, 79, 79, 0.78);
}

.form-card__hint a {
  color: var(--burnt-orange);
  font-weight: 600;
  text-decoration: none;
}

.form-card__hint a:hover,
.form-card__hint a:focus {
  color: var(--deep-green);
}

.form-card .elfsight-app {
  width: 100%;
}

/* Responsive tweaks */
@media (max-width: 768px) {
  .page-hero--contact .page-hero__content {
    text-align: center;
  }
}

@media (max-width: 540px) {
  .contact-touch-grid {
    grid-template-columns: 1fr;
  }
}
/*********************************************
  CULTURAL TOURS PAGE STYLES (Honeymoon-Inspired)
**********************************************/

  /* MAIN CONTENT (mirroring .honeymoon-intro) */
  .experience-section {
    padding: clamp(2rem, 4vw, 3rem) 5%;
    background: #fff;
  }
  .experience-section h2 {
    margin-bottom: clamp(1rem, 2vw, 1.5rem) !important;
    color: var(--brown) !important;
    font-size: clamp(1.8rem, 3vw, 2.2rem) !important;
    text-align: center !important;
  }
  .experience-section p {
    max-width: 900px !important;
    margin: 0 auto clamp(1rem, 2vw, 1.5rem) auto !important;
    line-height: 1.8 !important;
    text-align: left !important;
  }
  .experience-section ul {
    max-width: 600px !important;
    margin: clamp(1rem, 2vw, 1.5rem) auto !important;
    list-style: disc outside !important;
    text-align: left !important;
    line-height: 1.8 !important;
    padding-left: 1.2rem !important;
  }
  .experience-section li {
    margin-bottom: 0.5rem;
  }
  
  /* ALTERNATE (BEIGE) SECTION (mirroring .honeymoon-whoshouldgo or .honeymoon-besttime) */
  .experience-section-alt {
    padding: clamp(2rem, 4vw, 3rem) 5%;
    background: var(--beige);
  }
  .experience-section-alt h2 {
    margin-bottom: clamp(1rem, 2vw, 1.5rem);
    color: var(--brown);
    font-size: clamp(1.8rem, 3vw, 2.2rem);
    text-align: center;
  }
  .experience-section-alt p {
    max-width: 900px;
    margin: 0 auto clamp(1rem, 2vw, 1.5rem) auto;
    line-height: 1.8;
    text-align: left;
  }
  .experience-section-alt ul {
    max-width: 600px;
    margin: clamp(1rem, 2vw, 1.5rem) auto;
    list-style: disc outside;
    line-height: 1.8;
    text-align: left;
    padding-left: 1.2rem;
  }
  .experience-section-alt li {
    margin-bottom: 0.5rem;
  }
  
/* RESPONSIVE BREAKPOINTS */
@media (max-width: 768px) {
  .experience-section ul, .experience-section-alt ul {
    list-style-position: outside;
    padding-left: 1.5rem;
    margin-left: 0;
    margin-right: 0;
  }
  
  .experience-section p, .experience-section-alt p {
    padding: 0 1rem;
  }
}
/*********************************************
  DAY TRIPS DETAIL STYLES
**********************************************/

.page-hero--daytrips .page-hero__overlay {
  background: linear-gradient(115deg, rgba(14, 28, 30, 0.9) 0%, rgba(44, 63, 59, 0.78) 52%, rgba(214, 136, 74, 0.6) 100%);
}

.page-hero--daytrips .page-hero__content {
  background: linear-gradient(132deg, rgba(16, 29, 30, 0.92) 0%, rgba(27, 50, 48, 0.78) 54%, rgba(214, 136, 74, 0.6) 100%);
}

.page-hero--daytrips .page-hero__subtitle {
  color: rgba(255, 255, 255, 0.9);
}

.feature-card img {
  height: clamp(160px, 25vw, 190px);
}

@media (max-width: 720px) {
  .feature-card img {
    height: 180px;
  }
}
/*********************************************
  SHARED DESTINATION PAGE MODERN STYLING
**********************************************/

/* Apply bright theme to ALL pages */
body {
  background: #fdf8f1;
  color: var(--deep-green);
  /* Subtle fade-in on page load */
  animation: fadeInUp 0.8s ease-out;
}

body.destination-page {
  background: #fdf8f1;
  color: var(--deep-green);
}

body.destination-page main {
  display: block;
}

body.destination-page section {
  position: relative;
  padding: clamp(3rem, 6vw, 5rem) clamp(1.5rem, 7vw, 4.5rem);
  overflow: hidden;
}

body.destination-page .page-hero {
  padding: 0;
  overflow: hidden;
}

body.destination-page section > h1,
body.destination-page section > h2,
body.destination-page section > h3,
body.destination-page section > p,
body.destination-page section > ul,
body.destination-page section > div:not(.section-max):not(.final-cta-content):not(.glance-grid):not(.destinations-grid):not(.cta-buttons):not(.final-cta-buttons):not(.page-hero__content):not(.page-hero__actions) {
  max-width: min(62ch, 100%);
  margin-left: auto;
  margin-right: auto;
}

body.destination-page section > ul {
  list-style: none;
  padding-left: 0;
}

body.destination-page section > ul li {
  position: relative;
  padding-left: 1.75rem;
  margin-bottom: 0.65rem;
  line-height: 1.8;
}

body.destination-page section > ul li::before {
  content: "";
  position: absolute;
  left: 0;
  top: 0.7rem;
  width: 0.65rem;
  height: 0.65rem;
  border-radius: 50%;
  background: var(--burnt-orange);
  box-shadow: 0 0 0 4px rgba(204, 85, 0, 0.15);
}

/***********************
  QUICK FACTS GRID
***********************/
body.destination-page .glance-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
  gap: var(--card-gap-compact);
  margin-top: var(--section-margin-top);
  max-width: 980px;
}

body.destination-page .glance-item {
  background: linear-gradient(145deg, rgba(255,255,255,0.96) 0%, rgba(255,245,232,0.92) 100%);
  border: 1px solid rgba(139, 69, 19, 0.15);
  border-radius: 14px;
  padding: clamp(1rem, 2.4vw, 1.6rem);
  box-shadow: 0 20px 45px -25px rgba(18, 42, 37, 0.45);
  position: relative;
  overflow: hidden;
}

body.destination-page .glance-item::after {
  content: "";
  position: absolute;
  inset: 0;
  pointer-events: none;
  background: radial-gradient(circle at 20% 10%, rgba(204, 85, 0, 0.12), transparent 50%);
}

body.destination-page .glance-item strong {
  font-size: 0.95rem;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  display: block;
  margin-bottom: 0.35rem;
  color: var(--brown);
}

body.destination-page .glance-item p {
  margin: 0;
  font-size: 1rem;
  color: rgba(18, 37, 32, 0.85);
}

/***********************
  BEST TIME / SEASON CARDS
***********************/
body.destination-page [class$='-best-time'] > .best-time-item,
body.destination-page [class$='-best-time-grid'] .best-time-item {
  background: rgba(255, 255, 255, 0.96);
  border-radius: 16px;
  border: 1px solid rgba(85, 107, 47, 0.18);
  padding: clamp(1.25rem, 3vw, 1.75rem);
  box-shadow: 0 18px 38px -28px rgba(0, 0, 0, 0.6);
}

body.destination-page [class$='-best-time-grid'] {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
  gap: var(--card-gap-small);
  margin-top: var(--section-margin-compact);
  max-width: 880px;
}

body.destination-page .best-time-item strong {
  font-size: 1rem;
  color: var(--brown);
  text-transform: uppercase;
  letter-spacing: 0.06em;
}

body.destination-page .best-time-item p {
  margin-bottom: 0.4rem;
}

/***********************
  SECTION TYPOGRAPHY
***********************/
body.destination-page section h2 {
  text-transform: uppercase;
  letter-spacing: 0.04em;
  text-align: left;
  margin-bottom: clamp(1rem, 3vw, 1.75rem);
}

body.destination-page section p {
  line-height: 1.85;
  font-size: 1.05rem;
  color: rgba(18, 37, 32, 0.88);
  margin-bottom: clamp(1rem, 2.6vw, 1.6rem);
  text-align: left;
}

body.destination-page section p strong {
  color: var(--brown);
}

body.destination-page section a {
  color: var(--burnt-orange);
  font-weight: 600;
}

body.destination-page section a:hover,
body.destination-page section a:focus {
  color: var(--brown);
}

/***********************
  CTA BUTTON GROUPS
***********************/
body.destination-page .cta-buttons {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: 1rem;
  margin-top: clamp(1.5rem, 4vw, 2.5rem);
}

body.destination-page .destination-cta {
  padding-top: clamp(3rem, 5vw, 4.5rem);
  padding-bottom: clamp(3rem, 5vw, 4.5rem);
}

body.destination-page .destination-cta .final-cta-content {
  background: linear-gradient(132deg, rgba(16, 29, 26, 0.82) 0%, rgba(29, 52, 46, 0.76) 55%, rgba(204, 120, 58, 0.58) 100%);
  border: 1px solid rgba(255, 255, 255, 0.24);
  box-shadow: 0 32px 70px rgba(5, 8, 6, 0.4);
}

body.destination-page .destination-cta .final-cta-content h2 {
  color: #fff;
}

body.destination-page .destination-cta .final-cta-content p {
  color: rgba(255, 255, 255, 0.88);
}

/***********************
  RESPONSIVE TWEAKS
***********************/
@media (max-width: 640px) {
  .page-hero--destination .page-hero__heading {
    font-size: clamp(2rem, 5vw, 2.6rem);
  }

  body.destination-page .glance-grid {
    grid-template-columns: repeat(auto-fit, minmax(160px, 1fr));
  }

  body.destination-page section > h2 {
    font-size: clamp(1.4rem, 3vw + 0.8rem, 1.8rem);
  }
}
/*********************************************
  DESTINATIONS PAGE STYLES
**********************************************/

/* HERO CUSTOMIZATION */

/* OVERVIEW */
.destinations-overview {
  width: min(1100px, 92%);
  margin: var(--section-margin-top) auto;
}

.destinations-overview-card {
  background: #fff;
  border-radius: 28px;
  border: 1px solid rgba(139, 69, 19, 0.1);
  box-shadow: 0 28px 60px rgba(15, 29, 26, 0.12);
  padding: clamp(2.4rem, 5vw, 3.6rem);
  display: grid;
  gap: clamp(1.25rem, 3vw, 1.9rem);
  text-align: center;
}

.destinations-overview-card h2 {
  margin: 0;
  color: var(--brown);
}

.destinations-overview-card p {
  margin: 0 auto;
  max-width: 860px;
  line-height: 1.8;
  color: rgba(47, 79, 79, 0.88);
}

.destinations-overview-stats {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(240px, 1fr));
  gap: var(--card-gap-compact);
  margin-top: var(--section-margin-compact);
}

.overview-stat {
  background: rgba(248, 244, 236, 0.85);
  border-radius: 20px;
  border: 1px solid rgba(139, 69, 19, 0.12);
  padding: clamp(1.1rem, 3vw, 1.6rem);
  box-shadow: 0 20px 45px rgba(15, 29, 26, 0.08);
}

.overview-stat__label {
  display: block;
  font-size: 0.75rem;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  color: rgba(47, 79, 79, 0.68);
  margin-bottom: 0.35rem;
}

/* SAFARI CIRCUITS */
.destinations-circuits {
  width: min(1200px, 94%);
  margin: clamp(3.5rem, 7vw, 5rem) auto;
  display: grid;
  gap: clamp(2rem, 4vw, 3rem);
}

.destinations-circuits__intro {
  text-align: center;
  max-width: 780px;
  margin: 0 auto;
  color: rgba(47, 79, 79, 0.9);
  display: grid;
  gap: 1rem;
}

.destinations-circuits__intro h2 {
  margin: 0;
  color: var(--brown);
}

.destinations-circuit-grid {
  display: grid;
  gap: var(--card-gap-standard);
  grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
  margin-top: var(--section-margin-top);
}

.destinations-circuit-card {
  background: #fff;
  border-radius: 22px;
  border: 1px solid rgba(139, 69, 19, 0.12);
  box-shadow: 0 26px 52px rgba(15, 29, 26, 0.12);
  padding: clamp(1.6rem, 3.5vw, 2.2rem);
  display: flex;
  flex-direction: column;
  gap: 0.85rem;
  transition: transform 0.3s ease, box-shadow 0.3s ease;
}

.destinations-circuit-card:hover,
.destinations-circuit-card:focus-within {
  transform: translateY(-6px);
  box-shadow: 0 32px 68px rgba(15, 29, 26, 0.16);
}

.destinations-circuit-card h3 {
  margin: 0;
  color: var(--brown);
}

.destinations-circuit-card p {
  margin: 0;
  color: rgba(47, 79, 79, 0.88);
  line-height: 1.75;
}

.circuit-links {
  display: flex;
  flex-wrap: wrap;
  gap: 0.6rem;
  margin-top: 0.4rem;
}

.chip-link {
  display: inline-flex;
  align-items: center;
  padding: 0.35rem 0.9rem;
  border-radius: 999px;
  background: rgba(204, 85, 0, 0.12);
  color: var(--burnt-orange);
  font-size: 0.85rem;
  text-decoration: none;
  transition: background 0.3s ease, color 0.3s ease;
}

.chip-link:hover,
.chip-link:focus {
  background: rgba(204, 85, 0, 0.2);
  color: var(--brown);
}

/* JOURNEY BLENDS */
.destinations-journeys {
  width: min(1200px, 94%);
  margin: clamp(3.5rem, 7vw, 5rem) auto;
  display: grid;
  gap: var(--section-margin-top);
}

.journey-card {
  display: grid;
  grid-template-columns: minmax(280px, 0.95fr) minmax(0, 1.05fr);
  align-items: stretch;
  background: #fff;
  border-radius: 28px;
  border: 1px solid rgba(139, 69, 19, 0.12);
  box-shadow: 0 28px 60px rgba(15, 29, 26, 0.12);
  overflow: hidden;
  transition: transform 0.35s ease, box-shadow 0.35s ease;
}

.journey-card:hover,
.journey-card:focus-within {
  transform: translateY(-6px);
  box-shadow: 0 34px 72px rgba(15, 29, 26, 0.16);
}

.journey-card__copy {
  padding: clamp(1.9rem, 3.5vw, 2.8rem);
  display: flex;
  flex-direction: column;
  gap: clamp(0.85rem, 2vw, 1.25rem);
  justify-content: center;
}

.journey-card__copy h2 {
  margin: 0;
  color: var(--brown);
}

.journey-card__copy p {
  margin: 0;
  line-height: 1.75;
  color: rgba(47, 79, 79, 0.88);
}

.journey-card__media {
  position: relative;
  min-height: 260px;
}

.journey-card__media img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}

.journey-card--reverse {
  grid-template-columns: minmax(0, 1.05fr) minmax(260px, 0.95fr);
}

.journey-card--reverse .journey-card__copy {
  order: 2;
}

.journey-card--reverse .journey-card__image {
  order: 1;
}

/* FEATURED DESTINATIONS */
.selected-destinations {
  width: min(1200px, 94%);
  margin: clamp(3.5rem, 7vw, 5rem) auto;
  display: grid;
  gap: var(--section-margin-top);
}

.selected-destinations > h2 {
  text-align: center;
  color: var(--brown);
  margin-bottom: 0.5rem;
}

.dest-item {
  display: grid;
  grid-template-columns: minmax(280px, 0.95fr) minmax(0, 1.05fr);
  align-items: stretch;
  background: #fff;
  border-radius: 28px;
  border: 1px solid rgba(139, 69, 19, 0.12);
  box-shadow: 0 28px 60px rgba(15, 29, 26, 0.12);
  overflow: hidden;
  transition: transform 0.35s ease, box-shadow 0.35s ease;
}

.dest-item:hover,
.dest-item:focus-within {
  transform: translateY(-6px);
  box-shadow: 0 36px 75px rgba(15, 29, 26, 0.18);
}

.dest-photo-col {
  position: relative;
  min-height: 260px;
}

.dest-photo-col::after {
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(170deg, rgba(8, 22, 23, 0.3) 0%, rgba(8, 22, 23, 0) 55%);
  pointer-events: none;
}

.dest-photo {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}

.dest-info-col {
  padding: clamp(1.9rem, 3.5vw, 2.8rem);
  display: flex;
  flex-direction: column;
  gap: clamp(0.9rem, 2vw, 1.35rem);
  justify-content: center;
}

.dest-info-col h3 {
  margin: 0;
  font-size: clamp(1.3rem, 2.2vw, 1.65rem);
}

.dest-info-col p {
  margin: 0;
  line-height: 1.75;
  color: rgba(47, 79, 79, 0.88);
}

.dest-info-col .btn {
  align-self: flex-start;
}

/* RESPONSIVE */
@media (max-width: 980px) {
  .journey-card,
  .journey-card--reverse,
  .dest-item {
    grid-template-columns: 1fr;
  }

  .journey-card--reverse .journey-card__copy {
    order: 0;
  }

  .dest-photo-col,
  .journey-card__media {
    min-height: 220px;
  }
}

@media (max-width: 640px) {
  .destinations-overview-stats {
    grid-template-columns: 1fr;
  }

  .journey-card__media img {
    object-position: center;
  }

  .dest-info-col .btn,
  .journey-card__copy .btn {
    width: 100%;
    justify-content: center;
  }
}
/*********************************************
  EXPERIENCES-NEW.CSS
  Applies Honeymoon-Style Layout to 
  - Cultural Tours
  - Night Game Drives
  - Walking Safaris
  (and any other "experience" pages)
**********************************************/

/* 
  HERO SECTION 
  (Mirrors .honeymoon-hero styles, 
   but uses .experience-hero & overlay)
*/
.experience-hero {
  position: relative;
  height: 80vh;
  overflow: hidden;
}
.experience-hero img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}
.experience-hero-overlay {
  position: absolute;
  inset: 0;
  background: rgba(0, 0, 0, 0.3);
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  color: #fff;
  text-align: center;
  padding: 1rem;
}
.experience-hero-overlay h1 {
  font-size: 2.5rem;
  margin-bottom: 0.5rem;
}
.experience-hero-overlay p {
  font-size: 1.2rem;
}

/* UNIVERSAL EXPERIENCE PAGE ALIGNMENT FIX */
.experience-section h2,
.migration-whoshouldgo h2,
.migration-where h2,
.migration-besttime h2,
.balloon-whoshouldgo h2,
.balloon-where h2,
.balloon-besttime h2,
.birding-whoshouldgo h2,
.birding-where h2,
.birding-besttime h2,
.honeymoon-whoshouldgo h2,
.honeymoon-where h2,
.honeymoon-besttime h2,
.photo-whoshouldgo h2,
.photo-where h2,
.photo-besttime h2,
.private-whoshouldgo h2,
.private-where h2,
.private-besttime h2,
.smallgroup-whoshouldgo h2,
.smallgroup-where h2,
.smallgroup-besttime h2 {
  text-align: center !important;
  font-size: clamp(1.8rem, 3vw, 2.2rem) !important;
  margin-bottom: clamp(1rem, 2vw, 1.5rem) !important;
  color: var(--brown) !important;
}

.experience-section p,
.migration-whoshouldgo p,
.migration-where p,
.migration-besttime p,
.balloon-whoshouldgo p,
.balloon-where p,
.balloon-besttime p,
.birding-whoshouldgo p,
.birding-where p,
.birding-besttime p,
.honeymoon-whoshouldgo p,
.honeymoon-where p,
.honeymoon-besttime p,
.photo-whoshouldgo p,
.photo-where p,
.photo-besttime p,
.private-whoshouldgo p,
.private-where p,
.private-besttime p,
.smallgroup-whoshouldgo p,
.smallgroup-where p,
.smallgroup-besttime p {
  text-align: left !important;
  max-width: 900px !important;
  margin: 0 auto clamp(1rem, 2vw, 1.5rem) auto !important;
  line-height: 1.8 !important;
}

.experience-section ul,
.migration-whoshouldgo ul,
.migration-where ul,
.migration-besttime ul,
.balloon-whoshouldgo ul,
.balloon-where ul,
.balloon-besttime ul,
.birding-whoshouldgo ul,
.birding-where ul,
.birding-besttime ul,
.honeymoon-whoshouldgo ul,
.honeymoon-where ul,
.honeymoon-besttime ul,
.photo-whoshouldgo ul,
.photo-where ul,
.photo-besttime ul,
.private-whoshouldgo ul,
.private-where ul,
.private-besttime ul,
.smallgroup-whoshouldgo ul,
.smallgroup-where ul,
.smallgroup-besttime ul {
  text-align: left !important;
  max-width: 600px !important;
  margin: clamp(1rem, 2vw, 1.5rem) auto !important;
  list-style: disc outside !important;
  padding-left: 1.2rem !important;
  line-height: 1.8 !important;
}/*********************************************
  EXPERIENCES PAGE STYLES
**********************************************/

/* HERO CUSTOMIZATION */
.page-hero--experiences .page-hero__overlay {
  background: linear-gradient(120deg, rgba(17, 29, 26, 0.84) 0%, rgba(38, 62, 54, 0.74) 46%, rgba(204, 120, 58, 0.58) 100%);
}

.page-hero--experiences .page-hero__content {
  background: linear-gradient(132deg, rgba(16, 29, 26, 0.9) 0%, rgba(29, 52, 46, 0.78) 55%, rgba(204, 120, 58, 0.58) 100%);
}

.page-hero--experiences .page-hero__eyebrow {
  letter-spacing: 0.24em;
}

.page-hero--experiences .page-hero__subtitle {
  color: rgba(255, 255, 255, 0.9);
}

/* OVERVIEW SECTION */
.experiences-overview {
  width: min(1100px, 92%);
  margin: clamp(3rem, 6vw, 4.2rem) auto;
  padding: clamp(2rem, 5vw, 3.25rem);
  background: #fff;
  border-radius: 28px;
  border: 1px solid rgba(139, 69, 19, 0.08);
  box-shadow: 0 28px 60px rgba(15, 29, 26, 0.12);
  display: grid;
  gap: 1rem;
}

.experiences-overview h2 {
  text-align: center;
  margin: 0;
  color: var(--brown);
}

.experiences-overview p {
  margin: 0 auto;
  max-width: 820px;
  line-height: 1.75;
  color: rgba(47, 79, 79, 0.9);
}

/* HIGHLIGHTED EXPERIENCES GRID */
.selected-experiences {
  width: min(1200px, 94%);
  margin: clamp(3.5rem, 7vw, 5rem) auto;
  display: grid;
  gap: var(--section-margin-top);
}

.selected-experiences > h2 {
  text-align: center;
  margin-bottom: clamp(1.5rem, 3vw, 2rem);
  color: var(--brown);
}

.exp-item {
  display: grid;
  grid-template-columns: minmax(280px, 0.95fr) minmax(0, 1.05fr);
  align-items: stretch;
  background: #fff;
  border-radius: 28px;
  border: 1px solid rgba(139, 69, 19, 0.08);
  box-shadow: 0 26px 60px rgba(15, 29, 26, 0.12);
  overflow: hidden;
  transition: transform 0.35s ease, box-shadow 0.35s ease;
}

.exp-item:hover,
.exp-item:focus-within {
  transform: translateY(-6px);
  box-shadow: 0 32px 70px rgba(15, 29, 26, 0.16);
}

.exp-photo-col {
  position: relative;
  min-height: 280px;
}

.exp-photo-col::after {
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(160deg, rgba(12, 24, 21, 0.35) 0%, rgba(12, 24, 21, 0) 55%);
  pointer-events: none;
}

.exp-photo {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}

.exp-info-col {
  padding: clamp(1.8rem, 3vw, 2.6rem) clamp(2rem, 3.5vw, 3.1rem);
  display: flex;
  flex-direction: column;
  gap: clamp(0.85rem, 2vw, 1.25rem);
  justify-content: center;
}

.exp-info-col h3 {
  margin: 0;
  font-size: clamp(1.3rem, 2.2vw, 1.6rem);
}

.exp-info-col h3 a {
  color: var(--brown);
  text-decoration: none;
  position: relative;
}

.exp-info-col h3 a::after {
  content: "";
  position: absolute;
  left: 0;
  bottom: -0.35rem;
  width: 42px;
  height: 2px;
  background: linear-gradient(90deg, var(--burnt-orange) 0%, rgba(204, 85, 0, 0) 100%);
  opacity: 0.6;
  transition: width 0.3s ease, opacity 0.3s ease;
}

.exp-info-col h3 a:hover::after,
.exp-info-col h3 a:focus::after {
  width: 70px;
  opacity: 1;
}

.exp-info-col p {
  margin: 0;
  line-height: 1.75;
  color: rgba(47, 79, 79, 0.88);
}

.exp-info-col .btn {
  align-self: flex-start;
  margin-top: 0.5rem;
}

.exp-item:nth-child(even) {
  grid-template-columns: minmax(0, 1.05fr) minmax(280px, 0.95fr);
}

.exp-item:nth-child(even) .exp-info-col {
  order: 1;
}

.exp-item:nth-child(even) .exp-photo-col {
  order: 2;
}

/* RESPONSIVE BREAKPOINTS */
@media (max-width: 980px) {
  .exp-item {
    grid-template-columns: 1fr;
  }

  .exp-item:nth-child(even) {
    grid-template-columns: 1fr;
  }

  .exp-photo-col {
    min-height: 220px;
  }

  .exp-info-col {
    padding: clamp(1.6rem, 4vw, 2.2rem);
  }
}

@media (max-width: 640px) {
  .experiences-hero-overlay {
    padding: 2rem;
  }

  .experiences-hero-overlay h1 {
    letter-spacing: 0.06em;
  }

  .selected-experiences {
    gap: 2rem;
  }

  .exp-info-col .btn {
    width: 100%;
    justify-content: center;
  }

  .page-hero--experience .page-hero__content {
    text-align: center;
  }

  .page-hero--experience .page-hero__actions {
    justify-content: center;
  }
}
/*********************************************
  1. BASIC RESET / GLOBAL
**********************************************/
* {
    margin: 0;
    padding: 0;
    box-sizing: border-box;
}

/* Performance optimization - font loading strategy */
* {
  font-display: swap;
}

/* Critical CSS - Above the fold optimizations */
.page-hero {
  contain: layout style paint;
}

.navbar {
  contain: layout style;
}

/* Reduce layout shifts */
.feature-grid, .link-card-grid, .package-card {
  contain: layout;
}

/* Optimize animations for performance */
@media (prefers-reduced-motion: reduce) {
  *,
  *::before,
  *::after {
    animation-duration: 0.01ms !important;
    animation-iteration-count: 1 !important;
    transition-duration: 0.01ms !important;
    scroll-behavior: auto !important;
  }
}

/* SAFARI PACKAGE CARDS */
.package-card {
  background: #fff;
  border-radius: 24px;
  border: 1px solid rgba(139, 69, 19, 0.12);
  box-shadow: 0 24px 48px rgba(15, 29, 26, 0.08);
  overflow: hidden;
  transition: transform 0.3s ease, box-shadow 0.3s ease;
}

.package-card:hover {
  transform: translateY(-4px);
  box-shadow: 0 32px 64px rgba(15, 29, 26, 0.12);
}

.package-header {
  padding: 2rem 2rem 1rem;
  text-align: center;
}

.package-header h3 {
  margin: 0 0 0.5rem;
  color: var(--deep-green);
  font-size: clamp(1.4rem, 2.5vw, 1.8rem);
}

.package-subtitle {
  margin: 0;
  color: rgba(47, 79, 79, 0.7);
  font-size: 1rem;
  font-style: italic;
}

.package-details {
  padding: 0 2rem 1.5rem;
}

.package-info {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(140px, 1fr));
  gap: var(--card-internal-gap-small);
  margin-bottom: 1.5rem;
}

.info-item {
  text-align: center;
  padding: 1rem;
  background: rgba(248, 244, 236, 0.6);
  border-radius: 12px;
}

.info-item h4 {
  margin: 0 0 0.25rem;
  font-size: 0.85rem;
  color: var(--brown);
  text-transform: uppercase;
  letter-spacing: 0.5px;
}

.info-item p {
  margin: 0;
  font-size: 0.9rem;
  color: var(--deep-green);
  font-weight: 500;
}

.package-highlights {
  padding: 0 2rem 1.5rem;
}

.package-highlights h4 {
  margin: 0 0 1rem;
  color: var(--deep-green);
  font-size: 1.1rem;
}

.package-highlights ul {
  margin: 0;
  padding: 0;
  list-style: none;
}

.package-highlights li {
  margin-bottom: 0.75rem;
  padding-left: 1.5rem;
  position: relative;
  line-height: 1.5;
  color: rgba(47, 79, 79, 0.85);
}

.package-highlights li::before {
  content: "✓";
  position: absolute;
  left: 0;
  color: var(--golden-yellow);
  font-weight: bold;
}

.package-ideal-for {
  padding: 0 2rem 1.5rem;
}

.package-ideal-for h4 {
  margin: 0 0 1rem;
  color: var(--deep-green);
  font-size: 1.1rem;
}

.ideal-tags {
  display: flex;
  flex-wrap: wrap;
  gap: 0.5rem;
}

.tag {
  display: inline-block;
  padding: 0.4rem 0.8rem;
  background: linear-gradient(135deg, var(--burnt-orange), var(--golden-yellow));
  color: #fff;
  border-radius: 20px;
  font-size: 0.8rem;
  font-weight: 500;
  text-transform: uppercase;
  letter-spacing: 0.3px;
}

.package-actions {
  padding: 1.5rem 2rem 2rem;
  display: flex;
  gap: var(--card-internal-gap-small);
  justify-content: center;
  flex-wrap: wrap;
}

.package-actions .btn {
  flex: 1;
  min-width: 140px;
  text-align: center;
}

@media (max-width: 640px) {
  .package-info {
    grid-template-columns: 1fr 1fr;
  }
  
  .package-actions {
    flex-direction: column;
  }
  
  .package-actions .btn {
    width: 100%;
  }
}

/* SUBTLE ANIMATIONS & TRANSITIONS */
/* Smooth scroll behavior */
html {
  scroll-behavior: smooth;
}

/* Enhanced touch interactions for mobile */
@media (hover: none) and (pointer: coarse) {
  .btn, .link-card, .feature-card, .package-card {
    -webkit-tap-highlight-color: rgba(204, 120, 58, 0.2);
    touch-action: manipulation;
  }
  
  .btn:active {
    transform: scale(0.98);
    transition: transform 0.1s ease;
  }
  
  .link-card:active, .feature-card:active, .package-card:active {
    transform: scale(0.99);
    transition: transform 0.1s ease;
  }
}

/* Enhanced accessibility - focus states */
.btn:focus-visible,
.submenu-toggle:focus-visible,
.menu-icon:focus-visible {
  outline: 2px solid var(--golden-yellow);
  outline-offset: 2px;
  border-radius: 4px;
}

.link-card:focus-within,
.feature-card:focus-within,
.package-card:focus-within {
  outline: 2px solid var(--golden-yellow);
  outline-offset: 2px;
  border-radius: 8px;
}

/* Skip to content link for screen readers */
.skip-link {
  position: absolute;
  top: -40px;
  left: 6px;
  background: var(--deep-green);
  color: white;
  padding: 8px;
  text-decoration: none;
  border-radius: 4px;
  z-index: 1000;
}

.skip-link:focus {
  top: 6px;
}

/* Fade-in animation for sections */
@keyframes fadeInUp {
  from {
    opacity: 0;
    transform: translateY(30px);
  }
  to {
    opacity: 1;
    transform: translateY(0);
  }
}

/* Parallax-like subtle movement on scroll */
@keyframes floatGentle {
  0%, 100% { transform: translateY(0px); }
  50% { transform: translateY(-10px); }
}

/* Subtle pulse for CTA buttons */
@keyframes subtlePulse {
  0%, 100% { transform: scale(1); }
  50% { transform: scale(1.02); }
}

/* Gentle image zoom on hover */
.gentle-zoom {
  transition: transform 0.6s cubic-bezier(0.25, 0.46, 0.45, 0.94);
}

.gentle-zoom:hover {
  transform: scale(1.05);
}

/* Root color variables */
:root {
    --brown: #8B4513;
    --khaki: #F0E68C;
    --olive-green: #556B2F;
    --beige: #F5F5DD;
    --burnt-orange: #CC5500;
    --tan: #D2B48C;
    --deep-green: #2F4F4F;
    --golden-yellow: #FFD700;
    --nav-vertical-padding: clamp(0.6rem, 1.1vw, 0.9rem);
    --nav-inner-min-height: clamp(70px, 7vw, 88px);
    --nav-header-height: calc(var(--nav-inner-min-height) + 2 * var(--nav-vertical-padding));
    --hero-overlay-primary: linear-gradient(118deg, rgba(14, 28, 26, 0.45) 0%, rgba(34, 60, 52, 0.35) 48%, rgba(204, 136, 74, 0.25) 100%);
    --hero-overlay-primary-glow: radial-gradient(circle at 20% 20%, rgba(255, 215, 0, 0.15) 0%, transparent 58%),
                                 radial-gradient(circle at 78% 82%, rgba(204, 136, 74, 0.18) 0%, transparent 62%);
    --hero-overlay-detail: rgba(12, 32, 28, 0.45);
    --hero-overlay-detail-glow: transparent;
    --hero-card-primary: linear-gradient(132deg, rgba(15, 30, 26, 0.75) 0%, rgba(36, 64, 54, 0.65) 55%, rgba(204, 120, 58, 0.45) 100%);
    --hero-card-detail: rgba(12, 28, 24, 0.75);

    /* If you want a custom gradient, you can define it here */
    --sunset-gradient: linear-gradient(90deg, #cc5500 0%, #ffd700 100%);

    /* Commonly used spacing */
    --section-padding: 3rem;
    --small-padding: 1rem;
    --medium-padding: 1.5rem;
    --large-padding: 2rem;

    /* Font preferences (adjust as needed) */
    --main-font: 'Segoe UI', Tahoma, Geneva, Verdana, sans-serif;
}

body {
    font-family: var(--main-font);
    background-color: var(--beige);
    color: var(--deep-green);
    line-height: 1.6;
}

/*********************************************
  2. GLOBAL HEADINGS, TEXT, & LINKS
**********************************************/
h1, h2, h3, h4, h5, h6 {
    font-weight: 700;
    color: var(--brown);
    margin-bottom: 0.5rem;
}

p {
    margin-bottom: 1rem;
}

a {
    text-decoration: none;
    color: var(--brown);
}

a:hover {
    opacity: 0.8; /* Simple hover effect */
}

/* Content lists */
body :where(main, section, article) ul:not([class]),
body :where(main, section, article) ol:not([class]) {
    margin: clamp(1rem, 3vw, 1.75rem) 0;
    padding: 0;
    list-style: none;
    display: grid;
    gap: 0.85rem;
}

body :where(main, section, article) ul:not([class]) li,
body :where(main, section, article) ol:not([class]) li {
    position: relative;
    padding: 0.5rem 0.75rem 0.5rem 1.75rem;
    margin-bottom: 0.5rem;
    line-height: 1.6;
    color: rgba(47, 79, 79, 0.9);
}

/* Removed hover effects for cleaner list appearance */

body :where(main, section, article) ul:not([class]) li::before,
body :where(main, section, article) ol:not([class]) li::before {
    position: absolute;
    left: 0.5rem;
    top: 0.7rem;
    font-weight: 600;
    color: var(--burnt-orange);
}

body :where(main, section, article) ul:not([class]) li::before {
    content: "•";
    font-size: 1.35rem;
}

body :where(main, section, article) ol:not([class]) {
    counter-reset: rich-ol;
}

body :where(main, section, article) ol:not([class]) li::before {
    counter-increment: rich-ol;
    content: counter(rich-ol, decimal-leading-zero);
    font-size: 0.95rem;
    letter-spacing: 0.02em;
}

.content-section--dark ul:not([class]) li,
.content-section--dark ol:not([class]) li {
    background: rgba(18, 32, 29, 0.8);
    border-color: rgba(255, 255, 255, 0.12);
    color: rgba(255, 255, 255, 0.88);
    box-shadow: 0 20px 44px rgba(5, 9, 8, 0.45);
}

.content-section--dark ul:not([class]) li::before,
.content-section--dark ol:not([class]) li::before {
    color: var(--golden-yellow);
}

body :where(main, section, article) ul:not([class]) li strong,
body :where(main, section, article) ol:not([class]) li strong {
    color: var(--deep-green, #13302a);
}

@media (max-width: 640px) {
  body :where(main, section, article) ul:not([class]) li,
  body :where(main, section, article) ol:not([class]) li {
      padding-left: clamp(2rem, 7vw, 2.6rem);
  }
}

/*********************************************
  HERO SLIDESHOW
**********************************************/
.hero {
    position: relative;
    min-height: 100vh;
    display: grid;
    align-items: center;
    justify-items: center;
    padding: clamp(5rem, 8vw, 9rem) 5% clamp(3rem, 6vw, 4.5rem);
    color: #fff;
    overflow: hidden;
}

.hero::before {
    content: "";
    position: absolute;
    inset: 0;
    background: linear-gradient(118deg, rgba(17, 29, 26, 0.85) 8%, rgba(43, 64, 54, 0.72) 45%, rgba(204, 136, 74, 0.58) 100%);
    z-index: 1;
}

.hero-slideshow,
.slideshow-container {
    position: absolute;
    inset: 0;
    overflow: hidden;
    z-index: 0;
}

.hero-slideshow .mySlides,
.slideshow-container .mySlides {
    position: absolute;
    inset: 0;
    display: none;
    height: 100%;
}

.hero-slideshow .mySlides img,
.slideshow-container .mySlides img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    transform: scale(1.03);
    filter: saturate(1.05);
}

.caption {
    position: absolute;
    left: clamp(1.5rem, 6vw, 4rem);
    bottom: clamp(2.5rem, 7vw, 5rem);
    padding: 0.75rem 1.5rem;
    border-radius: 999px;
    border: 1px solid rgba(255, 255, 255, 0.28);
    background: rgba(12, 24, 21, 0.45);
    color: #fff;
    font-size: 0.95rem;
    letter-spacing: 0.1em;
    text-transform: uppercase;
    box-shadow: 0 20px 45px rgba(0, 0, 0, 0.3);
    backdrop-filter: blur(10px);
    z-index: 2;
}

.hero-nav {
    position: absolute;
    top: 50%;
    transform: translateY(-50%);
    z-index: 3;
    width: clamp(2.75rem, 4vw, 3.5rem);
    height: clamp(2.75rem, 4vw, 3.5rem);
    border-radius: 50%;
    border: 1px solid rgba(255, 255, 255, 0.3);
    background: rgba(12, 24, 21, 0.55);
    color: #fff;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 1.6rem;
    transition: transform 0.3s ease, background 0.3s ease, box-shadow 0.3s ease;
    backdrop-filter: blur(6px);
}

.hero-nav:hover,
.hero-nav:focus-visible {
    background: rgba(255, 255, 255, 0.2);
    box-shadow: 0 20px 40px rgba(0, 0, 0, 0.35);
    transform: translateY(-50%) scale(1.08);
}

.hero-prev {
    left: clamp(1.25rem, 4vw, 3.5rem);
}

.hero-next {
    right: clamp(1.25rem, 4vw, 3.5rem);
}

.hero-dots,
.dot-container {
    position: absolute;
    bottom: clamp(1.75rem, 5vw, 3.75rem);
    left: 50%;
    transform: translateX(-50%);
    display: flex;
    gap: 0.75rem;
    z-index: 3;
}

.hero-dots .dot,
.dot-container .dot {
    width: 14px;
    height: 14px;
    border-radius: 999px;
    border: 1px solid rgba(255, 255, 255, 0.45);
    background: rgba(255, 255, 255, 0.28);
    cursor: pointer;
    transition: transform 0.3s ease, background 0.3s ease, border-color 0.3s ease;
    padding: 0;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    outline: none;
}

.hero-dots .dot:hover,
.hero-dots .dot:focus-visible,
.dot-container .dot:hover,
.dot-container .dot:focus-visible,
.hero-dots .dot.active,
.dot-container .dot.active {
    background: var(--golden-yellow);
    border-color: var(--golden-yellow);
    transform: scale(1.2);
}

.hero-overlay {
    position: relative;
    z-index: 2;
    width: min(100%, 1120px);
    display: flex;
    justify-content: center;
}

/*********************************************
  4. SECTION: WELCOME SECTION
**********************************************/
.welcome-section {
    width: 100%;
}

.welcome-content {
    position: relative;
    max-width: 960px;
    background: linear-gradient(132deg, rgba(16, 29, 26, 0.9) 0%, rgba(29, 52, 46, 0.78) 55%, rgba(204, 120, 58, 0.6) 100%);
    border: 1px solid rgba(255, 255, 255, 0.24);
    border-radius: 30px;
    padding: clamp(2rem, 4vw, 3.5rem);
    box-shadow: 0 40px 80px rgba(5, 8, 6, 0.5);
    backdrop-filter: blur(18px);
    overflow: hidden;
    margin-top: clamp(1rem, 2.5vw, 2rem);
    margin-left: auto;
    margin-right: auto;
}

.welcome-content::after {
    content: "";
    position: absolute;
    inset: 0;
    background: radial-gradient(circle at 18% 18%, rgba(255, 215, 0, 0.24) 0%, transparent 55%),
                radial-gradient(circle at 82% 82%, rgba(204, 136, 74, 0.3) 0%, transparent 60%);
    pointer-events: none;
}

.welcome-heading {
    font-size: clamp(2.3rem, 3.6vw, 3.15rem);
    color: #fff;
    letter-spacing: 0.02em;
    margin-bottom: 0.5rem;
}

.welcome-subheading {
    font-size: clamp(1.35rem, 2.6vw, 1.9rem);
    color: rgba(255, 255, 255, 0.82);
    margin-bottom: 1.5rem;
}

.welcome-text {
    font-size: 1.05rem;
    line-height: 1.75;
    color: rgba(255, 255, 255, 0.86);
    margin-bottom: 1.5rem;
}

.hero-highlights {
    list-style: none;
    display: flex;
    flex-wrap: wrap;
    gap: 0.75rem;
    margin: 1.75rem 0 0;
    padding: 0;
    justify-content: center;
}

.hero-highlights li {
    display: inline-flex;
    align-items: center;
    gap: 0.55rem;
    padding: 0.6rem 1.2rem;
    border-radius: 999px;
    border: 1px solid rgba(255, 255, 255, 0.22);
    background: rgba(255, 255, 255, 0.14);
    color: #fff;
    font-weight: 600;
    font-size: 0.94rem;
    letter-spacing: 0.01em;
    backdrop-filter: blur(6px);
}

.hero-highlights li::before {
    content: "";
    width: 0.55rem;
    height: 0.55rem;
    border-radius: 999px;
    background: var(--golden-yellow);
    box-shadow: 0 0 12px rgba(255, 215, 0, 0.7);
}

.welcome-cta {
    margin-top: 2rem;
    display: flex;
    flex-wrap: wrap;
    gap: 0.85rem;
    justify-content: center;
}

.welcome-cta .btn {
    border-radius: 999px;
    padding: 0.85rem 1.75rem;
    box-shadow: 0 18px 35px rgba(0, 0, 0, 0.25);
}

.welcome-cta .btn-outline {
    color: #fff;
    border-color: rgba(255, 255, 255, 0.6);
    background: transparent;
}

.welcome-cta .btn-outline:hover {
    background: rgba(255, 255, 255, 0.18);
    color: #fff;
}

.scroll-indicator {
    display: inline-flex;
    align-items: center;
    gap: 0.5rem;
    margin-top: 2rem;
    font-weight: 600;
    letter-spacing: 0.14em;
    text-transform: uppercase;
    font-size: 0.85rem;
    color: rgba(255, 255, 255, 0.78);
    transition: transform 0.35s ease, color 0.35s ease;
}

.scroll-indicator span {
    font-size: 1.3rem;
    animation: pulse-down 1.6s ease-in-out infinite;
}

.scroll-indicator:hover {
    color: var(--golden-yellow);
    transform: translateY(6px);
}

/*********************************************
  TRUST BAR
**********************************************/
.trust-bar {
    position: relative;
    z-index: 3;
    margin-top: -3.5rem;
    padding: 0 5% clamp(2.5rem, 5vw, 3.5rem);
}

.trust-wrap {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
    gap: var(--card-gap-standard);
    background: rgba(255, 255, 255, 0.92);
    border: 1px solid rgba(139, 69, 19, 0.12);
    border-radius: 22px;
    padding: clamp(1.4rem, 3vw, 2rem) clamp(1.8rem, 4vw, 3rem);
    box-shadow: 0 32px 55px rgba(12, 24, 21, 0.12);
    backdrop-filter: blur(12px);
    max-width: 1100px;
    margin: 0 auto;
}

.trust-item {
    display: flex;
    align-items: center;
    gap: 1rem;
}

.trust-icon {
    font-size: 1.8rem;
    filter: drop-shadow(0 6px 12px rgba(204, 85, 0, 0.25));
}

.trust-copy {
    display: flex;
    flex-direction: column;
    gap: 0.2rem;
}

.trust-title {
    font-weight: 700;
    font-size: 1rem;
    color: var(--deep-green);
    margin: 0;
}

.trust-subtitle {
    margin: 0;
    font-size: 0.92rem;
    color: rgba(47, 79, 79, 0.76);
}

/*********************************************
  HERO QUICK LINKS
**********************************************/
.hero-quick-links {
    position: relative;
    padding: clamp(2.5rem, 4vw, 3.5rem) 5% 0;
}

.quick-links-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
    gap: var(--card-gap-standard);
    max-width: 1100px;
    margin: var(--section-margin-top) auto 0;
}

.quick-link-card {
    background: rgba(255, 255, 255, 0.9);
    border: 1px solid rgba(139, 69, 19, 0.12);
    border-radius: 20px;
    padding: 1.75rem;
    box-shadow: 0 28px 50px rgba(12, 24, 21, 0.12);
    backdrop-filter: blur(10px);
    text-align: left;
    transition: transform 0.35s ease, box-shadow 0.35s ease;
}

.quick-link-card:hover,
.quick-link-card:focus-within {
    transform: translateY(-8px);
    box-shadow: 0 40px 70px rgba(12, 24, 21, 0.18);
}

.quick-link-card h3 {
    margin-bottom: 0.75rem;
    font-size: 1.3rem;
    color: var(--deep-green);
}

.quick-link-card p {
    margin-bottom: 1rem;
    color: rgba(47, 79, 79, 0.82);
    font-size: 0.98rem;
    line-height: 1.6;
}

.quick-link-cta {
    font-weight: 600;
    color: var(--burnt-orange);
    display: inline-flex;
    align-items: center;
    gap: 0.35rem;
    letter-spacing: 0.02em;
    transition: color 0.3s ease;
    text-decoration: none;
}

.quick-link-cta:hover,
.quick-link-cta:focus {
    color: var(--brown);
    text-decoration: underline;
}

/*********************************************
  SCROLL REVEAL
**********************************************/
.reveal-on-scroll {
    opacity: 0;
    transform: translateY(40px);
    transition: opacity 0.7s ease, transform 0.7s ease;
}

.reveal-on-scroll.is-visible {
    opacity: 1;
    transform: translateY(0);
}

@media (prefers-reduced-motion: reduce) {
    .reveal-on-scroll {
        opacity: 1 !important;
        transform: none !important;
    }
}

/* If using a hero image or video background */
.welcome-image img {
    width: 100%;
    height: auto;
    border-radius: 8px;
}

/*********************************************
  5. SECTION: FEATURED EXPERIENCES (CARD LAYOUT)
**********************************************/
.featured-experiences {
    padding: var(--section-padding) 5%;
    text-align: center;
}

.section-heading {
    font-size: 1.8rem;
    color: var(--brown);
    margin-bottom: 2rem;
}

.experiences-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
    gap: var(--card-gap-standard);
    margin-top: var(--section-margin-top);
}

.experience-card {
    display: flex;
    flex-direction: column;
    background: linear-gradient(180deg, rgba(255, 255, 255, 0.95) 0%, rgba(255, 250, 240, 0.9) 100%);
    border-radius: 20px;
    border: 1px solid rgba(139, 69, 19, 0.1);
    box-shadow: 0 14px 35px rgba(47, 79, 79, 0.08);
    overflow: hidden;
    text-align: left;
    transition: transform 0.35s ease, box-shadow 0.35s ease;
}

.experience-card img {
    width: 100%;
    height: 220px;
    object-fit: cover;
    display: block;
    transition: transform 0.45s ease;
}

.experience-card h3 {
    font-size: 1.3rem;
    margin: 1.5rem 1.5rem 0.75rem;
    color: var(--deep-green);
}

.experience-card p {
    margin: 0 1.5rem 1.5rem 1.5rem;
    color: rgba(47, 79, 79, 0.88);
    font-size: 0.98rem;
}

.experience-card .btn {
    margin: auto 1.5rem 1.5rem;
    border-radius: 999px;
    padding: 0.75rem 1.4rem;
    box-shadow: 0 12px 24px rgba(204, 85, 0, 0.25);
}

.experience-card:hover,
.experience-card:focus-within {
    transform: translateY(-12px);
    box-shadow: 0 28px 60px rgba(47, 79, 79, 0.22);
}

.experience-card:hover img,
.experience-card:focus-within img {
    transform: scale(1.05);
}

.section-cta {
    margin-top: 2.25rem;
    display: flex;
    justify-content: center;
    gap: 1rem;
    position: relative;
    z-index: 3;
}

.section-cta .btn {
    border-radius: 999px;
    padding: 0.75rem 1.5rem;
    box-shadow: 0 12px 24px rgba(139, 69, 19, 0.18);
}

/* ---------------------------------
   HIGHLIGHTS OF TANZANIA (2x4 GRID)
   Responsive & Centered CTA
---------------------------------- */

/* The parent container for the entire section */
.tanzania-highlights {
    padding: var(--section-padding) 5%;
    text-align: center;
  }
  
  /* The grid container for the destination cards */
  .destinations-grid {
    display: grid;
    grid-template-columns: repeat(4, 1fr); /* 4 columns on large screens */
    gap: var(--medium-padding);
    margin-top: var(--small-padding);
  }
  
  /* Each destination card */
  .destination-item {
    position: relative;
    overflow: hidden;
    border-radius: 6px;
    cursor: pointer;
    min-height: 250px; /* Adjust as needed for bigger/larger cards */
  }
  
  /* Destination images */
  .destination-item img {
    width: 100%;
    height: 100%;
    display: block;
    object-fit: cover;  /* Ensures image fills the box nicely */
    transition: transform 0.5s;
  }
  
  /* Slight zoom on hover (not too large to avoid hiding the overlay text) */
  .destination-item:hover img {
    transform: scale(1.05);
  }
  
  /* The overlay that appears from bottom */
  .destination-overlay {
    position: absolute;
    bottom: 0;
    left: 0;
    right: 0;
    background: linear-gradient(180deg, rgba(0,0,0,0) 0%, rgba(0,0,0,0.8) 100%);
    color: #fff;
    padding: 1.5rem;
    transform: translateY(100%);
    transition: transform 0.5s;
    text-align: center;   /* Center all text & the CTA here */
  }
  
  /* Reveal overlay on hover */
  .destination-item:hover .destination-overlay {
    transform: translateY(0);
  }
  
  /* Overlay text styling */
  .destination-overlay h3 {
    margin-bottom: 0.5rem;
    font-size: 1.2rem;
    color: #fff;
  }
  
  .destination-overlay p {
    margin-bottom: 1rem;
    color: #fff;
  }
  
  /* CTA in the overlay - ensure it’s centered */
  .destination-overlay .btn {
    margin: 0 auto;        /* horizontally center */
    display: inline-block; /* needed so margin:auto works properly */
  }
  
  /* ---------------------------------
     RESPONSIVE MEDIA QUERIES
  ---------------------------------- */
  
  /* For tablets or smaller desktops, show 2 columns per row */
  @media (max-width: 1024px) {
    .destinations-grid {
      grid-template-columns: repeat(2, 1fr);
    }
  }
  
  /* For mobile screens, show 1 column per row */
  @media (max-width: 600px) {
    .destinations-grid {
      grid-template-columns: 1fr;
    }
  }

/*********************************************
  WHY CHOOSE US - REDESIGNED VERSION
**********************************************/

/*********************************************
  WHY CHOOSE US - REDESIGNED VERSION
**********************************************/

.why-choose-us {
  position: relative;
  padding: clamp(4rem, 6vw, 5.5rem) 5%;
  background: linear-gradient(180deg, rgba(249, 245, 236, 1) 0%, rgba(255, 250, 240, 1) 100%);
  text-align: center;
  overflow: hidden;
}

.why-choose-us::before {
  content: "";
  position: absolute;
  inset: 0;
  background: radial-gradient(circle at 18% 12%, rgba(204, 85, 0, 0.08) 0%, transparent 45%),
              radial-gradient(circle at 82% 88%, rgba(85, 107, 47, 0.08) 0%, transparent 52%);
  opacity: 0.8;
  z-index: 0;
}

.why-choose-us .section-heading {
  position: relative;
  z-index: 1;
  margin-bottom: 40px;
  color: var(--brown);
  font-size: 2rem;
  font-weight: 700;
}

.why-slider {
  position: relative;
  z-index: 1;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: clamp(1.5rem, 4vw, 2.6rem);
  background: rgba(255, 255, 255, 0.1);
  border-radius: 32px;
  padding: clamp(1.8rem, 4.2vw, 2.6rem) clamp(1.5rem, 4vw, 2.6rem) clamp(2.4rem, 5vw, 3rem);
  box-shadow: 0 40px 80px rgba(12, 24, 21, 0.16);
  backdrop-filter: blur(12px);
}

.why-slider::before {
  content: "";
  position: absolute;
  inset: -12% -8% -18% -8%;
  background: radial-gradient(circle at 18% 20%, rgba(204, 120, 58, 0.18) 0%, transparent 58%),
              radial-gradient(circle at 82% 80%, rgba(47, 79, 79, 0.18) 0%, transparent 60%);
  filter: blur(10px);
  z-index: -1;
}

.why-slider__viewport {
  flex: 1 1 auto;
  width: 100%;
  overflow: hidden;
  position: relative;
  border-radius: 26px;
}

.why-slider__track {
  display: flex;
  gap: clamp(1.25rem, 3vw, 2rem);
  padding: clamp(0.75rem, 2vw, 1.25rem) 0;
  transition: transform 0.6s cubic-bezier(0.22, 0.61, 0.36, 1);
}

.why-slide {
  min-width: clamp(280px, 70vw, 460px);
  max-width: clamp(280px, 70vw, 460px);
  background: linear-gradient(180deg, rgba(255, 255, 255, 0.95) 0%, rgba(248, 244, 236, 0.92) 100%);
  border-radius: 26px;
  border: 1px solid rgba(139, 69, 19, 0.12);
  overflow: hidden;
  box-shadow: 0 28px 65px rgba(12, 24, 21, 0.18);
  display: flex;
  flex-direction: column;
  transform: scale(0.92);
  opacity: 0.55;
  transition: transform 0.5s cubic-bezier(0.22, 0.61, 0.36, 1),
              opacity 0.45s ease,
              box-shadow 0.45s ease,
              filter 0.45s ease;
  position: relative;
}

.why-slide img {
  width: 100%;
  height: clamp(220px, 38vw, 280px);
  object-fit: cover;
  transition: transform 0.5s cubic-bezier(0.22, 0.61, 0.36, 1), filter 0.45s ease;
}

.why-slide__content {
  padding: clamp(1.6rem, 3vw, 2.2rem);
  display: grid;
  gap: 0.85rem;
  text-align: left;
}

.why-slide.is-prev,
.why-slide.is-next {
  opacity: 0.82;
  transform: scale(0.96);
}

.why-slide.is-active {
  transform: scale(1.05);
  opacity: 1;
  box-shadow: 0 48px 120px rgba(12, 24, 21, 0.28);
  z-index: 2;
}

.why-slide.is-active img {
  transform: scale(1.04);
}

.why-slide.is-prev img,
.why-slide.is-next img {
  transform: scale(1.02);
  filter: saturate(1.05);
}

.why-slide::after {
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(180deg, transparent 60%, rgba(204, 120, 58, 0.12) 100%);
  opacity: 0;
  transition: opacity 0.45s ease;
}

.why-slide.is-active::after {
  opacity: 1;
}

.why-slide__content h3 {
  margin: 0;
  font-size: clamp(1.5rem, 3vw, 1.9rem);
  color: var(--deep-green);
}

.why-slide__content p {
  margin: 0;
  font-size: clamp(1rem, 2vw, 1.12rem);
  line-height: 1.8;
  color: rgba(47, 79, 79, 0.82);
}

.why-slider__controls {
  width: 100%;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: clamp(1rem, 3vw, 2rem);
  flex-wrap: wrap;
}

.why-slider__nav {
  flex: 0 0 auto;
  min-width: clamp(48px, 9vw, 56px);
  height: clamp(48px, 9vw, 56px);
  border-radius: 50%;
  border: 1px solid rgba(255, 255, 255, 0.35);
  background: rgba(12, 24, 21, 0.6);
  color: #fff;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-size: clamp(1.5rem, 3vw, 1.9rem);
  cursor: pointer;
  transition: transform 0.3s ease, background 0.3s ease, border-color 0.3s ease;
}

.why-slider__nav:hover,
.why-slider__nav:focus-visible {
  transform: translateY(-2px);
  background: rgba(204, 120, 58, 0.85);
  border-color: rgba(255, 255, 255, 0.6);
}

.why-slider__dots {
  display: flex;
  justify-content: center;
  gap: 0.65rem;
}

.why-slider__dot {
  width: 10px;
  height: 10px;
  border-radius: 50%;
  border: none;
  background: rgba(255, 255, 255, 0.35);
  cursor: pointer;
  transition: transform 0.3s ease, background 0.3s ease;
}

.why-slider__dot[aria-selected="true"],
.why-slider__dot:hover,
.why-slider__dot:focus-visible {
  background: var(--golden-yellow);
  transform: scale(1.25);
}

.why-slider[data-paused="true"] .why-slider__nav {
  background: rgba(12, 24, 21, 0.7);
}

@media (max-width: 1024px) {
  .why-slider__viewport {
    width: 100%;
  }
}

@media (max-width: 640px) {
  .why-slider__nav {
    width: 40px;
    height: 40px;
    font-size: 1.4rem;
  }

  .why-slide {
    min-width: 86vw;
    max-width: 86vw;
  }

  .why-slide img {
    height: clamp(200px, 55vw, 240px);
  }
}

/*********************************************
  8. SECTION: ADVENTURE ACTIVITIES
**********************************************/
.adventure-activities {
    position: relative;
    padding: clamp(4rem, 6vw, 5.5rem) 5%;
    text-align: center;
    background: linear-gradient(180deg, rgba(255, 250, 240, 1) 0%, rgba(245, 245, 221, 1) 100%);
    overflow: hidden;
}

.adventure-activities::before {
    content: "";
    position: absolute;
    inset: 0;
    background: radial-gradient(circle at 15% 18%, rgba(204, 85, 0, 0.08) 0%, transparent 45%),
                radial-gradient(circle at 80% 82%, rgba(85, 107, 47, 0.08) 0%, transparent 50%);
    opacity: 0.85;
    z-index: 0;
}

.activities-scroller {
    position: relative;
    z-index: 1;
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(240px, 1fr));
    gap: 2rem;
    margin: clamp(2rem, 4vw, 3rem) auto 0;
    max-width: 1200px;
}

.activity-card {
    background: rgba(255, 255, 255, 0.9);
    border: 1px solid rgba(139, 69, 19, 0.12);
    border-radius: 22px;
    overflow: hidden;
    text-align: left;
    display: flex;
    flex-direction: column;
    box-shadow: 0 30px 60px rgba(12, 24, 21, 0.14);
    transition: transform 0.45s ease, box-shadow 0.45s ease;
    backdrop-filter: blur(10px);
}

.activity-card:hover,
.activity-card:focus-within {
    transform: translateY(-10px);
    box-shadow: 0 40px 88px rgba(12, 24, 21, 0.2);
}

.activity-card img {
    width: 100%;
    height: 240px;
    object-fit: cover;
    transition: transform 0.5s ease;
}

.activity-card:hover img,
.activity-card:focus-within img {
    transform: scale(1.06);
}

.activity-card h3 {
    font-size: 1.3rem;
    margin: 1.5rem 1.5rem 0.75rem;
    color: var(--deep-green);
}

.activity-card p {
    margin: 0 1.5rem 1.5rem;
    color: rgba(47, 79, 79, 0.82);
    font-size: 0.98rem;
}

.activity-card .btn {
    margin: 0 1.5rem 1.75rem;
    align-self: flex-start;
}

/*********************************************
  FAQ SECTION
**********************************************/
.faq-section {
    padding: clamp(3.5rem, 6vw, 5rem) 5%;
    background: rgba(245, 245, 221, 0.6);
}

.faq-grid {
    max-width: 900px;
    margin: 0 auto;
    display: grid;
    gap: 1.25rem;
}

.faq-item {
    border: 1px solid rgba(139, 69, 19, 0.18);
    border-radius: 16px;
    background: #fff;
    box-shadow: 0 18px 40px rgba(12, 24, 21, 0.08);
    padding: 1.1rem 1.35rem;
    transition: border-color 0.3s ease, box-shadow 0.3s ease;
}

.faq-item summary {
    cursor: pointer;
    font-weight: 600;
    font-size: 1.05rem;
    color: var(--deep-green);
    list-style: none;
    position: relative;
    padding-right: 2rem;
}

.faq-item summary::-webkit-details-marker {
    display: none;
}

.faq-item summary::after {
    content: "+";
    position: absolute;
    right: 0;
    top: 0;
    font-size: 1.2rem;
    transition: transform 0.3s ease;
}

.faq-item[open] summary::after {
    transform: rotate(45deg);
}

.faq-item p {
    margin-top: 0.85rem;
    font-size: 0.98rem;
    line-height: 1.7;
    color: rgba(47, 79, 79, 0.85);
}

.faq-item:focus-within,
.faq-item:hover {
    border-color: rgba(204, 85, 0, 0.4);
    box-shadow: 0 24px 50px rgba(12, 24, 21, 0.12);
}

/*********************************************
  9. SECTION: TESTIMONIALS
**********************************************/
.testimonials-section {
    padding: var(--section-padding) 5%;
    text-align: center;
    background: linear-gradient(180deg, rgba(245, 245, 221, 1) 0%, rgba(255, 250, 240, 1) 100%);
}

.testimonials-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
    gap: var(--card-gap-standard);
    margin: var(--section-margin-top) auto 0;
    max-width: 1100px;
}

.testimonial-card {
    background: rgba(255, 255, 255, 0.92);
    border: 1px solid rgba(139, 69, 19, 0.12);
    border-radius: 22px;
    padding: 2rem;
    box-shadow: 0 28px 60px rgba(12, 24, 21, 0.12);
    text-align: left;
    backdrop-filter: blur(10px);
}

.testimonial-card blockquote {
    font-style: italic;
    margin-bottom: 1rem;
    color: rgba(47, 79, 79, 0.9);
    line-height: 1.7;
}

.testimonial-author {
    font-weight: 600;
    color: var(--brown);
}

.testimonial-rating {
    display: inline-block;
    margin-bottom: 0.75rem;
    color: var(--golden-yellow);
    letter-spacing: 0.2em;
    font-size: 0.9rem;
}

.testimonial-cta {
    margin-top: 2rem;
}

@keyframes pulse-down {
    0%, 100% { transform: translateY(0); }
    50% { transform: translateY(6px); }
}

/*********************************************
  11. RESPONSIVE MEDIA QUERIES
**********************************************/
@media (max-width: 1024px) {
    .welcome-content {
        padding: clamp(2rem, 4vw, 2.8rem);
    }
    .trust-bar {
        margin-top: -2.5rem;
    }
}

@media (max-width: 768px) {
    .hero-highlights {
        flex-direction: column;
    }
    .hero-highlights li {
        width: 100%;
        justify-content: flex-start;
    }
    .welcome-cta {
        justify-content: flex-start;
    }
    .section-cta {
        flex-direction: column;
    }
    .section-cta .btn {
        width: 100%;
        justify-content: center;
    }
    .trust-bar {
        margin-top: 1.5rem;
        padding: 0 1.5rem 2.5rem;
    }
    .trust-wrap {
        padding: 1.4rem 1.6rem;
        gap: 1rem;
    }
}

@media (max-width: 600px) {
    .hero {
        padding: 5rem 1.5rem 3rem;
    }
    .welcome-section {
        padding: 3rem 1.5rem;
    }
    .welcome-content {
        padding: 2rem 1.5rem;
    }
    .scroll-indicator {
        margin-top: 1.5rem;
    }
    .trust-wrap {
        grid-template-columns: 1fr;
        text-align: left;
    }
}
/*********************************************
  HONEYMOON SAFARIS PAGE STYLES
**********************************************/

  /* INTRO SECTION */
  .honeymoon-intro {
    padding: 2rem 5%;
    background: #fff;
    text-align: center;
  }
  .honeymoon-intro h2 {
    margin-bottom: 1rem;
    color: var(--brown);
  }
  .honeymoon-intro p {
    max-width: 900px;
    margin: 0 auto;
    line-height: 1.8;
    text-align: left;
  }
  
  /* WHO SHOULD GO SECTION */
  .honeymoon-whoshouldgo {
    padding: clamp(2rem, 4vw, 3rem) 5%;
    background: var(--beige);
  }
  .honeymoon-whoshouldgo h2 {
    margin-bottom: clamp(1rem, 2vw, 1.5rem);
    color: var(--brown);
    text-align: center;
    font-size: clamp(1.8rem, 3vw, 2.2rem);
  }
  .honeymoon-whoshouldgo p {
    max-width: 900px;
    margin: 0 auto clamp(1rem, 2vw, 1.5rem) auto;
    line-height: 1.8;
    text-align: left;
  }
  .honeymoon-whoshouldgo ul {
    max-width: 600px;
    margin: clamp(1rem, 2vw, 1.5rem) auto;
    text-align: left;
    line-height: 1.8;
    list-style: disc outside;
    padding-left: 1.2rem;
  }
  
  /* WHERE TO EXPERIENCE SECTION */
  .honeymoon-where {
    padding: 2rem 5%;
    background: #fff;
    text-align: center;
  }
  .honeymoon-where h2 {
    margin-bottom: 1rem;
    color: var(--brown);
  }
  .honeymoon-where p {
    max-width: 900px;
    margin: 0 auto;
    line-height: 1.8;
    text-align: left;
  }
  
  /* WHEN TO GO SECTION */
  .honeymoon-besttime {
    padding: 2rem 5%;
    background: var(--beige);
    text-align: center;
  }
  .honeymoon-besttime h2 {
    margin-bottom: 1rem;
    color: var(--brown);
  }
  .honeymoon-besttime p {
    max-width: 900px;
    margin: 0 auto 1rem auto;
    line-height: 1.8;
    text-align: left;
  }
  .honeymoon-besttime-grid {
    display: flex;
    flex-wrap: wrap;
    gap: 2rem;
    max-width: 700px;
    margin: 1rem auto;
    justify-content: center;
    text-align: center;
  }
  .besttime-item {
    flex: 1 1 220px;
    background: var(--beige);
    border-radius: 6px;
    box-shadow: 0 2px 5px rgba(0,0,0,0.1);
    padding: 1rem;
  }
  
  /* CTA BANNER */
  .cta-banner-content {
    max-width: 900px;
    margin: 0 auto;
  }
  .cta-banner-content h2 {
    margin-bottom: 1rem;
    font-size: 2rem;
  }
  
  /* ACCOMMODATIONS SECTION */
  .honeymoon-accommodations {
    padding: 2rem 5%;
    background: #fff;
    text-align: center;
  }
  .honeymoon-accommodations h2 {
    margin-bottom: 1rem;
    color: var(--brown);
  }
  .honeymoon-accommodations p {
    max-width: 900px;
    margin: 0 auto;
    line-height: 1.8;
    text-align: left;
  }
  
  /* HIGHLIGHTS SECTION */
  .honeymoon-highlights {
    padding: 2rem 5%;
    background: var(--beige);
    text-align: center;
  }
  .honeymoon-highlights h2 {
    margin-bottom: 1rem;
    color: var(--brown);
  }
  .honeymoon-highlights p {
    max-width: 900px;
    margin: 0 auto;
    line-height: 1.8;
    text-align: left;
  }
  
  /* HONEYMOON DETAILS SECTION */
  .honeymoon-details {
    padding: 2rem 5%;
    background: #fff;
    text-align: center;
  }
  .honeymoon-details h2 {
    margin-bottom: 1rem;
    color: var(--brown);
  }
  .honeymoon-details p {
    max-width: 900px;
    margin: 0 auto;
    line-height: 1.8;
    text-align: left;
  }
  
  /* FINAL CTA SECTION */
  .honeymoon-final-cta {
    padding: 2rem 5%;
    background: var(--beige);
    text-align: center;
  }
  .honeymoon-final-cta h2 {
    margin-bottom: 1rem;
    color: var(--brown);
  }
  .honeymoon-final-cta p {
    max-width: 900px;
    margin: 0 auto 1.5rem auto;
    line-height: 1.8;
    text-align: left;
  }
  .final-cta-buttons {
    display: flex;
    gap: 1rem;
    flex-wrap: wrap;
    justify-content: center;
  }
  
  /* RESPONSIVE BREAKPOINTS */
  @media (max-width: 768px) {
    .honeymoon-besttime-grid {
      flex-direction: column;
      align-items: center;
    }
    .honeymoon-whoshouldgo ul {
      list-style-position: outside;
      padding-left: 1.5rem;
    }
  }
/*********************************************
  KATAVI NATIONAL PARK PAGE STYLES
**********************************************/

/* HERO SECTION */
.katavi-hero {
    position: relative;
    height: 80vh;
    overflow: hidden;
  }
  .katavi-hero-image {
    width: 100%;
    height: 100%;
    object-fit: cover;
  }
  .katavi-hero-overlay {
    position: absolute;
    inset: 0;
    background: rgba(0,0,0,0.3);
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    color: #fff;
    text-align: center;
    padding: 1rem;
  }
  .katavi-hero-overlay h1 {
    font-size: 2.5rem;
    margin-bottom: 0.5rem;
  }
  .katavi-hero-overlay p {
    font-size: 1.2rem;
  }
  
  /* AT A GLANCE SECTION */
  .katavi-glance {
    padding: 2rem 5%;
    background: var(--beige);
    text-align: center;
  }
  .katavi-glance h2 {
    margin-bottom: 1rem;
    color: var(--brown);
  }
  .glance-grid {
    max-width: 700px;
    margin: 0 auto;
    display: flex;
    gap: 1.5rem;
    flex-wrap: wrap;
    justify-content: center;
  }
  .glance-item {
    flex: 1 1 200px;
    background: #fff;
    border-radius: 6px;
    box-shadow: 0 2px 5px rgba(0,0,0,0.1);
    padding: 1rem;
    text-align: center;
  }
  .glance-item strong {
    display: block;
    margin-bottom: 0.5rem;
    color: var(--brown);
  }
  
  /* INTRO SECTION */
  .katavi-intro {
    padding: 2rem 5%;
    background: #fff;
    text-align: center;
  }
  .katavi-intro h2 {
    margin-bottom: 1rem;
    color: var(--brown);
  }
  .katavi-intro p {
    max-width: 900px;
    margin: 0 auto;
    line-height: 1.8;
    text-align: left;
  }
  
  /* HIGHLIGHTS SECTION */
  .katavi-highlights {
    padding: 2rem 5%;
    background: var(--beige);
    text-align: center;
  }
  .katavi-highlights h2 {
    margin-bottom: 1rem;
    color: var(--brown);
  }
  .katavi-highlights p {
    max-width: 900px;
    margin: 0 auto 1rem auto;
    line-height: 1.8;
    text-align: left;
  }
  
  /* WHEN TO GO */
  .katavi-best-time {
    padding: 2rem 5%;
    background: #fff;
    text-align: center;
  }
  .katavi-best-time h2 {
    margin-bottom: 1rem;
    color: var(--brown);
  }
  .katavi-best-time p {
    max-width: 900px;
    margin: 0 auto 1rem auto;
    line-height: 1.8;
    text-align: left;
  }
  .katavi-best-time-grid {
    display: flex;
    gap: 2rem;
    max-width: 700px;
    margin: 1rem auto;
    flex-wrap: wrap;
    justify-content: center;
  }
  .best-time-item {
    flex: 1 1 220px;
    background: var(--beige);
    padding: 1rem;
    text-align: center;
    border: 1px solid #ddd;
    border-radius: 6px;
    box-shadow: 0 2px 3px rgba(0,0,0,0.1);
    margin-bottom: 1rem;
  }
  
  /* WHY GO SECTION */
  .katavi-why-go {
    padding: 2rem 5%;
    background: var(--beige);
    text-align: center;
  }
  .katavi-why-go h2 {
    margin-bottom: 1rem;
    color: var(--brown);
  }
  .katavi-why-go p {
    max-width: 900px;
    margin: 0 auto;
    line-height: 1.8;
    text-align: left;
  }
  .testimonials {
    max-width: 900px;
    margin: 1rem auto;
    text-align: left;
  }
  .testimonials blockquote {
    background: #fff;
    border-left: 4px solid var(--brown);
    padding: 1rem;
    border-radius: 4px;
    margin: 0.5rem 0;
  }
  .testimonials cite {
    display: block;
    text-align: right;
    margin-top: 0.5rem;
    color: #555;
    font-style: italic;
  }
  
  /* THINGS TO DO SECTION */
  .katavi-things {
    padding: 2rem 5%;
    background: #fff;
    text-align: center;
  }
  .katavi-things h2 {
    margin-bottom: 1rem;
    color: var(--brown);
  }
  .katavi-things p {
    max-width: 900px;
    margin: 0 auto;
    line-height: 1.8;
    text-align: left;
  }
  
  /* WILDLIFE SECTION */
  .katavi-wildlife {
    padding: 2rem 5%;
    background: var(--beige);
    text-align: center;
  }
  .katavi-wildlife h2 {
    margin-bottom: 1rem;
    color: var(--brown);
  }
  .katavi-wildlife p {
    max-width: 900px;
    margin: 0 auto 1rem auto;
    line-height: 1.8;
    text-align: left;
  }
  
  /* WHERE TO STAY SECTION */
  .katavi-where {
    padding: 2rem 5%;
    background: #fff;
    text-align: center;
  }
  .katavi-where h2 {
    margin-bottom: 1rem;
    color: var(--brown);
  }
  .katavi-where p {
    max-width: 900px;
    margin: 0 auto 1rem auto;
    line-height: 1.8;
    text-align: left;
  }
  
  /* FINAL CTA */
  .katavi-final-cta {
    padding: 2rem 5%;
    background: var(--beige);
    text-align: center;
  }
  .katavi-final-cta h2 {
    margin-bottom: 1rem;
    color: var(--brown);
  }
  .katavi-final-cta p {
    max-width: 900px;
    margin: 0 auto 1.5rem auto;
    line-height: 1.8;
    text-align: left;
  }
  .final-cta-buttons {
    display: flex;
    flex-wrap: wrap;
    gap: 1rem;
    justify-content: center;
  }
  
  /* RESPONSIVE MEDIA QUERIES */
  @media (max-width: 768px) {
    .katavi-best-time-grid {
      flex-direction: column;
      align-items: center;
    }
  }/*********************************************
  KILIMANJARO DETAIL REFINEMENTS
**********************************************/

.page-hero--kilimanjaro .page-hero__overlay {
  background: linear-gradient(118deg, rgba(18, 28, 44, 0.9) 8%, rgba(42, 60, 76, 0.75) 48%, rgba(214, 143, 74, 0.58) 100%);
}

.page-hero--kilimanjaro .page-hero__content {
  background: linear-gradient(132deg, rgba(16, 28, 44, 0.92) 0%, rgba(38, 60, 76, 0.78) 55%, rgba(214, 143, 74, 0.62) 100%);
}

#kilimanjaro-highlights .feature-card img,
#kilimanjaro-faq .feature-card img {
  height: clamp(170px, 28vw, 210px);
}

#kilimanjaro-routes .split-feature + .split-feature {
  margin-top: var(--card-gap-compact);
}

@media (max-width: 720px) {
  #kilimanjaro-highlights .feature-card img,
  #kilimanjaro-faq .feature-card img {
    height: 190px;
  }
}
/*********************************************
  KITULO PLATEAU NATIONAL PARK PAGE STYLES
**********************************************/

/* HERO SECTION */
.kitulo-hero {
    position: relative;
    height: 80vh;
    overflow: hidden;
  }
  .kitulo-hero-image {
    width: 100%;
    height: 100%;
    object-fit: cover;
  }
  .kitulo-hero-overlay {
    position: absolute;
    inset: 0;
    background: rgba(0, 0, 0, 0.3);
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    color: #fff;
    text-align: center;
    padding: 1rem;
  }
  .kitulo-hero-overlay h1 {
    font-size: 2.5rem;
    margin-bottom: 0.5rem;
  }
  .kitulo-hero-overlay p {
    font-size: 1.2rem;
  }
  
  /* AT A GLANCE SECTION */
  .kitulo-glance {
    padding: 2rem 5%;
    background: var(--beige);
    text-align: center;
  }
  .kitulo-glance h2 {
    margin-bottom: 1rem;
    color: var(--brown);
  }
  .glance-grid {
    max-width: 700px;
    margin: 0 auto;
    display: flex;
    gap: 1.5rem;
    flex-wrap: wrap;
    justify-content: center;
  }
  .glance-item {
    flex: 1 1 200px;
    background: #fff;
    border-radius: 6px;
    box-shadow: 0 2px 5px rgba(0, 0, 0, 0.1);
    padding: 1rem;
    text-align: center;
  }
  .glance-item strong {
    display: block;
    margin-bottom: 0.5rem;
    color: var(--brown);
  }
  
  /* INTRO SECTION */
  .kitulo-intro {
    padding: 2rem 5%;
    background: #fff;
    text-align: center;
  }
  .kitulo-intro h2 {
    margin-bottom: 1rem;
    color: var(--brown);
  }
  .kitulo-intro p {
    max-width: 900px;
    margin: 0 auto;
    line-height: 1.8;
    text-align: left;
  }
  
  /* HIGHLIGHTS SECTION */
  .kitulo-highlights {
    padding: 2rem 5%;
    background: #fff;
    text-align: center;
  }
  .kitulo-highlights h2 {
    margin-bottom: 1rem;
    color: var(--brown);
  }
  .kitulo-highlights p {
    max-width: 900px;
    margin: 0 auto;
    line-height: 1.8;
    text-align: left;
  }
  
  /* BEST TIME SECTION */
  .kitulo-best-time {
    padding: 2rem 5%;
    background: var(--beige);
    text-align: center;
  }
  .kitulo-best-time h2 {
    margin-bottom: 1rem;
    color: var(--brown);
  }
  .kitulo-best-time p {
    max-width: 900px;
    margin: 0 auto 1rem auto;
    line-height: 1.8;
    text-align: left;
  }
  .kitulo-best-time-grid {
    display: flex;
    gap: 2rem;
    max-width: 700px;
    margin: 1rem auto;
    flex-wrap: wrap;
    justify-content: center;
  }
  .best-time-item {
    flex: 1 1 220px;
    background: var(--beige);
    padding: 1rem;
    text-align: center;
    border: 1px solid #ddd;
    border-radius: 6px;
    box-shadow: 0 2px 3px rgba(0, 0, 0, 0.1);
    margin-bottom: 1rem;
  }
  
  /* WHY GO SECTION */
  .kitulo-why-go {
    padding: 2rem 5%;
    background: #fff;
    text-align: center;
  }
  .kitulo-why-go h2 {
    margin-bottom: 1rem;
    color: var(--brown);
  }
  .kitulo-why-go p {
    max-width: 900px;
    margin: 0 auto 1rem auto;
    line-height: 1.8;
    text-align: left;
  }
  
  /* THINGS TO DO SECTION */
  .kitulo-things {
    padding: 2rem 5%;
    background: var(--beige);
    text-align: center;
  }
  .kitulo-things h2 {
    margin-bottom: 1rem;
    color: var(--brown);
  }
  .kitulo-things p {
    max-width: 900px;
    margin: 0 auto;
    line-height: 1.8;
    text-align: left;
  }
  
  /* WILDLIFE SECTION */
  .kitulo-wildlife {
    padding: 2rem 5%;
    background: #fff;
    text-align: center;
  }
  .kitulo-wildlife h2 {
    margin-bottom: 1rem;
    color: var(--brown);
  }
  .kitulo-wildlife p {
    max-width: 900px;
    margin: 0 auto 1rem auto;
    line-height: 1.8;
    text-align: left;
  }
  
  /* WHERE TO STAY / LOCATION SECTION */
  .kitulo-where {
    padding: 2rem 5%;
    background: var(--beige);
    text-align: center;
  }
  .kitulo-where h2 {
    margin-bottom: 1rem;
    color: var(--brown);
  }
  .kitulo-where p {
    max-width: 900px;
    margin: 0 auto 1rem auto;
    line-height: 1.8;
    text-align: left;
  }
  
  /* FINAL CTA */
  .kitulo-final-cta {
    padding: 2rem 5%;
    background: #fff;
    text-align: center;
  }
  .kitulo-final-cta h2 {
    margin-bottom: 1rem;
    color: var(--brown);
  }
  .kitulo-final-cta p {
    max-width: 900px;
    margin: 0 auto 1.5rem auto;
    line-height: 1.8;
    text-align: left;
  }
  .final-cta-buttons {
    display: flex;
    flex-wrap: wrap;
    gap: 1rem;
    justify-content: center;
  }
  
  /* RESPONSIVE BREAKPOINTS */
  @media (max-width: 768px) {
    .kitulo-best-time-grid {
      flex-direction: column;
      align-items: center;
    }
  }/*********************************************
  LAKE MANYARA NATIONAL PARK PAGE STYLES
**********************************************/

/* HERO SECTION */
.manyara-hero {
    position: relative;
    height: 80vh;
    overflow: hidden;
  }
  .manyara-hero-image {
    width: 100%;
    height: 100%;
    object-fit: cover;
  }
  .manyara-hero-overlay {
    position: absolute;
    inset: 0;
    background: rgba(0,0,0,0.3);
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    color: #fff;
    text-align: center;
    padding: 1rem;
  }
  .manyara-hero-overlay h1 {
    font-size: 2.5rem;
    margin-bottom: 0.5rem;
  }
  .manyara-hero-overlay p {
    font-size: 1.2rem;
  }
  
  /* AT A GLANCE SECTION */
  .manyara-glance {
    padding: 2rem 5%;
    background: var(--beige);
    text-align: center;
  }
  .manyara-glance h2 {
    margin-bottom: 1rem;
    color: var(--brown);
  }
  .glance-grid {
    max-width: 700px;
    margin: 0 auto;
    display: flex;
    gap: 1.5rem;
    flex-wrap: wrap;
    justify-content: center;
  }
  .glance-item {
    flex: 1 1 200px;
    background: #fff;
    border-radius: 6px;
    box-shadow: 0 2px 5px rgba(0,0,0,0.1);
    padding: 1rem;
    text-align: center;
  }
  .glance-item strong {
    display: block;
    margin-bottom: 0.5rem;
    color: var(--brown);
  }
  
  /* INTRO SECTION */
  .manyara-intro {
    padding: 2rem 5%;
    background: #fff;
    text-align: center;
  }
  .manyara-intro h2 {
    margin-bottom: 1rem;
    color: var(--brown);
  }
  .manyara-intro p {
    max-width: 900px;
    margin: 0 auto;
    line-height: 1.8;
    text-align: left;
  }
  
  /* OVERVIEW SECTION */
  .manyara-overview {
    padding: 2rem 5%;
    background: var(--beige);
    text-align: center;
  }
  .manyara-overview h2 {
    margin-bottom: 1rem;
    color: var(--brown);
  }
  .manyara-overview p {
    max-width: 900px;
    margin: 0 auto 1rem auto;
    line-height: 1.8;
    text-align: left;
  }
  
  /* HIGHLIGHTS SECTION */
  .manyara-highlights {
    padding: 2rem 5%;
    background: #fff;
    text-align: center;
  }
  .manyara-highlights h2 {
    margin-bottom: 1rem;
    color: var(--brown);
  }
  .manyara-highlights p {
    max-width: 900px;
    margin: 0 auto;
    line-height: 1.8;
    text-align: left;
  }
  
  /* BEST TIME SECTION */
  .manyara-best-time {
    padding: 2rem 5%;
    background: var(--beige);
    text-align: center;
  }
  .manyara-best-time h2 {
    margin-bottom: 1rem;
    color: var(--brown);
  }
  .manyara-best-time p {
    max-width: 900px;
    margin: 0 auto;
    line-height: 1.8;
    text-align: left;
  }
  .manyara-best-time-grid {
    display: flex;
    gap: 2rem;
    max-width: 700px;
    margin: 1rem auto;
    flex-wrap: wrap;
    justify-content: center;
  }
  .best-time-item {
    flex: 1 1 220px;
    background: var(--beige);
    padding: 1rem;
    text-align: center;
    border: 1px solid #ddd;
    border-radius: 6px;
    box-shadow: 0 2px 3px rgba(0,0,0,0.1);
    margin-bottom: 1rem;
  }
  
  /* WHY GO SECTION */
  .manyara-why-go {
    padding: 2rem 5%;
    background: #fff;
    text-align: center;
  }
  .manyara-why-go h2 {
    margin-bottom: 1rem;
    color: var(--brown);
  }
  .manyara-why-go p {
    max-width: 900px;
    margin: 0 auto 1rem auto;
    line-height: 1.8;
    text-align: left;
  }
  
  /* THINGS TO DO SECTION */
  .manyara-things {
    padding: 2rem 5%;
    background: var(--beige);
    text-align: center;
  }
  .manyara-things h2 {
    margin-bottom: 1rem;
    color: var(--brown);
  }
  .manyara-things p {
    max-width: 900px;
    margin: 0 auto;
    line-height: 1.8;
    text-align: left;
  }
  
  /* WILDLIFE SECTION */
  .manyara-wildlife {
    padding: 2rem 5%;
    background: #fff;
    text-align: center;
  }
  .manyara-wildlife h2 {
    margin-bottom: 1rem;
    color: var(--brown);
  }
  .manyara-wildlife p {
    max-width: 900px;
    margin: 0 auto 1rem auto;
    line-height: 1.8;
    text-align: left;
  }
  
  /* WHERE TO STAY / LOCATION SECTION */
  .manyara-where {
    padding: 2rem 5%;
    background: var(--beige);
    text-align: center;
  }
  .manyara-where h2 {
    margin-bottom: 1rem;
    color: var(--brown);
  }
  .manyara-where p {
    max-width: 900px;
    margin: 0 auto 1rem auto;
    line-height: 1.8;
    text-align: left;
  }
  
  /* FINAL CTA */
  .manyara-final-cta {
    padding: 2rem 5%;
    background: #fff;
    text-align: center;
  }
  .manyara-final-cta h2 {
    margin-bottom: 1rem;
    color: var(--brown);
  }
  .manyara-final-cta p {
    max-width: 900px;
    margin: 0 auto 1.5rem auto;
    line-height: 1.8;
    text-align: left;
  }
  .final-cta-buttons {
    display: flex;
    flex-wrap: wrap;
    gap: 1rem;
    justify-content: center;
  }
  
  /* RESPONSIVE BREAKPOINTS */
  @media (max-width: 768px) {
    .manyara-best-time-grid {
      flex-direction: column;
      align-items: center;
    }
  }/*********************************************
  LAKE NATRON & OL DOINYO LENGAI PAGE STYLES
**********************************************/

/* HERO SECTION */
.natron-hero {
    position: relative;
    height: 80vh;
    overflow: hidden;
  }
  .natron-hero-image {
    width: 100%;
    height: 100%;
    object-fit: cover;
  }
  .natron-hero-overlay {
    position: absolute;
    inset: 0;
    background: rgba(0,0,0,0.3);
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    color: #fff;
    text-align: center;
    padding: 1rem;
  }
  .natron-hero-overlay h1 {
    font-size: 2.5rem;
    margin-bottom: 0.5rem;
  }
  .natron-hero-overlay p {
    font-size: 1.2rem;
  }
  
  /* AT A GLANCE SECTION */
  .natron-glance {
    padding: 2rem 5%;
    background: var(--beige);
    text-align: center;
  }
  .natron-glance h2 {
    margin-bottom: 1rem;
    color: var(--brown);
  }
  .glance-grid {
    max-width: 700px;
    margin: 0 auto;
    display: flex;
    gap: 1.5rem;
    flex-wrap: wrap;
    justify-content: center;
  }
  .glance-item {
    flex: 1 1 200px;
    background: #fff;
    border-radius: 6px;
    box-shadow: 0 2px 5px rgba(0,0,0,0.1);
    padding: 1rem;
    text-align: center;
  }
  .glance-item strong {
    display: block;
    margin-bottom: 0.5rem;
    color: var(--brown);
  }
  
  /* INTRO SECTION */
  .natron-intro {
    padding: 2rem 5%;
    background: #fff;
    text-align: center;
  }
  .natron-intro h2 {
    margin-bottom: 1rem;
    color: var(--brown);
  }
  .natron-intro p {
    max-width: 900px;
    margin: 0 auto;
    line-height: 1.8;
    text-align: left;
  }
  
  /* OVERVIEW SECTION */
  .natron-overview {
    padding: 2rem 5%;
    background: var(--beige);
    text-align: center;
  }
  .natron-overview h2 {
    margin-bottom: 1rem;
    color: var(--brown);
  }
  .natron-overview p {
    max-width: 900px;
    margin: 0 auto 1rem auto;
    line-height: 1.8;
    text-align: left;
  }
  
  /* OL DOINYO LENGAI SECTION */
  .natron-lengai {
    padding: 2rem 5%;
    background: #fff;
    text-align: center;
  }
  .natron-lengai h2 {
    margin-bottom: 1rem;
    color: var(--brown);
  }
  .natron-lengai p {
    max-width: 900px;
    margin: 0 auto;
    line-height: 1.8;
    text-align: left;
  }
  
  /* ENGARE SERO SECTION */
  .natron-engare-sero {
    padding: 2rem 5%;
    background: var(--beige);
    text-align: center;
  }
  .natron-engare-sero h2 {
    margin-bottom: 1rem;
    color: var(--brown);
  }
  .natron-engare-sero p {
    max-width: 900px;
    margin: 0 auto;
    line-height: 1.8;
    text-align: left;
  }
  
  /* FLAMINGOS SECTION */
  .natron-flamingos {
    padding: 2rem 5%;
    background: #fff;
    text-align: center;
  }
  .natron-flamingos h2 {
    margin-bottom: 1rem;
    color: var(--brown);
  }
  .natron-flamingos p {
    max-width: 900px;
    margin: 0 auto 1rem auto;
    line-height: 1.8;
    text-align: left;
  }
  
  /* ACTIVITIES SECTION */
  .natron-activities {
    padding: 2rem 5%;
    background: var(--beige);
    text-align: center;
  }
  .natron-activities h2 {
    margin-bottom: 1rem;
    color: var(--brown);
  }
  .natron-activities p {
    max-width: 900px;
    margin: 0 auto;
    line-height: 1.8;
    text-align: left;
  }
  
  /* BEST TIME SECTION */
  .natron-best-time {
    padding: 2rem 5%;
    background: #fff;
    text-align: center;
  }
  .natron-best-time h2 {
    margin-bottom: 1rem;
    color: var(--brown);
  }
  .natron-best-time p {
    max-width: 900px;
    margin: 0 auto 1rem auto;
    line-height: 1.8;
    text-align: left;
  }
  .natron-best-time-grid {
    display: flex;
    gap: 2rem;
    max-width: 700px;
    margin: 1rem auto;
    flex-wrap: wrap;
    justify-content: center;
  }
  .best-time-item {
    flex: 1 1 220px;
    background: var(--beige);
    padding: 1rem;
    text-align: center;
    border: 1px solid #ddd;
    border-radius: 6px;
    box-shadow: 0 2px 3px rgba(0,0,0,0.1);
    margin-bottom: 1rem;
  }
  
  /* WHY TO GO SECTION */
  .natron-why-go {
    padding: 2rem 5%;
    background: var(--beige);
    text-align: center;
  }
  .natron-why-go h2 {
    margin-bottom: 1rem;
    color: var(--brown);
  }
  .natron-why-go p {
    max-width: 900px;
    margin: 0 auto;
    line-height: 1.8;
    text-align: left;
  }
  
  /* WHERE TO STAY SECTION */
  .natron-where {
    padding: 2rem 5%;
    background: #fff;
    text-align: center;
  }
  .natron-where h2 {
    margin-bottom: 1rem;
    color: var(--brown);
  }
  .natron-where p {
    max-width: 900px;
    margin: 0 auto 1rem auto;
    line-height: 1.8;
    text-align: left;
  }
  
  /* FINAL CTA SECTION */
  .natron-final-cta {
    padding: 2rem 5%;
    background: var(--beige);
    text-align: center;
  }
  .natron-final-cta h2 {
    margin-bottom: 1rem;
    color: var(--brown);
  }
  .natron-final-cta p {
    max-width: 900px;
    margin: 0 auto 1.5rem auto;
    line-height: 1.8;
    text-align: left;
  }
  .final-cta-buttons {
    display: flex;
    flex-wrap: wrap;
    gap: 1rem;
    justify-content: center;
  }
  
  /* RESPONSIVE BREAKPOINTS */
  @media (max-width: 768px) {
    .natron-best-time-grid {
      flex-direction: column;
      align-items: center;
    }
  }/*********************************************
  LODGE SAFARIS DETAIL STYLES
**********************************************/

.page-hero--lodge .page-hero__overlay {
  background: linear-gradient(115deg, rgba(18, 28, 30, 0.9) 0%, rgba(43, 60, 58, 0.78) 50%, rgba(204, 136, 90, 0.58) 100%);
}

.page-hero--lodge .page-hero__content {
  background: linear-gradient(132deg, rgba(18, 29, 32, 0.92) 0%, rgba(34, 55, 52, 0.78) 58%, rgba(204, 136, 90, 0.6) 100%);
}

.page-hero--lodge .page-hero__subtitle {
  color: rgba(255, 255, 255, 0.9);
}

.feature-card img {
  height: clamp(170px, 28vw, 210px);
}

@media (max-width: 720px) {
  .feature-card img {
    height: 190px;
  }
}
/*********************************************
  LUXURY SAFARIS DETAIL STYLES
**********************************************/

.page-hero--luxury .page-hero__overlay {
  background: linear-gradient(118deg, rgba(18, 24, 36, 0.9) 0%, rgba(58, 42, 38, 0.78) 52%, rgba(224, 164, 120, 0.58) 100%);
}

.page-hero--luxury .page-hero__content {
  background: linear-gradient(132deg, rgba(18, 24, 32, 0.92) 0%, rgba(54, 40, 32, 0.8) 55%, rgba(224, 164, 120, 0.62) 100%);
}

.page-hero--luxury .page-hero__subtitle {
  color: rgba(255, 255, 255, 0.92);
}

.feature-card img {
  height: clamp(170px, 28vw, 220px);
}

.link-card__body h3 {
  font-size: 1.22rem;
}

@media (max-width: 720px) {
  .feature-card img {
    height: 190px;
  }
}
/* Mafia Island page refinements */

.page-hero--mafia .page-hero__overlay {
  background: linear-gradient(118deg, rgba(18, 32, 32, 0.9) 0%, rgba(40, 72, 72, 0.74) 48%, rgba(214, 143, 74, 0.6) 100%);
}

.mafia-glance {
  background: linear-gradient(145deg, rgba(255, 255, 255, 0.98) 0%, rgba(245, 244, 232, 0.92) 100%);
  border: 1px solid rgba(139, 69, 19, 0.12);
  box-shadow: 0 26px 58px rgba(11, 28, 36, 0.12);
  text-align: center;
}

.mafia-glance .section-max {
  display: grid;
  gap: clamp(1.3rem, 3vw, 1.9rem);
}

.mafia-glance .glance-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
  gap: clamp(1.5rem, 4vw, 2rem);
  margin-top: clamp(1.5rem, 3vw, 2rem);
}

.mafia-glance .glance-item {
  background: rgba(255, 255, 255, 0.96);
  border-radius: 18px;
  border: 1px solid rgba(139, 69, 19, 0.14);
  padding: clamp(1rem, 2.6vw, 1.6rem);
  box-shadow: 0 20px 42px rgba(15, 29, 26, 0.12);
}

.mafia-glance .glance-item strong {
  display: block;
  margin-bottom: 0.35rem;
  color: var(--brown);
  letter-spacing: 0.08em;
  text-transform: uppercase;
  font-size: 0.9rem;
}

.mafia-intro .section-max,
.mafia-wildlife .section-max,
.mafia-where .section-max {
  display: grid;
  gap: clamp(1.2rem, 3vw, 1.8rem);
  text-align: center;
}

.mafia-details {
  background: linear-gradient(140deg, rgba(245, 243, 234, 0.95) 0%, rgba(255, 255, 255, 0.98) 100%);
  border: 1px solid rgba(32, 74, 80, 0.1);
  box-shadow: 0 26px 58px rgba(11, 28, 36, 0.12);
}

.mafia-details .section-max {
  display: grid;
  gap: clamp(1.4rem, 3vw, 2.1rem);
}

.mafia-cols {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(260px, 1fr));
  gap: clamp(1.6rem, 4vw, 2.4rem);
  text-align: left;
}

.mafia-col h3 {
  margin-bottom: 0.8rem;
  color: var(--brown);
  text-transform: uppercase;
  letter-spacing: 0.08em;
  font-size: 0.95rem;
}

.mafia-col p {
  margin: 0;
  line-height: 1.8;
  color: rgba(18, 37, 32, 0.9);
}

.mafia-final-cta {
  background: linear-gradient(130deg, rgba(18, 33, 29, 0.92) 0%, rgba(204, 85, 0, 0.78) 100%);
  color: #fff;
  border: 1px solid rgba(255, 255, 255, 0.18);
  box-shadow: 0 34px 72px rgba(8, 18, 16, 0.4);
}

.mafia-final-cta p {
  color: rgba(255, 255, 255, 0.88);
}

.mafia-final-cta .cta-buttons {
  justify-content: center;
  gap: 0.9rem;
  margin-top: clamp(1.6rem, 4vw, 2.4rem);
}

.mafia-final-cta .btn-outline {
  color: #fff;
  border-color: rgba(255, 255, 255, 0.6);
}

.mafia-final-cta .btn-outline:hover,
.mafia-final-cta .btn-outline:focus {
  background: rgba(255, 255, 255, 0.2);
  color: #fff;
}

@media (max-width: 640px) {
  .mafia-final-cta .cta-buttons {
    flex-direction: column;
  }

  .mafia-final-cta .btn {
    width: 100%;
    justify-content: center;
  }
}
/*********************************************
  MAHALE MOUNTAINS NATIONAL PARK PAGE STYLES
**********************************************/

/* HERO SECTION */
.mahale-hero {
    position: relative;
    height: 80vh;
    overflow: hidden;
  }
  .mahale-hero-image {
    width: 100%;
    height: 100%;
    object-fit: cover;
  }
  .mahale-hero-overlay {
    position: absolute;
    inset: 0;
    background: rgba(0,0,0,0.3);
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    color: #fff;
    text-align: center;
    padding: 1rem;
  }
  .mahale-hero-overlay h1 {
    font-size: 2.5rem;
    margin-bottom: 0.5rem;
  }
  .mahale-hero-overlay p {
    font-size: 1.2rem;
  }
  
  /* AT A GLANCE SECTION */
  .mahale-glance {
    padding: 2rem 5%;
    background: var(--beige);
    text-align: center;
  }
  .mahale-glance h2 {
    margin-bottom: 1rem;
    color: var(--brown);
  }
  .glance-grid {
    max-width: 700px;
    margin: 0 auto;
    display: flex;
    gap: 1.5rem;
    flex-wrap: wrap;
    justify-content: center;
  }
  .glance-item {
    flex: 1 1 200px;
    background: #fff;
    border-radius: 6px;
    box-shadow: 0 2px 5px rgba(0,0,0,0.1);
    padding: 1rem;
    text-align: center;
  }
  .glance-item strong {
    display: block;
    margin-bottom: 0.5rem;
    color: var(--brown);
  }
  
  /* INTRO SECTION */
  .mahale-intro {
    padding: 2rem 5%;
    background: #fff;
    text-align: center;
  }
  .mahale-intro h2 {
    margin-bottom: 1rem;
    color: var(--brown);
  }
  .mahale-intro p {
    max-width: 900px;
    margin: 0 auto;
    line-height: 1.8;
    text-align: left;
  }
  
  /* OVERVIEW SECTION */
  .mahale-overview {
    padding: 2rem 5%;
    background: var(--beige);
    text-align: center;
  }
  .mahale-overview h2 {
    margin-bottom: 1rem;
    color: var(--brown);
  }
  .mahale-overview p {
    max-width: 900px;
    margin: 0 auto 1rem auto;
    line-height: 1.8;
    text-align: left;
  }
  
  /* HIGHLIGHTS SECTION */
  .mahale-highlights {
    padding: 2rem 5%;
    background: #fff;
    text-align: center;
  }
  .mahale-highlights h2 {
    margin-bottom: 1rem;
    color: var(--brown);
  }
  .mahale-highlights p {
    max-width: 900px;
    margin: 0 auto;
    line-height: 1.8;
    text-align: left;
  }
  
  /* WHEN TO GO */
  .mahale-best-time {
    padding: 2rem 5%;
    background: var(--beige);
    text-align: center;
  }
  .mahale-best-time h2 {
    margin-bottom: 1rem;
    color: var(--brown);
  }
  .mahale-best-time p {
    max-width: 900px;
    margin: 0 auto 1rem auto;
    line-height: 1.8;
    text-align: left;
  }
  .mahale-best-time-grid {
    display: flex;
    gap: 2rem;
    max-width: 700px;
    margin: 1rem auto;
    flex-wrap: wrap;
    justify-content: center;
  }
  .best-time-item {
    flex: 1 1 220px;
    background: var(--beige);
    padding: 1rem;
    text-align: center;
    border: 1px solid #ddd;
    border-radius: 6px;
    box-shadow: 0 2px 3px rgba(0,0,0,0.1);
    margin-bottom: 1rem;
  }
  
  /* WHY GO SECTION */
  .mahale-why-go {
    padding: 2rem 5%;
    background: #fff;
    text-align: center;
  }
  .mahale-why-go h2 {
    margin-bottom: 1rem;
    color: var(--brown);
  }
  .mahale-why-go p {
    max-width: 900px;
    margin: 0 auto;
    line-height: 1.8;
    text-align: left;
  }
  
  /* THINGS TO DO SECTION */
  .mahale-things {
    padding: 2rem 5%;
    background: var(--beige);
    text-align: center;
  }
  .mahale-things h2 {
    margin-bottom: 1rem;
    color: var(--brown);
  }
  .mahale-things p {
    max-width: 900px;
    margin: 0 auto;
    line-height: 1.8;
    text-align: left;
  }
  
  /* WILDLIFE SECTION */
  .mahale-wildlife {
    padding: 2rem 5%;
    background: #fff;
    text-align: center;
  }
  .mahale-wildlife h2 {
    margin-bottom: 1rem;
    color: var(--brown);
  }
  .mahale-wildlife p {
    max-width: 900px;
    margin: 0 auto 1rem auto;
    line-height: 1.8;
    text-align: left;
  }
  
  /* WHERE TO STAY SECTION */
  .mahale-where {
    padding: 2rem 5%;
    background: var(--beige);
    text-align: center;
  }
  .mahale-where h2 {
    margin-bottom: 1rem;
    color: var(--brown);
  }
  .mahale-where p {
    max-width: 900px;
    margin: 0 auto 1rem auto;
    line-height: 1.8;
    text-align: left;
  }
  
  /* FINAL CTA SECTION */
  .mahale-final-cta {
    padding: 2rem 5%;
    background: #fff;
    text-align: center;
  }
  .mahale-final-cta h2 {
    margin-bottom: 1rem;
    color: var(--brown);
  }
  .mahale-final-cta p {
    max-width: 900px;
    margin: 0 auto 1.5rem auto;
    line-height: 1.8;
    text-align: left;
  }
  .final-cta-buttons {
    display: flex;
    flex-wrap: wrap;
    gap: 1rem;
    justify-content: center;
  }
  
  /* RESPONSIVE BREAKPOINTS */
  @media (max-width: 768px) {
    .mahale-best-time-grid {
      flex-direction: column;
      align-items: center;
    }
  }/* ---------------------------------
   RESET / GLOBAL
---------------------------------- */
* {
    margin: 0;
    padding: 0;
    box-sizing: border-box;
  }
  
  :root {
    /* Example brand colors */
    --brown: #8B4513;
    --khaki: #F0E68C;
    --olive-green: #556B2F;
    --beige: #f9f5ec;
    --burnt-orange: #CC5500;
    --tan: #D2B48C;
    --deep-green: #2F4F4F;
    --golden-yellow: #FFD700;
  
    /* Sunset gradient from burnt orange to golden yellow */
    --sunset-gradient: linear-gradient(90deg, #cc5500 0%, #ffd700 100%);

    /* Typography scale */
    --font-size-base: 16px;
    --font-size-h1: clamp(1.8rem, 2.5vw + 1rem, 2.6rem);
    --font-size-h2: clamp(1.4rem, 1.8vw + 0.8rem, 2rem);
    --font-size-h3: clamp(1.2rem, 1vw + 0.8rem, 1.4rem);

    /* Spacing */
    --space-xs: 0.5rem;
    --space-sm: 0.75rem;
    --space-md: 1rem;
    --space-lg: 1.5rem;
    --space-xl: 2rem;
  }
  
  body {
    font-family: "Segoe UI", Tahoma, Geneva, Verdana, sans-serif;
    background-color: var(--beige);
    color: var(--deep-green);
    line-height: 1.6;
    font-size: var(--font-size-base);
  }

  h1, h2, h3 {
    color: var(--brown);
    line-height: 1.25;
    margin: var(--space-md) 0 var(--space-sm);
  }
  h1 { font-size: var(--font-size-h1); }
  h2 { font-size: var(--font-size-h2); }
  h3 { font-size: var(--font-size-h3); }
  p { margin: 0 0 var(--space-md); }
  a { color: var(--brown); }
  a:hover { color: var(--burnt-orange); }
  a:focus-visible, button:focus-visible { outline: 3px solid var(--golden-yellow); outline-offset: 2px; }

  /* ---------------------------------
     BUTTONS & INTERACTIVE ELEMENTS
  ---------------------------------- */
  .btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    padding: 0.85rem 1.8rem;
    border-radius: 999px;
    font-weight: 600;
    text-align: center;
    transition: transform 0.4s cubic-bezier(0.25, 0.46, 0.45, 0.94), 
                box-shadow 0.4s ease, 
                background-color 0.3s ease, 
                color 0.3s ease;
    cursor: pointer;
    margin: 0.5rem 0.5rem 0.5rem 0;
    border: 2px solid transparent;
    position: relative;
    text-decoration: none;
    overflow: hidden;
  }

  .btn::before {
    content: '';
    position: absolute;
    top: 0;
    left: -100%;
    width: 100%;
    height: 100%;
    background: linear-gradient(90deg, transparent, rgba(255,255,255,0.2), transparent);
    transition: left 0.6s ease;
  }

  .btn:hover { 
    transform: translateY(-3px) scale(1.02); 
  }

  .btn:hover::before {
    left: 100%;
  }

  .btn:active { 
    transform: translateY(-1px) scale(0.98); 
  }

  .btn-primary {
    background: linear-gradient(135deg, var(--burnt-orange) 0%, var(--golden-yellow) 100%);
    color: #fff;
    border: none;
    box-shadow: 0 14px 28px rgba(204, 85, 0, 0.3);
  }

  .btn-primary:hover {
    box-shadow: 0 20px 36px rgba(204, 85, 0, 0.35);
    filter: saturate(1.05);
  }

  .btn-outline {
    color: var(--burnt-orange);
    background: rgba(255, 255, 255, 0.85);
    border: 2px solid var(--burnt-orange);
    box-shadow: 0 10px 24px rgba(139, 69, 19, 0.12);
  }

  .btn-outline:hover {
    background: var(--burnt-orange);
    color: #fff;
    box-shadow: 0 16px 32px rgba(139, 69, 19, 0.2);
  }

  .btn-group {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 0.75rem;
  }

  .btn-group .btn { margin: 0; }

  /* CTA clusters */
  .cta-buttons,
  .final-cta-buttons {
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    gap: 0.85rem;
  }

  .cta-buttons .btn,
  .final-cta-buttons .btn {
    border-radius: 999px;
    padding: 0.85rem 1.75rem;
    box-shadow: 0 16px 32px rgba(0, 0, 0, 0.25);
    margin: 0;
  }

  /* ---------------------------------
     CTA BANNERS (mid-page strips)
  ---------------------------------- */
  section[class*="cta-banner"]:not(.final-cta-banner) {
    position: relative;
    margin: clamp(3rem, 7vw, 5rem) auto;
    padding: clamp(3rem, 6vw, 4.5rem) 5%;
    border-radius: 32px;
    text-align: center;
    color: #fff;
    overflow: hidden;
    isolation: isolate;
    background: linear-gradient(128deg, rgba(12, 32, 28, 0.92) 0%, rgba(210, 111, 26, 0.82) 52%, rgba(240, 180, 58, 0.65) 100%);
    box-shadow: 0 32px 68px rgba(4, 10, 8, 0.35);
  }

  section[class*="cta-banner"]:not(.final-cta-banner)::before {
    content: "";
    position: absolute;
    inset: 0;
    background: url('../images/savanna.jpg') center/cover no-repeat;
    opacity: 0.4;
    transform: scale(1.05);
    z-index: -2;
  }

  section[class*="cta-banner"]:not(.final-cta-banner)::after {
    content: "";
    position: absolute;
    inset: 0;
    background: linear-gradient(128deg, rgba(12, 32, 28, 0.92) 0%, rgba(210, 111, 26, 0.82) 52%, rgba(240, 180, 58, 0.65) 100%);
    z-index: -1;
  }

  section[class*="cta-banner"]:not(.final-cta-banner) .cta-banner-content,
  section[class*="cta-banner"]:not(.final-cta-banner) .final-cta-content {
    max-width: 780px;
    margin: 0 auto;
    padding: clamp(2.8rem, 6vw, 3.8rem);
    border-radius: 26px;
    background: rgba(12, 25, 22, 0.52);
    border: 1px solid rgba(255, 255, 255, 0.24);
    box-shadow: 0 28px 70px rgba(3, 8, 7, 0.45);
    backdrop-filter: blur(10px);
    position: relative;
    overflow: visible;
  }

  section[class*="cta-banner"]:not(.final-cta-banner) .cta-banner-content h2,
  section[class*="cta-banner"]:not(.final-cta-banner) .final-cta-content h2 {
    color: #fff;
    letter-spacing: 0.02em;
    margin-bottom: clamp(0.75rem, 2vw, 1rem);
  }

  section[class*="cta-banner"]:not(.final-cta-banner) .cta-banner-content p,
  section[class*="cta-banner"]:not(.final-cta-banner) .final-cta-content p {
    color: rgba(255, 255, 255, 0.88);
    margin-bottom: clamp(1.5rem, 3vw, 2rem);
    line-height: 1.75;
  }

  @media (max-width: 640px) {
    section[class*="cta-banner"]:not(.final-cta-banner) {
      padding: clamp(2.3rem, 8vw, 3rem) 6%;
    }

    section[class*="cta-banner"]:not(.final-cta-banner) .cta-banner-content,
    section[class*="cta-banner"]:not(.final-cta-banner) .final-cta-content {
      padding: clamp(1.9rem, 7vw, 2.4rem);
    }
  }

  /* ---------------------------------
     FINAL CTA BANNERS
  ---------------------------------- */
  body .final-cta-banner {
    position: relative;
    padding: clamp(3.8rem, 7vw, 6.2rem) 5%;
    color: #fff;
    text-align: center;
    overflow: hidden;
    isolation: isolate;
    background: linear-gradient(125deg, rgba(12, 30, 26, 0.92) 0%, rgba(31, 69, 60, 0.75) 46%, rgba(204, 95, 0, 0.82) 100%);
    box-shadow: 0 36px 80px rgba(4, 10, 8, 0.38);
  }

  body .final-cta-banner::before {
    content: "";
    position: absolute;
    inset: 0;
    background: url('../images/savanna.jpg') center/cover no-repeat;
    opacity: 0.55;
    transform: scale(1.08);
    z-index: -2;
  }

  body .final-cta-banner::after {
    content: "";
    position: absolute;
    inset: 0;
    background:
      linear-gradient(125deg, rgba(12, 30, 26, 0.92) 0%, rgba(31, 69, 60, 0.75) 46%, rgba(204, 95, 0, 0.82) 100%),
      radial-gradient(circle at 18% 18%, rgba(255, 255, 255, 0.28) 0%, transparent 55%),
      radial-gradient(circle at 82% 82%, rgba(255, 214, 120, 0.32) 0%, transparent 58%);
    mix-blend-mode: overlay;
    z-index: -1;
  }

  body .final-cta-content {
    position: relative;
    max-width: 820px;
    margin: 0 auto;
    padding: clamp(2.6rem, 5vw, 3.6rem);
    border-radius: 30px;
    background: linear-gradient(132deg, rgba(16, 29, 26, 0.75) 0%, rgba(29, 52, 46, 0.68) 55%, rgba(204, 120, 58, 0.50) 100%);
    border: 1px solid rgba(255, 255, 255, 0.24);
    box-shadow: 0 32px 80px rgba(4, 8, 7, 0.42);
    backdrop-filter: blur(14px);
  }

  body .final-cta-content.cta-panel {
    background: linear-gradient(132deg, rgba(16, 29, 26, 0.82) 0%, rgba(29, 52, 46, 0.76) 55%, rgba(204, 120, 58, 0.58) 100%);
    border: 1px solid rgba(255, 255, 255, 0.24);
    box-shadow: 0 32px 70px rgba(5, 8, 6, 0.4);
  }

  body .final-cta-content h2 {
    margin-bottom: 1rem;
    font-size: clamp(2rem, 3.2vw, 2.5rem);
    color: #fff;
    letter-spacing: 0.02em;
  }

  body .final-cta-content p {
    margin-bottom: clamp(2rem, 4vw, 2.6rem);
    font-size: 1.08rem;
    line-height: 1.8;
    color: rgba(255, 255, 255, 0.88);
  }

  body .final-cta-banner .btn-outline {
    color: #fff;
    border-color: rgba(255, 255, 255, 0.65);
  }

  body .final-cta-banner .btn-outline:hover {
    background: rgba(255, 255, 255, 0.2);
    color: #fff;
  }
  
  /* ---------------------------------
     HEADER / NAVBAR
  ---------------------------------- */
header {
  background: linear-gradient(135deg, rgba(15, 28, 24, 0.94) 0%, rgba(41, 32, 21, 0.94) 100%);
  backdrop-filter: blur(14px);
  border-bottom: 1px solid rgba(255, 255, 255, 0.08);
  padding: var(--nav-vertical-padding) 0;
  position: sticky;
  top: 0;
  z-index: 999; /* ensures nav is on top */
  display: flex;
  align-items: center;
  justify-content: center;
  height: var(--nav-header-height);
  min-height: var(--nav-header-height);
}

body.nav-open {
  overflow: hidden;
}

.navbar {
  width: 90%;
  max-width: 1200px;
  margin: 0 auto;
  display: flex;
  align-items: center;
  justify-content: space-between;
  position: relative; /* So absolute submenus can align to this */
  min-height: var(--nav-inner-min-height);
  height: 100%;
}

/* Logo container spacing */
.logo {
  margin-left: 0;
}

/* Enlarged logo */
.logo img {
  height: clamp(60px, 7vw, 78px);
  width: auto;
  margin-right: clamp(0.9rem, 2vw, 1.4rem);
  transition: transform 0.25s ease;
}

  
  /* HAMBURGER ICON */
.menu-icon {
  display: none; /* Shown below 992px */
  cursor: pointer;
  font-size: 1.8rem;
  color: #fff;
  background: none;
  border: none;
}
  
  /* MAIN MENU */
  .menu {
    display: flex;
    list-style: none;
    transition: all 0.3s ease;
    /* 
      If you want the top-level items 
      also on a single line without wrapping,
      add:
        white-space: nowrap;
    */
    white-space: nowrap;
  }
  
  /* Each top-level <li> in the .menu */
.menu li {
  position: relative;
  margin: 0;
  padding: 0;
}

.menu > li + li {
  margin-left: 0.25rem;
}
  
  /* Menu links - no wrapping on text */
.menu a {
  position: relative;
  color: rgba(255, 255, 255, 0.88);
  text-decoration: none;
  padding: 0.65rem 1.15rem;
  display: block;
  font-weight: 600;
  transition: color 0.3s ease;

  /* No wrapping */
  white-space: nowrap; 
}

.menu a::after {
  content: "";
  position: absolute;
  left: 1.1rem;
  right: 1.1rem;
  bottom: 0.35rem;
  height: 2px;
  background: linear-gradient(90deg, var(--golden-yellow) 0%, rgba(255, 255, 255, 0) 100%);
  opacity: 0;
  transition: opacity 0.3s ease;
}

.menu a[aria-current="page"] {
  color: var(--golden-yellow);
}

.menu a[aria-current="page"]::after {
  opacity: 1;
}

.menu li.active > a {
  background: transparent;
  color: var(--golden-yellow);
}

.menu a:focus-visible {
  color: var(--golden-yellow);
}
  
  /* Hover effect for desktop */
@media (min-width: 993px) {
  .menu > li:hover > a {
    color: var(--golden-yellow);
  }
  .menu > li:hover > a::after {
    opacity: 1;
  }
}
  
  /* Submenu toggle button (for mobile) */
  .submenu-toggle {
    display: none;  /* shown on mobile only */
    background: none;
    border: none;
    font-size: 1.2rem;
    color: var(--brown);
    cursor: pointer;
    padding: 0.5rem;
  }
  
  /* SUBMENU (Hidden by default; small submenus left-aligned) */
.submenu {
  position: absolute;
  top: 100%;
  left: 0;
  display: none;
  list-style: none;
  margin: 0;
  padding: 0;
  background: rgba(20, 32, 29, 0.95);
  box-shadow: 0 22px 45px rgba(0, 0, 0, 0.28);
  border: 1px solid rgba(255, 255, 255, 0.08);
  border-radius: 14px;

  /* single column for smaller submenus */
  flex-direction: column;
  min-width: 200px;

    /* keep text on one line here, too */
    white-space: nowrap;
  }
  
  /* LARGE SUBMENU (multi-col, centered on desktop) */
.large-submenu {
  display: none;
  margin: 0;
  padding: 0.5rem;
  background: rgba(20, 32, 29, 0.95);
  box-shadow: 0 28px 60px rgba(0, 0, 0, 0.35);
  border: 1px solid rgba(255, 255, 255, 0.08);
  border-radius: 18px;
  font-size: 0.9rem;
    max-height: 70vh;   /* allow more options visible before scrolling */
    overflow-y: auto;    
    column-count: 2;     
    column-gap: 1rem;
    min-width: 420px;    
    white-space: nowrap; /* no text wrapping in columns */
    z-index: 1001;       /* ensure it appears above page content */
  }
  
  /* Submenu links no wrap */
.submenu li a {
  padding: 0.5rem 1rem;
  color: rgba(255, 255, 255, 0.9);
  white-space: nowrap; /* ensure items stay on one line */
  border-radius: 4px;
  transition: background 0.3s ease, color 0.3s ease;
}

  .submenu li a:hover {
    background-color: var(--burnt-orange);
    color: var(--beige);
  }
  
  /* Prevent item splitting in .large-submenu columns */
  .large-submenu li {
    break-inside: avoid; 
  }

  /* Optional headings inside mega menu for grouping */
.submenu-heading {
  font-weight: 700;
  color: var(--golden-yellow);
  padding: 0.5rem 1rem;
  cursor: default;
  break-inside: avoid;
}
  
  /* ---------------------------------
     DESKTOP (>= 993px)
  ---------------------------------- */
  @media (min-width: 993px) {
    /* Show submenus on hover */
    .has-submenu:hover .submenu {
      display: flex;
    }
    .has-submenu:hover .large-submenu {
      display: block;
    }
  
    /* Center the .large-submenu under the parent on desktop */
    .large-submenu {
      position: absolute;
      top: 100%;
      left: 50%;
      transform: translateX(-50%);
    }
    /* Wider screens: 3 columns for destinations */
    @media (min-width: 1200px) {
      .large-submenu { column-count: 3; min-width: 540px; }
    }
  }
  
  /* ---------------------------------
     MOBILE (<= 992px)
  ---------------------------------- */
  @media (max-width: 992px) {
    /* Show the hamburger icon */
    .menu-icon {
      display: block;
      background: none;
      border: none;
      color: #fff;
      padding: 0.5rem;
      z-index: 1000;
    }
  
    /* The entire menu becomes a full overlay */
    .menu {
      position: fixed;
      top: var(--nav-header-height, 70px);
      right: 0;
      left: 0;
      width: 100%;
      max-height: 0;
      background: rgba(20, 32, 29, 0.95);
      backdrop-filter: blur(12px);
      flex-direction: column;
      overflow: hidden;
      pointer-events: none;
      opacity: 0;
      transition: max-height 0.35s ease, opacity 0.25s ease;
    }

    .menu.is-open {
      max-height: calc(100vh - var(--nav-header-height, 70px));
      pointer-events: auto;
      opacity: 1;
      overflow-y: auto;
      z-index: 999;
      -webkit-overflow-scrolling: touch;
      scroll-behavior: smooth;
    }
  
    /* Each top-level item is full width on mobile */
    .menu li {
      width: 100%;
    }
  
    /* Hover does nothing on mobile */
    .has-submenu:hover .submenu,
    .has-submenu:hover .large-submenu {
      display: none;
    }
  
    /* Submenus on mobile => toggled via .submenu-toggle => JS sets display:block */
    .submenu,
    .large-submenu {
      position: static;
      display: block;
      box-shadow: none;
      background: rgba(20, 32, 29, 0.85);
      width: 100%;
      max-height: 0;
      overflow: hidden;
      padding: 0;
      opacity: 0;
      transition: max-height 0.3s ease, opacity 0.25s ease, padding 0.25s ease;

      column-count: 1;
      column-gap: 0;
      min-width: auto;
      transform: none;
      left: auto;
    }

    .submenu.is-open,
    .large-submenu.is-open {
      max-height: none !important;
      padding: 0.5rem 0 !important;
      opacity: 1 !important;
      display: block !important;
      overflow: visible !important;
      background: rgba(16, 29, 26, 0.95) !important;
      border-top: 1px solid rgba(255, 255, 255, 0.1) !important;
      border-bottom: 1px solid rgba(255, 255, 255, 0.1) !important;
    }
  
    /* Show the submenu toggle button on mobile */
  .submenu-toggle {
    display: inline-flex !important;
    align-items: center;
    justify-content: center;
    font-weight: 600;
    color: rgba(255, 255, 255, 0.85);
    background: none;
    border: none;
    padding: 1rem;
    cursor: pointer;
    min-width: 44px;
    min-height: 44px;
    font-size: 1.2rem;
  }

  .menu a {
    color: rgba(255, 255, 255, 0.9);
    border-bottom: 1px solid rgba(255, 255, 255, 0.08);
    flex: 1 1 auto;
  }

  /* Submenu items styling */
  .submenu a,
  .large-submenu a {
    color: rgba(255, 255, 255, 0.85) !important;
    padding: 0.75rem 1.5rem !important;
    border-bottom: 1px solid rgba(255, 255, 255, 0.05) !important;
    transition: background-color 0.2s ease, color 0.2s ease !important;
  }

  .submenu a:hover,
  .large-submenu a:hover {
    background-color: rgba(204, 120, 58, 0.2) !important;
    color: var(--golden-yellow) !important;
  }

  /* Submenu headings */
  .submenu-heading {
    color: var(--golden-yellow) !important;
    font-weight: 600 !important;
    font-size: 0.9rem !important;
    padding: 0.5rem 1.5rem 0.25rem !important;
    text-transform: uppercase !important;
    letter-spacing: 0.5px !important;
    border-bottom: none !important;
  }

    .menu li {
      display: flex;
      align-items: center;
      gap: 0.5rem;
    }

    .menu li .submenu-toggle {
      width: 36px;
      height: 36px;
      border-radius: 50%;
      background: rgba(255, 255, 255, 0.08);
      border: 1px solid rgba(255, 255, 255, 0.18);
    }

    .menu li .submenu-toggle:hover,
    .menu li .submenu-toggle:focus-visible {
      background: rgba(255, 255, 255, 0.16);
      color: var(--golden-yellow);
    }
  }
  
  /* ---------------------------------
     BACK TO TOP BUTTON
  ---------------------------------- */
.back-to-top {
    position: fixed;
    bottom: clamp(1.5rem, 4vw, 2.5rem);
    right: clamp(1.5rem, 4vw, 2.5rem);
    background: var(--burnt-orange);
    color: #fff;
    border: none;
    padding: 0.7rem 1.05rem;
    font-size: 1.05rem;
    cursor: pointer;
    border-radius: 999px;
    display: none; /* hidden by default */
    box-shadow: 0 18px 34px rgba(204, 85, 0, 0.25);
    backdrop-filter: blur(8px);
    z-index: 120;
    transition: transform 0.3s ease, background 0.3s ease, color 0.3s ease;
  }
  
  .back-to-top:hover {
    background: var(--brown);
    color: var(--golden-yellow);
    transform: translateY(-4px);
  }
  
  .back-to-top:focus-visible {
    outline: 2px solid var(--golden-yellow);
    outline-offset: 3px;
  }
  
  /* ---------------------------------
     FOOTER STYLES (unchanged)
  ---------------------------------- */
.footer {
  position: relative;
  background: linear-gradient(180deg, rgba(18, 35, 32, 0.92) 0%, rgba(37, 23, 8, 0.92) 100%);
  color: rgba(255, 255, 255, 0.92);
  padding: clamp(3.5rem, 6vw, 5rem) 5% clamp(2rem, 4vw, 3rem);
  margin-top: clamp(3rem, 6vw, 4.5rem);
  overflow: hidden;
}

.footer::before {
  content: "";
  position: absolute;
  inset: 0;
  background: radial-gradient(circle at 15% 20%, rgba(204, 85, 0, 0.25) 0%, transparent 55%),
              radial-gradient(circle at 85% 80%, rgba(85, 107, 47, 0.25) 0%, transparent 60%);
  opacity: 0.7;
  z-index: 0;
}

.footer-container {
  position: relative;
  z-index: 1;
  width: min(90%, 1200px);
  margin: 0 auto;
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
  gap: clamp(1.5rem, 4vw, 2.5rem);
}

.footer-col {
  background: rgba(12, 24, 21, 0.45);
  border: 1px solid rgba(255, 255, 255, 0.12);
  border-radius: 20px;
  padding: 1.75rem;
  box-shadow: 0 26px 50px rgba(0, 0, 0, 0.22);
  backdrop-filter: blur(10px);
}

.footer-col h3,
.footer-col h4 {
  color: var(--golden-yellow);
  margin-bottom: 1rem;
  position: relative;
  display: inline-block;
}

.footer-col h3::after,
.footer-col h4::after {
  content: "";
  position: absolute;
  left: 0;
  bottom: -0.4rem;
  width: 46px;
  height: 2px;
  background: linear-gradient(90deg, var(--golden-yellow) 0%, rgba(255, 255, 255, 0) 100%);
  opacity: 0.8;
}

.footer-col p {
  margin-bottom: 1rem;
  color: rgba(255, 255, 255, 0.85);
  line-height: 1.7;
}

.footer-col ul {
  list-style: none;
  padding: 0;
  margin: 0;
}

.footer-col ul li {
  margin-bottom: 0.6rem;
}

.footer-col ul li a {
  color: rgba(255, 255, 255, 0.85);
  text-decoration: none;
  transition: color 0.3s ease;
  display: inline-flex;
  align-items: center;
}

.footer-col ul li a:hover,
.footer-col ul li a:focus {
  color: var(--golden-yellow);
}

.contact-icon {
  width: 20px;
  height: 20px;
  margin-right: 6px;
  vertical-align: middle;
  filter: drop-shadow(0 4px 6px rgba(0,0,0,0.25));
}

.social-icons img {
  width: 32px;
  height: 32px;
  margin-right: 0.6rem;
  transition: transform 0.3s ease, filter 0.3s ease;
  display: inline-block;
  filter: drop-shadow(0 6px 12px rgba(0,0,0,0.3));
}

.social-icons img:hover,
.social-icons img:focus {
  transform: translateY(-3px);
  filter: drop-shadow(0 10px 18px rgba(0,0,0,0.35));
}

.footer-bottom {
  position: relative;
  z-index: 1;
  border-top: 1px solid rgba(255, 255, 255, 0.18);
  text-align: center;
  margin-top: clamp(2rem, 4vw, 3rem);
  padding-top: 1.25rem;
  font-size: 0.92rem;
  color: rgba(255, 255, 255, 0.75);
}
  
  /* Remove inline styles for phone / email / whatsapp links */
  .call-link,
  .email-link,
  .whatsapp-link {
    color: inherit;
    text-decoration: none;
    display: inline-flex;
    align-items: center;
    gap: 0.4rem;
  }
  
  .call-link:hover,
  .email-link:hover,
  .whatsapp-link:hover {
    color: var(--golden-yellow);
  }

  /* ---------------------------------
     GLOBAL RESPONSIVE ADJUSTMENTS
  ---------------------------------- */
  @media (max-width: 768px) {
    body .final-cta-content {
      padding: 2.2rem;
    }
  }

  @media (max-width: 600px) {
    .cta-buttons,
    .final-cta-buttons {
      flex-direction: column;
    }

    .cta-buttons .btn,
    .final-cta-buttons .btn {
      width: 100%;
      justify-content: center;
    }
  }
/*********************************************
  MIGRATION SAFARIS PAGE STYLES
**********************************************/

/* HERO SECTION */

  /* INTRO SECTION */
  .migration-intro {
    padding: 2rem 5%;
    background: #fff;
    text-align: center;
  }
  .migration-intro h2 {
    margin-bottom: 1rem;
    color: var(--brown);
  }
  .migration-intro p {
    max-width: 900px;
    margin: 0 auto;
    line-height: 1.8;
    text-align: left;
  }
  
  /* WHO SHOULD GO SECTION */
  .migration-whoshouldgo {
    padding: clamp(2rem, 4vw, 3rem) 5%;
    background: var(--beige);
  }
  .migration-whoshouldgo h2 {
    margin-bottom: clamp(1rem, 2vw, 1.5rem) !important;
    color: var(--brown) !important;
    text-align: center !important;
    font-size: clamp(1.8rem, 3vw, 2.2rem) !important;
  }
  .migration-whoshouldgo p {
    max-width: 900px;
    margin: 0 auto clamp(1rem, 2vw, 1.5rem) auto;
    line-height: 1.8;
    text-align: left;
  }
  .migration-whoshouldgo ul {
    max-width: 600px;
    margin: clamp(1rem, 2vw, 1.5rem) auto;
    text-align: left;
    line-height: 1.8;
    list-style: disc outside;
    padding-left: 1.2rem;
  }
  
  /* WHERE TO EXPERIENCE SECTION */
  .migration-where {
    padding: clamp(2rem, 4vw, 3rem) 5%;
    background: #fff;
  }
  .migration-where h2 {
    margin-bottom: clamp(1rem, 2vw, 1.5rem);
    color: var(--brown);
    text-align: center;
    font-size: clamp(1.8rem, 3vw, 2.2rem);
  }
  .migration-where p {
    max-width: 900px;
    margin: 0 auto clamp(1rem, 2vw, 1.5rem) auto;
    line-height: 1.8;
    text-align: left;
  }
  
  /* WHEN TO GO SECTION */
  .migration-besttime {
    padding: clamp(2rem, 4vw, 3rem) 5%;
    background: var(--beige);
  }
  .migration-besttime h2 {
    margin-bottom: clamp(1rem, 2vw, 1.5rem);
    color: var(--brown);
    text-align: center;
    font-size: clamp(1.8rem, 3vw, 2.2rem);
  }
  .migration-besttime p {
    max-width: 900px;
    margin: 0 auto clamp(1rem, 2vw, 1.5rem) auto;
    line-height: 1.8;
    text-align: left;
  }
  .migration-besttime-grid {
    display: flex;
    flex-wrap: wrap;
    gap: 2rem;
    max-width: 700px;
    margin: 1rem auto;
    justify-content: center;
    text-align: center;
  }
  .besttime-item {
    flex: 1 1 220px;
    background: var(--beige);
    border-radius: 6px;
    box-shadow: 0 2px 5px rgba(0,0,0,0.1);
    padding: 1rem;
  }
  
  /* CTA BANNER */
  .cta-banner-content {
    max-width: 900px;
    margin: 0 auto;
  }
  .cta-banner-content h2 {
    margin-bottom: 1rem;
    font-size: 2rem;
  }
  
  /* ACCOMMODATIONS SECTION */
  .migration-accommodations {
    padding: 2rem 5%;
    background: #fff;
    text-align: center;
  }
  .migration-accommodations h2 {
    margin-bottom: 1rem;
    color: var(--brown);
  }
  .migration-accommodations p {
    max-width: 900px;
    margin: 0 auto;
    line-height: 1.8;
    text-align: left;
  }
  
  /* ADDITIONAL INFO SECTION */
  .migration-info {
    padding: 2rem 5%;
    background: var(--beige);
    text-align: center;
  }
  .migration-info h2 {
    margin-bottom: 1rem;
    color: var(--brown);
  }
  .migration-info p {
    max-width: 900px;
    margin: 0 auto 1rem auto;
    line-height: 1.8;
    text-align: left;
  }
  
  /* MIGRATION DETAILS SECTION */
  .migration-details {
    padding: 2rem 5%;
    background: #fff;
    text-align: center;
  }
  .migration-details h2 {
    margin-bottom: 1rem;
    color: var(--brown);
  }
  .migration-details p {
    max-width: 900px;
    margin: 0 auto;
    line-height: 1.8;
    text-align: left;
  }
  
  /* FINAL CTA SECTION */
  .migration-final-cta {
    padding: 2rem 5%;
    background: var(--beige);
    text-align: center;
  }
  .migration-final-cta h2 {
    margin-bottom: 1rem;
    color: var(--brown);
  }
  .migration-final-cta p {
    max-width: 900px;
    margin: 0 auto 1.5rem auto;
    line-height: 1.8;
    text-align: left;
  }
  .final-cta-buttons {
    display: flex;
    gap: 1rem;
    flex-wrap: wrap;
    justify-content: center;
  }
  
  /* RESPONSIVE BREAKPOINTS */
  @media (max-width: 768px) {
    .migration-besttime-grid {
      flex-direction: column;
      align-items: center;
    }
    .migration-whoshouldgo ul {
      list-style-position: outside;
      padding-left: 1.5rem;
    }
  }
/*********************************************
  MIKUMI NATIONAL PARK PAGE STYLES
**********************************************/

/* HERO SECTION */
.mikumi-hero {
    position: relative;
    height: 80vh;
    overflow: hidden;
  }
  .mikumi-hero-image {
    width: 100%;
    height: 100%;
    object-fit: cover;
  }
  .mikumi-hero-overlay {
    position: absolute;
    inset: 0;
    background: rgba(0,0,0,0.3);
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    color: #fff;
    text-align: center;
    padding: 1rem;
  }
  .mikumi-hero-overlay h1 {
    font-size: 2.5rem;
    margin-bottom: 0.5rem;
  }
  .mikumi-hero-overlay p {
    font-size: 1.2rem;
  }
  
  /* AT A GLANCE SECTION */
  .mikumi-glance {
    padding: 2rem 5%;
    background: var(--beige);
    text-align: center;
  }
  .mikumi-glance h2 {
    margin-bottom: 1rem;
    color: var(--brown);
  }
  .glance-grid {
    max-width: 700px;
    margin: 0 auto;
    display: flex;
    gap: 1.5rem;
    flex-wrap: wrap;
    justify-content: center;
  }
  .glance-item {
    flex: 1 1 200px;
    background: #fff;
    border-radius: 6px;
    box-shadow: 0 2px 5px rgba(0,0,0,0.1);
    padding: 1rem;
    text-align: center;
  }
  .glance-item strong {
    display: block;
    margin-bottom: 0.5rem;
    color: var(--brown);
  }
  
  /* INTRO SECTION */
  .mikumi-intro {
    padding: 2rem 5%;
    background: #fff;
    text-align: center;
  }
  .mikumi-intro h2 {
    margin-bottom: 1rem;
    color: var(--brown);
  }
  .mikumi-intro p {
    max-width: 900px;
    margin: 0 auto;
    line-height: 1.8;
    text-align: left;
  }
  
  /* OVERVIEW SECTION */
  .mikumi-overview {
    padding: 2rem 5%;
    background: var(--beige);
    text-align: center;
  }
  .mikumi-overview h2 {
    margin-bottom: 1rem;
    color: var(--brown);
  }
  .mikumi-overview p {
    max-width: 900px;
    margin: 0 auto 1rem auto;
    line-height: 1.8;
    text-align: left;
  }
  
  /* HIGHLIGHTS SECTION */
  .mikumi-highlights {
    padding: 2rem 5%;
    background: #fff;
    text-align: center;
  }
  .mikumi-highlights h2 {
    margin-bottom: 1rem;
    color: var(--brown);
  }
  .mikumi-highlights p {
    max-width: 900px;
    margin: 0 auto;
    line-height: 1.8;
    text-align: left;
  }
  
  /* WHEN TO GO */
  .mikumi-best-time {
    padding: 2rem 5%;
    background: var(--beige);
    text-align: center;
  }
  .mikumi-best-time h2 {
    margin-bottom: 1rem;
    color: var(--brown);
  }
  .mikumi-best-time p {
    max-width: 900px;
    margin: 0 auto 1rem auto;
    line-height: 1.8;
    text-align: left;
  }
  .mikumi-best-time-grid {
    display: flex;
    gap: 2rem;
    max-width: 700px;
    margin: 1rem auto;
    flex-wrap: wrap;
    justify-content: center;
  }
  .best-time-item {
    flex: 1 1 220px;
    background: var(--beige);
    padding: 1rem;
    text-align: center;
    border: 1px solid #ddd;
    border-radius: 6px;
    box-shadow: 0 2px 3px rgba(0,0,0,0.1);
    margin-bottom: 1rem;
  }
  
  /* WHY TO GO SECTION */
  .mikumi-why-go {
    padding: 2rem 5%;
    background: #fff;
    text-align: center;
  }
  .mikumi-why-go h2 {
    margin-bottom: 1rem;
    color: var(--brown);
  }
  .mikumi-why-go p {
    max-width: 900px;
    margin: 0 auto;
    line-height: 1.8;
    text-align: left;
  }
  
  /* THINGS TO DO SECTION */
  .mikumi-things {
    padding: 2rem 5%;
    background: var(--beige);
    text-align: center;
  }
  .mikumi-things h2 {
    margin-bottom: 1rem;
    color: var(--brown);
  }
  .mikumi-things p {
    max-width: 900px;
    margin: 0 auto;
    line-height: 1.8;
    text-align: left;
  }
  
  /* WILDLIFE SECTION */
  .mikumi-wildlife {
    padding: 2rem 5%;
    background: #fff;
    text-align: center;
  }
  .mikumi-wildlife h2 {
    margin-bottom: 1rem;
    color: var(--brown);
  }
  .mikumi-wildlife p {
    max-width: 900px;
    margin: 0 auto 1rem auto;
    line-height: 1.8;
    text-align: left;
  }
  
  /* WHERE TO STAY SECTION */
  .mikumi-where {
    padding: 2rem 5%;
    background: var(--beige);
    text-align: center;
  }
  .mikumi-where h2 {
    margin-bottom: 1rem;
    color: var(--brown);
  }
  .mikumi-where p {
    max-width: 900px;
    margin: 0 auto 1rem auto;
    line-height: 1.8;
    text-align: left;
  }
  
  /* FINAL CTA SECTION */
  .mikumi-final-cta {
    padding: 2rem 5%;
    background: #fff;
    text-align: center;
  }
  .mikumi-final-cta h2 {
    margin-bottom: 1rem;
    color: var(--brown);
  }
  .mikumi-final-cta p {
    max-width: 900px;
    margin: 0 auto 1.5rem auto;
    line-height: 1.8;
    text-align: left;
  }
  .final-cta-buttons {
    display: flex;
    flex-wrap: wrap;
    gap: 1rem;
    justify-content: center;
  }
  
  /* RESPONSIVE BREAKPOINTS */
  @media (max-width: 768px) {
    .mikumi-best-time-grid {
      flex-direction: column;
      align-items: center;
    }
  }/*********************************************
  MKOMAZI NATIONAL PARK PAGE STYLES
**********************************************/

/* HERO SECTION */
.mkomazi-hero {
    position: relative;
    height: 80vh;
    overflow: hidden;
  }
  .mkomazi-hero-image {
    width: 100%;
    height: 100%;
    object-fit: cover;
  }
  .mkomazi-hero-overlay {
    position: absolute;
    inset: 0;
    background: rgba(0,0,0,0.3);
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    color: #fff;
    text-align: center;
    padding: 1rem;
  }
  .mkomazi-hero-overlay h1 {
    font-size: 2.5rem;
    margin-bottom: 0.5rem;
  }
  .mkomazi-hero-overlay p {
    font-size: 1.2rem;
  }
  
  /* AT A GLANCE SECTION */
  .mkomazi-glance {
    padding: 2rem 5%;
    background: var(--beige);
    text-align: center;
  }
  .mkomazi-glance h2 {
    margin-bottom: 1rem;
    color: var(--brown);
  }
  .glance-grid {
    max-width: 700px;
    margin: 0 auto;
    display: flex;
    gap: 1.5rem;
    flex-wrap: wrap;
    justify-content: center;
  }
  .glance-item {
    flex: 1 1 200px;
    background: #fff;
    border-radius: 6px;
    box-shadow: 0 2px 5px rgba(0,0,0,0.1);
    padding: 1rem;
    text-align: center;
  }
  .glance-item strong {
    display: block;
    margin-bottom: 0.5rem;
    color: var(--brown);
  }
  
  /* INTRO SECTION */
  .mkomazi-intro {
    padding: 2rem 5%;
    background: #fff;
    text-align: center;
  }
  .mkomazi-intro h2 {
    margin-bottom: 1rem;
    color: var(--brown);
  }
  .mkomazi-intro p {
    max-width: 900px;
    margin: 0 auto;
    line-height: 1.8;
    text-align: left;
  }
  
  /* OVERVIEW SECTION */
  .mkomazi-overview {
    padding: 2rem 5%;
    background: var(--beige);
    text-align: center;
  }
  .mkomazi-overview h2 {
    margin-bottom: 1rem;
    color: var(--brown);
  }
  .mkomazi-overview p {
    max-width: 900px;
    margin: 0 auto 1rem auto;
    line-height: 1.8;
    text-align: left;
  }
  
  /* HIGHLIGHTS SECTION */
  .mkomazi-highlights {
    padding: 2rem 5%;
    background: #fff;
    text-align: center;
  }
  .mkomazi-highlights h2 {
    margin-bottom: 1rem;
    color: var(--brown);
  }
  .mkomazi-highlights p {
    max-width: 900px;
    margin: 0 auto;
    line-height: 1.8;
    text-align: left;
  }
  
  /* WHEN TO GO */
  .mkomazi-best-time {
    padding: 2rem 5%;
    background: var(--beige);
    text-align: center;
  }
  .mkomazi-best-time h2 {
    margin-bottom: 1rem;
    color: var(--brown);
  }
  .mkomazi-best-time p {
    max-width: 900px;
    margin: 0 auto 1rem auto;
    line-height: 1.8;
    text-align: left;
  }
  .mkomazi-best-time-grid {
    display: flex;
    gap: 2rem;
    max-width: 700px;
    margin: 1rem auto;
    flex-wrap: wrap;
    justify-content: center;
  }
  .best-time-item {
    flex: 1 1 220px;
    background: var(--beige);
    padding: 1rem;
    text-align: center;
    border: 1px solid #ddd;
    border-radius: 6px;
    box-shadow: 0 2px 3px rgba(0,0,0,0.1);
    margin-bottom: 1rem;
  }
  
  /* WHY GO SECTION */
  .mkomazi-why-go {
    padding: 2rem 5%;
    background: #fff;
    text-align: center;
  }
  .mkomazi-why-go h2 {
    margin-bottom: 1rem;
    color: var(--brown);
  }
  .mkomazi-why-go p {
    max-width: 900px;
    margin: 0 auto;
    line-height: 1.8;
    text-align: left;
  }
  
  /* THINGS TO DO SECTION */
  .mkomazi-things {
    padding: 2rem 5%;
    background: var(--beige);
    text-align: center;
  }
  .mkomazi-things h2 {
    margin-bottom: 1rem;
    color: var(--brown);
  }
  .mkomazi-things p {
    max-width: 900px;
    margin: 0 auto;
    line-height: 1.8;
    text-align: left;
  }
  
  /* WILDLIFE SECTION */
  .mkomazi-wildlife {
    padding: 2rem 5%;
    background: #fff;
    text-align: center;
  }
  .mkomazi-wildlife h2 {
    margin-bottom: 1rem;
    color: var(--brown);
  }
  .mkomazi-wildlife p {
    max-width: 900px;
    margin: 0 auto 1rem auto;
    line-height: 1.8;
    text-align: left;
  }
  
  /* WHERE TO STAY SECTION */
  .mkomazi-where {
    padding: 2rem 5%;
    background: var(--beige);
    text-align: center;
  }
  .mkomazi-where h2 {
    margin-bottom: 1rem;
    color: var(--brown);
  }
  .mkomazi-where p {
    max-width: 900px;
    margin: 0 auto 1rem auto;
    line-height: 1.8;
    text-align: left;
  }
  
  /* FINAL CTA SECTION */
  .mkomazi-final-cta {
    padding: 2rem 5%;
    background: #fff;
    text-align: center;
  }
  .mkomazi-final-cta h2 {
    margin-bottom: 1rem;
    color: var(--brown);
  }
  .mkomazi-final-cta p {
    max-width: 900px;
    margin: 0 auto 1.5rem auto;
    line-height: 1.8;
    text-align: left;
  }
  .final-cta-buttons {
    display: flex;
    flex-wrap: wrap;
    gap: 1rem;
    justify-content: center;
  }
  
  /* RESPONSIVE BREAKPOINTS */
  @media (max-width: 768px) {
    .mkomazi-best-time-grid {
      flex-direction: column;
      align-items: center;
    }
  }/*********************************************
  MOBILE EXPLORER SAFARIS DETAIL STYLES
**********************************************/

.page-hero--mobile .page-hero__overlay {
  background: linear-gradient(118deg, rgba(12, 27, 24, 0.92) 0%, rgba(44, 63, 52, 0.78) 52%, rgba(214, 136, 74, 0.6) 100%);
}

.page-hero--mobile .page-hero__content {
  background: linear-gradient(132deg, rgba(14, 28, 24, 0.92) 0%, rgba(34, 54, 46, 0.78) 55%, rgba(214, 136, 74, 0.6) 100%);
}

.page-hero--mobile .page-hero__subtitle {
  color: rgba(255, 255, 255, 0.9);
}

.feature-card img {
  height: clamp(170px, 28vw, 210px);
}

@media (max-width: 720px) {
  .feature-card img {
    height: 190px;
  }
}
/*********************************************
  MOUNT KILIMANJARO NATIONAL PARK PAGE STYLES
**********************************************/

/* HERO SECTION */
.kili-hero {
    position: relative;
    height: 80vh;
    overflow: hidden;
  }
  .kili-hero-image {
    width: 100%;
    height: 100%;
    object-fit: cover;
  }
  .kili-hero-overlay {
    position: absolute;
    inset: 0;
    background: rgba(0,0,0,0.3);
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    color: #fff;
    text-align: center;
    padding: 1rem;
  }
  .kili-hero-overlay h1 {
    font-size: 2.5rem;
    margin-bottom: 0.5rem;
  }
  .kili-hero-overlay p {
    font-size: 1.2rem;
  }
  
  /* AT A GLANCE SECTION */
  .kili-glance {
    padding: 2rem 5%;
    background: var(--beige);
    text-align: center;
  }
  .kili-glance h2 {
    margin-bottom: 1rem;
    color: var(--brown);
  }
  .glance-grid {
    max-width: 700px;
    margin: 0 auto;
    display: flex;
    gap: 1.5rem;
    flex-wrap: wrap;
    justify-content: center;
  }
  .glance-item {
    flex: 1 1 200px;
    background: #fff;
    border-radius: 6px;
    box-shadow: 0 2px 5px rgba(0,0,0,0.1);
    padding: 1rem;
    text-align: center;
  }
  .glance-item strong {
    display: block;
    margin-bottom: 0.5rem;
    color: var(--brown);
  }
  
  /* INTRO SECTION */
  .kili-intro {
    padding: 2rem 5%;
    background: #fff;
    text-align: center;
  }
  .kili-intro h2 {
    margin-bottom: 1rem;
    color: var(--brown);
  }
  .kili-intro p {
    max-width: 900px;
    margin: 0 auto;
    line-height: 1.8;
    text-align: left;
  }
  
  /* OVERVIEW SECTION */
  .kili-overview {
    padding: 2rem 5%;
    background: var(--beige);
    text-align: center;
  }
  .kili-overview h2 {
    margin-bottom: 1rem;
    color: var(--brown);
  }
  .kili-overview p {
    max-width: 900px;
    margin: 0 auto 1rem auto;
    line-height: 1.8;
    text-align: left;
  }
  
  /* PLANT & WILDLIFE SECTION */
  .kili-plants {
    padding: 2rem 5%;
    background: #fff;
    text-align: center;
  }
  .kili-plants h2 {
    margin-bottom: 1rem;
    color: var(--brown);
  }
  .kili-plants p {
    max-width: 900px;
    margin: 0 auto;
    line-height: 1.8;
    text-align: left;
  }
  
  /* THINGS TO DO SECTION */
  .kili-things {
    padding: 2rem 5%;
    background: var(--beige);
    text-align: center;
  }
  .kili-things h2 {
    margin-bottom: 1rem;
    color: var(--brown);
  }
  .kili-things p {
    max-width: 900px;
    margin: 0 auto;
    line-height: 1.8;
    text-align: left;
  }
  
  /* WHEN TO GO */
  .kili-best-time {
    padding: 2rem 5%;
    background: #fff;
    text-align: center;
  }
  .kili-best-time h2 {
    margin-bottom: 1rem;
    color: var(--brown);
  }
  .kili-best-time p {
    max-width: 900px;
    margin: 0 auto 1rem auto;
    line-height: 1.8;
    text-align: left;
  }
  .kili-best-time-grid {
    display: flex;
    gap: 2rem;
    max-width: 700px;
    margin: 1rem auto;
    flex-wrap: wrap;
    justify-content: center;
  }
  .best-time-item {
    flex: 1 1 220px;
    background: var(--beige);
    padding: 1rem;
    text-align: center;
    border: 1px solid #ddd;
    border-radius: 6px;
    box-shadow: 0 2px 3px rgba(0,0,0,0.1);
    margin-bottom: 1rem;
  }
  
  /* WHY TO GO SECTION */
  .kili-why-go {
    padding: 2rem 5%;
    background: beige;
    text-align: center;
  }

  .kili-why-go h2 {
    margin-bottom: 1rem;
    color: var(--brown);
  }
  .kili-why-go p {
    max-width: 900px;
    margin: 0 auto;
    line-height: 1.8;
    text-align: left;
  }
  .kili-why-go {
    background: #fff;
  }
  
  /* WHERE TO STAY SECTION */
  .kili-where {
    padding: 2rem 5%;
    background: var(--beige);
    text-align: center;
  }
  .kili-where h2 {
    margin-bottom: 1rem;
    color: var(--brown);
  }
  .kili-where p {
    max-width: 900px;
    margin: 0 auto 1rem auto;
    line-height: 1.8;
    text-align: left;
  }
  
  /* FINAL CTA SECTION */
  .kili-final-cta {
    padding: 2rem 5%;
    background: #fff;
    text-align: center;
  }
  .kili-final-cta h2 {
    margin-bottom: 1rem;
    color: var(--brown);
  }
  .kili-final-cta p {
    max-width: 900px;
    margin: 0 auto 1.5rem auto;
    line-height: 1.8;
    text-align: left;
  }
  .final-cta-buttons {
    display: flex;
    flex-wrap: wrap;
    gap: 1rem;
    justify-content: center;
  }
  
  /* RESPONSIVE BREAKPOINTS */
  @media (max-width: 768px) {
    .kili-best-time-grid {
      flex-direction: column;
      align-items: center;
    }
  }/*********************************************
  MOUNT MERU DETAIL REFINEMENTS
**********************************************/

.page-hero--meru .page-hero__overlay {
  background: linear-gradient(118deg, rgba(18, 32, 27, 0.9) 8%, rgba(44, 64, 54, 0.76) 48%, rgba(214, 143, 74, 0.58) 100%);
}

.page-hero--meru .page-hero__content {
  background: linear-gradient(132deg, rgba(18, 32, 27, 0.92) 0%, rgba(44, 64, 54, 0.78) 55%, rgba(214, 143, 74, 0.6) 100%);
}

#meru-highlights .feature-card img,
#meru-addons .link-card__image {
  height: clamp(170px, 28vw, 210px);
}

#meru-itinerary .split-feature + .split-feature {
  margin-top: var(--card-gap-compact);
}

@media (max-width: 720px) {
  #meru-highlights .feature-card img,
  #meru-addons .link-card__image {
    height: 190px;
  }
}
/*********************************************
  NGORONGORO CRATER PAGE STYLES
**********************************************/

/* HERO SECTION */
.ngoro-hero {
    position: relative;
    height: 80vh;
    overflow: hidden;
  }
  .ngoro-hero-image {
    width: 100%;
    height: 100%;
    object-fit: cover;
  }
  .ngoro-hero-overlay {
    position: absolute;
    inset: 0;
    background: rgba(0,0,0,0.3);
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    color: #fff;
    text-align: center;
    padding: 1rem;
  }
  .ngoro-hero-overlay h1 {
    font-size: 2.5rem;
    margin-bottom: 0.5rem;
  }
  .ngoro-hero-overlay p {
    font-size: 1.2rem;
  }
  
  /* AT A GLANCE SECTION */
  .ngoro-glance {
    padding: 2rem 5%;
    background: var(--beige);
    text-align: center;
  }
  .ngoro-glance h2 {
    margin-bottom: 1rem;
    color: var(--brown);
  }
  .glance-grid {
    max-width: 700px;
    margin: 0 auto;
    display: flex;
    gap: 1.5rem;
    flex-wrap: wrap;
    justify-content: center;
  }
  .glance-item {
    flex: 1 1 220px;
    background: #fff;
    border-radius: 6px;
    box-shadow: 0 2px 5px rgba(0,0,0,0.1);
    padding: 1rem;
    text-align: center;
  }
  .glance-item strong {
    display: block;
    margin-bottom: 0.5rem;
    color: var(--brown);
  }
  
  /* INTRO SECTION */
  .ngoro-intro {
    padding: 2rem 5%;
    background: #fff;
    text-align: center;
  }
  .ngoro-intro h2 {
    margin-bottom: 1rem;
    color: var(--brown);
  }
  .ngoro-intro p {
    max-width: 900px;
    margin: 0 auto;
    line-height: 1.8;
    text-align: left;
  }
  
  /* OVERVIEW SECTION */
  .ngoro-overview {
    padding: 2rem 5%;
    background: var(--beige);
    text-align: center;
  }
  .ngoro-overview h2 {
    margin-bottom: 1rem;
    color: var(--brown);
  }
  .ngoro-overview p {
    max-width: 900px;
    margin: 0 auto 1rem auto;
    line-height: 1.8;
    text-align: left;
  }
  
  /* WHY GO SECTION */
  .ngoro-why-go {
    padding: 2rem 5%;
    background: #fff;
    text-align: center;
  }
  .ngoro-why-go h2 {
    margin-bottom: 1rem;
    color: var(--brown);
  }
  .ngoro-why-go p {
    max-width: 900px;
    margin: 0 auto;
    line-height: 1.8;
    text-align: left;
  }
  
  /* THINGS TO DO SECTION */
  .ngoro-things {
    padding: 2rem 5%;
    background: var(--beige);
    text-align: center;
  }
  .ngoro-things h2 {
    margin-bottom: 1rem;
    color: var(--brown);
  }
  .ngoro-things p {
    max-width: 900px;
    margin: 0 auto;
    line-height: 1.8;
    text-align: left;
  }
  
  /* WHEN TO GO */
  .ngoro-best-time {
    padding: 2rem 5%;
    background: #fff;
    text-align: center;
  }
  .ngoro-best-time h2 {
    margin-bottom: 1rem;
    color: var(--brown);
  }
  .ngoro-best-time p {
    max-width: 900px;
    margin: 0 auto 1rem auto;
    line-height: 1.8;
    text-align: left;
  }
  .ngoro-best-time-grid {
    display: flex;
    gap: 2rem;
    max-width: 700px;
    margin: 1rem auto;
    flex-wrap: wrap;
    justify-content: center;
  }
  .best-time-item {
    flex: 1 1 220px;
    background: var(--beige);
    padding: 1rem;
    text-align: center;
    border: 1px solid #ddd;
    border-radius: 6px;
    box-shadow: 0 2px 3px rgba(0,0,0,0.1);
    margin-bottom: 1rem;
  }
  
  /* WILDLIFE SECTION */
  .ngoro-wildlife {
    padding: 2rem 5%;
    background: #fff;
    text-align: center;
  }
  .ngoro-wildlife h2 {
    margin-bottom: 1rem;
    color: var(--brown);
  }
  .ngoro-wildlife p {
    max-width: 900px;
    margin: 0 auto 1rem auto;
    line-height: 1.8;
    text-align: left;
  }
  
  /* WHERE TO STAY SECTION */
  .ngoro-where {
    padding: 2rem 5%;
    background: var(--beige);
    text-align: center;
  }
  .ngoro-where h2 {
    margin-bottom: 1rem;
    color: var(--brown);
  }
  .ngoro-where p {
    max-width: 900px;
    margin: 0 auto 1rem auto;
    line-height: 1.8;
    text-align: left;
  }
  
  /* FINAL CTA SECTION */
  .ngoro-final-cta {
    padding: 2rem 5%;
    background: #fff;
    text-align: center;
  }
  .ngoro-final-cta h2 {
    margin-bottom: 1rem;
    color: var(--brown);
  }
  .ngoro-final-cta p {
    max-width: 900px;
    margin: 0 auto 1.5rem auto;
    line-height: 1.8;
    text-align: left;
  }
  .final-cta-buttons {
    display: flex;
    flex-wrap: wrap;
    gap: 1rem;
    justify-content: center;
  }
  
  /* RESPONSIVE BREAKPOINTS */
  @media (max-width: 768px) {
    .ngoro-best-time-grid {
      flex-direction: column;
      align-items: center;
    }
  }/*********************************************
  NIGHT GAME DRIVES PAGE STYLES (Honeymoon-Inspired)
**********************************************/

  /* Duplicate experience-section styles removed - using consolidated version */
/* Pemba Island page refinements */

.page-hero--pemba .page-hero__overlay {
  background: linear-gradient(118deg, rgba(16, 32, 27, 0.9) 0%, rgba(40, 70, 56, 0.74) 46%, rgba(214, 143, 74, 0.58) 100%);
}

.pemba-glance {
  background: linear-gradient(145deg, rgba(255, 255, 255, 0.98) 0%, rgba(241, 248, 240, 0.94) 100%);
  border: 1px solid rgba(32, 74, 80, 0.1);
  box-shadow: 0 26px 58px rgba(11, 28, 36, 0.12);
  text-align: center;
}

.pemba-glance .section-max {
  display: grid;
  gap: clamp(1.3rem, 3vw, 1.9rem);
}

.pemba-glance .glance-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
  gap: clamp(1.5rem, 4vw, 2rem);
  margin-top: clamp(1.5rem, 3vw, 2rem);
}

.pemba-glance .glance-item {
  background: rgba(255, 255, 255, 0.96);
  border-radius: 18px;
  border: 1px solid rgba(32, 74, 80, 0.12);
  padding: clamp(1rem, 2.6vw, 1.6rem);
  box-shadow: 0 20px 42px rgba(15, 29, 26, 0.12);
}

.pemba-glance .glance-item strong {
  display: block;
  margin-bottom: 0.35rem;
  color: var(--brown);
  letter-spacing: 0.08em;
  text-transform: uppercase;
  font-size: 0.9rem;
}

.pemba-intro .section-max,
.pemba-wildlife .section-max,
.pemba-where .section-max {
  display: grid;
  gap: clamp(1.2rem, 3vw, 1.8rem);
  text-align: center;
}

.pemba-details {
  background: linear-gradient(140deg, rgba(241, 248, 240, 0.95) 0%, rgba(255, 255, 255, 0.98) 100%);
  border: 1px solid rgba(32, 74, 80, 0.1);
  box-shadow: 0 26px 58px rgba(11, 28, 36, 0.12);
}

.pemba-details .section-max {
  display: grid;
  gap: clamp(1.4rem, 3vw, 2.1rem);
}

.pemba-cols {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(260px, 1fr));
  gap: clamp(1.6rem, 4vw, 2.4rem);
  text-align: left;
}

.pemba-col h3 {
  margin-bottom: 0.8rem;
  color: var(--brown);
  text-transform: uppercase;
  letter-spacing: 0.08em;
  font-size: 0.95rem;
}

.pemba-col p {
  margin: 0;
  line-height: 1.8;
  color: rgba(18, 37, 32, 0.9);
}

.pemba-final-cta {
  background: linear-gradient(128deg, rgba(12, 32, 28, 0.92) 0%, rgba(210, 111, 26, 0.82) 52%, rgba(240, 180, 58, 0.65) 100%) !important;
  color: #fff;
  border: 1px solid rgba(255, 255, 255, 0.24);
  box-shadow: 0 32px 68px rgba(4, 10, 8, 0.35);
  position: relative;
  margin: clamp(3rem, 7vw, 5rem) auto;
  padding: clamp(3rem, 6vw, 4.5rem) 5%;
  border-radius: 32px;
}

.pemba-final-cta::before {
  content: "";
  position: absolute;
  inset: 0;
  background: url('../images/safari-pattern.svg') center/cover;
  opacity: 0.08;
  z-index: -2;
}

.pemba-final-cta::after {
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(128deg, rgba(12, 32, 28, 0.92) 0%, rgba(210, 111, 26, 0.82) 52%, rgba(240, 180, 58, 0.65) 100%);
  z-index: -1;
}

.pemba-final-cta p {
  color: rgba(255, 255, 255, 0.88);
}

.pemba-final-cta .cta-buttons {
  justify-content: center;
  gap: 0.9rem;
  margin-top: clamp(1.6rem, 4vw, 2.4rem);
}

.pemba-final-cta .btn-outline {
  color: #fff;
  border-color: rgba(255, 255, 255, 0.6);
}

.pemba-final-cta .btn-outline:hover,
.pemba-final-cta .btn-outline:focus {
  background: rgba(255, 255, 255, 0.2);
  color: #fff;
}

@media (max-width: 640px) {
  .pemba-final-cta .cta-buttons {
    flex-direction: column;
  }

  .pemba-final-cta .btn {
    width: 100%;
    justify-content: center;
  }
}
/*********************************************
  PHOTO SAFARIS PAGE STYLES
**********************************************/

  /* INTRO SECTION */
  .photo-intro {
    padding: 2rem 5%;
    background: #fff;
    text-align: center;
  }
  .photo-intro h2 {
    margin-bottom: 1rem;
    color: var(--brown);
  }
  .photo-intro p {
    max-width: 900px;
    margin: 0 auto;
    line-height: 1.8;
    text-align: left;
  }
  
  /* WHO SHOULD GO SECTION */
  .photo-whoshouldgo {
    padding: clamp(2rem, 4vw, 3rem) 5%;
    background: var(--beige);
  }
  .photo-whoshouldgo h2 {
    margin-bottom: clamp(1rem, 2vw, 1.5rem);
    color: var(--brown);
    text-align: center;
    font-size: clamp(1.8rem, 3vw, 2.2rem);
  }
  .photo-whoshouldgo p {
    max-width: 900px;
    margin: 0 auto clamp(1rem, 2vw, 1.5rem) auto;
    line-height: 1.8;
    text-align: left;
  }
  .photo-whoshouldgo ul {
    max-width: 600px;
    margin: clamp(1rem, 2vw, 1.5rem) auto;
    text-align: left;
    line-height: 1.8;
    list-style: disc outside;
    padding-left: 1.2rem;
  }
  
  /* WHERE TO EXPERIENCE SECTION */
  .photo-where {
    padding: 2rem 5%;
    background: #fff;
    text-align: center;
  }
  .photo-where h2 {
    margin-bottom: 1rem;
    color: var(--brown);
  }
  .photo-where p {
    max-width: 900px;
    margin: 0 auto;
    line-height: 1.8;
    text-align: left;
  }
  
  /* WHEN TO GO SECTION */
  .photo-besttime {
    padding: 2rem 5%;
    background: var(--beige);
    text-align: center;
  }
  .photo-besttime h2 {
    margin-bottom: 1rem;
    color: var(--brown);
  }
  .photo-besttime p {
    max-width: 900px;
    margin: 0 auto 1rem auto;
    line-height: 1.8;
    text-align: left;
  }
  .photo-besttime-grid {
    display: flex;
    flex-wrap: wrap;
    gap: 2rem;
    max-width: 700px;
    margin: 1rem auto;
    justify-content: center;
    text-align: center;
  }
  .besttime-item {
    flex: 1 1 220px;
    background: var(--beige);
    border-radius: 6px;
    box-shadow: 0 2px 5px rgba(0,0,0,0.1);
    padding: 1rem;
  }
  
  /* CTA BANNER */
  .cta-banner-content {
    max-width: 900px;
    margin: 0 auto;
  }
  .cta-banner-content h2 {
    margin-bottom: 1rem;
    font-size: 2rem;
  }
  
  /* ACCOMMODATIONS SECTION */
  .photo-accommodations {
    padding: 2rem 5%;
    background: #fff;
    text-align: center;
  }
  .photo-accommodations h2 {
    margin-bottom: 1rem;
    color: var(--brown);
  }
  .photo-accommodations p {
    max-width: 900px;
    margin: 0 auto;
    line-height: 1.8;
    text-align: left;
  }
  
  /* ADDITIONAL INFO SECTION */
  .photo-info {
    padding: 2rem 5%;
    background: var(--beige);
    text-align: center;
  }
  .photo-info h2 {
    margin-bottom: 1rem;
    color: var(--brown);
  }
  .photo-info p {
    max-width: 900px;
    margin: 0 auto 1rem auto;
    line-height: 1.8;
    text-align: left;
  }
  
  /* PHOTO DETAILS SECTION */
  .photo-details {
    padding: 2rem 5%;
    background: #fff;
    text-align: center;
  }
  .photo-details h2 {
    margin-bottom: 1rem;
    color: var(--brown);
  }
  .photo-details p {
    max-width: 900px;
    margin: 0 auto;
    line-height: 1.8;
    text-align: left;
  }
  
  /* FINAL CTA SECTION */
  .photo-final-cta {
    padding: 2rem 5%;
    background: var(--beige);
    text-align: center;
  }
  .photo-final-cta h2 {
    margin-bottom: 1rem;
    color: var(--brown);
  }
  .photo-final-cta p {
    max-width: 900px;
    margin: 0 auto 1.5rem auto;
    line-height: 1.8;
    text-align: left;
  }
  .final-cta-buttons {
    display: flex;
    gap: 1rem;
    flex-wrap: wrap;
    justify-content: center;
  }
  
  /* RESPONSIVE BREAKPOINTS */
  @media (max-width: 768px) {
    .photo-besttime-grid {
      flex-direction: column;
      align-items: center;
    }
    .photo-whoshouldgo ul {
      list-style-position: outside;
      padding-left: 1.5rem;
    }
  }
/*********************************************
  PRIVATE SAFARIS PAGE STYLES
**********************************************/

/* HERO SECTION */

  /* INTRO SECTION */
  .private-intro {
    padding: 2rem 5%;
    background: #fff;
    text-align: center;
  }
  .private-intro h2 {
    margin-bottom: 1rem;
    color: var(--brown);
  }
  .private-intro p {
    max-width: 900px;
    margin: 0 auto;
    line-height: 1.8;
    text-align: left;
  }
  
  /* WHO SHOULD GO SECTION */
  .private-whoshouldgo {
    padding: clamp(2rem, 4vw, 3rem) 5%;
    background: var(--beige);
  }
  .private-whoshouldgo h2 {
    margin-bottom: clamp(1rem, 2vw, 1.5rem);
    color: var(--brown);
    text-align: center;
    font-size: clamp(1.8rem, 3vw, 2.2rem);
  }
  .private-whoshouldgo p {
    max-width: 900px;
    margin: 0 auto clamp(1rem, 2vw, 1.5rem) auto;
    line-height: 1.8;
    text-align: left;
  }
  .private-whoshouldgo ul {
    max-width: 600px;
    margin: clamp(1rem, 2vw, 1.5rem) auto;
    text-align: left;
    line-height: 1.8;
    list-style: disc outside;
    padding-left: 1.2rem;
  }
  
  /* WHERE TO EXPERIENCE SECTION */
  .private-where {
    padding: 2rem 5%;
    background: #fff;
    text-align: center;
  }
  .private-where h2 {
    margin-bottom: 1rem;
    color: var(--brown);
  }
  .private-where p {
    max-width: 900px;
    margin: 0 auto;
    line-height: 1.8;
    text-align: left;
  }
  
  /* WHEN TO GO SECTION */
  .private-besttime {
    padding: 2rem 5%;
    background: var(--beige);
    text-align: center;
  }
  .private-besttime h2 {
    margin-bottom: 1rem;
    color: var(--brown);
  }
  .private-besttime p {
    max-width: 900px;
    margin: 0 auto 1rem auto;
    line-height: 1.8;
    text-align: left;
  }
  .private-besttime-grid {
    display: flex;
    flex-wrap: wrap;
    gap: 2rem;
    max-width: 700px;
    margin: 1rem auto;
    justify-content: center;
    text-align: center;
  }
  .besttime-item {
    flex: 1 1 220px;
    background: var(--beige);
    border-radius: 6px;
    box-shadow: 0 2px 5px rgba(0,0,0,0.1);
    padding: 1rem;
  }
  
  /* CTA BANNER */
  .cta-banner-content {
    max-width: 900px;
    margin: 0 auto;
  }
  .cta-banner-content h2 {
    margin-bottom: 1rem;
    font-size: 2rem;
  }
  
  /* ACCOMMODATIONS SECTION */
  .private-accommodations {
    padding: 2rem 5%;
    background: #fff;
    text-align: center;
  }
  .private-accommodations h2 {
    margin-bottom: 1rem;
    color: var(--brown);
  }
  .private-accommodations p {
    max-width: 900px;
    margin: 0 auto;
    line-height: 1.8;
    text-align: left;
  }
  
  /* ADVANTAGES SECTION */
  .private-advantages {
    padding: 2rem 5%;
    background: var(--beige);
    text-align: center;
  }
  .private-advantages h2 {
    margin-bottom: 1rem;
    color: var(--brown);
  }
  .private-advantages p {
    max-width: 900px;
    margin: 0 auto 1rem auto;
    line-height: 1.8;
    text-align: left;
  }
  
  /* SAFARI DETAILS SECTION */
  .private-details {
    padding: 2rem 5%;
    background: #fff;
    text-align: center;
  }
  .private-details h2 {
    margin-bottom: 1rem;
    color: var(--brown);
  }
  .private-details p {
    max-width: 900px;
    margin: 0 auto;
    line-height: 1.8;
    text-align: left;
  }
  
  /* FINAL CTA SECTION */
  .private-final-cta {
    padding: 2rem 5%;
    background: var(--beige);
    text-align: center;
  }
  .private-final-cta h2 {
    margin-bottom: 1rem;
    color: var(--brown);
  }
  .private-final-cta p {
    max-width: 900px;
    margin: 0 auto 1.5rem auto;
    line-height: 1.8;
    text-align: left;
  }
  .final-cta-buttons {
    display: flex;
    gap: 1rem;
    flex-wrap: wrap;
    justify-content: center;
  }
  
  /* RESPONSIVE BREAKPOINTS */
  @media (max-width: 768px) {
    .private-besttime-grid {
      flex-direction: column;
      align-items: center;
    }
    .private-whoshouldgo ul {
      list-style-position: outside;
      padding-left: 1.5rem;
    }
  }
/*********************************************
  RUAHA NATIONAL PARK PAGE STYLES
**********************************************/

/* HERO SECTION */
.ruaha-hero {
    position: relative;
    height: 80vh;
    overflow: hidden;
  }
  .ruaha-hero-image {
    width: 100%;
    height: 100%;
    object-fit: cover;
  }
  .ruaha-hero-overlay {
    position: absolute;
    inset: 0;
    background: rgba(0,0,0,0.3);
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    color: #fff;
    text-align: center;
    padding: 1rem;
  }
  .ruaha-hero-overlay h1 {
    font-size: 2.5rem;
    margin-bottom: 0.5rem;
  }
  .ruaha-hero-overlay p {
    font-size: 1.2rem;
  }
  
  /* AT A GLANCE SECTION */
  .ruaha-glance {
    padding: 2rem 5%;
    background: var(--beige);
    text-align: center;
  }
  .ruaha-glance h2 {
    margin-bottom: 1rem;
    color: var(--brown);
  }
  .glance-grid {
    max-width: 700px;
    margin: 0 auto;
    display: flex;
    gap: 1.5rem;
    flex-wrap: wrap;
    justify-content: center;
  }
  .glance-item {
    flex: 1 1 220px;
    background: #fff;
    border-radius: 6px;
    box-shadow: 0 2px 5px rgba(0,0,0,0.1);
    padding: 1rem;
    text-align: center;
  }
  .glance-item strong {
    display: block;
    margin-bottom: 0.5rem;
    color: var(--brown);
  }
  
  /* INTRO SECTION */
  .ruaha-intro {
    padding: 2rem 5%;
    background: #fff;
    text-align: center;
  }
  .ruaha-intro h2 {
    margin-bottom: 1rem;
    color: var(--brown);
  }
  .ruaha-intro p {
    max-width: 900px;
    margin: 0 auto;
    line-height: 1.8;
    text-align: left;
  }
  
  /* PARK OVERVIEW SECTION */
  .ruaha-overview {
    padding: 2rem 5%;
    background: var(--beige);
    text-align: center;
  }
  .ruaha-overview h2 {
    margin-bottom: 1rem;
    color: var(--brown);
  }
  .ruaha-overview p {
    max-width: 900px;
    margin: 0 auto 1rem auto;
    line-height: 1.8;
    text-align: left;
  }
  
  /* VEGETATION & WILDLIFE SECTION */
  .ruaha-vegetation {
    padding: 2rem 5%;
    background: #fff;
    text-align: center;
  }
  .ruaha-vegetation h2 {
    margin-bottom: 1rem;
    color: var(--brown);
  }
  .ruaha-vegetation p {
    max-width: 900px;
    margin: 0 auto;
    line-height: 1.8;
    text-align: left;
  }
  
  /* THINGS TO DO SECTION */
  .ruaha-things {
    padding: 2rem 5%;
    background: var(--beige);
    text-align: center;
  }
  .ruaha-things h2 {
    margin-bottom: 1rem;
    color: var(--brown);
  }
  .ruaha-things p {
    max-width: 900px;
    margin: 0 auto;
    line-height: 1.8;
    text-align: left;
  }
  
  /* WHEN TO GO */
  .ruaha-best-time {
    padding: 2rem 5%;
    background: #fff;
    text-align: center;
  }
  .ruaha-best-time h2 {
    margin-bottom: 1rem;
    color: var(--brown);
  }
  .ruaha-best-time p {
    max-width: 900px;
    margin: 0 auto 1rem auto;
    line-height: 1.8;
    text-align: left;
  }
  .ruaha-best-time-grid {
    display: flex;
    gap: 2rem;
    max-width: 700px;
    margin: 1rem auto;
    flex-wrap: wrap;
    justify-content: center;
  }
  .best-time-item {
    flex: 1 1 220px;
    background: var(--beige);
    padding: 1rem;
    text-align: center;
    border: 1px solid #ddd;
    border-radius: 6px;
    box-shadow: 0 2px 3px rgba(0,0,0,0.1);
    margin-bottom: 1rem;
  }
  
  /* WHY TO GO SECTION */
  .ruaha-why-go {
    padding: 2rem 5%;
    background: #fff;
    text-align: center;
  }
  .ruaha-why-go h2 {
    margin-bottom: 1rem;
    color: var(--brown);
  }
  .ruaha-why-go p {
    max-width: 900px;
    margin: 0 auto;
    line-height: 1.8;
    text-align: left;
  }
  
  /* WHERE TO STAY SECTION */
  .ruaha-where {
    padding: 2rem 5%;
    background: var(--beige);
    text-align: center;
  }
  .ruaha-where h2 {
    margin-bottom: 1rem;
    color: var(--brown);
  }
  .ruaha-where p {
    max-width: 900px;
    margin: 0 auto 1rem auto;
    line-height: 1.8;
    text-align: left;
  }
  
  /* FINAL CTA SECTION */
  .ruaha-final-cta {
    padding: 2rem 5%;
    background: #fff;
    text-align: center;
  }
  .ruaha-final-cta h2 {
    margin-bottom: 1rem;
    color: var(--brown);
  }
  .ruaha-final-cta p {
    max-width: 900px;
    margin: 0 auto 1.5rem auto;
    line-height: 1.8;
    text-align: left;
  }
  .final-cta-buttons {
    display: flex;
    flex-wrap: wrap;
    gap: 1rem;
    justify-content: center;
  }
  
  /* RESPONSIVE BREAKPOINTS */
  @media (max-width: 768px) {
    .ruaha-best-time-grid {
      flex-direction: column;
      align-items: center;
    }
  }/*********************************************
  SAADANI NATIONAL PARK PAGE STYLES
**********************************************/

/* HERO SECTION */
.saadani-hero {
    position: relative;
    height: 80vh;
    overflow: hidden;
}
.saadani-hero-image {
    width: 100%;
    height: 100%;
    object-fit: cover;
}
.saadani-hero-overlay {
    position: absolute;
    inset: 0;
    background: rgba(0,0,0,0.3); /* For consistency with Serengeti’s overlay */
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    color: #fff;
    text-align: center;
    padding: 1rem;
}
.saadani-hero-overlay h1 {
    font-size: 2.5rem;
    margin-bottom: 0.5rem;
}
.saadani-hero-overlay p {
    font-size: 1.2rem;
}

/* AT A GLANCE SECTION */
.saadani-glance {
    padding: 2rem 5%;
    background: var(--beige);
    text-align: center;
}
.saadani-glance h2 {
    margin-bottom: 1rem;
    color: var(--brown);
}
.saadani-glance .glance-grid {
    max-width: 700px; /* Consistent width with Serengeti */
    margin: 0 auto;
    display: flex;
    flex-wrap: wrap;
    gap: 1.5rem;
    justify-content: center;
}
.saadani-glance .glance-item {
    flex: 1 1 220px;
    background: #fff;
    border-radius: 6px;
    box-shadow: 0 2px 5px rgba(0,0,0,0.1);
    padding: 1rem;
    text-align: center;
}
.saadani-glance .glance-item strong {
    display: block;
    margin-bottom: 0.5rem;
    color: var(--brown);
}

/* OVERVIEW SECTION */
.saadani-overview {
    padding: 2rem 5%;
    background: #fff;
    text-align: center;
}
.saadani-overview h2 {
    margin-bottom: 1rem;
    color: var(--brown);
}
.saadani-overview p {
    max-width: 900px;
    margin: 0 auto 1rem auto;
    line-height: 1.8;
    text-align: left; /* Align text to the left for readability */
}

/* ACTIVITIES SECTION */
.saadani-activities {
    padding: 2rem 5%;
    background: var(--beige);
    text-align: center;
}
.saadani-activities h2 {
    margin-bottom: 1rem;
    color: var(--brown);
}
.saadani-activities p {
    max-width: 900px;
    margin: 0 auto 1rem auto;
    line-height: 1.8;
    text-align: left;
}
.saadani-activities ul {
    max-width: 800px;
    margin: 0 auto;
    list-style: none; /* Remove default bullets */
    padding-left: 0;
    text-align: left;
}
.saadani-activities ul li {
    position: relative;
    margin-bottom: 0.5rem;
    padding-left: 1.5rem; /* Space for custom bullet */
}
.saadani-activities ul li::before {
    content: "•"; /* Custom bullet */
    position: absolute;
    left: 0;
    color: var(--brown);
    font-size: 1.2rem;
    line-height: 1;
}

/* WILDLIFE HIGHLIGHTS SECTION */
.saadani-wildlife {
    padding: 2rem 5%;
    background: var(--beige);
    text-align: center;
}
.saadani-wildlife h2 {
    margin-bottom: 1rem;
    color: var(--brown);
}
.saadani-wildlife p {
    max-width: 900px;
    margin: 0 auto 1rem auto;
    line-height: 1.8;
    text-align: left;
}
.saadani-wildlife ul {
    max-width: 800px;
    margin: 0 auto;
    list-style: none; /* Remove default bullets */
    padding-left: 0;
    text-align: left;
}
.saadani-wildlife ul li {
    position: relative;
    margin-bottom: 0.5rem;
    padding-left: 1.5rem; /* Space for custom bullet */
}
.saadani-wildlife ul li::before {
    content: "•"; /* Custom bullet */
    position: absolute;
    left: 0;
    color: var(--brown);
    font-size: 1.2rem;
    line-height: 1;
}

/* WALKING SECTION */
.saadani-walking {
    padding: 2rem 5%;
    background: #fff;
    text-align: center;
}
.saadani-walking h2 {
    margin-bottom: 1rem;
    color: var(--brown);
}
.saadani-walking p {
    max-width: 900px;
    margin: 0 auto 1rem auto;
    line-height: 1.8;
    text-align: left;
}

/* ACCOMMODATION SECTION */
.saadani-accommodation {
    padding: 2rem 5%;
    background: var(--beige);
    text-align: center;
}
.saadani-accommodation h2 {
    margin-bottom: 1rem;
    color: var(--brown);
}
.saadani-accommodation p {
    max-width: 900px;
    margin: 0 auto 1rem auto;
    line-height: 1.8;
    text-align: left;
}

/* FINAL CTA SECTION */
.saadani-final-cta {
    padding: 2rem 5%;
    background: #fff;
    text-align: center;
}
.saadani-final-cta h2 {
    margin-bottom: 1rem;
    color: var(--brown);
}
.saadani-final-cta p {
    max-width: 900px;
    margin: 0 auto 1.5rem auto;
    line-height: 1.8;
    text-align: left;
}
.cta-buttons {
    display: flex;
    flex-wrap: wrap;
    gap: 1rem;
    justify-content: center;
}

/* RESPONSIVE BREAKPOINTS */
@media (max-width: 768px) {
    .saadani-glance .glance-grid {
        display: flex;
        flex-wrap: wrap;
        justify-content: center;
        gap: 1rem;
    }
    .saadani-glance .glance-item {
        flex: 1 1 150px;
    }
}
/*********************************************
  SAANANE ISLAND NATIONAL PARK PAGE STYLES
**********************************************/

/* HERO SECTION */
.saanane-hero {
    position: relative;
    height: 80vh;
    overflow: hidden;
}
.saanane-hero-image {
    width: 100%;
    height: 100%;
    object-fit: cover;
}
.saanane-hero-overlay {
    position: absolute;
    inset: 0;
    background: rgba(0,0,0,0.3);
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    color: #fff;
    text-align: center;
    padding: 1rem;
}
.saanane-hero-overlay h1 {
    font-size: 2.5rem;
    margin-bottom: 0.5rem;
}
.saanane-hero-overlay p {
    font-size: 1.2rem;
}

/* AT A GLANCE SECTION */
.saanane-glance {
    padding: 2rem 5%;
    background: var(--beige);
    text-align: center;
}
.saanane-glance h2 {
    margin-bottom: 1rem;
    color: var(--brown);
}
.saanane-glance .glance-grid {
    max-width: 700px;
    margin: 0 auto;
    display: flex;
    flex-wrap: wrap;
    gap: 1.5rem;
    justify-content: center;
}
.saanane-glance .glance-item {
    flex: 1 1 220px;
    background: #fff;
    border-radius: 6px;
    box-shadow: 0 2px 5px rgba(0,0,0,0.1);
    padding: 1rem;
    text-align: center;
}
.saanane-glance .glance-item strong {
    display: block;
    margin-bottom: 0.5rem;
    color: var(--brown);
}

/* INTRO SECTION */
.saanane-intro {
    padding: 2rem 5%;
    background: #fff;
    text-align: center;
}
.saanane-intro h2 {
    margin-bottom: 1rem;
    color: var(--brown);
}
.saanane-intro p {
    max-width: 900px;
    margin: 0 auto 1rem auto;
    line-height: 1.8;
    text-align: left;
}

/* HIGHLIGHTS SECTION */
.saanane-highlights {
    padding: 2rem 5%;
    background: var(--beige);
    text-align: center;
}
.saanane-highlights h2 {
    margin-bottom: 1rem;
    color: var(--brown);
}
.saanane-highlights p {
    max-width: 900px;
    margin: 0 auto;
    line-height: 1.8;
    text-align: left;
}

/* BEST TIME SECTION */
.saanane-best-time {
    padding: 2rem 5%;
    background: #fff;
    text-align: center;
}
.saanane-best-time h2 {
    margin-bottom: 1rem;
    color: var(--brown);
}
.saanane-best-time p {
    max-width: 900px;
    margin: 0 auto 1rem auto;
    line-height: 1.8;
    text-align: left;
}
.saanane-best-time-grid {
    display: flex;
    gap: 2rem;
    max-width: 700px;
    margin: 1rem auto;
    flex-wrap: wrap;
    justify-content: center;
}
.best-time-item {
    flex: 1 1 220px;
    background: var(--beige);
    padding: 1rem;
    text-align: center;
    border: 1px solid #ddd;
    border-radius: 6px;
    box-shadow: 0 2px 3px rgba(0,0,0,0.1);
    margin-bottom: 1rem;
}

/* WHY GO SECTION */
.saanane-why-go {
    padding: 2rem 5%;
    background: var(--beige);
    text-align: center;
}
.saanane-why-go h2 {
    margin-bottom: 1rem;
    color: var(--brown);
}
.saanane-why-go p {
    max-width: 900px;
    margin: 0 auto;
    line-height: 1.8;
    text-align: left;
}

/* ACTIVITIES SECTION */
.saanane-activities {
    padding: 2rem 5%;
    background: #fff;
    text-align: center;
}
.saanane-activities h2 {
    margin-bottom: 1rem;
    color: var(--brown);
}
.saanane-activities p {
    max-width: 900px;
    margin: 0 auto 1rem auto;
    line-height: 1.8;
    text-align: left;
}
.saanane-activities ul {
    max-width: 800px;
    margin: 0 auto;
    list-style: none; /* Remove default bullets */
    padding-left: 0;
    text-align: left;
}
.saanane-activities ul li {
    position: relative;
    margin-bottom: 0.5rem;
    padding-left: 1.5rem; /* Space for custom bullet */
}
.saanane-activities ul li::before {
    content: "•"; /* Custom bullet */
    position: absolute;
    left: 0;
    color: var(--brown);
    font-size: 1.2rem;
    line-height: 1;
}

/* WILDLIFE SECTION */
.saanane-wildlife {
    padding: 2rem 5%;
    background: var(--beige);
    text-align: center;
}
.saanane-wildlife h2 {
    margin-bottom: 1rem;
    color: var(--brown);
}
.saanane-wildlife p {
    max-width: 900px;
    margin: 0 auto 1rem auto;
    line-height: 1.8;
    text-align: left;
}
.saanane-wildlife ul {
    max-width: 800px;
    margin: 0 auto;
    list-style: none; /* Remove default bullets */
    padding-left: 0;
    text-align: left;
}
.saanane-wildlife ul li {
    position: relative;
    margin-bottom: 0.5rem;
    padding-left: 1.5rem; /* Space for custom bullet */
}
.saanane-wildlife ul li::before {
    content: "•"; /* Custom bullet */
    position: absolute;
    left: 0;
    color: var(--brown);
    font-size: 1.2rem;
    line-height: 1;
}

/* WALKING SECTION */
.saanane-walking {
    padding: 2rem 5%;
    background: #fff;
    text-align: center;
}
.saanane-walking h2 {
    margin-bottom: 1rem;
    color: var(--brown);
}
.saanane-walking p {
    max-width: 900px;
    margin: 0 auto 1rem auto;
    line-height: 1.8;
    text-align: left;
}

/* ACCOMMODATION SECTION */
.saanane-accommodation {
    padding: 2rem 5%;
    background: var(--beige);
    text-align: center;
}
.saanane-accommodation h2 {
    margin-bottom: 1rem;
    color: var(--brown);
}
.saanane-accommodation p {
    max-width: 900px;
    margin: 0 auto 1rem auto;
    line-height: 1.8;
    text-align: left;
}

/* FINAL CTA SECTION */
.saanane-final-cta {
    padding: 2rem 5%;
    background: #fff;
    text-align: center;
}
.saanane-final-cta h2 {
    margin-bottom: 1rem;
    color: var(--brown);
}
.saanane-final-cta p {
    max-width: 900px;
    margin: 0 auto 1.5rem auto;
    line-height: 1.8;
    text-align: left;
}
.final-cta-buttons {
    display: flex;
    flex-wrap: wrap;
    gap: 1rem;
    justify-content: center;
}

/* RESPONSIVE BREAKPOINTS */
@media (max-width: 768px) {
    .saanane-best-time-grid {
        flex-direction: column;
        align-items: center;
    }
}
/*********************************************
  SAFARI DETAIL SHARED STYLES
**********************************************/

.page-hero--detail .page-hero__content {
  text-align: left;
}

.page-hero--detail .page-hero__actions {
  justify-content: flex-start;
  gap: 0.85rem;
}

.page-hero--detail .page-hero__actions .btn {
  border-radius: 999px;
  padding: 0.85rem 1.75rem;
  box-shadow: 0 18px 36px rgba(0, 0, 0, 0.25);
}

.page-hero--detail .page-hero__subtitle {
  max-width: 640px;
}

.content-section + .content-section {
  margin-top: clamp(2rem, 4vw, 3rem);
}

.feature-card h3 {
  font-size: 1.25rem;
}

.feature-card p {
  font-size: 0.98rem;
}

.link-card__body h3 {
  font-size: 1.2rem;
}

.link-card__cta {
  font-size: 0.95rem;
}

@media (max-width: 720px) {
  .page-hero--detail .page-hero__content {
    text-align: center;
  }

  .page-hero--detail .page-hero__actions {
    justify-content: center;
  }
}
/* Safari Shared Styles */
:root {
  --hero-overlay-dark: rgba(17, 29, 26, 0.82);
  --hero-overlay-warm: rgba(204, 136, 74, 0.52);
}

.page-hero {
  position: relative;
  min-height: clamp(60vh, 70vh + 10vw, 88vh);
  display: flex;
  align-items: center;
  justify-content: center;
  overflow: hidden;
  color: #fff;
  --hero-overlay-bg: var(--hero-overlay-detail);
  --hero-overlay-glow: var(--hero-overlay-detail-glow);
  --hero-card-bg: var(--hero-card-detail);
  --hero-card-border: rgba(255, 255, 255, 0.24);
  --hero-card-shadow: 0 36px 70px rgba(5, 8, 6, 0.48);
}

.page-hero__image {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center;
  transform: none;
  filter: saturate(1.1);
}

/* Fix for upside-down images */
.page-hero__image[src*="sunset_safari.jpg"] {
  transform: rotate(180deg);
}

/* Fix for upside-down guides image */
img[src*="guides.jpg"],
.why-slide img[src*="guides.jpg"] {
  transform: rotate(180deg) !important;
}

/* Safari pages consistent styling */
.page-hero--safaris .page-hero__overlay {
  background: linear-gradient(118deg, rgba(14, 28, 26, 0.45) 0%, rgba(34, 60, 52, 0.35) 48%, rgba(204, 136, 74, 0.25) 100%);
}

.page-hero--safaris .page-hero__content {
  background: linear-gradient(132deg, rgba(15, 30, 26, 0.75) 0%, rgba(36, 64, 54, 0.65) 55%, rgba(204, 120, 58, 0.45) 100%);
  border-color: rgba(255, 255, 255, 0.22);
  box-shadow: 0 32px 68px rgba(4, 8, 7, 0.45);
}

/* Safari style collection consistent spacing - match destinations exactly */
.safari-style-collection {
  margin-top: var(--section-margin-top);
  display: grid;
  gap: var(--section-margin-top);
}

.safari-style-collection .split-feature + .split-feature {
  margin-top: 0 !important;
}

/* Ensure safari cards work properly on mobile */
@media (max-width: 980px) {
  .safari-style-collection {
    gap: var(--card-gap-compact);
  }
}

@media (max-width: 768px) {
  .safari-style-collection {
    gap: var(--card-internal-gap);
  }
}

/* Safari page section spacing consistency */
.safari-overview-grid {
  margin-top: var(--section-margin-top);
}

.safari-media + .safari-media {
  margin-top: var(--card-gap-compact);
}

.safari-stats .stat-bar {
  margin-top: var(--section-margin-top);
}

.safari-faq .accordion {
  margin-top: var(--section-margin-top);
}

/* Safari overview gets slightly tighter spacing */
.safari-overview.content-section {
  padding: clamp(2rem, 4vw, 3rem) 5%;
}

.page-hero__overlay {
  position: absolute;
  inset: 0;
  background: var(--hero-overlay-bg);
  mix-blend-mode: normal;
}

.page-hero::after {
  content: "";
  position: absolute;
  inset: 0;
  background: var(--hero-overlay-glow, transparent);
  pointer-events: none;
  mix-blend-mode: screen;
  opacity: 0.65;
}
.page-hero__content {
  position: relative;
  z-index: 2;
  width: min(100%, 960px);
  margin: 0 auto;
  padding: clamp(2.5rem, 5vw, 3.5rem);
  border-radius: 28px;
  border: 1px solid rgba(255, 255, 255, 0.24);
  backdrop-filter: blur(14px);
  text-align: center;
  color: rgba(255, 255, 255, 0.95);
  background: linear-gradient(132deg, rgba(16, 29, 26, 0.9) 0%, rgba(29, 52, 46, 0.78) 55%, rgba(204, 120, 58, 0.6) 100%);
  --hero-card-bg: var(--hero-card-primary);
  --hero-card-border: rgba(255, 255, 255, 0.22);
  --hero-card-shadow: 0 32px 68px rgba(4, 8, 7, 0.45);
}

.page-hero.page-hero--primary::after {
  background: var(--hero-overlay-primary-glow);
}

.page-hero.page-hero--primary .page-hero__overlay {
  background: var(--hero-overlay-primary);
}

.page-hero.page-hero--primary .page-hero__content {
  background: var(--hero-card-primary);
  border-color: rgba(255, 255, 255, 0.22);
  box-shadow: 0 32px 68px rgba(4, 8, 7, 0.45);
}

.page-hero.page-hero--primary::after {
  content: "";
  position: absolute;
  inset: 0;
  background: var(--hero-overlay-primary-glow);
  pointer-events: none;
  mix-blend-mode: screen;
}

.page-hero.page-hero--primary .page-hero__overlay::after {
  content: "";
  position: absolute;
  inset: 0;
  background: var(--hero-overlay-primary-glow);
  pointer-events: none;
  mix-blend-mode: screen;
}

.page-hero:not(.page-hero--primary)::after {
  content: none !important;
  display: none;
}

.page-hero:not(.page-hero--primary) .page-hero__overlay {
  background: var(--hero-overlay-detail);
}

.page-hero:not(.page-hero--primary) .page-hero__content {
  background: var(--hero-card-detail);
  border-color: rgba(255, 255, 255, 0.24);
  box-shadow: none;
}

.page-hero .page-hero__overlay::after {
  content: none !important;
  display: none;
}

/* NUCLEAR FIX: Completely recreate destination hero sections from scratch */
body.destination-page .page-hero--destination.page-hero--detail {
  all: unset !important;
  position: relative !important;
  min-height: 85vh !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  overflow: hidden !important;
  color: #fff !important;
}

/* Add subtle entrance animation */
body.destination-page .page-hero--destination.page-hero--detail .page-hero__content {
  animation: heroFadeIn 1.2s ease-out !important;
}

@keyframes heroFadeIn {
  0% {
    opacity: 0;
    transform: translateY(30px);
  }
  100% {
    opacity: 1;
    transform: translateY(0);
  }
}

body.destination-page .page-hero--destination.page-hero--detail .page-hero__image {
  all: unset !important;
  position: absolute !important;
  inset: 0 !important;
  width: 100% !important;
  height: 100% !important;
  object-fit: cover !important;
  object-position: center !important;
  transform: none !important;
}

body.destination-page .page-hero--destination.page-hero--detail .page-hero__overlay {
  all: unset !important;
  position: absolute !important;
  inset: 0 !important;
  background: linear-gradient(135deg, 
    rgba(20, 45, 35, 0.35) 0%, 
    rgba(35, 65, 45, 0.25) 25%, 
    rgba(45, 80, 55, 0.30) 50%, 
    rgba(180, 120, 60, 0.20) 75%, 
    rgba(220, 140, 70, 0.15) 100%) !important;
  z-index: 1 !important;
}

body.destination-page .page-hero--destination.page-hero--detail .page-hero__content {
  all: unset !important;
  position: relative !important;
  z-index: 2 !important;
  width: min(100%, 960px) !important;
  margin: 0 5% !important;
  padding: clamp(2.5rem, 4vw, 3.5rem) !important;
  border-radius: 24px !important;
  border: 1px solid rgba(255, 255, 255, 0.3) !important;
  background: linear-gradient(132deg, rgba(16, 29, 26, 0.9) 0%, rgba(29, 52, 46, 0.78) 55%, rgba(204, 120, 58, 0.6) 100%) !important;
  backdrop-filter: blur(20px) !important;
  -webkit-backdrop-filter: blur(20px) !important;
  box-shadow: 0 25px 50px rgba(0, 0, 0, 0.3), 
              0 0 0 1px rgba(255, 255, 255, 0.1) inset !important;
  color: #fff !important;
  display: block !important;
}

/* Reset all child elements */
body.destination-page .page-hero--destination.page-hero--detail .page-hero__content * {
  all: unset !important;
  display: revert !important;
  color: inherit !important;
}

/* Restore essential typography */
body.destination-page .page-hero--destination.page-hero--detail .page-hero__heading {
  font-size: clamp(2.5rem, 4.2vw, 3.8rem) !important;
  margin-bottom: 1rem !important;
  line-height: 1.1 !important;
  font-weight: 700 !important;
  text-shadow: 0 4px 8px rgba(0, 0, 0, 0.4) !important;
  letter-spacing: -0.02em !important;
}

body.destination-page .page-hero--destination.page-hero--detail .page-hero__subtitle {
  font-size: clamp(1.1rem, 2vw, 1.4rem) !important;
  line-height: 1.6 !important;
  margin-bottom: 2.5rem !important;
  color: rgba(255, 255, 255, 0.95) !important;
  text-shadow: 0 2px 4px rgba(0, 0, 0, 0.3) !important;
  max-width: 600px !important;
}

body.destination-page .page-hero--destination.page-hero--detail .page-hero__eyebrow {
  font-size: 0.8rem !important;
  letter-spacing: 0.25em !important;
  text-transform: uppercase !important;
  color: rgba(220, 140, 70, 0.9) !important;
  margin-bottom: 0.75rem !important;
  display: block !important;
  font-weight: 600 !important;
  text-shadow: 0 2px 4px rgba(0, 0, 0, 0.3) !important;
}

body.destination-page .page-hero--destination.page-hero--detail .page-hero__actions {
  display: flex !important;
  gap: 1rem !important;
  flex-wrap: wrap !important;
}

body.destination-page .page-hero--destination.page-hero--detail .btn {
  display: inline-block !important;
  padding: 0.85rem 1.75rem !important;
  border-radius: 999px !important;
  text-decoration: none !important;
  font-weight: 600 !important;
  cursor: pointer !important;
  pointer-events: auto !important;
  position: relative !important;
  z-index: 10 !important;
}

body.destination-page .page-hero--destination.page-hero--detail .btn-primary {
  background: linear-gradient(135deg, #D4851A 0%, #CC5500 50%, #B8470A 100%) !important;
  color: white !important;
  box-shadow: 0 8px 25px rgba(204, 85, 0, 0.4), 
              0 0 0 1px rgba(255, 255, 255, 0.1) inset !important;
  transition: all 0.3s ease !important;
}

body.destination-page .page-hero--destination.page-hero--detail .btn-primary:hover {
  background: linear-gradient(135deg, #E6941F 0%, #D4851A 50%, #CC5500 100%) !important;
  transform: translateY(-2px) !important;
  box-shadow: 0 12px 35px rgba(204, 85, 0, 0.5), 
              0 0 0 1px rgba(255, 255, 255, 0.15) inset !important;
}

body.destination-page .page-hero--destination.page-hero--detail .btn-outline {
  background: rgba(255, 255, 255, 0.1) !important;
  color: #fff !important;
  border: 1px solid rgba(255, 255, 255, 0.4) !important;
  backdrop-filter: blur(10px) !important;
  -webkit-backdrop-filter: blur(10px) !important;
  transition: all 0.3s ease !important;
}

body.destination-page .page-hero--destination.page-hero--detail .btn-outline:hover {
  background: rgba(255, 255, 255, 0.2) !important;
  border-color: rgba(255, 255, 255, 0.6) !important;
  transform: translateY(-2px) !important;
}


.page-hero__eyebrow {
  display: inline-block;
  font-size: 0.75rem;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  color: rgba(255, 255, 255, 0.7);
  margin-bottom: 0.75rem;
}

.page-hero__heading {
  font-size: clamp(2.3rem, 3.8vw, 3.4rem);
  margin-bottom: 0.8rem;
  line-height: 1.15;
  color: #fff;
}

.page-hero__subtitle {
  font-size: clamp(1.05rem, 1.8vw, 1.3rem);
  line-height: 1.75;
  margin-bottom: clamp(1.5rem, 3vw, 2.25rem);
  color: rgba(255, 255, 255, 0.88);
}

.page-hero__actions {
  display: flex;
  flex-wrap: wrap;
  gap: 0.9rem;
}

.page-hero__actions .btn {
  border-radius: 999px;
  padding: 0.85rem 1.75rem;
  box-shadow: 0 18px 38px rgba(0, 0, 0, 0.3);
}

.page-hero__actions .btn-outline {
  color: #fff;
  border-color: rgba(255, 255, 255, 0.6);
  background: transparent;
}

.page-hero__actions .btn-outline:hover {
  background: rgba(255, 255, 255, 0.2);
  color: #fff;
}

.page-hero--experience,
.page-hero--destination,
.page-hero--destinations {
  min-height: clamp(60vh, 70vh + 10vw, 88vh);
}

.page-hero--experience .page-hero__content,
.page-hero--destination .page-hero__content,
.page-hero--destinations .page-hero__content {
  width: min(100%, 960px);
}

.page-hero--lodge .page-hero__overlay {
  background: linear-gradient(118deg, rgba(16, 28, 24, 0.88) 12%, rgba(41, 64, 54, 0.72) 52%, rgba(191, 130, 71, 0.55) 100%);
}

.page-hero--luxury .page-hero__overlay {
  background: linear-gradient(118deg, rgba(15, 24, 32, 0.88) 10%, rgba(58, 42, 26, 0.78) 48%, rgba(224, 164, 90, 0.6) 100%);
}

.page-hero--camping .page-hero__overlay {
  background: linear-gradient(118deg, rgba(9, 20, 16, 0.9) 0%, rgba(36, 54, 44, 0.78) 48%, rgba(181, 128, 68, 0.58) 100%);
}

.page-hero--mobile .page-hero__overlay {
  background: linear-gradient(118deg, rgba(10, 18, 15, 0.92) 0%, rgba(54, 64, 53, 0.75) 45%, rgba(214, 136, 65, 0.58) 100%);
}

.page-hero--tailor .page-hero__overlay {
  background: linear-gradient(118deg, rgba(16, 24, 32, 0.92) 0%, rgba(60, 44, 26, 0.75) 48%, rgba(214, 143, 74, 0.6) 100%);
}

.page-hero--daytrips .page-hero__overlay {
  background: linear-gradient(118deg, rgba(15, 25, 30, 0.9) 8%, rgba(48, 69, 74, 0.72) 48%, rgba(214, 136, 74, 0.6) 100%);
}

@media (max-width: 768px) {
  .page-hero {
    min-height: 70vh;
  }
  .page-hero__content {
    padding: 2rem 1.75rem;
    margin: 0 1.5rem;
  }
  .page-hero__actions {
    flex-direction: column;
  }
  .page-hero__actions .btn {
    width: 100%;
    justify-content: center;
  }
}

@media (max-width: 640px) {
  .page-hero--experience .page-hero__content,
  .page-hero--destination .page-hero__content,
  .page-hero--destinations .page-hero__content {
    text-align: center;
  }

  .page-hero--experience .page-hero__actions,
  .page-hero--destination .page-hero__actions,
  .page-hero--destinations .page-hero__actions {
    justify-content: center;
  }
}

/* Section Layouts */
.content-section {
  position: relative;
  padding: clamp(2.5rem, 5vw, 3.5rem) 5%;
  background: rgba(255, 255, 255, 0.98);
}

.content-section--tint {
  background: rgba(245, 243, 234, 0.96);
}

.content-section--dark {
  background: linear-gradient(160deg, rgba(18, 33, 29, 0.45) 0%, rgba(36, 26, 16, 0.45) 100%);
  color: rgba(255, 255, 255, 0.95);
}

.content-section--dark .btn-outline {
  color: #fff;
  border-color: rgba(255, 255, 255, 0.6);
}

.content-section--dark .btn-outline:hover,
.content-section--dark .btn-outline:focus {
  background: rgba(255, 255, 255, 0.2);
  color: #fff;
}

.section-max {
  width: min(90%, 1100px);
  margin: 0 auto;
}

.section-eyebrow {
  display: block;
  text-transform: uppercase;
  letter-spacing: 0.24em;
  font-size: 0.75rem;
  color: rgba(47, 79, 79, 0.65);
  text-align: center;
  margin-bottom: 0.75rem;
}

.content-section--dark .section-eyebrow,
.cta-panel .section-eyebrow {
  color: rgba(255, 255, 255, 0.72);
}

.section-header {
  text-align: center;
  margin-bottom: clamp(2rem, 4vw, 2.75rem);
}

.section-header.section-header--left {
  text-align: left;
}

.section-header.section-header--left .section-heading {
  text-align: left;
  margin-left: 0;
  margin-right: 0;
}

.section-header.section-header--left .section-intro {
  margin-left: 0;
  margin-right: 0;
}

.section-header.section-header--left .section-eyebrow {
  text-align: left;
}

.section-heading {
  margin: 0 0 clamp(2rem, 4vw, 2.75rem);
  font-size: clamp(1.8rem, 3.5vw, 2.4rem);
  font-weight: 700;
  text-align: center;
  line-height: 1.25;
  color: var(--brown);
}

.content-section--dark .section-heading {
  color: #fff;
}

.section-intro {
  max-width: 850px;
  margin: 0 auto clamp(2.5rem, 5vw, 3.5rem);
  font-size: 1.05rem;
  line-height: 1.75;
  color: rgba(47, 79, 79, 0.9);
}

.content-section--dark .section-intro {
  color: rgba(255, 255, 255, 0.82);
}

/* Card Grid */
.feature-grid {
  display: grid;
  gap: var(--card-gap-standard);
  grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
  margin-top: var(--section-margin-top);
}

.feature-card {
  background: rgba(255, 255, 255, 0.92);
  border: 1px solid rgba(139, 69, 19, 0.15);
  border-radius: 20px;
  padding: clamp(1.5rem, 2.5vw, 2rem);
  box-shadow: 0 22px 40px rgba(12, 24, 21, 0.12);
  transition: transform 0.3s ease, box-shadow 0.3s ease;
  display: flex;
  flex-direction: column;
  gap: 0.75rem;
}

/* Link cards (used across multiple pages) */
.link-card-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
  gap: var(--card-gap-standard);
  margin-top: var(--section-margin-top);
}

.link-card {
  background: rgba(255, 255, 255, 0.96);
  border: 1px solid rgba(139, 69, 19, 0.12);
  border-radius: 20px;
  overflow: hidden;
  box-shadow: 0 22px 48px rgba(12, 24, 21, 0.1);
  display: flex;
  flex-direction: column;
  height: 100%;
  transition: transform 0.3s ease, box-shadow 0.3s ease;
}

.link-card:hover,
.link-card:focus-within {
  transform: translateY(-6px);
  box-shadow: 0 28px 60px rgba(12, 24, 21, 0.15);
}

.link-card__image {
  width: 100%;
  height: 180px;
  object-fit: cover;
}

.link-card__body {
  padding: clamp(1.4rem, 2.4vw, 1.9rem);
  display: flex;
  flex-direction: column;
  gap: 0.75rem;
  flex: 1 1 auto;
}

.link-card__body h3 {
  margin: 0;
  font-size: 1.15rem;
  color: var(--deep-green);
}

.link-card__body p {
  margin: 0;
  line-height: 1.65;
  color: rgba(47, 79, 79, 0.85);
}

.link-card__cta {
  margin-top: auto;
  font-weight: 600;
  color: var(--burnt-orange);
  text-decoration: none;
  display: inline-flex;
  align-items: center;
  gap: 0.35rem;
  transition: color 0.25s ease, transform 0.25s ease;
}

.link-card__cta::after {
  content: "→";
  transition: transform 0.25s ease;
}

.link-card__cta:hover,
.link-card__cta:focus {
  color: var(--deep-green);
}

.link-card__cta:hover::after,
.link-card__cta:focus::after {
  transform: translateX(4px);
}

.feature-card img {
  width: 100%;
  height: clamp(180px, 26vw, 220px);
  object-fit: cover;
  border-radius: 16px;
  margin-bottom: 0.5rem;
  box-shadow: 0 16px 32px rgba(12, 24, 21, 0.12);
}

.content-section--dark .feature-card {
  background: rgba(18, 29, 26, 0.72);
  border: 1px solid rgba(255, 255, 255, 0.1);
  color: rgba(255, 255, 255, 0.88);
  box-shadow: 0 28px 55px rgba(5, 8, 6, 0.4);
}

.feature-card:hover,
.feature-card:focus-within {
  transform: translateY(-6px);
  box-shadow: 0 34px 60px rgba(12, 24, 21, 0.2);
}

.feature-card h3 {
  font-size: 1.35rem;
  color: var(--deep-green);
}

.content-section--dark .feature-card h3 {
  color: #fff;
}

.feature-card p {
  line-height: 1.7;
  color: rgba(47, 79, 79, 0.85);
}

.content-section--dark .feature-card p {
  color: rgba(255, 255, 255, 0.78);
}

.feature-card .btn {
  margin-top: auto;
  align-self: flex-start;
}

.feature-card .btn-outline {
  border-color: var(--burnt-orange);
  color: var(--burnt-orange);
}

.feature-card .btn-outline:hover,
.feature-card .btn-outline:focus {
  background: var(--burnt-orange);
  color: #fff;
}

.content-section--dark .feature-card .btn-outline {
  border-color: rgba(255, 255, 255, 0.65);
  color: #fff;
}

.content-section--dark .feature-card .btn-outline:hover,
.content-section--dark .feature-card .btn-outline:focus {
  background: rgba(255, 255, 255, 0.2);
  color: #fff;
}

/* Split feature blocks (image + copy) */
.split-feature {
  display: grid;
  grid-template-columns: minmax(280px, 0.95fr) minmax(0, 1.05fr);
  align-items: stretch;
  border-radius: 28px;
  border: 1px solid rgba(139, 69, 19, 0.12);
  overflow: hidden;
  transition: transform 0.35s ease, box-shadow 0.35s ease;
  box-shadow: 0 28px 60px rgba(15, 29, 26, 0.12);
  background: transparent;
}

.split-feature:hover,
.split-feature:focus-within {
  transform: translateY(-6px);
  box-shadow: 0 36px 75px rgba(15, 29, 26, 0.18);
}

.split-feature__media {
  position: relative;
  min-height: 260px;
  overflow: hidden;
}

.split-feature__media img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
  transform: scale(1.02);
  transition: transform 0.5s ease;
}

.split-feature:hover .split-feature__media img,
.split-feature:focus-within .split-feature__media img {
  transform: scale(1.08);
}

.split-feature__media::after {
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(170deg, rgba(8, 22, 23, 0.3) 0%, rgba(8, 22, 23, 0) 55%);
  pointer-events: none;
}

.split-feature__content {
  padding: clamp(1.9rem, 3.5vw, 2.8rem);
  display: flex;
  flex-direction: column;
  gap: clamp(0.9rem, 2vw, 1.35rem);
  justify-content: center;
  position: relative;
  background: linear-gradient(135deg, rgba(255, 255, 255, 0.98) 0%, rgba(248, 244, 236, 0.94) 100%);
  color: rgba(47, 79, 79, 0.9);
  border-radius: 0 28px 28px 0;
}

.split-feature + .split-feature {
  margin-top: var(--card-gap-compact);
}

.split-feature__content h3 {
  margin: 0;
  font-size: clamp(1.3rem, 2.2vw, 1.65rem);
  color: var(--deep-green);
}

.split-feature__content p {
  margin: 0;
  line-height: 1.75;
  color: rgba(47, 79, 79, 0.88);
}

.split-feature__tagline {
  font-size: 0.95rem;
  color: rgba(47, 79, 79, 0.7);
  letter-spacing: 0.02em;
}

.split-feature__eyebrow {
  font-size: 0.8rem;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  color: rgba(47, 79, 79, 0.65);
}

.split-feature .btn-group {
  margin-top: 0.5rem;
}

.split-feature--reverse {
  grid-template-columns: minmax(0, 1.05fr) minmax(260px, 0.95fr);
}

.split-feature--reverse .split-feature__content {
  order: 2;
}

.split-feature--reverse .split-feature__media {
  order: 1;
}

@media (max-width: 980px) {
  .split-feature,
  .split-feature--reverse {
    grid-template-columns: 1fr;
  }

  .split-feature__media {
    min-height: 220px;
  }

  .split-feature__content {
    border-radius: 0 0 28px 28px;
  }

  .split-feature--reverse .split-feature__content {
    border-radius: 0 0 28px 28px;
  }

  .split-feature__media img,
  .split-feature--reverse .split-feature__media img {
    border-radius: 28px 28px 0 0;
  }

  .split-feature__content .btn,
  .split-feature__content .btn-outline {
    width: 100%;
    justify-content: center;
  }
}

/* Media block */
.media-block {
  display: grid;
  gap: clamp(1.5rem, 4vw, 2.5rem);
  align-items: center;
  grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
}

.media-block__image img {
  width: 100%;
  border-radius: 18px;
  box-shadow: 0 24px 50px rgba(12, 24, 21, 0.16);
}

.media-block__content h3 {
  font-size: 1.6rem;
  margin-bottom: 1rem;
}

.media-block__content p {
  line-height: 1.75;
  margin-bottom: 1rem;
  color: rgba(47, 79, 79, 0.88);
}

.content-section--dark .media-block__content p {
  color: rgba(255, 255, 255, 0.8);
}

.media-list {
  display: grid;
  gap: 0.65rem;
  margin-top: 0.75rem;
}

.media-list li {
  list-style: none;
  display: flex;
  gap: 0.65rem;
  align-items: flex-start;
}

.media-list li::before {
  content: "▹";
  color: var(--burnt-orange);
  margin-top: 0.1rem;
}

/* Stat bar */
.stat-bar {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
  gap: 1.25rem;
}

.stat-card {
  background: rgba(255, 255, 255, 0.92);
  border-radius: 18px;
  border: 1px solid rgba(139, 69, 19, 0.1);
  padding: 1.5rem;
  text-align: center;
  box-shadow: 0 22px 45px rgba(12, 24, 21, 0.12);
}

.content-section--dark .stat-card {
  background: rgba(18, 29, 26, 0.72);
  border: 1px solid rgba(255, 255, 255, 0.12);
  color: rgba(255, 255, 255, 0.88);
  box-shadow: 0 28px 55px rgba(5, 8, 6, 0.4);
}

.stat-card h4 {
  font-size: 1.75rem;
  margin-bottom: 0.35rem;
  color: var(--burnt-orange);
}

/* CTA banner (alternate) */
.cta-panel {
  position: relative;
  background: linear-gradient(132deg, rgba(16, 29, 26, 0.82) 0%, rgba(29, 52, 46, 0.76) 55%, rgba(204, 120, 58, 0.58) 100%);
  border-radius: 28px;
  padding: clamp(2.5rem, 5vw, 3.5rem);
  text-align: center;
  border: 1px solid rgba(255, 255, 255, 0.24);
  box-shadow: 0 32px 70px rgba(5, 8, 6, 0.4);
}

.cta-panel h3 {
  font-size: clamp(1.8rem, 3vw, 2.2rem);
  margin-bottom: 1rem;
}

.cta-panel p {
  line-height: 1.7;
  margin-bottom: 1.5rem;
  color: rgba(255, 255, 255, 0.82);
}

.cta-panel .cta-buttons {
  display: flex;
  flex-wrap: wrap;
  gap: 0.85rem;
}

.cta-panel .cta-buttons .btn {
  border-radius: 999px;
  padding: 0.8rem 1.65rem;
  box-shadow: 0 20px 38px rgba(0, 0, 0, 0.28);
}

.cta-panel .cta-buttons .btn-outline {
  border-color: rgba(255, 255, 255, 0.6);
  color: #fff;
  background: transparent;
}

.cta-panel .cta-buttons .btn-outline:hover {
  background: rgba(255, 255, 255, 0.18);
}

/* FAQ accordion */
.accordion {
  display: grid;
  gap: 1rem;
}

.accordion details {
  border: 1px solid rgba(139, 69, 19, 0.18);
  border-radius: 16px;
  background: #fff;
  box-shadow: 0 18px 40px rgba(12, 24, 21, 0.08);
  padding: 1.1rem 1.4rem;
  transition: border-color 0.3s ease, box-shadow 0.3s ease;
}

.accordion summary {
  list-style: none;
  font-weight: 600;
  color: var(--deep-green);
  position: relative;
  cursor: pointer;
  padding-right: 2rem;
}

.accordion summary::-webkit-details-marker { display: none; }

.accordion summary::after {
  content: "+";
  position: absolute;
  right: 0;
  top: 0;
  font-size: 1.2rem;
  transition: transform 0.3s ease;
}

.accordion details[open] summary::after {
  transform: rotate(45deg);
}

.accordion details p {
  margin-top: 0.85rem;
  font-size: 0.98rem;
  line-height: 1.7;
  color: rgba(47, 79, 79, 0.85);
}

.content-section--dark .accordion details {
  background: rgba(18, 29, 26, 0.72);
  border: 1px solid rgba(255, 255, 255, 0.12);
  color: rgba(255, 255, 255, 0.88);
  box-shadow: 0 24px 55px rgba(5, 8, 6, 0.45);
}

.content-section--dark .accordion summary {
  color: #fff;
}

.content-section--dark .accordion details p {
  color: rgba(255, 255, 255, 0.78);
}

@media (max-width: 768px) {
  .media-block {
    grid-template-columns: 1fr;
  }
  .feature-grid {
    grid-template-columns: 1fr;
  }
  .stat-bar {
    grid-template-columns: 1fr 1fr;
  }
  .link-card__image {
    height: 200px;
  }
}

@media (max-width: 540px) {
  .stat-bar {
    grid-template-columns: 1fr;
  }
  .link-card-grid {
    grid-template-columns: 1fr;
  }
}
.split-feature--reverse .split-feature__content {
  border-radius: 28px 0 0 28px;
}

.split-feature__media img {
  border-radius: 28px 0 0 28px;
}

.split-feature--reverse .split-feature__media img {
  border-radius: 0 28px 28px 0;
}
/*********************************************
  SAFARI COLLECTION PAGE ENHANCEMENTS
**********************************************/

.safari-hero .page-hero__overlay {
  background: linear-gradient(118deg, rgba(10, 18, 15, 0.88) 0%, rgba(26, 40, 34, 0.75) 42%, rgba(204, 85, 0, 0.55) 100%);
}

.safari-hero .page-hero__content {
  background: rgba(12, 24, 21, 0.6);
  border: 1px solid rgba(255, 255, 255, 0.18);
}

.safari-hero .page-hero__subtitle {
  color: rgba(255, 255, 255, 0.84);
}

/* Overview cards */
.safari-overview-grid .feature-card {
  border: 1px solid rgba(255, 255, 255, 0.08);
  background: rgba(17, 29, 26, 0.78);
  color: rgba(255, 255, 255, 0.88);
  box-shadow: 0 28px 55px rgba(5, 8, 6, 0.4);
}

.safari-overview-grid .feature-card h3 {
  color: var(--golden-yellow);
}

.safari-overview-grid .feature-card p {
  color: rgba(255, 255, 255, 0.78);
}

/* Safari style cards */
.safari-style-grid {
  grid-template-columns: minmax(0, 1fr);
  gap: clamp(1.65rem, 3vw, 2.4rem);
  grid-auto-rows: 1fr;
}

.safari-style-card {
  background: rgba(255, 255, 255, 0.95);
  border: 1px solid rgba(139, 69, 19, 0.14);
  padding: 0;
  border-radius: 26px;
  overflow: hidden;
  display: flex;
  flex-direction: column;
  min-height: 100%;
  box-shadow: 0 32px 55px rgba(12, 24, 21, 0.14);
  transition: transform 0.3s ease, box-shadow 0.3s ease;
}

.safari-style-card:hover,
.safari-style-card:focus-within {
  transform: translateY(-6px);
  box-shadow: 0 40px 70px rgba(12, 24, 21, 0.18);
}

.safari-style-card__media {
  position: relative;
  margin: 0;
  aspect-ratio: 4 / 3;
  overflow: hidden;
}

.safari-style-card__media img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transform: scale(1.02);
  transition: transform 0.5s ease;
}

.safari-style-card:hover .safari-style-card__media img,
.safari-style-card:focus-within .safari-style-card__media img {
  transform: scale(1.08);
}

.safari-style-card__body {
  padding: clamp(1.6rem, 2.8vw, 2.25rem);
  display: flex;
  flex-direction: column;
  gap: 1rem;
  flex: 1;
}

.safari-style-card h3 {
  color: var(--deep-green);
  margin: 0;
}

.safari-style-card p {
  color: rgba(47, 79, 79, 0.88);
  margin: 0;
}

.safari-style-card__tagline {
  font-size: 0.95rem;
  color: rgba(47, 79, 79, 0.7);
  letter-spacing: 0.01em;
}

.safari-style-card__footer {
  padding: 0 clamp(1.6rem, 3vw, 2.25rem) clamp(1.6rem, 3vw, 2.25rem);
  margin-top: auto;
}

.safari-style-collection {
  display: grid;
  gap: var(--section-margin-top);
}

/* Hero customization */
.safari-hero .page-hero__overlay {
  background: linear-gradient(120deg, rgba(17, 29, 26, 0.84) 0%, rgba(38, 62, 54, 0.74) 46%, rgba(204, 120, 58, 0.58) 100%);
}

.safari-hero .page-hero__content {
  background: linear-gradient(132deg, rgba(16, 29, 26, 0.9) 0%, rgba(29, 52, 46, 0.78) 55%, rgba(204, 120, 58, 0.6) 100%);
}

@media (min-width: 720px) {
  .safari-style-collection {
    gap: var(--section-margin-top);
  }
}

/* Planning sections */
.safari-planning blockquote {
  font-style: italic;
  margin-top: 1rem;
  color: rgba(255, 255, 255, 0.78);
}

.safari-media .media-block__content h3 {
  color: #fff;
}

.safari-media .media-block__content p,
.safari-media .media-list li {
  color: rgba(255, 255, 255, 0.8);
}

.safari-media .media-list li::before {
  color: var(--golden-yellow);
}

/* Stats */
.safari-stats .stat-card {
  border-radius: 20px;
}

.safari-stats .stat-card h4 {
  font-size: 2.1rem;
  color: var(--burnt-orange);
  margin-bottom: 0.4rem;
}

.safari-stats .stat-card p {
  font-size: 0.96rem;
  color: rgba(47, 79, 79, 0.85);
}

/* FAQ */
.safari-faq .accordion details:hover,
.safari-faq .accordion details:focus-within {
  border-color: rgba(204, 85, 0, 0.35);
  box-shadow: 0 26px 55px rgba(12, 24, 21, 0.16);
}

/* CTA Panel on this page */
.safari-cta .cta-panel {
  margin-top: clamp(2.5rem, 5vw, 3.5rem);
}

.safari-cta .cta-panel .cta-buttons {
  justify-content: center;
}

@media (max-width: 540px) {
  .safari-style-card__media {
    aspect-ratio: 16 / 11;
  }
}

/* Extra spacing for How We Shape Every Journey media blocks */
#safari-planning .media-block + .media-block {
  margin-top: clamp(3.6rem, 6vw, 4.8rem);
}

/* Rich text lists ------------------------------------------------------- */
main ul:not([class]),
main ol:not([class]) {
  list-style: none;
  padding-left: 0;
  margin: clamp(1.5rem, 3vw, 2.4rem) 0;
}

main ul:not([class]) li,
main ol:not([class]) li {
  position: relative;
  padding: clamp(0.75rem, 1.6vw, 1.1rem) clamp(1.4rem, 3vw, 2rem) clamp(0.75rem, 1.6vw, 1.1rem)
           clamp(2.5rem, 4vw, 3.2rem);
  margin-bottom: clamp(0.65rem, 1.4vw, 1rem);
  background: rgba(255, 255, 255, 0.92);
  border: 1px solid rgba(204, 120, 58, 0.16);
  border-radius: 22px;
  box-shadow: 0 20px 42px rgba(12, 24, 21, 0.12);
  line-height: 1.75;
  color: rgba(18, 40, 36, 0.92);
  backdrop-filter: blur(6px);
}

main ul:not([class]) li::before {
  content: '\25B8';
  position: absolute;
  left: clamp(1.1rem, 3vw, 1.6rem);
  top: 50%;
  transform: translateY(-50%);
  color: var(--burnt-orange, #cc5500);
  font-size: 0.9rem;
  font-weight: 700;
  letter-spacing: 0.05em;
}

main ol:not([class]) {
  counter-reset: ordered-list;
}

main ol:not([class]) li::before {
  counter-increment: ordered-list;
  content: counter(ordered-list, decimal-leading-zero);
  position: absolute;
  left: clamp(1.1rem, 3vw, 1.6rem);
  top: 50%;
  transform: translateY(-50%);
  color: var(--burnt-orange, #cc5500);
  font-weight: 700;
  font-size: 0.95rem;
}

/* ----------------------------------------------------------------------
   404 PAGE
------------------------------------------------------------------------ */
body.not-found-page {
  background: radial-gradient(circle at top, rgba(18, 45, 44, 0.65) 0%, rgba(5, 12, 10, 0.95) 60%, #020707 100%);
  color: #fff;
}

.not-found-main {
  min-height: calc(100vh - 200px);
  display: flex;
  align-items: center;
  justify-content: center;
  padding: clamp(5rem, 8vw, 7rem) 5% clamp(4rem, 7vw, 6rem);
}

.not-found-hero {
  width: 100%;
  max-width: 960px;
  position: relative;
  border-radius: 40px;
  padding: clamp(3rem, 6vw, 4.5rem);
  background: linear-gradient(135deg, rgba(10, 24, 22, 0.88) 0%, rgba(34, 68, 59, 0.78) 52%, rgba(210, 112, 32, 0.82) 100%);
  box-shadow: 0 42px 96px rgba(2, 8, 7, 0.6);
  overflow: hidden;
  isolation: isolate;
}

.not-found-hero::before {
  content: "";
  position: absolute;
  inset: 0;
  background: url('../images/savanna.jpg') center/cover no-repeat;
  opacity: 0.25;
  transform: scale(1.05);
  z-index: -2;
}

.not-found-hero::after {
  content: "";
  position: absolute;
  inset: 0;
  background:
    radial-gradient(circle at 20% 20%, rgba(255, 255, 255, 0.18) 0%, transparent 60%),
    radial-gradient(circle at 80% 80%, rgba(240, 190, 90, 0.24) 0%, transparent 65%);
  z-index: -1;
  mix-blend-mode: screen;
}

.not-found-card {
  background: rgba(10, 22, 20, 0.6);
  border: 1px solid rgba(255, 255, 255, 0.22);
  border-radius: 28px;
  padding: clamp(2.8rem, 5vw, 3.6rem);
  box-shadow: 0 32px 68px rgba(2, 8, 7, 0.5);
  text-align: center;
  backdrop-filter: blur(14px);
  display: grid;
  gap: clamp(1.8rem, 3vw, 2.4rem);
}

.not-found-card h1 {
  font-size: clamp(2.4rem, 4vw, 3.1rem);
  margin-bottom: 1.2rem;
  color: #fff;
}

.not-found-card p {
  color: rgba(255, 255, 255, 0.85);
  margin-bottom: clamp(1.5rem, 3vw, 2rem);
  line-height: 1.75;
}

.not-found-card .not-found-eyebrow {
  text-transform: uppercase;
  letter-spacing: 0.35em;
  color: rgba(255, 255, 255, 0.6);
  margin-bottom: 1.2rem;
  font-size: 0.9rem;
}

.not-found-card .cta-buttons {
  justify-content: center;
}

.not-found-card .cta-buttons .btn-outline {
  border-color: rgba(255, 255, 255, 0.65);
  color: #fff;
}

.not-found-card .cta-buttons .btn-outline:hover {
  background: rgba(255, 255, 255, 0.2);
}

.not-found-card ul {
  margin: 0;
}

.not-found-card ul:not([class]) li {
  background: rgba(8, 20, 18, 0.72);
  border-color: rgba(255, 255, 255, 0.16);
  color: rgba(255, 255, 255, 0.82);
  box-shadow: 0 18px 40px rgba(2, 8, 7, 0.45);
}

.not-found-card ul:not([class]) li::before {
  color: var(--golden-yellow);
}

.not-found-helper-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
  gap: clamp(1rem, 2vw, 1.6rem);
  text-align: left;
}

.not-found-helper-card {
  background: rgba(8, 20, 18, 0.72);
  border: 1px solid rgba(255, 255, 255, 0.18);
  border-radius: 22px;
  padding: clamp(1.4rem, 3vw, 1.8rem);
  box-shadow: 0 24px 50px rgba(2, 8, 7, 0.45);
  display: grid;
  gap: 0.75rem;
  height: 100%;
  transition: transform 0.3s ease, box-shadow 0.3s ease;
}

.not-found-helper-card:hover,
.not-found-helper-card:focus-within {
  transform: translateY(-4px);
  box-shadow: 0 28px 60px rgba(2, 8, 7, 0.55);
}

.not-found-helper-icon {
  font-size: 1.6rem;
}

.not-found-helper-card h3 {
  margin: 0;
  font-size: 1.1rem;
  color: rgba(255, 255, 255, 0.95);
}

.not-found-helper-card p {
  margin: 0;
  color: rgba(255, 255, 255, 0.75);
  line-height: 1.6;
}

.not-found-helper-link {
  display: inline-flex;
  align-items: center;
  gap: 0.35rem;
  font-weight: 600;
  color: var(--golden-yellow);
}

.not-found-helper-link::after {
  content: "→";
  transition: transform 0.25s ease;
}

.not-found-helper-link:hover::after,
.not-found-helper-link:focus::after {
  transform: translateX(4px);
}

@media (max-width: 640px) {
  .not-found-main {
    padding: clamp(4rem, 12vw, 5rem) 6% clamp(3rem, 10vw, 4.5rem);
  }

  .not-found-hero {
    padding: clamp(2.4rem, 9vw, 3.1rem);
  }

  .not-found-card {
    padding: clamp(2.2rem, 8vw, 3rem);
  }
}
/*********************************************
  SELOUS & NYERERE NATIONAL PARK PAGE STYLES
**********************************************/

/* HERO SECTION */
.selous-hero {
    position: relative;
    height: 80vh;
    overflow: hidden;
  }
  .selous-hero-image {
    width: 100%;
    height: 100%;
    object-fit: cover;
  }
  .selous-hero-overlay {
    position: absolute;
    inset: 0;
    background: rgba(0,0,0,0.3);
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    color: #fff;
    text-align: center;
    padding: 1rem;
  }
  .selous-hero-overlay h1 {
    font-size: 2.5rem;
    margin-bottom: 0.5rem;
  }
  .selous-hero-overlay p {
    font-size: 1.2rem;
  }
  
  /* AT A GLANCE SECTION */
  .selous-glance {
    padding: 2rem 5%;
    background: var(--beige);
    text-align: center;
  }
  .selous-glance h2 {
    margin-bottom: 1rem;
    color: var(--brown);
  }
  .glance-grid {
    max-width: 700px;
    margin: 0 auto;
    display: flex;
    gap: 1.5rem;
    flex-wrap: wrap;
    justify-content: center;
  }
  .glance-item {
    flex: 1 1 220px;
    background: #fff;
    border-radius: 6px;
    box-shadow: 0 2px 5px rgba(0,0,0,0.1);
    padding: 1rem;
    text-align: center;
  }
  .glance-item strong {
    display: block;
    margin-bottom: 0.5rem;
    color: var(--brown);
  }
  
  /* INTRO SECTION */
  .selous-intro {
    padding: 2rem 5%;
    background: #fff;
    text-align: center;
  }
  .selous-intro h2 {
    margin-bottom: 1rem;
    color: var(--brown);
  }
  .selous-intro p {
    max-width: 900px;
    margin: 0 auto;
    line-height: 1.8;
    text-align: left;
  }
  
  /* PARK OVERVIEW SECTION */
  .selous-overview {
    padding: 2rem 5%;
    background: var(--beige);
    text-align: center;
  }
  .selous-overview h2 {
    margin-bottom: 1rem;
    color: var(--brown);
  }
  .selous-overview p {
    max-width: 900px;
    margin: 0 auto 1rem auto;
    line-height: 1.8;
    text-align: left;
  }
  
  /* WHY GO SECTION */
  .selous-why-go {
    padding: 2rem 5%;
    background: #fff;
    text-align: center;
  }
  .selous-why-go h2 {
    margin-bottom: 1rem;
    color: var(--brown);
  }
  .selous-why-go p {
    max-width: 900px;
    margin: 0 auto;
    line-height: 1.8;
    text-align: left;
  }
  
 /* THINGS TO DO SECTION */
.selous-things {
  padding: 2rem 5%;
  background: var(--beige);
  text-align: center;
}
.selous-things h2 {
  margin-bottom: 1rem;
  color: var(--brown);
}
.selous-things p {
  max-width: 900px;
  margin: 0 auto;
  line-height: 1.8;
  text-align: left;
}
.selous-things ul { /* Add this rule */
  padding-left: 2rem; /* Adjust this value as needed */
  text-align: left; /* Ensure text within the list is left-aligned */
  max-width: 900px;
  margin: 0 auto;
}
  
  /* WHEN TO GO */
  .selous-best-time {
    padding: 2rem 5%;
    background: #fff;
    text-align: center;
  }
  .selous-best-time h2 {
    margin-bottom: 1rem;
    color: var(--brown);
  }
  .selous-best-time p {
    max-width: 900px;
    margin: 0 auto 1rem auto;
    line-height: 1.8;
    text-align: left;
  }
  .selous-best-time-grid {
    display: flex;
    gap: 2rem;
    max-width: 700px;
    margin: 1rem auto;
    flex-wrap: wrap;
    justify-content: center;
  }
  .best-time-item {
    flex: 1 1 220px;
    background: var(--beige);
    padding: 1rem;
    text-align: center;
    border: 1px solid #ddd;
    border-radius: 6px;
    box-shadow: 0 2px 3px rgba(0,0,0,0.1);
    margin-bottom: 1rem;
  }
  
  /* WILDLIFE SECTION */
  .selous-wildlife {
    padding: 2rem 5%;
    background: #fff;
    text-align: center;
  }
  .selous-wildlife h2 {
    margin-bottom: 1rem;
    color: var(--brown);
  }
  .selous-wildlife p {
    max-width: 900px;
    margin: 0 auto 1rem auto;
    line-height: 1.8;
    text-align: left;
  }
  
  /* WHERE TO STAY SECTION */
  .selous-where {
    padding: 2rem 5%;
    background: var(--beige);
    text-align: center;
  }
  .selous-where h2 {
    margin-bottom: 1rem;
    color: var(--brown);
  }
  .selous-where p {
    max-width: 900px;
    margin: 0 auto 1rem auto;
    line-height: 1.8;
    text-align: left;
  }
  
  /* FINAL CTA SECTION */
  .selous-final-cta {
    padding: 2rem 5%;
    background: #fff;
    text-align: center;
  }
  .selous-final-cta h2 {
    margin-bottom: 1rem;
    color: var(--brown);
  }
  .selous-final-cta p {
    max-width: 900px;
    margin: 0 auto 1.5rem auto;
    line-height: 1.8;
    text-align: left;
  }
  .final-cta-buttons {
    display: flex;
    flex-wrap: wrap;
    gap: 1rem;
    justify-content: center;
  }
  
  /* RESPONSIVE BREAKPOINTS */
  @media (max-width: 768px) {
    .selous-best-time-grid {
      flex-direction: column;
      align-items: center;
    }
  }/*********************************************
  SERENGETI NATIONAL PARK PAGE STYLES
**********************************************/

/* HERO SECTION */
.serengeti-hero {
    position: relative;
    height: 80vh;
    overflow: hidden;
  }
  .serengeti-hero-image {
    width: 100%;
    height: 100%;
    object-fit: cover;
  }
  .serengeti-hero-overlay {
    position: absolute;
    inset: 0;
    background: rgba(0,0,0,0.3);
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    color: #fff;
    text-align: center;
    padding: 1rem;
  }
  .serengeti-hero-overlay h1 {
    font-size: 2.5rem;
    margin-bottom: 0.5rem;
  }
  .serengeti-hero-overlay p {
    font-size: 1.2rem;
  }
  
  /* AT A GLANCE SECTION */
  .serengeti-glance {
    padding: 2rem 5%;
    background: var(--beige);
    text-align: center;
  }
  .serengeti-glance h2 {
    margin-bottom: 1rem;
    color: var(--brown);
  }
  .glance-grid {
    max-width: 700px;
    margin: 0 auto;
    display: flex;
    gap: 1.5rem;
    flex-wrap: wrap;
    justify-content: center;
  }
  .glance-item {
    flex: 1 1 220px;
    background: #fff;
    border-radius: 6px;
    box-shadow: 0 2px 5px rgba(0,0,0,0.1);
    padding: 1rem;
    text-align: center;
  }
  .glance-item strong {
    display: block;
    margin-bottom: 0.5rem;
    color: var(--brown);
  }
  
  /* INTRO SECTION */
  .serengeti-intro {
    padding: 2rem 5%;
    background: #fff;
    text-align: center;
  }
  .serengeti-intro h2 {
    margin-bottom: 1rem;
    color: var(--brown);
  }
  .serengeti-intro p {
    max-width: 900px;
    margin: 0 auto;
    line-height: 1.8;
    text-align: left;
  }
  
  /* PARK AREAS SECTION */
  .serengeti-areas {
    padding: 2rem 5%;
    background: var(--beige);
    text-align: center;
  }
  .serengeti-areas h2 {
    margin-bottom: 1.5rem;
    color: var(--brown);
  }
  .serengeti-area {
    max-width: 900px;
    margin: 1rem auto;
    text-align: left;
    line-height: 1.8;
  }
  .serengeti-area h3 {
    font-size: 1.3rem;
    color: var(--brown);
    margin-bottom: 0.5rem;
  }
  .serengeti-area p {
    margin-bottom: 1rem;
  }
  
  /* MIGRATION & WILDLIFE SECTION */
  .serengeti-migration {
    padding: 2rem 5%;
    background: #fff;
    text-align: center;
  }
  .serengeti-migration h2 {
    margin-bottom: 1rem;
    color: var(--brown);
  }
  .serengeti-migration p {
    max-width: 900px;
    margin: 0 auto;
    line-height: 1.8;
    text-align: left;
  }
  
  /* WHEN TO GO SECTION */
  .serengeti-best-time {
    padding: 2rem 5%;
    background: var(--beige);
    text-align: center;
  }
  .serengeti-best-time h2 {
    margin-bottom: 1rem;
    color: var(--brown);
  }
  .serengeti-best-time p {
    max-width: 900px;
    margin: 0 auto 1rem auto;
    line-height: 1.8;
    text-align: left;
  }
  .serengeti-best-time-grid {
    display: flex;
    gap: 2rem;
    max-width: 700px;
    margin: 1rem auto;
    flex-wrap: wrap;
    justify-content: center;
  }
  .best-time-item {
    flex: 1 1 220px;
    background: var(--beige);
    padding: 1rem;
    text-align: center;
    border: 1px solid #ddd;
    border-radius: 6px;
    box-shadow: 0 2px 3px rgba(0,0,0,0.1);
    margin-bottom: 1rem;
  }
  
  /* WHY GO SECTION */
  .serengeti-why-go {
    padding: 2rem 5%;
    background: #fff;
    text-align: center;
  }
  .serengeti-why-go h2 {
    margin-bottom: 1rem;
    color: var(--brown);
  }
  .serengeti-why-go p {
    max-width: 900px;
    margin: 0 auto;
    line-height: 1.8;
    text-align: left;
  }
  
  /* THINGS TO DO SECTION */
  .serengeti-things {
    padding: 2rem 5%;
    background: var(--beige);
    text-align: center;
  }
  .serengeti-things h2 {
    margin-bottom: 1rem;
    color: var(--brown);
  }
  .serengeti-things p {
    max-width: 900px;
    margin: 0 auto;
    line-height: 1.8;
    text-align: left;
  }
  
  /* WHERE TO STAY SECTION */
  .serengeti-where {
    padding: 2rem 5%;
    background: #fff;
    text-align: center;
  }
  .serengeti-where h2 {
    margin-bottom: 1rem;
    color: var(--brown);
  }
  .serengeti-where p {
    max-width: 900px;
    margin: 0 auto 1rem auto;
    line-height: 1.8;
    text-align: left;
  }
  
  /* FINAL CTA SECTION */
  .serengeti-final-cta {
    padding: 2rem 5%;
    background: var(--beige);
    text-align: center;
  }
  .serengeti-final-cta h2 {
    margin-bottom: 1rem;
    color: var(--brown);
  }
  .serengeti-final-cta p {
    max-width: 900px;
    margin: 0 auto 1.5rem auto;
    line-height: 1.8;
    text-align: left;
  }
  .final-cta-buttons {
    display: flex;
    flex-wrap: wrap;
    gap: 1rem;
    justify-content: center;
  }
  
  /* RESPONSIVE BREAKPOINTS */
  @media (max-width: 768px) {
    .serengeti-best-time-grid {
      flex-direction: column;
      align-items: center;
    }
  }/* SLIDESHOW CONTAINER */
.slideshow-container {
    position: relative;
    overflow: hidden;
    width: 100%;
}

/* HIDE ALL SLIDES BY DEFAULT */
.mySlides {
    display: none;
    position: relative;
    width: 100%;
}

/* SLIDE IMAGES */
.mySlides img {
    width: 100%;    /* Make images responsive */
    height: auto;
    display: block;
}

/* CAPTION TEXT */
.caption {
    position: absolute;
    bottom: 8%;
    left: 5%;
    color: #fff;
    padding: 0.5rem 1rem;
    background-color: rgba(0, 0, 0, 0.4);
    font-size: 1.2rem;
    border-radius: 4px;
}

/* FADING ANIMATION */
.fade {
    animation-name: fade;
    animation-duration: 1.5s;
}
@keyframes fade {
    from { opacity: 0; }
    to   { opacity: 1; }
}

/* NEXT & PREV ARROWS */
.prev, .next {
    cursor: pointer;
    position: absolute;
    top: 50%;
    width: auto;
    padding: 0.5rem;
    margin-top: -22px;
    color: #fff;
    font-weight: bold;
    font-size: 1.5rem;
    border-radius: 3px;
    user-select: none;
    transition: 0.3s;
    background-color: rgba(0, 0, 0, 0.3);
}

.prev {
    left: 0;
}
.next {
    right: 0;
}

.prev:hover,
.next:hover {
    background-color: rgba(0, 0, 0, 0.6);
}

/* DOT CONTAINER */
.dot-container {
    text-align: center;
    margin: 1rem 0;
}

/* DOTS */
.dot {
    cursor: pointer;
    height: 15px;
    width: 15px;
    margin: 0 4px;
    background-color: #D2B48C;
    border-radius: 50%;
    display: inline-block;
    transition: background-color 0.3s;
}

.active, .dot:hover {
    background-color: #8B4513;
}

/* RESPONSIVE MEDIA QUERY */
@media only screen and (max-width: 600px) {
    .caption {
        font-size: 1rem; /* slightly smaller captions on mobile */
        bottom: 5%;
    }
    .prev, .next {
        font-size: 1.2rem;
        padding: 0.3rem;
    }
}/*********************************************
  SMALL GROUP SAFARIS PAGE STYLES
**********************************************/

/* HERO SECTION */

  /* INTRO SECTION */
  .smallgroup-intro {
    padding: 2rem 5%;
    background: #fff;
    text-align: center;
  }
  .smallgroup-intro h2 {
    margin-bottom: 1rem;
    color: var(--brown);
  }
  .smallgroup-intro p {
    max-width: 900px;
    margin: 0 auto;
    line-height: 1.8;
    text-align: left;
  }
  
  /* WHO SHOULD GO SECTION */
  .smallgroup-whoshouldgo {
    padding: clamp(2rem, 4vw, 3rem) 5%;
    background: var(--beige);
  }
  .smallgroup-whoshouldgo h2 {
    margin-bottom: clamp(1rem, 2vw, 1.5rem);
    color: var(--brown);
    text-align: center;
    font-size: clamp(1.8rem, 3vw, 2.2rem);
  }
  .smallgroup-whoshouldgo p {
    max-width: 900px;
    margin: 0 auto clamp(1rem, 2vw, 1.5rem) auto;
    line-height: 1.8;
    text-align: left;
  }
  .smallgroup-whoshouldgo ul {
    max-width: 600px;
    margin: clamp(1rem, 2vw, 1.5rem) auto;
    text-align: left;
    line-height: 1.8;
    list-style: disc outside;
    padding-left: 1.2rem;
  }
  
  /* WHERE TO EXPERIENCE SECTION */
  .smallgroup-where {
    padding: 2rem 5%;
    background: #fff;
    text-align: center;
  }
  .smallgroup-where h2 {
    margin-bottom: 1rem;
    color: var(--brown);
  }
  .smallgroup-where p {
    max-width: 900px;
    margin: 0 auto;
    line-height: 1.8;
    text-align: left;
  }
  
  /* WHEN TO GO SECTION */
  .smallgroup-besttime {
    padding: 2rem 5%;
    background: var(--beige);
    text-align: center;
  }
  .smallgroup-besttime h2 {
    margin-bottom: 1rem;
    color: var(--brown);
  }
  .smallgroup-besttime p {
    max-width: 900px;
    margin: 0 auto 1rem auto;
    line-height: 1.8;
    text-align: left;
  }
  .smallgroup-besttime-grid {
    display: flex;
    flex-wrap: wrap;
    gap: 2rem;
    max-width: 700px;
    margin: 1rem auto;
    justify-content: center;
    text-align: center;
  }
  .besttime-item {
    flex: 1 1 220px;
    background: var(--beige);
    border-radius: 6px;
    box-shadow: 0 2px 5px rgba(0,0,0,0.1);
    padding: 1rem;
  }
  
  /* ACCOMMODATIONS SECTION */
  .smallgroup-accommodations {
    padding: 2rem 5%;
    background: #fff;
    text-align: center;
  }
  .smallgroup-accommodations h2 {
    margin-bottom: 1rem;
    color: var(--brown);
  }
  .smallgroup-accommodations p {
    max-width: 900px;
    margin: 0 auto;
    line-height: 1.8;
    text-align: left;
  }
  
  /* ADVANTAGES SECTION */
  .smallgroup-advantages {
    padding: 2rem 5%;
    background: var(--beige);
    text-align: center;
  }
  .smallgroup-advantages h2 {
    margin-bottom: 1rem;
    color: var(--brown);
  }
  .smallgroup-advantages p {
    max-width: 900px;
    margin: 0 auto 1rem auto;
    line-height: 1.8;
    text-align: left;
  }
  
  /* SAFARI DETAILS SECTION */
  .smallgroup-details {
    padding: 2rem 5%;
    background: #fff;
    text-align: center;
  }
  .smallgroup-details h2 {
    margin-bottom: 1rem;
    color: var(--brown);
  }
  .smallgroup-details p {
    max-width: 900px;
    margin: 0 auto;
    line-height: 1.8;
    text-align: left;
  }
  
  /* FINAL CTA SECTION */
  .smallgroup-final-cta {
    padding: 2rem 5%;
    background: var(--beige);
    text-align: center;
  }
  .smallgroup-final-cta h2 {
    margin-bottom: 1rem;
    color: var(--brown);
  }
  .smallgroup-final-cta p {
    max-width: 900px;
    margin: 0 auto 1.5rem auto;
    line-height: 1.8;
    text-align: left;
  }
  .final-cta-buttons {
    display: flex;
    gap: 1rem;
    flex-wrap: wrap;
    justify-content: center;
  }
  
  /* RESPONSIVE BREAKPOINTS */
  @media (max-width: 768px) {
    .smallgroup-besttime-grid {
      flex-direction: column;
      align-items: center;
    }
    .smallgroup-whoshouldgo ul {
      list-style-position: outside;
      padding-left: 1.5rem;
    }
  }
/*********************************************
  TAILOR-MADE SAFARIS DETAIL STYLES
**********************************************/

.page-hero--tailor .page-hero__overlay {
  background: linear-gradient(118deg, rgba(18, 28, 34, 0.92) 0%, rgba(51, 63, 58, 0.78) 50%, rgba(204, 136, 90, 0.6) 100%);
}

.page-hero--tailor .page-hero__content {
  background: linear-gradient(132deg, rgba(18, 29, 34, 0.92) 0%, rgba(37, 56, 54, 0.78) 55%, rgba(204, 136, 90, 0.6) 100%);
}

.page-hero--tailor .page-hero__subtitle {
  color: rgba(255, 255, 255, 0.92);
}

.feature-card img {
  height: clamp(170px, 28vw, 210px);
}

@media (max-width: 720px) {
  .feature-card img {
    height: 190px;
  }
}
/*********************************************
  TARANGIRE NATIONAL PARK PAGE STYLES
**********************************************/

/* HERO SECTION */
.tarangire-hero {
    position: relative;
    height: 80vh;
    overflow: hidden;
  }
  .tarangire-hero-image {
    width: 100%;
    height: 100%;
    object-fit: cover;
  }
  .tarangire-hero-overlay {
    position: absolute;
    inset: 0;
    background: rgba(0,0,0,0.3);
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    color: #fff;
    text-align: center;
    padding: 1rem;
  }
  .tarangire-hero-overlay h1 {
    font-size: 2.5rem;
    margin-bottom: 0.5rem;
  }
  .tarangire-hero-overlay p {
    font-size: 1.2rem;
  }
  
  /* AT A GLANCE SECTION */
  .tarangire-glance {
    padding: 2rem 5%;
    background: var(--beige);
    text-align: center;
  }
  .tarangire-glance h2 {
    margin-bottom: 1rem;
    color: var(--brown);
  }
  .glance-grid {
    max-width: 700px;
    margin: 0 auto;
    display: flex;
    gap: 1.5rem;
    flex-wrap: wrap;
    justify-content: center;
  }
  .glance-item {
    flex: 1 1 220px;
    background: #fff;
    border-radius: 6px;
    box-shadow: 0 2px 5px rgba(0,0,0,0.1);
    padding: 1rem;
    text-align: center;
  }
  .glance-item strong {
    display: block;
    margin-bottom: 0.5rem;
    color: var(--brown);
  }
  
  /* INTRO SECTION */
  .tarangire-intro {
    padding: 2rem 5%;
    background: #fff;
    text-align: center;
  }
  .tarangire-intro h2 {
    margin-bottom: 1rem;
    color: var(--brown);
  }
  .tarangire-intro p {
    max-width: 900px;
    margin: 0 auto;
    line-height: 1.8;
    text-align: left;
  }
  
  /* PARK OVERVIEW SECTION */
  .tarangire-overview {
    padding: 2rem 5%;
    background: var(--beige);
    text-align: center;
  }
  .tarangire-overview h2 {
    margin-bottom: 1rem;
    color: var(--brown);
  }
  .tarangire-overview p {
    max-width: 900px;
    margin: 0 auto 1rem auto;
    line-height: 1.8;
    text-align: left;
  }
  
  /* WILDLIFE SECTION */
  .tarangire-wildlife {
    padding: 2rem 5%;
    background: #fff;
    text-align: center;
  }
  .tarangire-wildlife h2 {
    margin-bottom: 1rem;
    color: var(--brown);
  }
  .tarangire-wildlife p {
    max-width: 900px;
    margin: 0 auto;
    line-height: 1.8;
    text-align: left;
  }
  
  /* VEGETATION SECTION */
  .tarangire-vegetation {
    padding: 2rem 5%;
    background: var(--beige);
    text-align: center;
  }
  .tarangire-vegetation h2 {
    margin-bottom: 1rem;
    color: var(--brown);
  }
  .tarangire-vegetation p {
    max-width: 900px;
    margin: 0 auto;
    line-height: 1.8;
    text-align: left;
  }
  
  /* WHEN TO GO */
  .tarangire-best-time {
    padding: 2rem 5%;
    background: #fff;
    text-align: center;
  }
  .tarangire-best-time h2 {
    margin-bottom: 1rem;
    color: var(--brown);
  }
  .tarangire-best-time p {
    max-width: 900px;
    margin: 0 auto 1rem auto;
    line-height: 1.8;
    text-align: left;
  }
  .tarangire-best-time-grid {
    display: flex;
    gap: 2rem;
    max-width: 700px;
    margin: 1rem auto;
    flex-wrap: wrap;
    justify-content: center;
  }
  .best-time-item {
    flex: 1 1 220px;
    background: var(--beige);
    padding: 1rem;
    text-align: center;
    border: 1px solid #ddd;
    border-radius: 6px;
    box-shadow: 0 2px 3px rgba(0,0,0,0.1);
    margin-bottom: 1rem;
  }
  
  /* WHY GO SECTION */
  .tarangire-why-go {
    padding: 2rem 5%;
    background: #fff;
    text-align: center;
  }
  .tarangire-why-go h2 {
    margin-bottom: 1rem;
    color: var(--brown);
  }
  .tarangire-why-go p {
    max-width: 900px;
    margin: 0 auto;
    line-height: 1.8;
    text-align: left;
  }
  
  /* THINGS TO DO SECTION */
  .tarangire-things {
    padding: 2rem 5%;
    background: var(--beige);
    text-align: center;
  }
  .tarangire-things h2 {
    margin-bottom: 1rem;
    color: var(--brown);
  }
  .tarangire-things p {
    max-width: 900px;
    margin: 0 auto;
    line-height: 1.8;
    text-align: left;
  }
  
  /* WHERE TO STAY SECTION */
  .tarangire-where {
    padding: 2rem 5%;
    background: #fff;
    text-align: center;
  }
  .tarangire-where h2 {
    margin-bottom: 1rem;
    color: var(--brown);
  }
  .tarangire-where p {
    max-width: 900px;
    margin: 0 auto 1rem auto;
    line-height: 1.8;
    text-align: left;
  }
  
  /* FINAL CTA SECTION */
  .tarangire-final-cta {
    padding: 2rem 5%;
    background: var(--beige);
    text-align: center;
  }
  .tarangire-final-cta h2 {
    margin-bottom: 1rem;
    color: var(--brown);
  }
  .tarangire-final-cta p {
    max-width: 900px;
    margin: 0 auto 1.5rem auto;
    line-height: 1.8;
    text-align: left;
  }
  .final-cta-buttons {
    display: flex;
    flex-wrap: wrap;
    gap: 1rem;
    justify-content: center;
  }
  
  /* RESPONSIVE BREAKPOINTS */
  @media (max-width: 768px) {
    .tarangire-best-time-grid {
      flex-direction: column;
      align-items: center;
    }
  }/* thank-you.css */

/* Thank-you page */
.thank-you-section {
  min-height: calc(100vh - 200px);
  display: flex;
  align-items: center;
  justify-content: center;
  padding: clamp(4rem, 8vw, 6rem) 5% clamp(4rem, 8vw, 6rem);
}

.thank-you-content {
  max-width: 680px;
  text-align: center;
}

.thank-you-content h1 {
  font-size: clamp(2.3rem, 4vw, 2.8rem);
  margin-bottom: 1.2rem;
}

.thank-you-content p {
  margin-bottom: clamp(1.2rem, 2.8vw, 1.8rem);
}
/*********************************************
  TRAVEL INFO PAGE STYLES
**********************************************/

/* HERO CUSTOMIZATION */
.page-hero--travel .page-hero__overlay {
  background: linear-gradient(120deg, rgba(16, 29, 32, 0.86) 0%, rgba(41, 70, 68, 0.74) 46%, rgba(204, 120, 58, 0.58) 100%);
}

.page-hero--travel .page-hero__content {
  background: linear-gradient(132deg, rgba(16, 29, 32, 0.92) 0%, rgba(29, 52, 50, 0.78) 55%, rgba(204, 120, 58, 0.6) 100%);
}

.page-hero--travel .page-hero__subtitle {
  color: rgba(255, 255, 255, 0.9);
}

/* TANZANIA AT A GLANCE */
.travel-glance .glance-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: clamp(1.5rem, 4vw, 2rem);
  margin-top: clamp(1.5rem, 3vw, 2rem);
}

.travel-glance .glance-card {
  position: relative;
  background: linear-gradient(140deg, rgba(255, 255, 255, 0.95) 0%, rgba(248, 244, 236, 0.92) 100%);
  border-radius: 22px;
  border: 1px solid rgba(139, 69, 19, 0.12);
  padding: clamp(1.2rem, 2.8vw, 1.8rem);
  box-shadow: 0 24px 48px rgba(15, 29, 26, 0.12);
  color: rgba(47, 79, 79, 0.9);
}

.travel-glance .glance-card h3 {
  font-size: 1.05rem;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  margin-bottom: 0.5rem;
  color: var(--brown);
}

.travel-glance .glance-card p {
  margin: 0;
  line-height: 1.65;
}

/* TRAVEL TIP GRID */
.travel-tip-grid {
  display: grid;
  gap: clamp(1.6rem, 3vw, 2.4rem);
}

.travel-tip-card {
  background: linear-gradient(140deg, rgba(255, 255, 255, 0.97) 0%, rgba(248, 244, 236, 0.92) 100%);
}

.travel-tip-card .link-card__image {
  height: clamp(180px, 26vw, 220px);
  object-fit: cover;
}

.travel-tip-card__eyebrow {
  display: inline-block;
  text-transform: uppercase;
  letter-spacing: 0.2em;
  font-size: 0.72rem;
  color: rgba(47, 79, 79, 0.6);
}

.travel-tip-card .link-card__body {
  gap: 0.75rem;
}

.travel-tip-card .link-card__body h3 {
  margin-bottom: 0.25rem;
  color: var(--deep-green);
}

.travel-tip-card .link-card__body p {
  color: rgba(47, 79, 79, 0.85);
}

.travel-tip-card .link-card__cta {
  margin-top: auto;
}

/* FINAL CTA tweaks */
#travel-hero + .content-section .section-intro {
  text-align: center;
}

@media (max-width: 980px) {
  .travel-glance .glance-grid {
    grid-template-columns: repeat(2, 1fr);
  }
}

@media (max-width: 640px) {
  .travel-glance .glance-grid {
    grid-template-columns: 1fr;
  }
}

@media (max-width: 640px) {
  .travel-tip-grid {
    gap: 1.4rem;
  }
}
/*********************************************
  TRAVEL TIPS PAGE STYLES
**********************************************/

.page-hero--travel .page-hero__overlay {
  background: linear-gradient(118deg, rgba(14, 28, 26, 0.92) 12%, rgba(43, 66, 58, 0.78) 52%, rgba(204, 125, 58, 0.6) 100%);
}
/*********************************************
  TREKKING DETAIL SHARED STYLES
**********************************************/

.page-hero--kilimanjaro .page-hero__overlay {
  background: linear-gradient(118deg, rgba(12, 24, 32, 0.9) 0%, rgba(38, 60, 72, 0.78) 52%, rgba(214, 136, 74, 0.6) 100%);
}

.page-hero--kilimanjaro .page-hero__content {
  background: linear-gradient(132deg, rgba(14, 28, 36, 0.92) 0%, rgba(36, 61, 72, 0.78) 55%, rgba(214, 136, 74, 0.62) 100%);
}

.page-hero--meru .page-hero__overlay {
  background: linear-gradient(118deg, rgba(12, 32, 28, 0.92) 0%, rgba(38, 66, 54, 0.78) 52%, rgba(204, 136, 90, 0.6) 100%);
}

.page-hero--meru .page-hero__content {
  background: linear-gradient(132deg, rgba(14, 32, 28, 0.92) 0%, rgba(34, 62, 50, 0.78) 55%, rgba(204, 136, 90, 0.6) 100%);
}

.page-hero--kilimanjaro .page-hero__subtitle,
.page-hero--meru .page-hero__subtitle {
  color: rgba(255, 255, 255, 0.92);
}

.feature-card img {
  height: clamp(170px, 28vw, 210px);
}

@media (max-width: 720px) {
  .feature-card img {
    height: 190px;
  }
}
/*********************************************
  TREKKING OVERVIEW PAGE STYLES
**********************************************/

.page-hero--trekking .page-hero__overlay {
  background: linear-gradient(120deg, rgba(14, 28, 32, 0.86) 0%, rgba(36, 71, 73, 0.72) 46%, rgba(204, 120, 58, 0.58) 100%);
}

.page-hero--trekking .page-hero__content {
  background: linear-gradient(132deg, rgba(16, 29, 32, 0.9) 0%, rgba(30, 62, 64, 0.78) 55%, rgba(204, 120, 58, 0.6) 100%);
}

.page-hero--trekking .page-hero__subtitle {
  color: rgba(255, 255, 255, 0.9);
}

.media-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 0.8rem;
  margin-top: 1.75rem;
}

.media-actions .btn {
  border-radius: 999px;
}

#trekking-highlights .feature-card img {
  height: clamp(170px, 28vw, 210px);
}

#trekking-highlights .feature-grid {
  gap: clamp(1.8rem, 4vw, 2.5rem);
}

#trekking-addons .link-card__image {
  height: clamp(200px, 28vw, 220px);
}

#trekking-addons .link-card-grid {
  gap: clamp(1.8rem, 4vw, 2.5rem);
}

.trekking-media + .trekking-media {
  margin-top: clamp(2rem, 4vw, 3rem);
}

#trekking-expect .media-block__content ul {
  margin-top: 1.1rem;
}

@media (max-width: 720px) {
  .media-actions {
    justify-content: center;
  }
}
/*********************************************
  UDZUNGWA MOUNTAINS NATIONAL PARK PAGE STYLES
**********************************************/

/* HERO SECTION */
.udzungwa-hero {
    position: relative;
    height: 80vh;
    overflow: hidden;
}
.udzungwa-hero-image {
    width: 100%;
    height: 100%;
    object-fit: cover;
}
.udzungwa-hero-overlay {
    position: absolute;
    inset: 0;
    background: rgba(0, 0, 0, 0.3);
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    color: #fff;
    text-align: center;
    padding: 1rem;
}
.udzungwa-hero-overlay h1 {
    font-size: 2.5rem;
    margin-bottom: 0.5rem;
}
.udzungwa-hero-overlay p {
    font-size: 1.2rem;
}

/* AT A GLANCE SECTION */
.udzungwa-glance {
    padding: 2rem 5%;
    background: var(--beige);
    text-align: center;
}
.udzungwa-glance h2 {
    margin-bottom: 1rem;
    color: var(--brown);
}
.udzungwa-glance .glance-grid {
    max-width: 700px;
    margin: 0 auto;
    display: flex;
    gap: 1.5rem;
    flex-wrap: wrap;
    justify-content: center;
}
.udzungwa-glance .glance-item {
    flex: 1 1 220px;
    background: #fff;
    border-radius: 6px;
    box-shadow: 0 2px 5px rgba(0,0,0,0.1);
    padding: 1rem;
    text-align: center;
}
.udzungwa-glance .glance-item strong {
    display: block;
    margin-bottom: 0.5rem;
    color: var(--brown);
}

/* OVERVIEW SECTION */
.udzungwa-overview {
    padding: 2rem 5%;
    background: #fff;
    text-align: center;
}
.udzungwa-overview h2 {
    margin-bottom: 1rem;
    color: var(--brown);
}
.udzungwa-overview p {
    max-width: 900px;
    margin: 0 auto 1rem auto;
    line-height: 1.8;
    text-align: left;
}

/* ACTIVITIES SECTION */
.udzungwa-activities {
    padding: 2rem 5%;
    background: var(--beige);
    text-align: center;
}
.udzungwa-activities h2 {
    margin-bottom: 1rem;
    color: var(--brown);
}
.udzungwa-activities p {
    max-width: 900px;
    margin: 0 auto 1rem auto;
    line-height: 1.8;
    text-align: left;
}
.udzungwa-activities ul {
    max-width: 800px;
    margin: 0 auto;
    list-style: none; /* Remove default bullets */
    padding-left: 0;
}
.udzungwa-activities ul li {
    position: relative;
    margin-bottom: 0.5rem;
    padding-left: 1.5rem; /* Space for custom bullet */
    text-align: left;
}
.udzungwa-activities ul li::before {
    content: "•"; /* Custom bullet */
    position: absolute;
    left: 0;
    color: var(--brown);
    font-size: 1.2rem;
    line-height: 1;
}

/* WILDLIFE HIGHLIGHTS SECTION */
.udzungwa-wildlife {
    padding: 2rem 5%;
    background: #fff;
    text-align: center;
}
.udzungwa-wildlife h2 {
    margin-bottom: 1rem;
    color: var(--brown);
}
.udzungwa-wildlife p {
    max-width: 900px;
    margin: 0 auto 1rem auto;
    line-height: 1.8;
    text-align: left;
}
.udzungwa-wildlife ul {
    max-width: 800px;
    margin: 0 auto;
    list-style: none; /* Remove default bullets */
    padding-left: 0;
}
.udzungwa-wildlife ul li {
    position: relative;
    margin-bottom: 0.5rem;
    padding-left: 1.5rem; /* Space for custom bullet */
    text-align: left;
}
.udzungwa-wildlife ul li::before {
    content: "•"; /* Custom bullet */
    position: absolute;
    left: 0;
    color: var(--brown);
    font-size: 1.2rem;
    line-height: 1;
}

/* RESPONSIVE BREAKPOINTS */
@media (max-width: 768px) {
    .glance-grid, .serengeti-best-time-grid {
        flex-direction: column;
        align-items: center;
    }
}
/*********************************************
  WALKING SAFARIS PAGE STYLES (Honeymoon-Inspired)
**********************************************/

/* HERO SECTION */

  /* Duplicate experience-section styles removed - using consolidated version */
  
/* MOBILE OPTIMIZATION IMPROVEMENTS */
@media (max-width: 768px) {
  /* Ensure minimum touch target size */
  .btn, button, a[class*="btn"] {
    min-height: 44px !important;
    min-width: 44px !important;
    padding: 12px 20px !important;
  }
  
  /* Better mobile spacing */
  .page-hero__actions {
    gap: 1rem !important;
    margin-top: 2rem !important;
  }
  
  .page-hero__actions .btn {
    flex: 1 1 auto !important;
    text-align: center !important;
    min-width: 140px !important;
  }
  
  /* Improved mobile navigation */
  .navbar {
    padding: 0 4% !important;
  }
  
  /* Better mobile hero spacing */
  .page-hero__content {
    margin: 0 4% !important;
    padding: 2rem !important;
  }
  
  /* Mobile-friendly text sizing */
  .page-hero__heading {
    font-size: clamp(2rem, 8vw, 2.8rem) !important;
    line-height: 1.1 !important;
  }
  
  .page-hero__subtitle {
    font-size: clamp(1rem, 4vw, 1.2rem) !important;
    margin-bottom: 2rem !important;
  }
  
  /* Better mobile section spacing */
  .content-section {
    padding: clamp(2rem, 6vw, 2.5rem) 4% !important;
  }
  
  /* Fix mobile final CTA visibility */
  section[class*="cta-banner"]:not(.final-cta-banner) .final-cta-content {
    padding: clamp(2rem, 6vw, 2.8rem) !important;
    margin: 1rem !important;
  }
  
  .experience-section ul {
    list-style-position: outside;
  }
}
/* Zanzibar page refinements */

.page-hero--zanzibar .page-hero__overlay {
  background: linear-gradient(118deg, rgba(18, 30, 32, 0.45) 6%, rgba(46, 72, 76, 0.35) 48%, rgba(214, 143, 74, 0.25) 100%);
}

/* Zanzibar CTA styling to match site consistency */
#zanzibar-cta {
  background: linear-gradient(128deg, rgba(12, 32, 28, 0.92) 0%, rgba(210, 111, 26, 0.82) 52%, rgba(240, 180, 58, 0.65) 100%) !important;
  position: relative;
  margin: clamp(3rem, 7vw, 5rem) auto;
  padding: clamp(3rem, 6vw, 4.5rem) 5%;
  border-radius: 32px;
  border: 1px solid rgba(255, 255, 255, 0.24);
  box-shadow: 0 32px 68px rgba(4, 10, 8, 0.35);
}

#zanzibar-cta::before {
  content: "";
  position: absolute;
  inset: 0;
  background: url('../images/safari-pattern.svg') center/cover;
  opacity: 0.08;
  z-index: -2;
}

#zanzibar-cta .cta-panel {
  max-width: 780px;
  margin: 0 auto;
  padding: clamp(2.8rem, 6vw, 3.8rem);
  border-radius: 26px;
  background: rgba(12, 25, 22, 0.52);
  border: 1px solid rgba(255, 255, 255, 0.24);
  box-shadow: 0 28px 70px rgba(3, 8, 7, 0.45);
  backdrop-filter: blur(10px);
  position: relative;
  overflow: visible;
}

#zanzibar-highlights .feature-card,
#zanzibar-stay .feature-card,
#zanzibar-activities .feature-card {
  min-height: 100%;
}

.zanzibar-media .media-block__content h3 {
  margin-bottom: 1rem;
}

.pairing-buttons {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: 0.85rem;
  margin-top: 1.5rem;
}

.pairing-buttons .btn {
  border-radius: 999px;
}

#zanzibar-activities .feature-card {
  text-align: left;
}

/*********************************************
  HOME PAGE ENHANCEMENTS
**********************************************/

/* Welcome Stats Section */
.welcome-stats {
  display: flex;
  justify-content: center;
  gap: clamp(1.5rem, 4vw, 3rem);
  margin: clamp(1.5rem, 3vw, 2rem) 0;
  padding: clamp(1rem, 2vw, 1.5rem) 0;
  border-top: 1px solid rgba(255, 255, 255, 0.2);
  border-bottom: 1px solid rgba(255, 255, 255, 0.2);
}

.stat-item {
  text-align: center;
  color: #fff;
}

.stat-number {
  display: block;
  font-size: clamp(1.8rem, 3vw, 2.5rem);
  font-weight: 700;
  color: #ffd700;
  text-shadow: 0 2px 4px rgba(0, 0, 0, 0.3);
  margin-bottom: 0.25rem;
}

.stat-label {
  display: block;
  font-size: clamp(0.8rem, 1.5vw, 0.9rem);
  font-weight: 500;
  color: rgba(255, 255, 255, 0.9);
  text-transform: uppercase;
  letter-spacing: 0.5px;
}

@media (max-width: 640px) {
  .welcome-stats {
    flex-direction: column;
    gap: var(--card-internal-gap-small);
    text-align: center;
  }
  
  .stat-item {
    padding: 0.5rem 0;
  }
}

/*********************************************
  STANDARDIZED SPACING OVERRIDES
  Apply consistent spacing across all components
**********************************************/

/* Standardize all best-time grids */
[class$='-best-time-grid'],
[class$='-besttime-grid'] {
  gap: var(--card-gap-compact) !important;
}

/* Standardize glance grids */
[class$='-glance'] .glance-grid,
.glance-grid {
  gap: var(--card-gap-compact) !important;
}

/* Standardize all flex containers with 1.5rem gap */
.flex-container,
.activities-scroller,
.destinations-grid {
  gap: var(--card-gap-compact) !important;
}

/* Standardize button groups and action containers */
.cta-buttons,
.final-cta-buttons,
.package-actions {
  gap: var(--card-internal-gap-small) !important;
}

/* Ensure consistent internal card spacing */
.promise-card,
.offering-card,
.contact-card {
  gap: var(--card-internal-gap-small) !important;
}

/* Standardize all feature and card grids */
.feature-grid,
.link-card-grid,
.experiences-grid,
.testimonials-grid,
.quick-links-grid,
.destinations-circuit-grid,
.trust-wrap,
.safari-overview-grid {
  gap: var(--card-gap-standard) !important;
}

/* Standardize safari-specific spacing */
.safari-style-collection {
  gap: var(--section-margin-top) !important;
}

.split-feature + .split-feature {
  margin-top: var(--card-gap-compact) !important;
}

.package-card + .package-card {
  margin-top: var(--section-margin-top) !important;
}

/* Standardize media blocks */
.media-block + .media-block {
  margin-top: var(--section-margin-top) !important;
}

/* Standardize all large section margins */
.destinations-overview,
.destinations-journeys,
.selected-destinations,
.selected-experiences,
.combine-cta,
.beaches-wrap {
  margin-top: var(--section-margin-top) !important;
  margin-bottom: var(--section-margin-top) !important;
}

/* Standardize all section gaps */
.destinations-journeys,
.selected-destinations,
.selected-experiences {
  gap: var(--section-margin-top) !important;
}

/* Standardize beach destination spacing */
.beach-destination {
  margin-bottom: var(--section-margin-top) !important;
}

/* Override any remaining large spacing values */
[class*="clamp(3rem"],
[class*="clamp(2.5rem"] {
  gap: var(--section-margin-top) !important;
  margin-top: var(--section-margin-top) !important;
}

/* TRUSTED PARTNERS SECTION */
.trusted-partners {
  background: rgba(245, 243, 234, 0.96);
}

.partners-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(250px, 1fr));
  gap: var(--card-gap-compact);
  margin-top: var(--section-margin-top);
}

.partner-item {
  background: rgba(255, 255, 255, 0.95);
  border-radius: 18px;
  border: 1px solid rgba(139, 69, 19, 0.12);
  transition: all 0.3s ease;
  overflow: hidden;
}

.partner-item:hover {
  transform: translateY(-2px);
  box-shadow: 0 8px 24px rgba(139, 69, 19, 0.15);
  border-color: rgba(139, 69, 19, 0.2);
}

.partner-item a {
  display: block;
  padding: clamp(1.5rem, 3vw, 2rem);
  text-decoration: none;
  color: inherit;
}

.partner-logo {
  text-align: center;
}

.partner-name {
  display: block;
  font-size: clamp(1.2rem, 2.5vw, 1.5rem);
  font-weight: 600;
  color: var(--deep-green);
  margin-bottom: 0.5rem;
}

.partner-description {
  font-size: clamp(0.9rem, 2vw, 1rem);
  color: var(--text-muted);
  margin: 0;
}

/* Mobile responsive */
@media (max-width: 768px) {
  .partners-grid {
    grid-template-columns: repeat(2, 1fr);
    gap: var(--card-internal-gap);
  }
}

@media (max-width: 480px) {
  .partners-grid {
    grid-template-columns: 1fr;
  }
}

/* FOOTER PARTNERS SECTION */
.footer-partners {
  background: rgba(15, 28, 24, 0.98);
  border-top: 1px solid rgba(255, 255, 255, 0.1);
  border-bottom: 1px solid rgba(255, 255, 255, 0.1);
  padding: clamp(2rem, 4vw, 2.5rem) 5%;
  margin-top: clamp(1.5rem, 3vw, 2rem);
  text-align: center;
}

.footer-partners h4 {
  color: rgba(255, 255, 255, 0.9);
  font-size: clamp(1.1rem, 2.2vw, 1.3rem);
  margin-bottom: clamp(1.2rem, 2.5vw, 1.8rem);
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.5px;
}

.footer-partners-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
  gap: clamp(1rem, 2.5vw, 1.5rem);
  max-width: 800px;
  margin: 0 auto;
}

.footer-partners-grid a {
  display: block;
  background: rgba(255, 255, 255, 0.05);
  border: 1px solid rgba(255, 255, 255, 0.1);
  border-radius: 12px;
  padding: clamp(0.8rem, 2vw, 1.2rem);
  color: rgba(255, 255, 255, 0.8);
  text-decoration: none;
  font-size: clamp(0.9rem, 1.8vw, 1rem);
  font-weight: 500;
  transition: all 0.3s ease;
  white-space: nowrap;
  text-align: center;
  cursor: pointer;
  position: relative;
  z-index: 10;
}

.footer-partners-grid a:hover,
.footer-partners-grid a:focus {
  background: rgba(255, 255, 255, 0.1);
  border-color: var(--golden-yellow);
  color: var(--golden-yellow);
  transform: translateY(-2px);
  box-shadow: 0 4px 12px rgba(255, 215, 0, 0.2);
}

.footer-partners-grid a:active {
  transform: translateY(0);
}

/* Enhanced mobile responsive for footer partners */
@media (max-width: 768px) {
  .footer-partners-grid {
    grid-template-columns: repeat(2, 1fr);
    gap: clamp(0.8rem, 2vw, 1rem);
  }
}

@media (max-width: 480px) {
  .footer-partners-grid {
    grid-template-columns: 1fr;
    gap: 0.8rem;
  }
  
  .footer-partners-grid a {
    padding: clamp(1rem, 3vw, 1.2rem);
    font-size: clamp(0.95rem, 2.2vw, 1.05rem);
  }
}

/* Clean CSS - no more overrides needed */
