/********** Template CSS **********/
html {
  scroll-behavior: smooth
}

body {
  font-family: 'Poppins', sans-serif;
  background: #f2fbf5;
  color: #1a3320;
  overflow-x: hidden
}

a {
  text-decoration: none;
  color: inherit
}

:root {
  --primary: #86B817;
  --secondary: #FE8800;
  --light: #F5F5F5;
  --dark: #14141F;
  --lightgreen: #4d9c40;
  --lightdrackgreen: #1d6562;
  --hasgreen: #32a180;
  --maincolor: #22412f;
  --goldcolor: #c8920a;

  --G: #3db870;
  /* main green */
  --DG: #1e6e40;
  /* dark green */
  --LG: #e8f8ef;
  /* light green bg */
  --MG: #c5e8d3;
  /* mid green border */
  --GOLD: #c8920a;
  /* gold */
  --LGOLD: #fff8e6;
  /* light gold */
  --TEXT: #1a3320;
  --MUT: #4a7a5a;
  --BOR: #cce8d8;
  --BG: #f2fbf5;
  --WHITE: #ffffff;
}

:root {
  --ff-primary: 'Playfair Display', serif;
  --ff-secondary: "Times New Roman", Times, serif;
  --ff-popin: 'Poppins', sans-serif;
}

.logo-text {
  font-family: var(--ff-primary);
}

.top-bar-bg {
  background-color: var(--maincolor);
  border-bottom: 4px solid var(--goldcolor);
}

.booknow-btn {
  background-color: var(--maincolor);
  color: white;
}

.main-color span {
  color: var(--goldcolor);
}

.main-color {
  color: var(--maincolor);
  /* font-family: var(--ff-primary); */
}

.bg-maincolor {
  background: var(--maincolor);
}

.sticky-top a h1 {
  color: var(--maincolor) !important;
}

.fw-medium {
  font-weight: 600 !important;
}

.fw-semi-bold {
  font-weight: 700 !important;
}

.back-to-top {
  position: fixed;
  display: none;
  right: 45px;
  bottom: 45px;
  z-index: 99;
}


/*** Spinner ***/
#spinner {
  opacity: 0;
  visibility: hidden;
  transition: opacity .5s ease-out, visibility 0s linear .5s;
  z-index: 99999;
}

#spinner.show {
  transition: opacity .5s ease-out, visibility 0s linear 0s;
  visibility: visible;
  opacity: 1;
}


/*** Button ***/
.btn {
  font-family: 'Nunito', sans-serif;
  font-weight: 600;
  transition: .5s;
}

.btn.btn-primary,
.btn.btn-secondary {
  color: #FFFFFF;
}

.btn-square {
  width: 38px;
  height: 38px;
}

.btn-sm-square {
  width: 32px;
  height: 32px;
}

.btn-lg-square {
  width: 48px;
  height: 48px;
}

.btn-square,
.btn-sm-square,
.btn-lg-square {
  padding: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  font-weight: normal;
  border-radius: 0px;
}


/*** Navbar ***/
.navbar-light .navbar-nav .nav-link {
  font-family: var(--ff-popin);
  position: relative;
  margin-right: 25px;
  padding: 35px 0;
  color: var(--maincolor) !important;
  font-size: 16px;
  font-weight: 500;
  outline: none;
  transition: .5s;
}

.sticky-top.navbar-light .navbar-nav .nav-link {
  padding: 20px 0;
  color: var(--dark) !important;
}

.navbar-light .navbar-nav .nav-link:hover,
.navbar-light .navbar-nav .nav-link.active {
  color: var(--secondary) !important;
}

.hero-badge {
  display: inline-flex;
  align-items: center;
  gap: 7px;
  background: rgba(200, 146, 10, 0.2);
  border: 1px solid rgba(200, 146, 10, 0.5);
  color: #f5d060;
  font-size: 0.63rem;
  font-weight: 600;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  padding: 5px 12px;
  border-radius: 99px;
  margin-bottom: 11px;
}

.hero h1 {
  font-family: 'Playfair Display', serif;
  font-size: 2.3rem;
  line-height: 1.1;
  color: #fff;
  font-weight: 700;
  margin-bottom: 5px;
}

.hero p {
  font-family: var(--ff-popin);
  font-size: 12px I !important;
  color: #fff !important;
}

.hero-btns {
  display: flex;
  flex-direction: row;
  gap: 9px;
}

.btn-gold {
  width: 100%;
  padding: 14px;
  background: var(--goldcolor);
  color: #fff;
  border: none;
  border-radius: 8px;
  font-size: 0.88rem;
  font-weight: 700;
}

