/* Africompass Travel Packages - faithful v7 layout, brand-recolored, scoped to #acmpPkg */
#acmpPkg *{margin: 0; padding: 0; box-sizing: border-box;}
#acmpPkg{scroll-behavior: smooth;}
#acmpPkg{font-family: 'Plus Jakarta Sans', sans-serif;
  background: #ffffff;
  color: #111111;
  overflow-x: hidden;}
#acmpPkg #stickyBar{position: fixed;
  top: 0; left: 0; right: 0;
  z-index: 1000;
  display: flex;
  align-items: center;
  justify-content: flex-end;
  gap: 10px;
  padding: 10px 32px;
  background: rgba(255,255,255,0.97);
  backdrop-filter: blur(10px);
  border-bottom: 1px solid #ece8e1;
  box-shadow: 0 2px 12px rgba(0,0,0,0.08);
  transform: translateY(-110%);
  transition: transform 0.4s ease;}
#acmpPkg #stickyBar.visible{transform: translateY(0);}
#acmpPkg #stickyBar button{font-family: 'Plus Jakarta Sans', sans-serif;
  font-weight: 700;
  font-size: 12px;
  cursor: pointer;
  border-radius: 100px;
  padding: 9px 22px;
  letter-spacing: 0.5px;
  border: none;}
#acmpPkg #stickyGallery{background: transparent;
  border: 1.5px solid #ea7940 !important;
  color: #ea7940;}
#acmpPkg #stickyBook{background: #ea7940;
  color: #ffffff;
  text-transform: uppercase;
  letter-spacing: 1px;}
#acmpPkg #sectionNav{position: sticky;
  top: 0;
  z-index: 990;
  background: rgba(255,255,255,0.96);
  backdrop-filter: blur(14px);
  -webkit-backdrop-filter: blur(14px);
  border-bottom: 1px solid rgba(203,213,225,0.6);
  transition: box-shadow 0.35s ease, background 0.35s ease;}
#acmpPkg #sectionNav.elevated{box-shadow: 0 6px 32px rgba(22,21,15,0.10);}
#acmpPkg .section-nav-inner{max-width: 1060px;
  margin: 0 auto;
  padding: 10px 32px;
  display: flex;
  align-items: center;
  gap: 6px;
  overflow-x: auto;
  scrollbar-width: none;
  -ms-overflow-style: none;}
#acmpPkg .section-nav-inner::-webkit-scrollbar{display: none;}
#acmpPkg .snav-tab{display: flex;
  flex-direction: row;
  align-items: center;
  gap: 7px;
  padding: 9px 18px;
  cursor: pointer;
  border: 1.5px solid transparent;
  border-radius: 100px;
  background: transparent;
  font-family: 'Plus Jakarta Sans', sans-serif;
  font-size: 13px;
  font-weight: 600;
  color: #64748B;
  white-space: nowrap;
  flex-shrink: 0;
  position: relative;
  transition: color 0.2s, background 0.2s, border-color 0.2s, box-shadow 0.2s;
  letter-spacing: 0.1px;}
#acmpPkg .snav-tab:hover{color: #1E40AF;
  background: #faf5ee;
  border-color: #fdf0e7;}
#acmpPkg .snav-tab.active{color: #ffffff;
  background: #1f1c16;
  border-color: #1f1c16;
  font-weight: 700;
  box-shadow: 0 4px 14px rgba(31,28,22,0.28);}
#acmpPkg .snav-icon{font-size: 15px;
  line-height: 1;
  flex-shrink: 0;}
#acmpPkg .snav-sep{width: 4px;
  height: 4px;
  border-radius: 50%;
  background: #CBD5E1;
  flex-shrink: 0;
  pointer-events: none;}
@media (max-width: 640px){
#acmpPkg .section-nav-inner{padding: 8px 16px; gap: 4px;}
#acmpPkg .snav-tab{padding: 8px 14px; font-size: 12px;}
#acmpPkg .snav-icon{font-size: 13px;}
#acmpPkg .snav-sep{display: none;}
}
#acmpPkg #heroWrap{position: relative; width: 100%; height: 90vh; min-height: 520px; overflow: hidden;}
#acmpPkg #heroBg{position: absolute; top: -20%; left: 0; right: 0; bottom: -20%;
  background-image: var(--hero);
  background-size: cover; background-position: center; will-change: transform;}
@media (max-width: 767px){
#acmpPkg #heroBg{background-image: var(--hero-m, var(--hero));
    background-position: center top;}
}
#acmpPkg #heroFade{position: absolute; bottom: 0; left: 0; right: 0; height: 45%;
  background: linear-gradient(to top, rgba(255,255,255,1) 0%, rgba(255,255,255,0.85) 30%, rgba(255,255,255,0.4) 60%, transparent 100%);
  pointer-events: none; z-index: 2;}
