/* ==========================================================================
   Voyage East — Interior page layouts
   ========================================================================== */

/* Generic two-column feature list (journeys "what is", private planning) */
.feature-grid { display: grid; grid-template-columns: repeat(2, 1fr); gap: clamp(28px,3.5vw,52px) clamp(36px,5vw,72px); }
.feature-grid.cols-3 { grid-template-columns: repeat(3, 1fr); }
.feature-grid.cols-4 { grid-template-columns: repeat(4, 1fr); }
.feature-item { padding-top: 26px; border-top: 1px solid var(--rule); }
.feature-item .index-num { font-size: 26px; display: block; margin-bottom: 16px; }
.feature-item-title { font-family: var(--font-serif); font-weight: 400; font-size: clamp(21px,2.2vw,26px); color: var(--fg1); margin-bottom: 12px; line-height: 1.18; }
.feature-item-desc { font-size: var(--fs-small); line-height: 1.62; color: var(--fg2); text-wrap: pretty; }

/* Two-column editorial split (intro text + list) */
.split-2 { display: grid; grid-template-columns: 1fr 1fr; gap: clamp(36px,5vw,80px); align-items: start; }
.split-2--narrow-left { grid-template-columns: 0.85fr 1.15fr; }
.split-2--balanced { grid-template-columns: 1.08fr 0.92fr; align-items: start; }
.lead-text { font-family: var(--font-serif); font-weight: 300; font-size: clamp(22px,2.6vw,32px); line-height: 1.32; color: var(--fg1); text-wrap: pretty; }
.lead-text em { font-style: italic; color: var(--signature-deep); }
.body-text { font-size: var(--fs-body-lg); line-height: var(--lh-loose); color: var(--fg2); text-wrap: pretty; }
.body-text + .body-text { margin-top: 18px; }

/* Tick list (who it is for / what we can help with) */
.tick-list { list-style: none; display: flex; flex-direction: column; }
.tick-list li {
  font-size: var(--fs-body); line-height: 1.5; color: var(--fg2);
  padding: 16px 0 16px 34px; border-top: 1px solid var(--rule); position: relative;
}
.tick-list li::before {
  content: ''; position: absolute; left: 0; top: 22px;
  width: 9px; height: 9px; border-radius: 50%; background: var(--ve-celadon);
}
.tick-list li:last-child { border-bottom: 1px solid var(--rule); }

/* Inline tag list (categories / what we look for) */
.tag-flow { display: flex; flex-wrap: wrap; gap: 12px; }
.tag-flow .tag {
  font-family: var(--font-serif); font-style: italic; font-size: clamp(18px,2vw,24px);
  color: var(--fg1); display: inline-flex; align-items: center; gap: 12px;
}
.tag-flow .tag::after { content: '·'; color: var(--ve-flax); margin-left: 12px; }
.tag-flow .tag:last-child::after { display: none; }

/* Where we work (core vs partner) */
.regions-grid { display: grid; grid-template-columns: 1fr 1fr; gap: clamp(24px,3vw,40px); }
.region-panel { padding: clamp(28px,3vw,42px); border: 1px solid var(--rule); }
.region-panel--core { background: var(--ve-celadon-wash); border-color: var(--ve-celadon); }
.region-panel-label { font-size: 11px; text-transform: uppercase; letter-spacing: var(--tracking-eyebrow); color: var(--signature-deep); margin-bottom: 18px; display: flex; align-items: center; gap: 10px; }
.region-panel-label .pin { width: 8px; height: 8px; border-radius: 50%; background: var(--ve-celadon); }
.region-panel--partner .region-panel-label .pin { background: var(--ve-flax); }
.region-panel-title { font-family: var(--font-serif); font-weight: 400; font-size: clamp(20px,2.2vw,26px); color: var(--ve-teal-deep); margin-bottom: 16px; }
.region-cities { display: flex; flex-wrap: wrap; gap: 10px; }
.region-city {
  font-size: 13px; color: var(--fg1); background: var(--bg-elevated);
  border: 1px solid var(--rule); padding: 8px 14px; border-radius: var(--radius-pill);
}
.region-panel--core .region-city { background: rgba(255,255,255,0.5); border-color: rgba(95,130,117,0.3); }

