/* ============================================================
   ILH — Destination Detail Pages
   ============================================================ */

/* ---------- HERO ---------- */
.dest-hero {
  position: relative; height: 100vh; min-height: 680px;
  display: flex; flex-direction: column; overflow: hidden;
}
.dest-hero-img {
  position: absolute; inset: 0; width: 100%; height: 100%;
  object-fit: cover; animation: kenburns 14s ease-in-out forwards;
}
.dest-hero-wash {
  position: absolute; inset: 0; z-index: 1;
  background:
    linear-gradient(to top, rgba(6,14,26,1) 0%, rgba(6,14,26,0.45) 40%, rgba(6,14,26,0.12) 75%),
    linear-gradient(to right, rgba(6,14,26,0.75) 0%, rgba(6,14,26,0) 62%);
}
.dest-hero-inner {
  position: relative; z-index: 2; flex: 1;
  display: flex; align-items: flex-end; padding-bottom: 80px;
}
.dest-hero-content { max-width: 680px; }
.dest-breadcrumb {
  display: inline-flex; align-items: center; gap: 10px;
  font-family: 'Montserrat', sans-serif; font-size: 9px; font-weight: 700;
  letter-spacing: 0.22em; text-transform: uppercase; color: var(--text-muted);
  margin-bottom: 30px; text-decoration: none; transition: color .3s;
}
.dest-breadcrumb::before { content: '←'; font-size: 13px; }
.dest-breadcrumb:hover { color: var(--gold); }
.dest-eyebrow-hero { margin-bottom: 16px; }
.dest-hero-title {
  font-family: 'Cormorant Garamond', serif; font-weight: 300;
  font-size: 100px; line-height: 0.88; color: var(--ivory); margin: 0 0 22px;
  letter-spacing: -0.015em;
}
.dest-hero-title em { color: var(--gold); font-style: italic; }
.dest-hero-sub {
  font-family: 'Cormorant Garamond', serif; font-weight: 300; font-style: italic;
  font-size: 22px; color: var(--text-muted); margin: 0 0 40px;
  max-width: 500px; line-height: 1.55;
}
.dest-hero-btns { display: flex; gap: 14px; flex-wrap: wrap; }
.dest-num-ghost {
  position: absolute; right: 60px; bottom: 90px; z-index: 2;
  font-family: 'Cormorant Garamond', serif; font-weight: 300;
  font-size: 220px; color: rgba(193,155,72,0.07); line-height: 0.8;
  letter-spacing: -0.03em; pointer-events: none;
}

/* ---------- STAT STRIP ---------- */
.dest-stat-strip {
  position: relative; z-index: 3;
  background: rgba(6,14,26,0.92); backdrop-filter: blur(16px);
  -webkit-backdrop-filter: blur(16px); border-top: 1px solid var(--gold-border);
}
.dss { display: flex; }
.dss-item {
  flex: 1; padding: 22px 24px; display: flex;
  flex-direction: column; align-items: center; gap: 5px; text-align: center; position: relative;
}
.dss-item + .dss-item::before {
  content: ''; position: absolute; left: 0; top: 22%; bottom: 22%;
  width: 1px; background: var(--gold-border);
}
.dss-num {
  font-family: 'Cormorant Garamond', serif; font-weight: 300;
  font-size: 30px; color: var(--gold); line-height: 1;
}
.dss-label {
  font-size: 8px; font-weight: 700; letter-spacing: 0.18em;
  text-transform: uppercase; color: var(--text-muted);
}

/* ---------- OVERVIEW ---------- */
.overview-grid {
  display: grid; grid-template-columns: 1fr 1fr; gap: 72px; align-items: start;
}
.overview-desc {
  font-size: 13px; line-height: 2.1; color: var(--text-muted);
  margin: 26px 0 32px; max-width: 520px;
}
.overview-tags { display: flex; flex-wrap: wrap; gap: 8px; }
.hl-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 12px; }
.hl-card {
  background: var(--deep-navy); border: 1px solid var(--gold-border);
  border-radius: var(--r-card); overflow: hidden;
  transition: border-color .35s, transform .35s cubic-bezier(.2,.8,.2,1);
}
.hl-card:hover { border-color: var(--gold); transform: translateY(-4px); }
.hl-card-img { height: 150px; overflow: hidden; }
.hl-card-img img { width: 100%; height: 100%; object-fit: cover; display: block; transition: transform .8s cubic-bezier(.2,.8,.2,1); }
.hl-card:hover .hl-card-img img { transform: scale(1.07); }
.hl-card-body { padding: 18px 20px 22px; }
.hl-card-title { font-size: 9.5px; font-weight: 700; letter-spacing: 0.16em; text-transform: uppercase; color: var(--ivory); margin-bottom: 7px; }
.hl-card-desc { font-family: 'Cormorant Garamond', serif; font-style: italic; font-size: 15px; color: var(--text-muted); line-height: 1.5; }