#acmpPkg #heroTopFade{position: absolute; top: 0; left: 0; right: 0; height: 30%;
  background: linear-gradient(to bottom, rgba(0,0,0,0.25) 0%, transparent 100%);
  pointer-events: none; z-index: 2;}
#acmpPkg #heroOverlay{position: absolute; inset: 0; background: #ffffff; opacity: 0; pointer-events: none; z-index: 3;}
#acmpPkg #heroContent{position: absolute; inset: 0; z-index: 4; display: flex; flex-direction: column; justify-content: flex-end; padding: 28px 40px 44px;}
#acmpPkg #heroBottom{display: flex; flex-direction: column; gap: 10px; text-align: left;}
#acmpPkg .hero-title{font-size: clamp(34px,4.8vw,68px); font-weight: 800; color: #111111 !important;
  line-height: 1.05; letter-spacing: -1.5px;}
@media (max-width: 767px){
#acmpPkg .hero-title{font-size: clamp(26px,8vw,38px); letter-spacing: -0.5px;}
}
#acmpPkg .hero-destination{font-size: 14px; font-weight: 700; color: #ea7940; letter-spacing: 0.3px; margin-top: 2px;}
@media (min-width: 768px){
#acmpPkg .hero-destination{font-size: 16px;}
}
#acmpPkg .hero-deal{background: #ea7940; color: #ffffff !important; padding: 7px 16px; border-radius: 100px;
  font-size: 11px; font-weight: 800; white-space: nowrap; display: inline-flex;
  align-items: center; align-self: flex-start; letter-spacing: 0.3px;}
#acmpPkg .hero-deal-mobile{display: inline-flex;}
#acmpPkg .hero-deal-desktop{display: none;}
@media (min-width: 768px){
#acmpPkg .hero-deal-mobile{display: none;}
#acmpPkg .hero-deal-desktop{display: inline-flex;}
}
#acmpPkg .hero-price-row{display: flex; align-items: center; gap: 14px; flex-wrap: wrap;}
#acmpPkg .price-from{font-size: 14px; font-weight: 700; margin-right: 2px; color: inherit; vertical-align: baseline;}
#acmpPkg .hero-price{font-size: 28px; font-weight: 800; color: #111111 !important; letter-spacing: -0.5px;}
#acmpPkg .hero-price sub{font-size: 12px; font-weight: 600; color: #666666; vertical-align: baseline;}
@media (max-width: 767px){
#acmpPkg .hero-price{font-size: 22px; color: #ea7940 !important;}
#acmpPkg .hero-price sub{color: #ea7940; opacity: 0.75;}
#acmpPkg .price-from{font-size: 13px;}
}
@media (min-width: 768px){
#acmpPkg .hero-price{font-size: 36px;}
#acmpPkg .price-from{font-size: 16px;}
#acmpPkg .hero-includes{font-size: 15px !important; line-height: 1.7 !important;}
#acmpPkg .hero-validity{font-size: 13px !important;}
}
#acmpPkg .hero-includes{font-size: 13px; color: #222222 !important; font-weight: 600; line-height: 1.6;}
#acmpPkg .hero-includes strong{color: #111111 !important;}
#acmpPkg .hero-bottom-row{display: flex; align-items: center; justify-content: space-between; flex-wrap: wrap; gap: 12px;}
#acmpPkg .hero-validity{font-size: 12px; color: #555555 !important; font-weight: 600;}
#acmpPkg .hero-book{background: #ea7940; border: none; color: #ffffff !important; padding: 13px 34px;
  border-radius: 100px; font-size: 14px; font-weight: 800; text-transform: uppercase;
  letter-spacing: 1px; cursor: pointer; font-family: 'Plus Jakarta Sans', sans-serif;
  box-shadow: 0 4px 20px rgba(224,100,28,0.4); transition: transform 0.2s, box-shadow 0.2s;}
#acmpPkg .hero-book:hover{transform: translateY(-2px); box-shadow: 0 6px 28px rgba(224,100,28,0.5);}
#acmpPkg #detail{background: #ffffff; padding: 0 40px 80px;}
#acmpPkg #detailInner{max-width: 1060px; margin: 0 auto; text-align: left;}
#acmpPkg .page-section{padding-top: 60px; scroll-margin-top: 56px;}
#acmpPkg .section-heading{font-family: 'Poppins', sans-serif; font-size: 24px; font-weight: 800; letter-spacing: -0.3px; text-transform: none;
  color: #1f1c16; margin: 0 0 22px; display: flex; align-items: center; gap: 14px;}
