.htt-wrap { max-width: 1100px; margin: 0 auto; padding: 24px 16px; }
.htt-cats { margin: 10px 0 18px; }
.htt-cats a { margin-right: 10px; }

.htt-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 16px;
}

@media (max-width: 980px) {
  .htt-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); }
}
@media (max-width: 640px) {
  .htt-grid { grid-template-columns: 1fr; }
}

.htt-card {
  border: 1px solid #e5e5e5;
  border-radius: 12px;
  padding: 12px;
  background: #fff;
}

.htt-thumb img { width: 100%; height: auto; border-radius: 10px; display: block; }
.htt-title { margin: 10px 0 6px; font-size: 18px; }
.htt-from { margin: 6px 0 8px; color: #b32d2e; }
.htt-excerpt { color: #333; }

/* HTT Currency bar (top of page) */
.htt-currency-bar{
  position: sticky;
  top: 0;
  z-index: 9999;
  background: #fff;
  border-bottom: 1px solid rgba(0,0,0,.08);
}

.htt-currency-bar__inner{
  max-width: 1100px;
  margin: 0 auto;
  padding: 8px 16px;
  display: flex;
  align-items: center;
  justify-content: flex-end;
  gap: 10px;
}

.htt-currency-bar__label{
  font-size: 13px;
  opacity: .75;
}

.htt-currency-switcher select#htt_currency_select{
  height: 34px;
  padding: 0 10px;
}



/* Tour single */
.htt-tour__head{ margin-bottom: 18px; }
.htt-tour__title{ margin: 0 0 10px; }
.htt-tour__meta{ display:flex; flex-wrap:wrap; gap:8px; margin-bottom: 10px; }
.htt-badges{ display:flex; flex-wrap:wrap; gap:8px; }
.htt-badge{
  display:inline-flex; gap:6px; align-items:center;
  padding:6px 10px;
  border:1px solid #e5e5e5;
  border-radius: 999px;
  font-size: 13px;
  background:#fff;
}
.htt-badge--muted{ background:#f7f7f7; color:#444; }
.htt-badge--price{ border-color:#d6a4a4; }
.htt-tour__terms{ display:flex; flex-wrap:wrap; gap:8px; }
.htt-term{
  display:inline-block; padding:4px 10px;
  border-radius:999px;
  background:#f3f3f3;
  text-decoration:none;
  font-size:13px;
}

.htt-section{ margin: 22px 0; }
.htt-section__title{ margin: 0 0 12px; font-size: 20px; }
.htt-prose{ line-height: 1.7; }
.htt-note{
  border-left:4px solid #e5e5e5;
  padding:10px 12px;
  background:#fafafa;
  margin: 0 0 14px;
}

.htt-gallery{ display:grid; grid-template-columns: repeat(3, minmax(0, 1fr)); gap:10px; }
.htt-gallery--small{ grid-template-columns: repeat(5, minmax(0, 1fr)); }
@media (max-width: 980px){
  .htt-gallery{ grid-template-columns: repeat(2, minmax(0, 1fr)); }
  .htt-gallery--small{ grid-template-columns: repeat(4, minmax(0, 1fr)); }
}
@media (max-width: 640px){
  .htt-gallery{ grid-template-columns: 1fr; }
  .htt-gallery--small{ grid-template-columns: repeat(2, minmax(0, 1fr)); }
}
.htt-gallery__item img{ width:100%; height:auto; border-radius: 12px; display:block; }

.htt-option{ border:1px solid #eaeaea; border-radius: 14px; padding: 14px; background:#fff; margin: 14px 0; }
.htt-option__title{ margin: 0 0 10px; font-size: 18px; }
.htt-option__desc{ margin-bottom: 10px; }

.htt-schedule{ border-top:1px dashed #e5e5e5; margin-top: 12px; padding-top: 12px; }
.htt-schedule__head{ display:flex; flex-direction:column; gap:6px; margin-bottom: 10px; }

.htt-table-wrap{ overflow:auto; }
.htt-table{ width:100%; border-collapse: collapse; min-width: 520px; }
.htt-table th, .htt-table td{ border-bottom:1px solid #eee; padding:10px 8px; text-align:left; vertical-align:top; }
.htt-table th{ background:#fafafa; font-weight:600; }

.htt-two-col{ display:grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 14px; }
@media (max-width: 640px){ .htt-two-col{ grid-template-columns: 1fr; } }

.htt-box{ border:1px solid #eaeaea; border-radius: 14px; padding: 14px; background:#fff; margin: 12px 0; }
.htt-box h3{ margin:0 0 10px; font-size: 16px; }
.htt-subbox{ border:1px dashed #e5e5e5; border-radius: 12px; padding: 10px 12px; margin: 10px 0; background:#fcfcfc; }

.htt-list{ margin: 0; padding-left: 18px; }
.htt-kv{ display:grid; gap:6px; }
.htt-kv--admin{ margin-top:8px; opacity: .9; }
.htt-kv--supplier{ margin: 10px 0; }

.htt-red{ color:#b32d2e; font-weight: 600; }

/* Landing page layout (single tour) */
.htt-lp{ padding-top: 18px; }

.htt-hero{
  display:grid;
  grid-template-columns: minmax(0, 1.2fr) minmax(0, .8fr);
  gap: 18px;
  margin: 0 0 18px;
  align-items: start;
}
@media (max-width: 980px){
  .htt-hero{ grid-template-columns: 1fr; }
}

.htt-hero__media{ display:grid; gap: 10px; }
.htt-hero__mediaMain img{ width:100%; height:auto; border-radius: 18px; display:block; }
.htt-hero__thumbs{ display:grid; grid-template-columns: repeat(6, minmax(0, 1fr)); gap: 8px; }
@media (max-width: 980px){ .htt-hero__thumbs{ grid-template-columns: repeat(5, minmax(0, 1fr)); } }
@media (max-width: 640px){ .htt-hero__thumbs{ grid-template-columns: repeat(4, minmax(0, 1fr)); } }
.htt-hero__thumb img{ width:100%; height:auto; border-radius: 12px; display:block; }

.htt-hero__title{ margin: 0 0 10px; font-size: 30px; line-height: 1.15; }
@media (max-width: 640px){ .htt-hero__title{ font-size: 24px; } }

.htt-hero__terms{ margin-top: 10px; }

.htt-hero__highlights{
  margin-top: 14px;
  border: 1px solid #eaeaea;
  border-radius: 16px;
  padding: 14px;
  background: #fff;
}
.htt-hero__highlightsTitle{ font-weight: 700; margin-bottom: 10px; }
.htt-hero__highlightsList{ margin: 0; padding-left: 18px; }
.htt-hero__highlightsList li{ margin: 6px 0; }

.htt-lp__grid{
  display:grid;
  grid-template-columns: minmax(0, 1fr) minmax(0, 340px);
  gap: 18px;
  align-items: start;
}
@media (max-width: 980px){
  .htt-lp__grid{ grid-template-columns: 1fr; }
}

.htt-anchor{
  position: sticky;
  top: 54px; /* below currency bar */
  z-index: 20;
  display:flex;
  flex-wrap: wrap;
  gap: 10px;
  padding: 10px;
  margin: 0 0 14px;
  border: 1px solid rgba(0,0,0,.08);
  border-radius: 14px;
  background: rgba(255,255,255,.92);
  backdrop-filter: blur(6px);
}
.htt-anchor a{
  text-decoration: none;
  font-size: 13px;
  padding: 6px 10px;
  border-radius: 999px;
  border: 1px solid rgba(0,0,0,.08);
}
.htt-anchor a:hover{ background: #f7f7f7; }

.htt-lp__aside{ position: relative; }
.htt-stickyCard{
  position: sticky;
  top: 90px;
  border: 1px solid #eaeaea;
  border-radius: 18px;
  padding: 14px;
  background: #fff;
}
@media (max-width: 980px){
  .htt-stickyCard{ position: static; }
}

.htt-stickyCard__price{ font-size: 20px; font-weight: 800; margin-bottom: 8px; }
.htt-stickyCard__note{ font-size: 13px; opacity: .8; margin-bottom: 12px; }
.htt-stickyCard__block{ margin-top: 14px; }
.htt-stickyCard__label{ font-size: 12px; font-weight: 700; text-transform: uppercase; letter-spacing: .04em; opacity: .75; margin-bottom: 8px; }
.htt-stickyCard__block--admin{ border-top: 1px dashed #e5e5e5; padding-top: 12px; }

/* Slightly larger section titles on landing */
.htt-lp .htt-section__title{ font-size: 22px; }


.htt-breakdown-field{display:inline-block;margin-right:14px;margin-bottom:10px}
.htt-breakdown-qty{width:90px;margin-left:8px}