/* Experiences: city section header */
.city-section + .city-section { margin-top: clamp(56px,7vw,104px); }
.city-section-head { display: flex; align-items: baseline; gap: 18px; margin-bottom: clamp(32px,4vw,52px); padding-bottom: 20px; border-bottom: 1px solid var(--rule); }
.city-section-cn { font-family: var(--font-serif-cn); font-weight: 300; font-size: clamp(28px,3vw,40px); color: var(--signature); }
.city-section-name { font-family: var(--font-serif); font-weight: 300; font-size: clamp(28px,3.4vw,46px); color: var(--fg1); letter-spacing: -0.02em; }
.city-section-count { margin-left: auto; font-size: 12px; text-transform: uppercase; letter-spacing: var(--tracking-eyebrow); color: var(--fg3); }
.exp-grid--merch { align-items: stretch; }
.exp-grid--merch .exp-card--hero {
  grid-column: span 2;
  background: var(--bg-elevated);
  border: 1px solid var(--rule);
  padding: clamp(18px, 2vw, 26px);
}
.exp-grid--merch .exp-card--hero .exp-card-image { aspect-ratio: 16 / 9; }
.exp-grid--merch .exp-card--hero .exp-card-title { font-size: clamp(27px, 3vw, 38px); }
.exp-grid--merch .exp-card--hero .exp-card-desc { font-size: var(--fs-body); line-height: 1.66; }
.media-hero-copy--wide { max-width: 980px; }
.media-hero--experiences .media-hero-scrim {
  background:
    linear-gradient(180deg, rgba(18,28,26,0.52) 0%, rgba(18,28,26,0.14) 34%, rgba(18,28,26,0.34) 70%, rgba(18,28,26,0.78) 100%),
    linear-gradient(88deg, rgba(18,28,26,0.68) 0%, rgba(18,28,26,0.34) 48%, rgba(18,28,26,0.08) 78%);
}
.media-hero--private .media-hero-scrim {
  background:
    linear-gradient(180deg, rgba(18,28,26,0.5) 0%, rgba(18,28,26,0.08) 34%, rgba(18,28,26,0.28) 68%, rgba(18,28,26,0.72) 100%),
    linear-gradient(86deg, rgba(18,28,26,0.72) 0%, rgba(18,28,26,0.28) 46%, rgba(18,28,26,0.08) 76%);
}
.chip-row--over-image .chip--outline {
  color: rgba(244,239,230,0.88);
  border-color: rgba(244,239,230,0.42);
  background: rgba(18,28,26,0.18);
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
}
.chip-row--over-image .chip--outline:hover,
.chip-row--over-image .chip--outline.is-on {
  color: var(--ve-teal-deep);
  background: var(--ve-celadon);
  border-color: var(--ve-celadon);
}
.exp-card-fit {
  margin-top: 16px;
  padding-top: 14px;
  border-top: 1px solid var(--rule);
  font-size: 12.5px;
  line-height: 1.55;
  color: var(--fg3);
  text-wrap: pretty;
}
.exp-card-fit b { color: var(--signature-deep); font-weight: 500; }
.by-request-line {
  margin-top: 24px; padding-top: 18px; border-top: 1px solid var(--rule);
  font-family: var(--font-serif); font-style: italic; font-size: clamp(18px, 2vw, 24px);
  line-height: 1.45; color: var(--fg2);
}
.chapter-badge {
  position: absolute;
  right: 14px;
  top: 14px;
  z-index: 2;
  background: var(--ve-cinnabar);
  color: var(--ve-paper);
  border-color: transparent;
}