#acmpPkg .section-heading::before{content: ''; width: 30px; height: 4px; border-radius: 2px; background: var(--grad, linear-gradient(135deg,#f5873f,#e0641c)); flex: 0 0 auto;}
#acmpPkg .section-heading::after{content: ''; flex: 1; height: 1px; background: #ece8e1;}
@media (min-width: 761px){#acmpPkg .section-heading{font-size: 28px;}}
#acmpPkg .section-subheading{font-size: 11px; font-weight: 800; letter-spacing: 2.4px; text-transform: uppercase;
  color: #1f5c2e; margin: 30px 0 14px; display: flex; align-items: center; gap: 10px;}
#acmpPkg .section-subheading::before{content: ''; width: 18px; height: 3px; border-radius: 2px; background: #1f5c2e; flex: 0 0 auto;}
#acmpPkg .section-subheading::after{content: ''; flex: 1; height: 1px; background: #ece8e1;}
#acmpPkg .list-card:has(.ilist.inc) h4{color: #1f5c2e;}
#acmpPkg .list-card:has(.ilist.exc) h4{color: #8b2e2e;}
#acmpPkg .img-strip{display: flex; gap: 8px; margin-bottom: 56px; min-height: 180px;}
#acmpPkg .img-strip-item{flex: 1; position: relative; overflow: hidden; border-radius: 10px; cursor: pointer; min-height: 180px;}
#acmpPkg .img-strip-item img{width: 100%; height: 100%; object-fit: cover; display: block; transition: transform 0.4s ease;}
#acmpPkg .img-strip-item:hover img{transform: scale(1.06);}
#acmpPkg .img-strip-item.see-all::after{content: ''; position: absolute; inset: 0; background: rgba(0,0,0,0.55); pointer-events: none;}
@media (max-width: 767px){
#acmpPkg .img-strip-item.mobile-last::after{content: ''; position: absolute; inset: 0; background: rgba(0,0,0,0.55); pointer-events: none;}
}
#acmpPkg .see-all-label{position: absolute; inset: 0; z-index: 2; display: none; flex-direction: column;
  align-items: center; justify-content: center; gap: 8px; color: #ffffff; font-weight: 800;
  font-size: 13px; text-align: center; pointer-events: none; line-height: 1.3;}
#acmpPkg .img-strip-item.see-all .see-all-label{display: flex;}
@media (max-width: 767px){
#acmpPkg .img-strip-item.mobile-last .see-all-label{display: flex;}
}
#acmpPkg .see-all-icon{font-size: 26px; line-height: 1;}
#acmpPkg .img-strip-item.desktop-only{display: none;}
@media (min-width: 768px){
#acmpPkg .img-strip-item.desktop-only{display: block;}
#acmpPkg .img-strip{min-height: 220px;}
#acmpPkg .img-strip-item{min-height: 220px;}
#acmpPkg .see-all-label{font-size: 14px;}
}
#acmpPkg .trip-info{padding-bottom: 36px; border-bottom: 1px solid #ece8e1; margin-bottom: 44px;}
#acmpPkg .trip-info-body{font-size: 15px; font-weight: 400; color: #333333; line-height: 1.85; max-width: 820px; margin-bottom: 20px;}
@media (min-width: 768px){
#acmpPkg .trip-info-body{font-size: 16px;}
}
#acmpPkg .trip-info-payment{display: inline-block; font-size: 13px; font-weight: 700; color: #ea7940;
  background: #faf5ee; border-left: 3px solid #ea7940; border-radius: 0 8px 8px 0; padding: 12px 18px;}
@media (min-width: 768px){
#acmpPkg .trip-info-payment{font-size: 15px; padding: 14px 22px;}
}
#acmpPkg .two-col{display: grid; grid-template-columns: 1fr 1fr; gap: 20px; margin-bottom: 56px;}
@media (max-width: 767px){
#acmpPkg .two-col{grid-template-columns: 1fr;}
}
#acmpPkg .list-card{background: #faf5ee; border: 1px solid #fdf0e7; border-radius: 14px; padding: 26px;}
#acmpPkg .list-card h4{font-size: 10px; font-weight: 800; letter-spacing: 2px; text-transform: uppercase; color: #ea7940; margin-bottom: 18px;}
#acmpPkg .ilist{list-style: none; display: flex; flex-direction: column; gap: 11px;}
#acmpPkg .ilist li{display: flex; align-items: flex-start; gap: 10px; font-size: 14px; font-weight: 600; color: #222222; line-height: 1.4;}
#acmpPkg .ilist.inc li::before{content: "✓"; color: #2e7d32; font-weight: 800; flex-shrink: 0;}
#acmpPkg .ilist.exc li::before{content: '✕'; color: #8b2e2e; font-weight: 800; flex-shrink: 0;}
#acmpPkg .hotels-label{font-size: 10px; font-weight: 800; letter-spacing: 2.5px; text-transform: uppercase;
  color: #ea7940; margin-bottom: 16px; display: flex; align-items: center; gap: 12px;}