.btn-wa {
  width: 100%;
  padding: 13px;
  background: var(--maincolor);
  color: #fff;
  border: 2px solid var(--goldcolor);
  border-radius: 8px;
  font-size: 0.88rem;
  font-weight: 600;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 7px;
}

.btn-wa:hover {
  background: var(--lightdrackgreen);
  border-color: var(--lightgreen);
  border: 2px dashed var(--goldcolor);
}

button {
  cursor: pointer;
  font-family: 'Poppins', sans-serif;
}

.trust {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  background: var(--maincolor);
  border-top: 1px solid rgba(255, 255, 255, 0.1);
}

.trust-box {
  padding: 12px 4px;
  text-align: center;
  border-right: 1px solid rgba(255, 255, 255, 0.1);
}

.trust-box strong {
  display: block;
  font-family: 'Playfair Display', serif;
  font-size: 1.15rem;
  color: #f5d060;
  line-height: 1;
}

.trust-box span {
  font-size: 12px;
  color: rgba(255, 255, 255, 0.6);
  text-transform: uppercase;
  letter-spacing: 0.07em;
  display: block;
  margin-top: 2px;
}

.navbar-light .navbar-brand img {
  /*max-height: 60px;*/
  transition: .5s;
}

.sticky-top.navbar-light .navbar-brand img {
  max-height: 85px;
}

/* ═══ WELCOME SECTION ═══════════════════ */
.welcome {
  background: var(--WHITE);
  padding: 32px 18px 28px;
  text-align: center;
  border-bottom: 3px solid var(--LG);
}

.welcome-emoji {
  font-size: 2.6rem;
  margin-bottom: 10px
}

.welcome h2 {
  font-family: 'Playfair Display', serif;
  font-size: 1.55rem;
  color: var(--DG);
  margin-bottom: 10px;
  line-height: 1.2;
}

.welcome h2 em {
  font-style: italic;
  color: var(--G)
}

.welcome p {
  font-size: 0.85rem;
  color: var(--MUT);
  line-height: 1.75;
  font-weight: 300;
  margin-bottom: 20px;
}

.welcome-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 9px;
  text-align: left;
}

.wg-item {
  display: flex;
  align-items: center;
  gap: 8px;
  background: var(--LG);
  border: 1px solid var(--MG);
  border-radius: 8px;
  padding: 10px 11px;
  font-size: 0.76rem;
  color: var(--DG);
  font-weight: 500;
}

.wg-icon {
  font-size: 1rem;
  flex-shrink: 0
}

@media (max-width: 991.98px) {
  .sticky-top.navbar-light {
    position: relative;
    background: #FFFFFF;
  }

  .navbar-light .navbar-collapse {
    margin-top: 15px;
    border-top: 1px solid #DDDDDD;
  }

  .navbar-light .navbar-nav .nav-link,
  .sticky-top.navbar-light .navbar-nav .nav-link {
    padding: 10px 0;
    margin-left: 0;
    color: var(--dark) !important;
  }

  .navbar-light .navbar-brand img {
    max-height: 80px;
  }
}

@media (min-width: 992px) {
  .navbar-light {
    /* position: absolute; */
    width: 100%;
    top: 0;
    left: 0;
    border-bottom: 1px solid rgba(256, 256, 256, .1);
    z-index: 999;
  }

  .sticky-top.navbar-light {
    position: fixed;
    background: #FFFFFF;
  }

  .navbar-light .navbar-nav .nav-link::before {
    position: absolute;
    content: "";
    width: 0;
    height: 2px;
    bottom: -1px;
    left: 50%;
    background: var(--primary);
    transition: .5s;
  }

  .navbar-light .navbar-nav .nav-link:hover::before,
  .navbar-light .navbar-nav .nav-link.active::before {
    width: calc(100% - 2px);
    left: 1px;
  }

  .navbar-light .navbar-nav .nav-link.nav-contact::before {
    display: none;
  }
}


/*** Hero Header ***/
.hero-header {
  background: linear-gradient(rgba(20, 20, 31, .7), rgba(20, 20, 31, .7)), url(../img/bg-hero.jpg);
  background-position: center center;
  background-repeat: no-repeat;
  background-size: cover;
}

.breadcrumb-item+.breadcrumb-item::before {
  color: rgba(255, 255, 255, .5);
}


/*** Section Title ***/
.section-title {
  position: relative;
  display: inline-block;
  text-transform: uppercase;
}

.section-title::before {
  position: absolute;
  content: "";
  width: calc(100% + 80px);
  height: 2px;
  top: 4px;
  left: -40px;
  background: var(--primary);
  z-index: -1;
}

.section-title::after {
  position: absolute;
  content: "";
  width: calc(100% + 120px);
  height: 2px;
  bottom: 5px;
  left: -60px;
  background: var(--primary);
  z-index: -1;
}