/* ---------- EXPERIENCES ---------- */
.exp-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 16px; }
.exp-card {
  position: relative; border-radius: var(--r-card); overflow: hidden;
  min-height: 480px; display: flex; align-items: flex-end;
}
.exp-card img {
  position: absolute; inset: 0; width: 100%; height: 100%;
  object-fit: cover; transition: transform 1s cubic-bezier(.2,.8,.2,1);
}
.exp-card:hover img { transform: scale(1.06); }
.exp-card-overlay {
  position: absolute; inset: 0;
  background: linear-gradient(to top, rgba(5,11,20,0.96) 0%, rgba(5,11,20,0.35) 55%, rgba(5,11,20,0) 100%);
}
.exp-card-body { position: relative; z-index: 2; padding: 36px 32px; }
.exp-num { font-family: 'Cormorant Garamond', serif; font-size: 64px; font-weight: 300; color: rgba(193,155,72,0.18); line-height: 1; margin-bottom: -10px; }
.exp-title { font-family: 'Cormorant Garamond', serif; font-weight: 400; font-size: 32px; color: var(--ivory); margin: 0 0 14px; line-height: 1.1; }
.exp-desc { font-size: 12px; line-height: 1.9; color: rgba(250,246,238,0.7); max-width: 340px; }
.exp-tag {
  display: inline-flex; margin-top: 18px;
  font-size: 8px; font-weight: 700; letter-spacing: 0.2em; text-transform: uppercase;
  color: var(--gold); border: 1px solid var(--gold-border); padding: 7px 14px; border-radius: var(--r-chip);
}

/* ---------- GALLERY ---------- */
.gallery-grid {
  display: grid; grid-template-columns: 1.5fr 1fr 1fr;
  grid-template-rows: 300px 220px; gap: 12px;
}
.gal-img { border-radius: var(--r-card); overflow: hidden; }
.gal-img img { width: 100%; height: 100%; object-fit: cover; display: block; transition: transform .8s cubic-bezier(.2,.8,.2,1); }
.gal-img:hover img { transform: scale(1.05); }
.gal-img.span-col { grid-column: 2 / 4; }
.gal-img.span-row { grid-row: 1 / 3; }

/* ---------- DEST PACKAGES ---------- */
.dest-pkg-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 20px; }

/* ---------- PRACTICAL ---------- */
.practical-strip {
  display: grid; grid-template-columns: repeat(5, 1fr);
  gap: 1px; background: var(--gold-border); border: 1px solid var(--gold-border);
  border-radius: var(--r-card); overflow: hidden;
}
.practical-item { background: var(--deep-navy); padding: 28px 24px; display: flex; flex-direction: column; gap: 7px; }
.practical-label { font-size: 8px; font-weight: 700; letter-spacing: 0.22em; text-transform: uppercase; color: var(--gold); }
.practical-value { font-family: 'Cormorant Garamond', serif; font-size: 18px; color: var(--ivory); line-height: 1.35; }
.practical-note { font-size: 10.5px; line-height: 1.5; color: var(--text-muted); }

/* ---------- CTA BANNER ---------- */
.dest-cta {
  background: var(--deep-navy); border-top: 1px solid var(--gold-border);
  border-bottom: 1px solid var(--gold-border); padding: 100px 40px; text-align: center;
}
.dest-cta h2 {
  font-family: 'Cormorant Garamond', serif; font-weight: 300;
  font-size: 60px; color: var(--ivory); margin: 0 0 18px; line-height: 1.02;
}
.dest-cta h2 em { color: var(--gold); font-style: italic; }
.dest-cta p {
  font-family: 'Cormorant Garamond', serif; font-style: italic;
  font-size: 21px; color: var(--text-muted); margin: 0 0 44px; line-height: 1.6;
}
.dest-cta-btns { display: flex; gap: 16px; justify-content: center; flex-wrap: wrap; }

/* ---------- RESPONSIVE ---------- */
@media (max-width: 1080px) {
  .dest-hero-title { font-size: 74px; }
  .overview-grid { grid-template-columns: 1fr; gap: 48px; }
  .exp-grid { grid-template-columns: 1fr; }
  .exp-card { min-height: 380px; }
  .dest-pkg-grid { grid-template-columns: 1fr 1fr; }
  .gallery-grid { grid-template-columns: 1fr 1fr; grid-template-rows: 280px 280px; }
  .gal-img.span-row { grid-row: auto; }
  .gal-img.span-col { grid-column: 1 / 3; }
  .practical-strip { grid-template-columns: repeat(3, 1fr); }
}
@media (max-width: 720px) {
  .dest-hero-title { font-size: 52px; }
  .dest-num-ghost { display: none; }
  .hl-grid { grid-template-columns: 1fr; }
  .exp-grid { grid-template-columns: 1fr; }
  .gallery-grid { grid-template-columns: 1fr; grid-template-rows: auto; }
  .gal-img { height: 240px !important; }
  .gal-img.span-col, .gal-img.span-row { grid-column: auto; grid-row: auto; }
  .dest-pkg-grid { grid-template-columns: 1fr; }
  .practical-strip { grid-template-columns: 1fr 1fr; }
  .dest-cta h2 { font-size: 40px; }
  .dss { flex-wrap: wrap; }
  .dss-item { flex: 1 1 50%; }
  .itin-grid { grid-template-columns: 1fr 1fr; }
  .itin-tabs { gap: 8px; }
}