#acmpPkg .hotels-label::after{content: ''; flex: 1; height: 1px; background: #ece8e1;}
#acmpPkg .hotel-strip{display: flex; align-items: stretch; background: #ffffff; border: 1px solid #fdf0e7;
  border-radius: 14px; overflow: hidden; margin-bottom: 12px;
  box-shadow: 0 2px 12px rgba(234,121,64,0.06); transition: box-shadow 0.2s, border-color 0.2s; cursor: pointer;}
#acmpPkg .hotel-strip:hover{box-shadow: 0 4px 20px rgba(234,121,64,0.14); border-color: #93C5FD;}
#acmpPkg .hotel-strip-img{width: 130px; min-height: 110px; flex-shrink: 0; overflow: hidden;}
#acmpPkg .hotel-strip-img img{width: 100%; height: 100%; object-fit: cover; display: block; transition: transform 0.4s ease;}
#acmpPkg .hotel-strip:hover .hotel-strip-img img{transform: scale(1.06);}
#acmpPkg .hotel-strip-body{flex: 1; padding: 16px 18px; display: flex; flex-direction: column; justify-content: space-between;}
#acmpPkg .strip-top{display: flex; flex-direction: column; gap: 4px;}
#acmpPkg .strip-opt{font-size: 10px; font-weight: 800; letter-spacing: 1.5px; text-transform: uppercase; color: #ea7940;}
#acmpPkg .strip-name{font-size: 16px; font-weight: 800; color: #111111; line-height: 1.2;}
#acmpPkg .strip-loc{font-size: 12px; color: #888888; font-weight: 600;}
#acmpPkg .strip-plan{font-size: 12px; color: #555555; font-weight: 600; margin-top: 2px;}
#acmpPkg .strip-details{margin-top: 8px; list-style: none; display: flex; flex-direction: column; gap: 4px;}
#acmpPkg .strip-details li{font-size: 12px; color: #555555; font-weight: 600; display: flex; gap: 6px; align-items: flex-start;}
#acmpPkg .strip-details li::before{content: '•'; color: #ea7940; flex-shrink: 0;}
#acmpPkg .strip-bottom{display: flex; align-items: center; justify-content: space-between; flex-wrap: wrap; gap: 8px; margin-top: 10px;}
#acmpPkg .strip-price{font-size: 18px; font-weight: 800; color: #ea7940; letter-spacing: -0.5px; white-space: nowrap;}
#acmpPkg .strip-price .price-from-small{font-size: 11px; font-weight: 700; color: #ea7940; margin-right: 2px;}
#acmpPkg .strip-price span{font-size: 11px; font-weight: 600; color: #888888;}
#acmpPkg .strip-cta{background: #ea7940; border: none; color: #ffffff; padding: 9px 18px; border-radius: 100px;
  font-size: 11px; font-weight: 800; text-transform: uppercase; letter-spacing: 0.8px;
  cursor: pointer; font-family: 'Plus Jakarta Sans', sans-serif; white-space: nowrap; transition: transform 0.2s;}
#acmpPkg .strip-cta:hover{transform: scale(1.03);}
#acmpPkg .itinerary-day{margin-bottom: 14px; border: 1px solid #ece8e1; border-radius: 16px; overflow: hidden;}
#acmpPkg .day-header{background: #fdf0e7; padding: 16px 24px; display: flex; align-items: center; gap: 16px;
  cursor: pointer; user-select: none; transition: background 0.2s;}
#acmpPkg .day-header:hover{background: #E0EEFF;}
#acmpPkg .day-number-badge{background: #ea7940; color: #ffffff; font-size: 11px; font-weight: 800; letter-spacing: 1px;
  text-transform: uppercase; padding: 5px 14px; border-radius: 100px; white-space: nowrap; flex-shrink: 0;}