/* Chapter product page */
.chapter-highlight-list {
  list-style: none;
  display: grid;
  grid-template-columns: 1fr;
  border-top: 1px solid rgba(95,130,117,0.35);
}
.chapter-highlight-list li {
  position: relative;
  padding: 20px 0 20px 34px;
  border-bottom: 1px solid rgba(95,130,117,0.35);
  font-size: clamp(18px, 2vw, 24px);
  line-height: 1.42;
  color: var(--fg1);
  font-family: var(--font-serif);
}
.chapter-highlight-list li::before {
  content: '';
  position: absolute;
  left: 0;
  top: 30px;
  width: 9px;
  height: 9px;
  border-radius: 50%;
  background: var(--signature);
}
.program-list {
  border-top: 1px solid var(--rule);
}
.program-day {
  display: grid;
  grid-template-columns: minmax(112px, 0.24fr) 1fr;
  gap: clamp(24px, 4vw, 64px);
  padding: clamp(26px, 3.8vw, 48px) 0;
  border-bottom: 1px solid var(--rule);
}
.program-day-num {
  font-family: var(--font-serif);
  font-style: italic;
  font-size: clamp(20px, 2vw, 26px);
  color: var(--signature-deep);
}
.program-day h3 {
  font-family: var(--font-serif);
  font-weight: 300;
  font-size: clamp(26px, 3vw, 42px);
  line-height: 1.1;
  color: var(--fg1);
  margin-bottom: 10px;
}
.program-day p {
  font-size: var(--fs-body-lg);
  line-height: 1.65;
  color: var(--fg2);
}
.chapter-info-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: clamp(24px, 3vw, 40px);
}
.chapter-info-card,
.host-card,
.chapter-faq-item {
  background: var(--bg-elevated);
  border: 1px solid var(--rule);
  padding: clamp(26px, 3vw, 40px);
}
.chapter-info-card .eyebrow { margin-bottom: 18px; }
.chapter-info-card h3,
.host-card h3,
.chapter-faq-item h3 {
  font-family: var(--font-serif);
  font-weight: 400;
  font-size: clamp(22px, 2.4vw, 30px);
  line-height: 1.15;
  color: var(--fg1);
  margin-bottom: 12px;
}
.chapter-info-card p,
.host-card p,
.chapter-faq-item p {
  font-size: var(--fs-small);
  line-height: 1.66;
  color: var(--fg2);
  text-wrap: pretty;
}
.date-row {
  display: grid;
  grid-template-columns: 1.2fr 1fr auto auto;
  gap: 14px;
  align-items: center;
  padding: 16px 0;
  border-top: 1px solid rgba(95,130,117,0.35);
  color: var(--fg2);
}
.date-row:last-of-type { border-bottom: 1px solid rgba(95,130,117,0.35); }
.date-row-title {
  font-family: var(--font-serif);
  font-size: 21px;
  color: var(--fg1);
}
.date-row-date,
.date-row-price {
  font-size: var(--fs-small);
}
.date-row-status {
  font-size: 11px;
  text-transform: uppercase;
  letter-spacing: var(--tracking-eyebrow);
  border: 1px solid rgba(95,130,117,0.35);
  padding: 7px 10px;
  border-radius: var(--radius-pill);
  white-space: nowrap;
}
.date-row-status.is-open {
  background: rgba(95,130,117,0.16);
  color: var(--signature-deep);
}
.date-row--muted {
  opacity: 0.62;
}
.waitlist-form--stack {
  margin-top: 24px;
}
.host-grid,
.chapter-faq-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: clamp(18px, 2.5vw, 30px);
}
.host-role {
  font-size: 11px !important;
  text-transform: uppercase;
  letter-spacing: var(--tracking-eyebrow);
  color: var(--signature-deep) !important;
  margin-bottom: 16px;
}
.host-card--placeholder {
  background: transparent;
}

/* What's inside (guide) */
.inside-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: clamp(24px,3vw,40px); }
.inside-item { padding: clamp(24px,2.6vw,34px); background: var(--bg-elevated); border: 1px solid var(--rule); }
.inside-item-num { font-family: var(--font-serif); font-style: italic; font-size: 20px; color: var(--signature-deep); margin-bottom: 14px; display: block; }
.inside-item-title { font-family: var(--font-serif); font-weight: 400; font-size: 22px; color: var(--fg1); margin-bottom: 10px; }
.inside-item-desc { font-size: var(--fs-small); line-height: 1.6; color: var(--fg2); text-wrap: pretty; }

/* Email capture (celadon) */
.capture { background: var(--ve-celadon-wash); border: 1px solid var(--ve-celadon); padding: clamp(34px,4vw,60px); }
.capture-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 18px 24px; margin-bottom: 24px; }
.capture .field input, .capture .field select { background: rgba(255,255,255,0.6); }

/* About: POV numbered list */
.pov-list { display: grid; grid-template-columns: 1fr 1fr; gap: clamp(20px,2.5vw,36px) clamp(36px,5vw,64px); }
.pov-item { display: flex; gap: 18px; align-items: baseline; padding-top: 22px; border-top: 1px solid var(--rule); }
.pov-num { font-family: var(--font-serif); font-style: italic; font-size: 22px; color: var(--signature-deep); flex-shrink: 0; }
.pov-text { font-size: var(--fs-body); line-height: 1.55; color: var(--fg2); }