/* ---------- ITINERARIES ---------- */
.itin-intro {
  font-family: var(--ff-sans); font-size: 13px; color: rgba(255,255,255,0.55);
  letter-spacing: 0.04em; margin-top: 12px; max-width: 560px;
}
.itin-tabs {
  display: flex; flex-wrap: wrap; gap: 10px;
  margin: 40px 0 36px;
}
.itin-tab {
  font-family: var(--ff-sans); font-size: 11px; font-weight: 600;
  letter-spacing: 0.14em; text-transform: uppercase;
  padding: 9px 18px; border-radius: 999px;
  border: 1px solid var(--gold-border); background: transparent;
  color: rgba(255,255,255,0.55); cursor: pointer;
  transition: all .25s ease;
}
.itin-tab:hover { border-color: var(--gold); color: var(--gold); }
.itin-tab.active { background: var(--gold); border-color: var(--gold); color: var(--midnight); }
.itin-grid {
  display: grid; grid-template-columns: repeat(3, 1fr); gap: 20px;
}
.itin-card {
  background: var(--card-bg); border: 1px solid var(--gold-border);
  border-radius: var(--r-card); overflow: hidden;
  display: flex; flex-direction: column;
  transition: transform .3s cubic-bezier(.2,.8,.2,1), border-color .3s;
}
.itin-card:hover { transform: translateY(-5px); border-color: var(--gold); }
.itin-top-bar { height: 3px; background: var(--gold); width: 100%; flex: none; }
.itin-head {
  display: flex; justify-content: space-between; align-items: center;
  padding: 16px 20px 0;
}
.itin-badge {
  font-family: var(--ff-sans); font-size: 8.5px; font-weight: 700;
  letter-spacing: 0.16em; text-transform: uppercase;
  padding: 4px 10px; border-radius: 999px;
}
.itin-badge.gt { background: rgba(193,155,72,0.15); color: var(--gold); }
.itin-badge.ks { background: rgba(99,162,220,0.15); color: #63a2dc; }
.itin-badge.kr { background: rgba(76,175,80,0.15); color: #6abf6e; }
.itin-badge.sm { background: rgba(176,141,255,0.15); color: #b08dff; }
.itin-badge.bd { background: rgba(255,183,77,0.15); color: #ffb74d; }
.itin-badge.ll { background: rgba(77,208,225,0.15); color: #4dd0e1; }
.itin-badge.wl { background: rgba(129,199,132,0.15); color: #81c784; }
.itin-badge.ct { background: rgba(240,98,146,0.15); color: #f06292; }
.itin-badge.mb { background: rgba(255,138,101,0.15); color: #ff8a65; }
.itin-badge.hl { background: rgba(174,213,129,0.15); color: #aed581; }
.itin-dur {
  font-family: var(--ff-sans); font-size: 10px; font-weight: 600;
  letter-spacing: 0.1em; color: rgba(255,255,255,0.4);
}
.itin-name {
  font-family: var(--ff-serif); font-size: 20px; font-weight: 400;
  color: var(--ivory); line-height: 1.25;
  padding: 12px 20px 6px;
}
.itin-route {
  font-family: var(--ff-sans); font-size: 11px; letter-spacing: 0.08em;
  color: rgba(255,255,255,0.4); padding: 0 20px 18px;
  flex: 1;
}
.itin-btn {
  display: flex; align-items: center; justify-content: space-between;
  margin: 0 20px 20px; padding: 11px 16px;
  background: transparent; border: 1px solid var(--gold-border);
  border-radius: 8px; color: var(--gold);
  font-family: var(--ff-sans); font-size: 10.5px; font-weight: 600;
  letter-spacing: 0.12em; text-transform: uppercase; text-decoration: none;
  transition: background .25s, border-color .25s;
}
.itin-btn:hover { background: var(--gold); color: var(--midnight); border-color: var(--gold); }
.itin-btn span { font-size: 14px; }
@media (max-width: 600px) {
  .itin-grid { grid-template-columns: 1fr; }
  .itin-tabs { overflow-x: auto; flex-wrap: nowrap; padding-bottom: 6px; }
  .itin-tab { white-space: nowrap; }
}