#acmpPkg .day-title{font-size: 15px; font-weight: 700; color: #16150f; flex: 1;}
#acmpPkg .day-toggle-icon{font-size: 18px; color: #8a8276; transition: transform 0.3s ease; flex-shrink: 0;}
#acmpPkg .itinerary-day.open .day-toggle-icon{transform: rotate(180deg);}
#acmpPkg .day-body{display: none; padding: 24px; border-top: 1px solid #ece8e1;}
#acmpPkg .itinerary-day.open .day-body{display: block;}
#acmpPkg .day-description{font-size: 14.5px; color: #444444; line-height: 1.8; margin-bottom: 24px;}
#acmpPkg .day-activities{list-style: none; display: flex; flex-direction: column; gap: 10px; margin-bottom: 28px;}
#acmpPkg .day-activities li{display: flex; gap: 12px; align-items: flex-start; font-size: 13.5px; font-weight: 600; color: #333333;}
#acmpPkg .day-activities li::before{content: ''; width: 7px; height: 7px; background: #ea7940; border-radius: 50%; flex-shrink: 0; margin-top: 6px;}
#acmpPkg .day-accommodation{background: #faf5ee; border: 1px solid #fdf0e7; border-radius: 12px; padding: 18px 20px;}
#acmpPkg .day-accomm-label{font-size: 10px; font-weight: 800; letter-spacing: 2px; text-transform: uppercase; color: #ea7940; margin-bottom: 14px; display: flex; align-items: center; gap: 8px;}
#acmpPkg .day-accomm-label::before{content: '🏨'; font-size: 14px;}
#acmpPkg .day-accommodation .hotel-strip{margin-bottom: 0;}
#acmpPkg .day-accommodation .hotel-strip + .hotel-strip{margin-top: 10px;}
#acmpPkg .rates-intro{font-size: 14.5px; color: #444444; line-height: 1.8; margin-bottom: 32px;}
#acmpPkg .season-tabs{display: flex; gap: 8px; margin-bottom: 24px; flex-wrap: wrap;}
#acmpPkg .season-tab-btn{padding: 8px 20px; border-radius: 100px; font-family: 'Plus Jakarta Sans', sans-serif;
  font-size: 12.5px; font-weight: 700; cursor: pointer; border: 1.5px solid #fdf0e7;
  background: transparent; color: #8a8276; transition: all 0.2s;}
#acmpPkg .season-tab-btn.active, #acmpPkg .season-tab-btn:hover{background: #ea7940; border-color: #ea7940; color: #ffffff;}
#acmpPkg .season-panel{display: none;}
#acmpPkg .season-panel.active{display: block;}
#acmpPkg .rates-table{width: 100%; border-collapse: collapse; margin-bottom: 20px; border-radius: 12px; overflow: hidden; border: 1px solid #fdf0e7;}
#acmpPkg .rates-table thead tr{background: #faf5ee;}
#acmpPkg .rates-table th{padding: 13px 18px; font-size: 11px; font-weight: 800; letter-spacing: 1.5px; text-transform: uppercase; color: #ea7940; text-align: left;}
#acmpPkg .rates-table tbody tr{border-top: 1px solid #ece8e1; transition: background 0.15s;}
#acmpPkg .rates-table tbody tr:hover{background: #faf5ee;}
#acmpPkg .rates-table td{padding: 13px 18px; font-size: 13.5px; font-weight: 600; color: #333333;}
#acmpPkg .rates-table td.price-cell{font-weight: 800; color: #16150f; font-size: 15px;}
#acmpPkg .rates-note{font-size: 12.5px; color: #8a8276; font-weight: 600; line-height: 1.7; background: #faf5ee; border-left: 3px solid #fdf0e7; border-radius: 0 8px 8px 0; padding: 12px 16px; margin-top: 16px;}
#acmpPkg .cta-section{margin-top: 60px; padding: 40px 36px; background: #faf5ee; border: 1px solid #fdf0e7; border-radius: 20px; display: flex; flex-direction: column; align-items: center; gap: 10px; text-align: center;}
#acmpPkg .cta-section-title{font-size: 20px; font-weight: 800; color: #111111; margin-bottom: 2px;}
#acmpPkg .cta-section-sub{font-size: 13px; color: #555555; font-weight: 600; max-width: 420px; line-height: 1.6; margin-bottom: 6px;}
#acmpPkg .cta-buttons{display: flex; gap: 14px; flex-wrap: wrap; justify-content: center;}
#acmpPkg .btn-book-now{background: #ea7940; border: none; color: #ffffff; padding: 14px 40px; border-radius: 100px;
  font-size: 14px; font-weight: 800; text-transform: uppercase; letter-spacing: 1px;
  cursor: pointer; font-family: 'Plus Jakarta Sans', sans-serif;
  box-shadow: 0 4px 20px rgba(224,100,28,0.35); transition: transform 0.2s, box-shadow 0.2s;}
#acmpPkg .btn-book-now:hover{transform: translateY(-2px); box-shadow: 0 6px 28px rgba(224,100,28,0.5);}
#acmpPkg .btn-get-help{background: #ffffff; border: 2px solid #ea7940; color: #ea7940; padding: 14px 40px;
  border-radius: 100px; font-size: 14px; font-weight: 800; text-transform: uppercase;
  letter-spacing: 1px; cursor: pointer; font-family: 'Plus Jakarta Sans', sans-serif; transition: background 0.2s, color 0.2s;}