/* Enquiry success message */
.enquiry-success { display: none; }
.enquiry-success.show { display: block; }
.enquiry-form.hide { display: none; }
.success-card {
  background: var(--ve-celadon-wash); border: 1px solid var(--ve-celadon);
  padding: clamp(40px,5vw,72px); text-align: center; max-width: 640px; margin: 0 auto;
}
.success-card .seal { width: 56px; height: 56px; margin: 0 auto 26px; writing-mode: vertical-rl; font-size: 16px; }
.success-card h2 { font-family: var(--font-serif); font-weight: 300; font-size: clamp(28px,3.2vw,40px); color: var(--ve-teal-deep); margin-bottom: 18px; }
.success-card p { font-size: var(--fs-body-lg); line-height: 1.65; color: var(--ve-ink-2); }

/* Sample journey rows (Journeys page) */
.jrow { display: grid; grid-template-columns: 1fr 1fr; gap: clamp(28px,4vw,72px); align-items: center; }
.jrow + .jrow { margin-top: clamp(56px,7vw,104px); }
.jrow:nth-child(even) .jrow-media { order: 2; }
.jrow-media { position: relative; aspect-ratio: 5/4; overflow: hidden; }
.jrow-media img { width: 100%; height: 100%; object-fit: cover; filter: saturate(0.84); transition: transform 1.1s var(--ease-out); }
.jrow:hover .jrow-media img { transform: scale(1.04); }
.jrow-media-days { position: absolute; top: 0; left: 0; background: var(--ve-teal); color: var(--ve-paper); font-family: var(--font-serif); font-style: italic; font-size: 19px; padding: 9px 18px; }
.jrow-route { font-size: 11px; text-transform: uppercase; letter-spacing: var(--tracking-eyebrow); color: var(--signature-deep); margin-bottom: 14px; display: flex; align-items: center; gap: 8px; }
.jrow-route .sep { color: var(--ve-flax); }
.jrow-title { font-family: var(--font-serif); font-weight: 300; font-size: clamp(28px,3.4vw,44px); line-height: 1.08; letter-spacing: -0.02em; color: var(--fg1); margin-bottom: 18px; }
.jrow-fee { font-family: var(--font-serif); font-style: italic; font-size: 19px; color: var(--signature-deep); margin-bottom: 24px; }
.jrow-days { list-style: none; display: flex; flex-direction: column; margin-bottom: 28px; }
.jrow-days li { display: flex; gap: 16px; padding: 14px 0; border-top: 1px solid var(--rule); font-size: var(--fs-small); line-height: 1.55; color: var(--fg2); }
.jrow-days li b { color: var(--ve-teal-deep); font-weight: 500; white-space: nowrap; min-width: 58px; }
.jrow-summary { font-size: var(--fs-body-lg); line-height: 1.7; color: var(--fg2); margin-bottom: 28px; text-wrap: pretty; }
@media (max-width: 940px) {
  .jrow { grid-template-columns: 1fr; gap: 28px; }
  .jrow:nth-child(even) .jrow-media { order: 0; }
}

@media (max-width: 940px) {
  .feature-grid, .feature-grid.cols-4 { grid-template-columns: 1fr 1fr; }
  .split-2, .split-2--narrow-left, .split-2--balanced { grid-template-columns: 1fr; gap: 36px; }
  .regions-grid { grid-template-columns: 1fr; }
  .exp-grid--merch .exp-card--hero { grid-column: 1 / -1; }
  .inside-grid { grid-template-columns: 1fr 1fr; }
  .pov-list { grid-template-columns: 1fr; }
  .capture-grid { grid-template-columns: 1fr; }
  .chapter-info-grid,
  .host-grid,
  .chapter-faq-grid { grid-template-columns: 1fr 1fr; }
  .date-row { grid-template-columns: 1fr 1fr; }
}
@media (max-width: 600px) {
  .feature-grid, .feature-grid.cols-4 { grid-template-columns: 1fr; }
  .inside-grid { grid-template-columns: 1fr; }
  .chapter-info-grid,
  .host-grid,
  .chapter-faq-grid,
  .date-row { grid-template-columns: 1fr; }
  .program-day { grid-template-columns: 1fr; gap: 12px; }
  .city-section-head { flex-wrap: wrap; }
  .city-section-count { width: 100%; margin-left: 0; }
}