.section-title.text-start::before {
  width: calc(100% + 40px);
  left: 0;
}

.section-title.text-start::after {
  width: calc(100% + 60px);
  left: 0;
}


/*** Service ***/
.service-item {
  box-shadow: 0 0 45px rgba(0, 0, 0, .08);
  transition: .5s;
}

.service-item:hover {
  background: var(--primary);
}

.service-item * {
  transition: .5s;
}

.service-item:hover * {
  color: var(--light) !important;
}

/* packages lister */

.single-line-text {
  white-space: nowrap;
  /* Prevents the text from wrapping to a new line */
  overflow: hidden;
  /* Hides any text that overflows the container's width */
  text-overflow: ellipsis;
  /* Displays an ellipsis (...) for the clipped text */
  max-width: 100%;
  /* Optional: Define a maximum width for the container */
}

.truncate-text {
  /* Required for the clamping to work */
  display: -webkit-box;
  -webkit-box-orient: vertical;
  overflow: hidden;
  text-overflow: ellipsis;
  /* Set the number of lines to display */
  -webkit-line-clamp: 3;
  line-clamp: 3;


  /* Standard property for future support */

  /* Optional styling */
  width: 100%;
  /* Define a width for the container */
  font-family: Arial, sans-serif;
  line-height: 1.4em;
  /* Improve readability */
  height: 50px;
}

.clip-row {
  height: 100px;
}

.pack-det-head div h1,
h2,
h3,
h4 {
  font-family: 'Playfair Display', serif !important;
  color: var(--DG);
  font-size: 22px;
}

.pack-det-head div p {
  text-align: justify;
}

/*** Destination ***/
.destination img {
  transition: .5s;
}

.destination a:hover img {
  transform: scale(1.1);
}

.booking {
  background: linear-gradient(rgba(15, 23, 43, .7), rgba(15, 23, 43, .7)), url(../img/booking.jpg);
  background-position: center center;
  background-repeat: no-repeat;
  background-size: cover;
}

/*** Footer ***/
.footer .btn.btn-social {
  margin-right: 5px;
  width: 35px;
  height: 35px;
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--light);
  font-weight: normal;
  border: 1px solid #FFFFFF;
  border-radius: 35px;
  transition: .3s;
}

.footer .btn.btn-social:hover {
  color: var(--primary);
}

.footer .btn.btn-link {
  display: block;
  margin-bottom: 5px;
  padding: 0;
  text-align: left;
  color: #FFFFFF;
  font-size: 15px;
  font-weight: normal;
  text-transform: capitalize;
  transition: .3s;
}

.footer .btn.btn-link::before {
  position: relative;
  content: "\f105";
  font-family: "Font Awesome 5 Free";
  font-weight: 900;
  margin-right: 10px;
}

.footer .btn.btn-link:hover {
  letter-spacing: 1px;
  box-shadow: none;
}

.footer .copyright {
  padding: 25px 0;
  font-size: 15px;
  border-top: 1px solid rgba(256, 256, 256, .1);
}

.footer .copyright a {
  color: var(--light);
}

.footer .footer-menu a {
  margin-right: 15px;
  padding-right: 15px;
  border-right: 1px solid rgba(255, 255, 255, .1);
}

.footer .footer-menu a:last-child {
  margin-right: 0;
  padding-right: 0;
  border-right: none;
}

.card:hover {
  transform: translateY(-5px);
  transition: 0.3s;
  box-shadow: 0 10px 25px rgba(0, 0, 0, 0.15);
}

.cat-bg-sid-bar {
  background-color: #e5e5e5;
  padding: 3% 3%;
}

.nav-logo-text {
  display: flex;
  align-items: center;
}

.nav-logo-text img {
  max-height: 130px;
}

.cat-bg-sid-bar {
  background: #f8f9fa;
  padding: 20px;
  border-radius: 8px;
}

.cat-bg-sid-bar li {
  border-bottom: 1px solid #eee;
  padding: 10px 0;
}

.testimonial-item {
  display: flex;
  align-items: center;
  flex-direction: column;
}


.testimonial-item {
  min-height: 300px;
}

.package-item {
  text-align: center;
  box-shadow: 0px 4px 10px;
}



@media (max-width:768px) {

  .nav-logo-text h3 {
    font-size: 12px;
  }

  .hero-btns {
    display: flex;
    flex-direction: column;
    gap: 9px;
  }

}

.login-fot {
  display: flex;
  justify-content: space-between;
}

.book-btn:hover {
  background-color: #0d2115;
  animation-fill-mode: backwards;
  color: #fff;
}

/* new template css  */

═══ SECTION WRAPPER ═══════════════════ .sec {
  padding: 30px 16px
}

.sec.white {
  background: var(--WHITE)
}