#acmpPkg .btn-get-help:hover{background: #ea7940; color: #ffffff;}
#acmpPkg .route-map-wrap{margin-bottom: 52px;
  border: 1px solid #fdf0e7;
  border-radius: 18px;
  overflow: hidden;
  background: #ffffff;
  box-shadow: 0 4px 24px rgba(234,121,64,0.08);}
#acmpPkg .route-map-inner{display: flex;
  align-items: stretch;
  min-height: 360px;}
#acmpPkg .route-map-svg-col{flex: 1;
  position: relative;
  background: #fdf0e7;
  min-width: 0;}
#acmpPkg .route-map-svg-col svg{display: block;
  width: 100%;
  height: 100%;}
#acmpPkg .route-map-sidebar{width: 230px;
  flex-shrink: 0;
  background: #ffffff;
  border-left: 1px solid #ece8e1;
  display: flex;
  flex-direction: column;
  overflow: hidden;}
#acmpPkg .rms-header{padding: 18px 20px 14px;
  border-bottom: 1px solid #ece8e1;}
#acmpPkg .rms-title{font-size: 11px;
  font-weight: 800;
  letter-spacing: 2px;
  text-transform: uppercase;
  color: #ea7940;
  margin-bottom: 2px;}
#acmpPkg .rms-sub{font-size: 11px;
  font-weight: 600;
  color: #94A3B8;}
#acmpPkg .rms-stops{flex: 1;
  overflow-y: auto;
  padding: 10px 0;
  scrollbar-width: thin;
  scrollbar-color: #fdf0e7 transparent;}
#acmpPkg .rms-stop{display: flex;
  align-items: flex-start;
  gap: 12px;
  padding: 10px 18px;
  cursor: pointer;
  transition: background 0.15s;
  border-radius: 0;
  position: relative;}
#acmpPkg .rms-stop:hover{background: #fdf0e7;}
#acmpPkg .rms-stop.active{background: #faf5ee;}
#acmpPkg .rms-stop-left{display: flex;
  flex-direction: column;
  align-items: center;
  gap: 0;
  flex-shrink: 0;
  padding-top: 2px;}
#acmpPkg .rms-dot{width: 12px; height: 12px;
  border-radius: 50%;
  background: #ffffff;
  border: 2.5px solid #ea7940;
  flex-shrink: 0;
  transition: background 0.2s, border-color 0.2s;
  position: relative;
  z-index: 1;}
#acmpPkg .rms-stop:first-child .rms-dot, #acmpPkg .rms-stop:last-child .rms-dot{background: #ea7940;
  border-color: #1f1c16;}
#acmpPkg .rms-stop.active .rms-dot{background: #ea7940;
  border-color: #ea7940;
  box-shadow: 0 0 0 4px rgba(224,100,28,0.18);}
#acmpPkg .rms-line-seg{width: 2px;
  flex: 1;
  min-height: 18px;
  background: #BFDBFE;
  margin: 2px 0;}
#acmpPkg .rms-stop:last-child .rms-line-seg{display: none;}
#acmpPkg .rms-stop-body{flex: 1; min-width: 0;}
#acmpPkg .rms-day{font-size: 10px; font-weight: 800; letter-spacing: 1.5px;
  text-transform: uppercase; color: #ea7940; margin-bottom: 1px;}
#acmpPkg .rms-name{font-size: 13px; font-weight: 700; color: #111111; line-height: 1.2;}
#acmpPkg .rms-detail{font-size: 11px; color: #8a8276; font-weight: 600; margin-top: 2px; line-height: 1.4;}
#acmpPkg .rms-footer{padding: 14px 18px;
  border-top: 1px solid #ece8e1;
  display: flex;
  justify-content: center;}
#acmpPkg .rms-animate-btn{font-family: 'Plus Jakarta Sans', sans-serif;
  font-size: 11px; font-weight: 800; letter-spacing: 0.8px;
  text-transform: uppercase; cursor: pointer;
  background: #1f1c16; color: #ffffff;
  border: none; border-radius: 100px;
  padding: 9px 20px;
  transition: background 0.2s, transform 0.15s;
  display: flex; align-items: center; gap: 7px;}
#acmpPkg .rms-animate-btn:hover{background: #ea7940; transform: scale(1.03);}
#acmpPkg .rms-animate-btn svg{flex-shrink: 0;}
#acmpPkg .map-tooltip{position: absolute;
  background: #1f1c16;
  color: #ffffff;
  padding: 8px 12px;
  border-radius: 10px;
  font-size: 12px;
  font-weight: 700;
  pointer-events: none;
  opacity: 0;
  transition: opacity 0.2s;
  white-space: nowrap;
  z-index: 10;
  box-shadow: 0 4px 16px rgba(0,0,0,0.25);
  transform: translate(-50%, -120%);}
