.pkg-hero {
  background: linear-gradient(135deg, #6B0E23 0%, #3D1018 60%, #1A0A0F 100%);
  padding: 48px 0 36px;
  position: relative;
  overflow: hidden;
}
.pkg-hero::before {
  content: '';
  position: absolute;
  inset: 0;
  background-image: url('<?= !empty($pkg['cover_image']) ? e($pkg['cover_image']) : '' ?>');
  background-size: cover;
  background-position: center;
  opacity: 0.18;
}
.pkg-hero-inner { position: relative; z-index: 2; max-width: 1600px; margin: 0 auto; padding: 0 20px; }
.pkg-hero-badge { display: inline-flex; align-items: center; gap: 6px; background: rgba(201,146,42,.25); border: 1px solid rgba(201,146,42,.5); color: #E8A83A; padding: 4px 14px; border-radius: 20px; font-size: 11px; font-weight: 700; letter-spacing: 1.5px; text-transform: uppercase; margin-bottom: 14px; }
.pkg-hero-title { font-size: 38px; font-weight: 800; color: #fff; line-height: 1.2; margin-bottom: 10px; }
.pkg-hero-title em { font-style: italic; color: #E8A83A; font-weight: 700; }
.pkg-hero-sub { font-size: 16px; color: rgba(255,255,255,.65); margin-bottom: 16px; max-width: 680px; }
.pkg-hero-breadcrumb { display: flex; align-items: center; gap: 7px; font-size: 12.5px; color: rgba(255,255,255,.5); margin-top: 10px; }
.pkg-hero-breadcrumb a { color: rgba(255,255,255,.5); text-decoration: none; }
.pkg-hero-breadcrumb a:hover { color: #E8A83A; }
.pkg-hero-breadcrumb i { font-size: 9px; }
nav { position: relative !important; top: auto !important; }
.pkg-tabs-wrap { background: #3D0A14; position: sticky; top: 0; z-index: 90; box-shadow: 0 2px 12px rgba(0,0,0,.35); }
.pkg-tabs-inner { max-width: 1600px; margin: 0 auto; padding: 0 20px; display: flex; align-items: stretch; justify-content: space-between; gap: 0; overflow: hidden; }
.pkg-tabs-list { display: flex; gap: 0; overflow-x: auto; overflow-y: hidden; scrollbar-width: none; -webkit-overflow-scrolling: touch; flex: 1; }
.pkg-tabs-list::-webkit-scrollbar { display: none; }
.pkg-tab-btn { display: flex; align-items: center; justify-content: center; gap: 8px; padding: 0 24px; height: 52px; font-size: 13.5px; font-weight: 600; color: rgba(255,255,255,.6); cursor: pointer; border: none; background: none; font-family: 'Outfit', sans-serif; white-space: nowrap; transition: all .2s; border-bottom: 3px solid transparent; letter-spacing: .2px; border-right: 1px solid rgba(255,255,255,.1); border-left: 1px solid rgba(255,255,255,.1); margin-left: -1px; }
.pkg-tab-btn:first-child { border-left: none; }
.pkg-tab-btn i { font-size: 13px; }
.pkg-tab-btn.active, .pkg-tab-btn:hover { color: #fff; background: rgba(255,255,255,.07); border-bottom-color: #C9922A; }
.pkg-tabs-actions { display: flex; align-items: center; gap: 0; flex-shrink: 0; }
.tab-action-btn { display: flex; align-items: center; gap: 8px; padding: 0 26px; height: 52px; font-size: 13.5px; font-weight: 700; font-family: 'Outfit', sans-serif; cursor: pointer; border: none; text-decoration: none; transition: all .2s; white-space: nowrap; letter-spacing: .2px; }
.tab-action-rates { background: #C9922A; color: #fff; }
.tab-action-rates:hover { background: #B8821E; }
.tab-action-book { background: #fff; color: #3D0A14; }
.tab-action-book:hover { background: #f0f0f0; }
.pkg-layout { max-width: 1600px; margin: 0 auto; padding: 24px 20px 60px; display: grid; grid-template-columns: 1fr 360px; gap: 28px; align-items: start; }
.pkg-main { min-width: 0; }
.pkg-sidebar { position: static; }
.page-section { scroll-margin-top: 60px; }
.content-section { margin-bottom: 36px; }
.section-hd { display: flex; align-items: center; gap: 12px; font-size: 20px; font-weight: 700; color: #1a1a2e; margin-bottom: 18px; padding-bottom: 14px; border-bottom: 2px solid #f0f0f0; }
.section-hd i { color: #C9922A; font-size: 18px; }
.section-hd-icon { width: 34px; height: 34px; border-radius: 8px; background: linear-gradient(135deg, #6B0E23, #8B0E28); display: flex; align-items: center; justify-content: center; flex-shrink: 0; }
.section-hd-icon i { color: #fff; font-size: 14px; }
.gallery-carousel { margin-bottom: 32px; }
.gallery-main-wrap { position: relative; border-radius: 14px 14px 0 0; overflow: hidden; aspect-ratio: 16/7; background: #111; cursor: pointer; }
.gallery-main-img { width: 100%; height: 100%; object-fit: cover; display: block; transition: opacity .35s; }
.gallery-nav-btn { position: absolute; top: 50%; transform: translateY(-50%); width: 42px; height: 42px; border-radius: 50%; background: rgba(0,0,0,.52); border: none; cursor: pointer; display: flex; align-items: center; justify-content: center; font-size: 17px; color: #fff; z-index: 5; transition: all .2s; }
.gallery-nav-btn:hover { background: rgba(0,0,0,.82); }
.gallery-nav-prev { left: 14px; }
.gallery-nav-next { right: 14px; }
.gallery-count { position: absolute; bottom: 12px; right: 14px; background: rgba(0,0,0,.55); color: #fff; font-size: 12px; font-weight: 600; padding: 4px 10px; border-radius: 12px; }
.gallery-thumbs { display: flex; flex-direction: row; flex-wrap: nowrap; gap: 0; border-radius: 0 0 14px 14px; overflow-x: auto; overflow-y: hidden; scrollbar-width: none; -ms-overflow-style: none; border-top: 2px solid #fff; }
.gallery-thumbs::-webkit-scrollbar { display: none; }
.gallery-thumb { flex: 0 0 calc(100% / 5); min-width: 90px; height: 70px; overflow: hidden; cursor: pointer; border-top: 3px solid transparent; transition: border-color .2s; position: relative; background: #111; }
.gallery-thumb.active { border-top-color: #C9922A; }
.gallery-thumb img { width: 100%; height: 100%; object-fit: cover; display: block; transition: transform .25s; }
.gallery-thumb:hover img { transform: scale(1.07); }
.gallery-thumb + .gallery-thumb { border-left: 2px solid #fff; }
.pkg-overview-card { background: #fff; border: 1px solid #e8ecf0; border-radius: 14px; padding: 22px 24px; margin-bottom: 20px; box-shadow: 0 2px 8px rgba(0,0,0,.04); }
.pkg-overview-title { font-size: 24px; font-weight: 800; color: #1a1a2e; margin-bottom: 14px; line-height: 1.3; }
.pkg-meta-chips { display: flex; flex-wrap: wrap; gap: 8px; margin-bottom: 0; }
.meta-chip { display: inline-flex; align-items: center; gap: 6px; background: #f4f6f9; border: 1px solid #e8ecf0; border-radius: 20px; padding: 7px 15px; font-size: 14px; font-weight: 600; color: #374151; }
.meta-chip i { color: #6B0E23; font-size: 13px; }
.highlights-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(280px, 1fr)); gap: 10px; }
.highlight-item { display: flex; align-items: flex-start; gap: 9px; font-size: 15px; color: #374151; font-weight: 500; line-height: 1.5; }
.highlight-item i { color: #C9922A; margin-top: 3px; flex-shrink: 0; font-size: 14px; }
.ie-wrap { display: grid; grid-template-columns: 1fr 1fr; gap: 20px; }
.ie-box { border-radius: 12px; overflow: hidden; border: 1px solid #e8ecf0; }
.ie-box-hd { display: flex; align-items: center; gap: 10px; padding: 14px 18px; font-size: 15px; font-weight: 700; }
.ie-box-hd i { font-size: 17px; }
.ie-inc-hd { background: rgba(22,163,74,.1); color: #15803d; border-bottom: 1px solid rgba(22,163,74,.2); }
.ie-exc-hd { background: rgba(220,38,38,.08); color: #dc2626; border-bottom: 1px solid rgba(220,38,38,.15); }
.ie-list { list-style: none; display: flex; flex-direction: column; gap: 0; padding: 10px 0; }
.ie-list li { display: flex; align-items: flex-start; gap: 10px; font-size: 14.5px; color: #374151; line-height: 1.55; padding: 9px 18px; border-bottom: 1px solid #f5f7fa; }
.ie-list li:last-child { border-bottom: none; }
.ie-list li i { flex-shrink: 0; margin-top: 3px; font-size: 14px; }
.inc-icon { color: #16a34a; }
.exc-icon { color: #dc2626; }
.itin-list { display: flex; flex-direction: column; gap: 0; }
.itin-item { display: flex; gap: 20px; position: relative; padding-bottom: 32px; }
.itin-item:last-child { padding-bottom: 0; }
.itin-item:not(:last-child)::before { content: ''; position: absolute; left: 20px; top: 46px; bottom: 0; width: 2px; background: #e5e7eb; }
.itin-dot { width: 42px; height: 42px; border-radius: 50%; background: #6B0E23; color: #fff; display: flex; align-items: center; justify-content: center; font-size: 15px; font-weight: 700; flex-shrink: 0; position: relative; z-index: 1; box-shadow: 0 2px 8px rgba(107,14,35,.35); }
.itin-content { flex: 1; padding-top: 8px; }
.itin-day-title { font-size: 16px; font-weight: 700; color: #6B0E23; margin-bottom: 8px; line-height: 1.3; }
.itin-day-desc { font-size: 15px; line-height: 1.75; color: #4a5568; }
.special-notes-list { display: flex; flex-direction: column; gap: 12px; }
.special-note-item { display: flex; align-items: flex-start; gap: 13px; background: #fffbf5; border: 1px solid #fde8c0; border-radius: 10px; padding: 13px 16px; }
.note-num { width: 26px; height: 26px; border-radius: 50%; background: #C9922A; color: #fff; font-size: 12px; font-weight: 700; display: flex; align-items: center; justify-content: center; flex-shrink: 0; }
.note-text { font-size: 15px; color: #4a3728; line-height: 1.65; }

.booking-card { background: #fff; border-radius: 16px; overflow: hidden; box-shadow: 0 8px 32px rgba(0,0,0,.12); border: 1px solid #eee; margin-bottom: 20px; }
.booking-card-header { background: linear-gradient(135deg, #4A0D1A, #6B0E23); padding: 22px 20px 18px; text-align: center; position: relative; overflow: hidden; }
.book-badge-corner { position: absolute; top: 12px; right: -8px; background: #C9922A; color: #fff; font-size: 10px; font-weight: 800; letter-spacing: .8px; text-transform: uppercase; padding: 5px 18px 5px 12px; border-radius: 3px 0 0 3px; clip-path: polygon(0 0, 100% 0, 100% 100%, 0 100%, 8px 50%); }
.booking-starting { font-size: 10px; color: rgba(255,255,255,.6); text-transform: uppercase; letter-spacing: 1.2px; margin-bottom: 4px; }
.booking-price { font-size: 52px; font-weight: 800; color: #fff; line-height: 1; }
.booking-price sup { font-size: 22px; vertical-align: top; margin-top: 10px; font-weight: 700; }
.booking-price-label { font-size: 11px; color: rgba(255,255,255,.5); margin-top: 4px; }
.booking-card-body { padding: 18px 18px 16px; }
.form-field { margin-bottom: 14px; }
.form-field label { display: flex; align-items: center; gap: 6px; font-size: 11px; font-weight: 700; text-transform: uppercase; letter-spacing: .9px; color: #6b7280; margin-bottom: 6px; }
.form-field label i { color: #6B0E23; font-size: 12px; }
.form-field input, .form-field select { width: 100%; padding: 11px 14px; border: 1.5px solid #e5e7eb; border-radius: 9px; font-family: 'Outfit', sans-serif; font-size: 14px; color: #1a1a2e; background: #fff; outline: none; transition: border .2s; }
.form-field input:focus, .form-field select:focus { border-color: #6B0E23; box-shadow: 0 0 0 3px rgba(107,14,35,.06); }
.btn-book-now-card { display: flex; width: 100%; padding: 14px; background: #C9922A; color: #fff; border: none; border-radius: 10px; font-family: 'Outfit', sans-serif; font-size: 15px; font-weight: 700; cursor: pointer; text-align: center; text-decoration: none; transition: all .3s; margin-top: 14px; align-items: center; justify-content: center; gap: 8px; box-shadow: 0 4px 14px rgba(201,146,42,.35); }
.btn-book-now-card:hover { background: #B8821E; transform: translateY(-1px); color: #fff; }

.secure-note { text-align: center; margin-top: 14px; font-size: 12px; color: #9ca3af; display: flex; align-items: center; justify-content: center; gap: 5px; }

.addons-card {
  background: #fff; border-radius: 16px; overflow: hidden;
  box-shadow: 0 4px 18px rgba(0,0,0,.08); border: 1px solid #eee; margin-bottom: 20px;
}
.addons-card-header {
  background: linear-gradient(135deg, #1a2e1a, #1e4020);
  padding: 14px 18px; display: flex; align-items: center; gap: 10px;
}
.addons-card-header i { color: #4ade80; font-size: 16px; }
.addons-card-header h3 { font-size: 14px; font-weight: 700; color: #fff; }
.addons-card-header span { margin-left: auto; font-size: 11px; color: rgba(255,255,255,.55); }
.addon-item {
  display: flex; align-items: center; gap: 12px;
  padding: 12px 16px; border-bottom: 1px solid #f5f7fa; cursor: pointer;
  transition: background .15s;
}
.addon-item:last-child { border-bottom: none; }
.addon-item:hover { background: #fafafa; }
.addon-item-icon {
  width: 38px; height: 38px; border-radius: 9px; flex-shrink: 0;
  background: linear-gradient(135deg, #f0fdf4, #dcfce7);
  border: 1px solid #86efac;
  display: flex; align-items: center; justify-content: center;
}
.addon-item-icon i { color: #16a34a; font-size: 15px; }
.addon-item-info { flex: 1; min-width: 0; }
.addon-item-name { font-size: 13.5px; font-weight: 700; color: #1a1a2e; margin-bottom: 1px; }
.addon-item-desc { font-size: 11.5px; color: #6b7280; line-height: 1.5; }
.addon-item-price { font-size: 14px; font-weight: 800; color: #16a34a; white-space: nowrap; }
.addon-item-price span { font-size: 10px; font-weight: 500; color: #9ca3af; display: block; text-align: right; }
.addons-checkout-note {
  background: linear-gradient(135deg, #fffbeb, #fef3c7);
  border: 1px solid #fde68a;
  border-radius: 10px; margin: 14px 16px 16px; padding: 11px 14px;
  display: flex; gap: 9px; align-items: flex-start;
}
.addons-checkout-note i { color: #d97706; margin-top: 2px; flex-shrink: 0; font-size: 14px; }
.addons-checkout-note p { font-size: 12px; color: #78350f; line-height: 1.6; }
.addons-checkout-note strong { color: #92400e; }

.similar-section { background: #f8f6f2; padding: 52px 0 60px; border-top: 1px solid #e8e4dc; }
.similar-section-inner { max-width: 1600px; margin: 0 auto; padding: 0 20px; }
.similar-section-hd { display: flex; align-items: center; justify-content: space-between; margin-bottom: 28px; }
.similar-section-title { display: flex; align-items: center; gap: 12px; font-size: 26px; font-weight: 800; color: #1a1a2e; }
.similar-section-title span { width: 38px; height: 38px; border-radius: 10px; background: linear-gradient(135deg, #6B0E23, #8B0E28); display: flex; align-items: center; justify-content: center; flex-shrink: 0; }
.similar-section-title span i { color: #fff; font-size: 16px; }
.similar-section-link { font-size: 13.5px; font-weight: 700; color: #6B0E23; text-decoration: none; display: flex; align-items: center; gap: 6px; border: 1.5px solid #6B0E23; padding: 8px 18px; border-radius: 8px; transition: all .2s; }
.similar-section-link:hover { background: #6B0E23; color: #fff; }
.similar-pkg-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 20px; }
.sim-pkg-card { background: #fff; border-radius: 14px; overflow: hidden; border: 1px solid #e8ecf0; box-shadow: 0 4px 16px rgba(0,0,0,.07); text-decoration: none; display: flex; flex-direction: column; transition: transform .25s, box-shadow .25s; }
.sim-pkg-card:hover { transform: translateY(-5px); box-shadow: 0 12px 32px rgba(0,0,0,.13); }
.sim-pkg-img { position: relative; aspect-ratio: 4/3; overflow: hidden; }
.sim-pkg-img img { width: 100%; height: 100%; object-fit: cover; display: block; transition: transform .4s; }
.sim-pkg-card:hover .sim-pkg-img img { transform: scale(1.06); }
.sim-pkg-badge { position: absolute; top: 10px; left: 10px; background: #6B0E23; color: #fff; font-size: 10px; font-weight: 700; letter-spacing: .8px; text-transform: uppercase; padding: 4px 10px; border-radius: 6px; }
.sim-pkg-body { padding: 14px 16px 16px; flex: 1; display: flex; flex-direction: column; gap: 6px; }
.sim-pkg-title { font-size: 14px; font-weight: 700; color: #1a1a2e; line-height: 1.35; display: -webkit-box; -webkit-line-clamp: 2; -webkit-box-orient: vertical; overflow: hidden; }
.sim-pkg-meta { font-size: 12px; color: #6b7280; display: flex; align-items: center; gap: 10px; }
.sim-pkg-meta i { color: #C9922A; font-size: 11px; }
.sim-pkg-footer { display: flex; align-items: center; justify-content: space-between; margin-top: auto; padding-top: 10px; border-top: 1px solid #f0f0f0; }
.sim-pkg-price { font-size: 16px; font-weight: 800; color: #6B0E23; }
.sim-pkg-price span { font-size: 11px; font-weight: 500; color: #9ca3af; display: block; }
.sim-pkg-arrow { width: 30px; height: 30px; border-radius: 50%; background: rgba(107,14,35,.08); display: flex; align-items: center; justify-content: center; color: #6B0E23; font-size: 12px; transition: all .2s; }
.sim-pkg-card:hover .sim-pkg-arrow { background: #6B0E23; color: #fff; }
.share-card { background: #fff; border-radius: 16px; border: 1px solid #eee; padding: 16px 18px; box-shadow: 0 4px 16px rgba(0,0,0,.07); }
.share-title { font-size: 13px; font-weight: 700; color: #1a1a2e; margin-bottom: 12px; display: flex; align-items: center; gap: 8px; }
.share-title i { color: #6B0E23; }
.share-btns { display: flex; gap: 8px; flex-wrap: wrap; }
.share-btn { display: inline-flex; align-items: center; gap: 6px; padding: 8px 14px; border-radius: 8px; font-size: 12.5px; font-weight: 600; font-family: 'Outfit', sans-serif; cursor: pointer; border: none; text-decoration: none; transition: all .2s; flex: 1; justify-content: center; }
.share-fb { background: #1877f2; color: #fff; } .share-fb:hover { background: #1565d8; }
.share-wa { background: #25d366; color: #fff; } .share-wa:hover { background: #1db954; }
.share-ig { background: linear-gradient(135deg, #f58529, #dd2a7b, #8134af); color: #fff; } .share-ig:hover { opacity: .88; }
.share-tt { background: #010101; color: #fff; } .share-tt:hover { background: #2a2a2a; }
.share-copy { background: #f4f6f9; color: #374151; border: 1px solid #e5e7eb; width: 100%; margin-top: 6px; }
.share-copy:hover { background: #edf0f4; }
.content-box { background: #fff; border: 1px solid #e8ecf0; border-radius: 16px; padding: 28px; }
.mobile-book-bar { display: none; position: fixed; bottom: 0; left: 0; right: 0; z-index: 100; background: #fff; border-top: 1px solid #e5e7eb; padding: 10px 14px; gap: 10px; box-shadow: 0 -4px 20px rgba(0,0,0,.12); align-items: center; }
.mobile-book-bar-price { flex: 1; min-width: 0; }
.mobile-book-bar-price .mob-from { font-size: 10px; color: #9ca3af; font-weight: 600; text-transform: uppercase; letter-spacing: .8px; display: block; }
.mobile-book-bar-price .mob-amount { font-size: 22px; font-weight: 800; color: #6B0E23; line-height: 1.1; }
.mobile-book-bar-btns { display: flex; gap: 8px; flex-shrink: 0; }
.mob-btn-book { padding: 10px 18px; background: #C9922A; color: #fff; border: none; border-radius: 9px; font-family: 'Outfit', sans-serif; font-size: 13px; font-weight: 700; cursor: pointer; text-decoration: none; display: flex; align-items: center; gap: 5px; white-space: nowrap; box-shadow: 0 4px 12px rgba(201,146,42,.35); }
@media (max-width: 768px) { .mobile-book-bar { display: flex; } .pkg-layout { padding-bottom: 80px; } .pkg-tabs-wrap { position: static !important; top: auto !important; } }
@media (max-width: 1024px) { .pkg-layout { grid-template-columns: 1fr 300px; } .tab-action-btn { padding: 0 18px; font-size: 12.5px; } }
@media (max-width: 900px) { .pkg-tabs-actions { display: none; } }
@media (max-width: 960px) { .pkg-layout { grid-template-columns: 1fr; } .pkg-sidebar { position: static; } }
@media (max-width: 960px) { .similar-pkg-grid { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 560px) { .similar-pkg-grid { grid-template-columns: 1fr; } }
@media (max-width: 768px) { .pkg-hero { padding: 28px 0 20px; } .pkg-hero-inner { padding: 0 16px; } .pkg-hero-title { font-size: 24px; } .pkg-hero-sub { font-size: 14px; } .pkg-tabs-inner { padding: 0; } .pkg-tabs-actions { display: none; } .pkg-tabs-list { width: 100%; padding: 0; overflow-x: visible; } .pkg-tab-btn { flex: 1; padding: 0 8px; font-size: 12px; height: 48px; gap: 5px; flex-direction: column; justify-content: center; align-items: center; line-height: 1.2; white-space: normal; text-align: center; border-right: 1px solid rgba(255,255,255,.1); border-left: none; margin-left: 0; } .pkg-tab-btn:first-child { border-left: none; } .pkg-tab-btn i { font-size: 15px; } .pkg-layout { padding: 12px 12px 40px; gap: 20px; } .pkg-overview-card { padding: 16px 14px; } .pkg-overview-title { font-size: 18px; } .gallery-main-wrap { aspect-ratio: 16/8; border-radius: 10px 10px 0 0; } .gallery-thumb { flex: 0 0 33.333%; min-width: 70px; height: 54px; } .highlights-grid { grid-template-columns: 1fr; } .ie-wrap { grid-template-columns: 1fr; gap: 14px; } .section-hd { font-size: 17px; gap: 10px; } .itin-item { gap: 14px; } .itin-dot { width: 36px; height: 36px; font-size: 13px; } .itin-item:not(:last-child)::before { left: 17px; top: 40px; } .booking-card-header { padding: 18px 16px 14px; } .booking-price { font-size: 42px; } .similar-pkg-grid { grid-template-columns: repeat(2, 1fr); } .similar-section { padding: 36px 0 44px; } .similar-section-title { font-size: 20px; } }
@media (max-width: 480px) { .pkg-hero { padding: 20px 0 16px; } .pkg-hero-title { font-size: 20px; } .pkg-layout { padding: 10px 10px 36px; gap: 16px; } .pkg-overview-card { padding: 14px 12px; } .pkg-overview-title { font-size: 16px; } .gallery-thumb { flex: 0 0 25%; min-width: 60px; height: 46px; } .ie-list li { font-size: 13.5px; padding: 8px 12px; } .itin-item { gap: 12px; padding-bottom: 24px; } .itin-dot { width: 32px; height: 32px; font-size: 12px; } .booking-price { font-size: 38px; } .similar-pkg-grid { grid-template-columns: 1fr 1fr; gap: 12px; } .similar-section-hd { flex-direction: column; align-items: flex-start; gap: 10px; } }
@media (max-width: 360px) { .pkg-hero-title { font-size: 18px; } .similar-pkg-grid { grid-template-columns: 1fr; } }