.sec.light {
  background: var(--BG)
}

.sec-tag {
  font-size: 0.63rem;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  font-weight: 600;
  color: var(--G);
  margin-bottom: 5px;
}

.sec-title {
  font-family: 'Playfair Display', serif;
  font-size: 1.55rem;
  color: var(--DG);
  margin-bottom: 7px;
  line-height: 1.15;
}

.sec-title em {
  font-style: italic;
  color: var(--G)
}

.sec-sub {
  font-size: 0.82rem;
  color: var(--MUT);
  line-height: 1.7;
  font-weight: 300;
  margin-bottom: 22px;
}

/* ═══ PACKAGE CARDS ═════════════════════ */
.card-stack {
  display: flex;
  flex-direction: column;
  gap: 16px
}

.card {
  background: var(--WHITE);
  border-radius: 14px;
  overflow: hidden;
  border: 1.5px solid var(--BOR);
  box-shadow: 0 3px 16px rgba(0, 0, 0, 0.06);
}

.card.best {
  border: 2px solid var(--G);
  padding: 0px;
}

/* ── IMAGE BOX — always visible ── */
.card-pic {
  height: 190px;
  position: relative;
  display: flex;
  align-items: center;
  justify-content: center;
  overflow: hidden;
}

/* Solid gradient background — ALWAYS visible, no broken images */
.pic-munnar {
  background: linear-gradient(140deg, #a8edbc, #3db870)
}

.pic-alleppey {
  background: linear-gradient(140deg, #a8d8f0, #3498db)
}

.pic-wayanad {
  background: linear-gradient(140deg, #b8f0c8, #27ae60)
}

.pic-kovalam {
  background: linear-gradient(140deg, #fde68a, #f59e0b)
}

.pic-thekkady {
  background: linear-gradient(140deg, #d4edda, #52be80)
}

.pic-grand {
  background: linear-gradient(140deg, #d6c6f7, #7c5cbf)
}

.pic-hm1 {
  background: linear-gradient(140deg, #ffd6e7, #e91e8c)
}

.pic-hm2 {
  background: linear-gradient(140deg, #ffecd2, #fcb69f)
}

.card-pic-emoji {
  font-size: 4.5rem;
  filter: drop-shadow(0 4px 8px rgba(0, 0, 0, 0.15));
  z-index: 1;
}

.card-pic-img {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  z-index: 2;
}

.card-rib {
  position: absolute;
  top: 11px;
  left: 11px;
  z-index: 3;
  background: var(--GOLD);
  color: #fff;
  font-size: 0.58rem;
  font-weight: 700;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  padding: 4px 10px;
  border-radius: 4px;
}

.card-body {
  padding: 16px 16px 18px
}

.card-nights {
  font-size: 0.61rem;
  letter-spacing: 0.15em;
  text-transform: uppercase;
  color: var(--G);
  font-weight: 600;
  margin-bottom: 4px;
}

.card h3 {
  font-family: 'Playfair Display', serif;
  font-size: 1.15rem;
  color: var(--DG);
  margin-bottom: 6px;
  line-height: 1.2;
}

.card p {
  font-size: 0.81rem;
  color: var(--MUT);
  line-height: 1.62;
  margin-bottom: 12px;
}

.chips {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
  margin-bottom: 12px
}

.chip {
  font-size: 0.63rem;
  padding: 3px 9px;
  background: var(--LG);
  border: 1px solid var(--MG);
  border-radius: 99px;
  color: var(--DG);
  font-weight: 500;
}

.card-foot {
  display: flex;
  align-items: center;
  justify-content: space-between;
  border-top: 1px solid var(--BOR);
  padding-top: 11px;
}

.price {
  font-family: 'Playfair Display', serif;
  font-size: 1.35rem;
  color: var(--G);
  font-weight: 700;
}

.price small {
  font-family: 'Poppins', sans-serif;
  font-size: 0.65rem;
  color: #aaa;
  font-weight: 300;
}

.book-btn {
  background: var(--G);
  color: #fff;
  padding: 9px 15px;
  border-radius: 7px;
  border: none;
  font-size: 0.75rem;
  font-weight: 600;
}

/* ═══ DESTINATIONS ══════════════════════ */
.dest-list {
  display: flex;
  flex-direction: column;
  gap: 11px
}

.dest-tile {
  border-radius: 12px;
  overflow: hidden;
  position: relative;
  height: 145px;
  display: flex;
  align-items: center;
  justify-content: center;
}

.dest-tile-emoji {
  font-size: 3.5rem;
  position: absolute;
  inset: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  z-index: 0;
}

.dest-tile img {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  z-index: 1;
}

.dest-grad {
  position: absolute;
  inset: 0;
  z-index: 2;
  background: linear-gradient(to top, rgba(10, 40, 20, 0.88) 0%, transparent 55%);
}

.dest-info {
  position: absolute;
  bottom: 0;
  left: 0;
  right: 0;
  padding: 13px 15px;
  z-index: 3;
}

.dest-name {
  font-family: 'Playfair Display', serif;
  font-size: 1.15rem;
  color: #fff;
  margin-bottom: 2px;
  z-index: 5;
}

.dest-sub {
  font-size: 0.6rem;
  color: rgba(255, 255, 255, 0.62);
  text-transform: uppercase;
  letter-spacing: 0.1em;
}

.dest-badge {
  position: absolute;
  top: 9px;
  right: 9px;
  z-index: 3;
  background: rgba(255, 255, 255, 0.18);
  backdrop-filter: blur(6px);
  border: 1px solid rgba(255, 255, 255, 0.3);
  color: #fff;
  font-size: 0.57rem;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  padding: 3px 9px;
  border-radius: 99px;
}

/* ═══ WHY US ════════════════════════════ */
.why-list {
  display: flex;
  flex-direction: column;
  gap: 12px
}

.why-item {
  display: flex;
  gap: 13px;
  align-items: flex-start;
  background: var(--WHITE);
  border-radius: 11px;
  padding: 15px;
  border: 1px solid var(--BOR);
  box-shadow: 0 2px 8px rgba(0, 0, 0, 0.04);
}

.why-icon {
  width: 42px;
  height: 42px;
  border-radius: 9px;
  background: var(--LG);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 1.15rem;
  flex-shrink: 0;
}

.why-item h4 {
  font-size: 0.87rem;
  font-weight: 600;
  color: var(--DG);
  margin-bottom: 3px
}

.why-item p {
  font-size: 0.77rem;
  color: var(--MUT);
  line-height: 1.58
}

/* ═══ TESTIMONIALS ══════════════════════ */
.testi-list {
  display: flex;
  flex-direction: column;
  gap: 13px
}

.testi-card {
  background: var(--WHITE);
  border-radius: 12px;
  padding: 18px 16px;
  border: 1px solid var(--BOR);
  box-shadow: 0 2px 10px rgba(0, 0, 0, 0.04);
}

.testi-stars {
  color: #f59e0b;
  font-size: 0.82rem;
  margin-bottom: 9px
}

.testi-quote {
  font-family: 'Playfair Display', serif;
  font-style: italic;
  font-size: 0.88rem;
  color: var(--TEXT);
  line-height: 1.68;
  margin-bottom: 12px;
}

.testi-name {
  font-size: 0.76rem;
  font-weight: 600;
  color: var(--G)
}

.testi-loc {
  font-size: 0.63rem;
  color: #aaa;
  margin-top: 2px
}

.contact-form-int input {
  color: #000 !important;
}

.contact-form-int label {
  color: #000 !important;
}

.chips {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
}

.chip {
  background: #f1f1f1;
  padding: 5px 10px;
  border-radius: 20px;
  font-size: 13px;
}


/* ═══ CTA BAND ══════════════════════════ */
.cta-band {
  background: var(--GOLD);
  padding: 32px 18px;
  text-align: center;
}

.cta-band h2 {
  font-family: 'Playfair Display', serif;
  font-size: 1.5rem;
  color: #fff;
  margin-bottom: 8px;
  line-height: 1.2;
}

.cta-band h2 em {
  font-style: italic
}

.cta-band p {
  font-size: 0.83rem;
  color: rgba(255, 255, 255, 0.88);
  margin-bottom: 18px;
  line-height: 1.6;
}

.cta-btns {
  display: flex;
  flex-direction: column;
  gap: 9px
}

.btn-cta-w {
  width: 100%;
  padding: 14px;
  background: #fff;
  color: var(--GOLD);
  border: none;
  border-radius: 8px;
  font-size: 0.87rem;
  font-weight: 700;
}

.btn-cta-t {
  width: 100%;
  padding: 13px;
  background: transparent;
  color: #fff;
  border: 2px solid rgba(255, 255, 255, 0.55);
  border-radius: 8px;
  font-size: 0.87rem;
  font-weight: 600;
}

.form-floating input {
  color: #ffffff;
}

.form-floating label {
  color: #fff;
  opacity: 2 !important;
}

.default {
  background-color: white;
  color: black;
}

.form-select {
  color: #000;
}

.form-control:focus {
  color: #fff;
}

.footer-bg {
  background-color: #0d2115;
  border-top: 7px solid #ff9308;
}

/* ═══ ABOUT PAGE ════════════════════════ */
.about-top {
  background: linear-gradient(135deg, var(--DG), var(--G));
  padding: 44px 18px 32px;
  text-align: center;
  color: #fff;
}

.about-top h2 {
  font-family: 'Playfair Display', serif;
  font-size: 1.85rem;
  margin-bottom: 10px;
  color: #2C3E50;
}

.about-top h2 em {
  font-style: italic;
  color: #a8f0c0
}

h3 .chip-pk-dt {
  font-family: 'Playfair Display', serif;
  font-size: 18px;
  color: #000;
}

.about-top p {
  font-size: 0.86rem;
  line-height: 1.72;
  opacity: 0.85
}

.stat-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 11px;
  padding: 22px 16px;
  background: var(--WHITE);
}

.stat-box {
  background: var(--LG);
  border-radius: 11px;
  padding: 16px 12px;
  text-align: center;
  border: 1px solid var(--MG);
}

.stat-box strong {
  font-family: 'Playfair Display', serif;
  font-size: 1.75rem;
  color: var(--G);
  display: block;
}

.stat-box span {
  font-size: 0.7rem;
  color: var(--MUT);
  margin-top: 2px;
  display: block
}

.story {
  padding: 24px 16px;
  background: var(--BG)
}

.story h3 {
  font-family: 'Playfair Display', serif;
  font-size: 1.2rem;
  color: var(--DG);
  margin-bottom: 10px;
}

.story p {
  font-size: 0.84rem;
  color: var(--MUT);
  line-height: 1.78;
  margin-bottom: 13px
}

/* ═══ HONEYMOON PAGE ════════════════════ */
.hm-top {
  background: linear-gradient(135deg, #ffe4f0, #ffc2dc);
  padding: 44px 18px 30px;
  text-align: center;
}

.hm-top h2 {
  font-family: 'Playfair Display', serif;
  font-size: 1.85rem;
  color: #7a1040;
  margin-bottom: 10px;
}

.hm-top h2 em {
  font-style: italic;
  color: #c2185b
}

.hm-top p {
  font-size: 0.86rem;
  color: #6b3050;
  line-height: 1.7
}

.hm-includes {
  padding: 22px 16px;
  background: var(--WHITE)
}

.hm-includes h3 {
  font-family: 'Playfair Display', serif;
  font-size: 1.15rem;
  color: var(--DG);
  margin-bottom: 14px;
}

.hm-list {
  display: flex;
  flex-direction: column;
  gap: 9px
}

.hm-item {
  display: flex;
  align-items: center;
  gap: 11px;
  padding: 11px 13px;
  background: #fff0f6;
  border-radius: 9px;
  border: 1px solid #ffd6e7;
  font-size: 0.81rem;
  color: #7a1040;
  font-weight: 500;
}

.hm-item-icon {
  font-size: 1.05rem;
  flex-shrink: 0
}

/* ═══ BLOG PAGE ═════════════════════════ */
.blog-list {
  display: flex;
  flex-direction: column;
  gap: 15px
}

.blog-card {
  background: var(--WHITE);
  border-radius: 12px;
  overflow: hidden;
  border: 1px solid var(--BOR);
  box-shadow: 0 2px 10px rgba(0, 0, 0, 0.05);
}

.blog-thumb {
  height: 150px;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 3.3rem;
}

.blog-body {
  padding: 15px 16px 17px
}

.blog-tag {
  font-size: 0.58rem;
  font-weight: 600;
  letter-spacing: 0.15em;
  text-transform: uppercase;
  color: var(--G);
  margin-bottom: 5px;
}

.blog-card h3 {
  font-family: 'Playfair Display', serif;
  font-size: 1.0rem;
  color: var(--DG);
  margin-bottom: 7px;
  line-height: 1.3;
}

.contact-form-int textarea {
  color: #000 !important;
}

.pack-bk-frm select:focus {
  color: #000 !important;
}

.blog-card p {
  font-size: 0.79rem;
  color: var(--MUT);
  line-height: 1.62;
  margin-bottom: 11px
}

.blog-read {
  font-size: 0.71rem;
  font-weight: 600;
  color: var(--G)
}

/* ═══ CONTACT PAGE ══════════════════════ */
.contact-top {
  background: linear-gradient(135deg, var(--DG), var(--G));
  padding: 44px 18px 30px;
  text-align: center;
  color: #fff;
}

.contact-top h2 {
  font-family: 'Playfair Display', serif;
  font-size: 1.85rem;
  margin-bottom: 8px;
  color: #fff;
}

.contact-top h2 em {
  font-style: italic;
  color: #a8f0c0
}

.contact-top p {
  font-size: 0.86rem;
  opacity: 0.85;
  line-height: 1.65
}

.contact-dets {
  padding: 20px 16px;
  background: var(--WHITE);
  display: flex;
  flex-direction: column;
  gap: 11px;
}

.cdet {
  display: flex;
  align-items: center;
  gap: 13px;
  padding: 13px 14px;
  background: var(--LG);
  border-radius: 10px;
  border: 1px solid var(--MG);
}

.cdet-ico {
  width: 38px;
  height: 38px;
  background: var(--WHITE);
  border-radius: 8px;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 1.05rem;
  flex-shrink: 0;
}

.cdet-lbl {
  font-size: 0.58rem;
  letter-spacing: 0.13em;
  text-transform: uppercase;
  color: var(--MUT);
  margin-bottom: 1px
}

.cdet-val {
  font-size: 0.83rem;
  color: var(--DG);
  font-weight: 500
}

.form-wrap {
  padding: 18px 16px 36px;
  background: var(--BG)
}

.form-box {
  background: var(--WHITE);
  border-radius: 14px;
  padding: 20px 16px;
  border: 1px solid var(--BOR);
  box-shadow: 0 3px 14px rgba(0, 0, 0, 0.06);
}

.form-box h3 {
  font-family: 'Playfair Display', serif;
  font-size: 1.25rem;
  color: var(--DG);
  margin-bottom: 3px;
}

.form-box .fsub {
  font-size: 0.76rem;
  color: var(--MUT);
  margin-bottom: 18px
}

.fg {
  margin-bottom: 12px
}

label {
  display: block;
  font-size: 0.6rem;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--MUT);
  font-weight: 600;
  margin-bottom: 5px;
}

input,
select,
textarea {
  width: 100%;
  padding: 12px 13px;
  border: 1.5px solid var(--BOR);
  border-radius: 8px;
  font-family: 'Poppins', sans-serif;
  font-size: 0.86rem;
  color: var(--TEXT);
  background: var(--WHITE);
  outline: none;
  -webkit-appearance: none;
}

input:focus,
select:focus,
textarea:focus {
  border-color: var(--G)
}

input::placeholder,
textarea::placeholder {
  color: #c5c5c5
}

textarea {
  resize: none;
  height: 85px
}

.submit-btn {
  width: 100%;
  padding: 14px;
  background: #25D366;
  color: #fff;
  border: none;
  border-radius: 8px;
  font-family: 'Poppins', sans-serif;
  font-size: 0.87rem;
  font-weight: 700;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 7px;
  margin-top: 5px;
}

/* ═══ FOOTER ════════════════════════════ */
footer {
  background: #0d2115;
  padding: 36px 16px 22px;
}

.foot-brand {
  font-family: 'Playfair Display', serif;
  font-size: 30px;
  color: #fff;
  /* text-align: center; */
  margin-bottom: 3px;
}

.foot-brand span {
  color: #f5d060
}

.footer-h h4 {
  font-family: 'Playfair Display', serif;
  color: #fff;
  font-size: 30px;
  font-weight: 400;
}

.foot-url {
  text-align: center;
  font-size: 0.73rem;
  color: #c8920a;
  margin-bottom: 8px
}

.foot-desc {
  text-align: center;
  font-size: 0.74rem;
  color: rgba(255, 255, 255, 0.3);
  line-height: 1.72;
  max-width: 260px;
  margin: 0 auto 24px;
}

.foot-cols {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 22px;
  margin-bottom: 22px;
}

.foot-col h4 {
  font-size: 0.6rem;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  color: rgba(255, 255, 255, 0.42);
  margin-bottom: 11px;
  font-weight: 600;
}

.foot-col ul {
  list-style: none;
  display: flex;
  flex-direction: column;
  gap: 8px
}

.foot-col ul li a {
  font-size: 0.78rem;
  color: rgba(255, 255, 255, 0.32)
}

.foot-btm {
  border-top: 1px solid rgba(255, 255, 255, 0.07);
  padding-top: 16px;
  text-align: center;
  font-size: 0.66rem;
  color: rgba(255, 255, 255, 0.2);
  line-height: 1.8;
}

.foot-btm span {
  color: rgba(200, 146, 10, 0.4);
  display: block
}

/* ═══ ANIMATIONS ════════════════════════ */
.reveal {
  opacity: 1;
  transform: translateY(20px);
  transition: opacity 0.55s ease, transform 0.55s ease
}

.reveal.in {
  opacity: 1;
  transform: none
}

/* tabs css only  */

/* Tabs Container */
.custom-tabs {
  width: 100%;
}

/* Tab Navigation */
.tab-nav {
  display: flex;
  border-bottom: 2px solid #ddd;
  list-style: none;
  padding: 0;
  margin: 0;
}

.tab-nav li {
  padding: 10px 20px;
  cursor: pointer;
  border: 1px solid #ddd;
  border-bottom: none;
  background: #f8f8f8;
  margin-right: 5px;
  transition: 0.3s;
}

.tab-nav li.active {
  background: #fff;
  font-weight: bold;
  border-top: 3px solid #007bff;
}

/* Mobile Responsive */
@media (max-width: 768px) {

  .tab-nav {
    flex-direction: row;
    /* stack tabs */
    border-bottom: none;
  }

  .tab-nav li {
    width: 100%;
    margin: 0;
    font-size: 14px;
    font-weight: 700;
    padding: 5px 5px;
    border-bottom: 1px solid #ddd;
    border-right: none;
    border-left: none;
    border-top: none;
    background: #f5f5f5;
  }

  .tab-nav li.active {
    font-size: 11px;
    background: #fff;
    border-left: 4px solid #007bff;
    /* highlight active */
    font-weight: bold;
  }

  .tab-content {
    border-top: none;
  }

  .str-price {
    position: absolute;
    top: 0;
    left: 70% !important;
    height: 108px;
    padding: 9px;
    /* background-color: #FF9800;
    border-bottom-left-radius: 100px;
    border-bottom-right-radius: 100px; */
    /* box-shadow: 3px 3px 5px #000; */
  }

  .pack-mob-con {
    padding-top: 0px !important;
  }

  .pack-mob-con .container {
    padding: 10px;
  }

  .pack-mob-con .container .row .col-lg-8 {
    padding: 10px;
  }

  .features-icon {
    font-size: 12px;
  }

  .fec-icon i {
    font-size: 20px;
  }
}

/* Tab Content */
.tab-content {
  display: none;
  border: 1px solid #ddd;
  padding: 20px;
  background: #fff;
}

.tab-content.active {
  display: block;
}


/* Accordion Container */
.accordion {
  width: 100%;
  max-width: 800px;
  margin: auto;
}

/* Each Item */
.acc-item {
  border: 1px solid #ddd;
  margin-bottom: 10px;
  border-radius: 6px;
  overflow: hidden;
}

/* Header Button */
.acc-header {
  width: 100%;
  padding: 15px;
  text-align: left;
  background: #f7f7f7;
  border: none;
  outline: none;
  cursor: pointer;
  font-size: 16px;
  font-weight: 600;
  transition: 0.3s;
  position: relative;
}

/* Plus Icon */
.acc-header::after {
  content: "+";
  position: absolute;
  right: 20px;
  font-size: 18px;
}

/* Active Header */
.acc-header.active {
  background: #007bff;
  color: #fff;
}

.acc-header.active::after {
  content: "-";
}

/* Content */
.acc-content {
  max-height: 0;
  overflow: hidden;
  background: #fff;
  transition: max-height 0.3s ease;
  padding: 0 15px;
}

/* Inner Content Padding */
.acc-content p {
  margin: 15px 0;
}



/* ex/in  */

.accordion {
  width: 100%;
}

.acc-item {
  border: 1px solid #ddd;
  margin-bottom: 10px;
  border-radius: 6px;
  overflow: hidden;
}

.acc-header {
  width: 100%;
  padding: 14px;
  background: #f5f5f5;
  border: none;
  text-align: left;
  font-weight: 600;
  cursor: pointer;
  position: relative;
}

/* Icon */
.acc-header::after {
  content: "+";
  position: absolute;
  right: 15px;
}

.acc-header.active {
  background: #28a745;
  /* green for inclusion */
  color: #fff;
}

.acc-item:nth-child(2) .acc-header.active {
  background: #dc3545;
  /* red for exclusion */
}

/* Content */
.acc-content {
  max-height: 0;
  overflow: hidden;
  transition: 0.3s;
  background: #fff;
  padding: 0 15px;
}

.acc-list {
  padding: 10px 0;
}

.acc-list li {
  margin-bottom: 8px;
}

.tlp div h3 {
  font-size: 18px;
}

.fec-icon {
  text-align: center;
}

.features-icon {
  display: flex;
  flex-direction: row;
  justify-content: space-between;
  align-items: center;
  padding: 20px 10px;
  background: #e3f5b9;
  font-size: 14px;
}

.fec-icon i {
  font-size: 28px;
}

.pak-img {
  position: relative;
}

.str-price {
  position: absolute;
  top: 0;
  left: 80%;
  height: 120px;
  padding: 10px;
  /* background-color: #FF9800; */
  background-image: url(../img/bg_price.png);
  background-size: cover;
  background-position: center;
  background-repeat: no-repeat;
  /* border-bottom-left-radius: 100px; */
  /* border-bottom-right-radius: 100px; */
  /* box-shadow: 3px 3px 5px #000; */
  font-size: 14px;
  text-align: center;
  font-weight: 600;
  vertical-align: middle;
  display: flex;
  align-content: center;
  flex-direction: column;
  justify-content: center;
  color: #023c1b;
}