#acmpPkg .map-tooltip::after{content: '';
  position: absolute;
  bottom: -5px; left: 50%;
  transform: translateX(-50%);
  border: 5px solid transparent;
  border-bottom: none;
  border-top-color: #1f1c16;}
#acmpPkg .map-tooltip.visible{opacity: 1;}
@media (max-width: 767px){
#acmpPkg .route-map-inner{flex-direction: column;}
#acmpPkg .route-map-sidebar{width: 100%; border-left: none; border-top: 1px solid #ece8e1; min-height: 0;}
#acmpPkg .rms-stops{display: flex; flex-direction: row; overflow-x: auto; overflow-y: hidden; padding: 8px 12px; gap: 0;}
#acmpPkg .rms-stop{flex-direction: column; align-items: center; text-align: center; padding: 8px 10px; min-width: 90px; gap: 6px;}
#acmpPkg .rms-stop-left{flex-direction: row; padding-top: 0;}
#acmpPkg .rms-line-seg{display: none;}
#acmpPkg .rms-stop-body{min-width: 0;}
}
#acmpPkg .reveal{opacity: 0; transform: translateY(24px); transition: opacity 0.55s ease, transform 0.55s ease;}
#acmpPkg .reveal.on{opacity: 1; transform: translateY(0);}
@media (max-width: 767px){
#acmpPkg #detail{padding: 0 20px 60px;}
#acmpPkg #heroContent{padding: 20px 20px 32px;}
#acmpPkg #stickyBar{padding: 10px 16px;}
#acmpPkg .hotel-strip-img{width: 100px;}
#acmpPkg .strip-name{font-size: 14px;}
#acmpPkg .cta-section{padding: 28px 20px;}
#acmpPkg .cta-section-title{font-size: 18px;}
#acmpPkg .day-header{padding: 14px 16px; gap: 12px;}
#acmpPkg .day-body{padding: 18px 16px;}
#acmpPkg .rates-table th, #acmpPkg .rates-table td{padding: 10px 12px; font-size: 12px;}
}

/* hero video (optional) sits behind the fades */
#acmpPkg .hero-video{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;z-index:1;border:0;pointer-events:none}
#acmpPkg #heroFade,#acmpPkg #heroTopFade,#acmpPkg #heroOverlay{z-index:3}
#acmpPkg #heroContent{z-index:4}

/* built-in lightbox */
#acmpPkg .acmp-lb{position:fixed;inset:0;z-index:100000;display:none;align-items:center;justify-content:center;background:rgba(22,21,15,.92)}
#acmpPkg .acmp-lb.open{display:flex}
#acmpPkg .acmp-lb-img{max-width:92vw;max-height:86vh;border-radius:8px;box-shadow:0 10px 40px rgba(0,0,0,.5)}
#acmpPkg .acmp-lb-close,#acmpPkg .acmp-lb-prev,#acmpPkg .acmp-lb-next{position:absolute;background:rgba(255,255,255,.14);color:#fff;border:0;width:48px;height:48px;border-radius:50%;font-size:24px;cursor:pointer;display:flex;align-items:center;justify-content:center}
#acmpPkg .acmp-lb-close{top:18px;right:18px;font-size:30px}
#acmpPkg .acmp-lb-prev{left:14px;top:50%;transform:translateY(-50%)}
#acmpPkg .acmp-lb-next{right:14px;top:50%;transform:translateY(-50%)}
#acmpPkg .acmp-lb-close:hover,#acmpPkg .acmp-lb-prev:hover,#acmpPkg .acmp-lb-next:hover{background:rgba(234,121,64,.85)}
@media(max-width:600px){#acmpPkg .acmp-lb-prev,#acmpPkg .acmp-lb-next{width:40px;height:40px}}

/* route-map national parks (shaded, labelled) */
#acmpPkg .acmp-park{fill:#2e7d32;fill-opacity:.16;stroke:#1f5c2e;stroke-width:.8;stroke-opacity:.55;stroke-linejoin:round}
#acmpPkg .acmp-park-lbl{font-family:'Plus Jakarta Sans',sans-serif;font-size:7.5px;font-weight:700;fill:#1f5c2e;opacity:.92;pointer-events:none}

/* Leaflet route map (real tiles) */
#acmpPkg .acmp-leaflet{height:460px;width:100%;border-radius:14px;overflow:hidden;z-index:1;background:#e9eef2}
#acmpPkg .leaflet-container{font-family:'Plus Jakarta Sans',sans-serif}
#acmpPkg .acmp-pin{background:none;border:0}
#acmpPkg .acmp-pin span{display:flex;align-items:center;justify-content:center;width:26px;height:26px;border-radius:50%;background:#ea7940;color:#fff;font-weight:800;font-size:13px;border:2px solid #fff;box-shadow:0 2px 6px rgba(0,0,0,.3)}
#acmpPkg .leaflet-popup-content{margin:10px 12px;font-size:13px;line-height:1.45;color:#1f1c16}
#acmpPkg .leaflet-popup-content strong{color:#16150f}
@media (max-width:760px){#acmpPkg .acmp-leaflet{height:340px}}

/* Stop the theme's global img/svg rules from breaking Leaflet tiles and attribution */
#acmpPkg .leaflet-container img,#acmpPkg .leaflet-pane img{max-width:none !important;max-height:none !important;width:auto;padding:0;margin:0;border-radius:0;box-shadow:none}
#acmpPkg .leaflet-container svg{max-width:none !important}
#acmpPkg .leaflet-control-attribution{font-size:10px;line-height:1.4;background:rgba(255,255,255,.82)}
#acmpPkg .leaflet-control-attribution svg,#acmpPkg .leaflet-control-attribution img{width:auto !important;height:10px !important;max-height:10px !important;display:inline-block !important;vertical-align:baseline;box-shadow:none}

/* Route line draws itself, pure CSS, no JS trigger needed. --acmp-len is set by JS
   for an exact-length draw; the fallback keeps it animating even if JS never runs. */
@keyframes acmpRouteDraw {
  0%   { stroke-dashoffset: var(--acmp-len, 1600); }
  60%  { stroke-dashoffset: 0; }
  100% { stroke-dashoffset: 0; }
}
#acmpPkg path.acmp-route,
#acmpPkg .leaflet-overlay-pane svg path {
  stroke-dasharray: var(--acmp-len, 1600);
  animation: acmpRouteDraw 4.5s ease-in-out infinite;
}

/* ===== interactive route map: pan + zoom (self-contained, no Leaflet) ===== */
/* The map now shows the full route by default (preserveAspectRatio "meet").
   These rules give it a usable height, a grab cursor, and on-map controls. */
#acmpPkg .route-map-inner{min-height:440px;}
#acmpPkg .route-map-svg-col{min-height:440px;}
#acmpPkg .acmp-osm-svg{cursor:grab;touch-action:none;-webkit-user-select:none;user-select:none;}
#acmpPkg .acmp-osm-svg.is-grabbing{cursor:grabbing;}

#acmpPkg .acmp-map-ctrl{position:absolute;top:12px;right:12px;z-index:6;display:flex;flex-direction:column;gap:6px;}
#acmpPkg .acmp-zbtn{width:34px;height:34px;padding:0;border:1px solid #f0e2d6;border-radius:9px;background:rgba(255,255,255,.95);color:#b8551f;font-family:'Plus Jakarta Sans',sans-serif;font-size:20px;font-weight:700;line-height:1;display:flex;align-items:center;justify-content:center;cursor:pointer;box-shadow:0 2px 8px rgba(60,40,20,.16);transition:background .15s,color .15s,transform .15s;}
#acmpPkg .acmp-zbtn:hover{background:#ea7940;color:#fff;transform:translateY(-1px);}
#acmpPkg .acmp-zbtn:active{transform:translateY(0);}
#acmpPkg .acmp-zoom-reset svg{display:block;}

#acmpPkg .acmp-map-attr{position:absolute;left:10px;bottom:10px;z-index:6;font-family:'Plus Jakarta Sans',sans-serif;font-size:10px;color:#5c5749;background:rgba(255,255,255,.82);padding:2px 7px;border-radius:6px;pointer-events:none;}

#acmpPkg .acmp-map-hint{position:absolute;left:50%;bottom:12px;transform:translateX(-50%);z-index:6;white-space:nowrap;font-family:'Plus Jakarta Sans',sans-serif;font-size:11px;font-weight:600;color:#fff;background:rgba(31,28,22,.74);padding:5px 12px;border-radius:20px;pointer-events:none;opacity:0;animation:acmpMapHint 5.5s ease forwards;}
@keyframes acmpMapHint{0%{opacity:0;}12%{opacity:1;}80%{opacity:1;}100%{opacity:0;}}
#acmpPkg .route-map-svg-col.acmp-touched .acmp-map-hint{display:none;}

@media (max-width:767px){
  #acmpPkg .route-map-inner{min-height:0;}
  #acmpPkg .route-map-svg-col{min-height:300px;}
  #acmpPkg .acmp-zbtn{width:38px;height:38px;}
}
