/* ── HERO CAROUSEL ── */
.hero-carousel { position: relative; width: 100%; height: 540px; overflow: hidden; background: var(--mtt-color-black); }
.hc-track { display: flex; height: 100%; transition: transform 0.7s cubic-bezier(0.77, 0, 0.18, 1); will-change: transform; }
.hc-slide { position: relative; min-width: 100%; height: 100%; overflow: hidden; }
.hc-slide img { width: 100%; height: 100%; object-fit: cover; display: block; transform: scale(1.04); transition: transform 8s ease; }
.hc-slide.active img { transform: scale(1); }
.hc-slide::after { content: ''; position: absolute; inset: 0; background: linear-gradient(to top, rgba(10, 30, 50, 0.82) 0%, rgba(10,30,50,0.3) 45%, transparent 70%), linear-gradient(to right, rgba(10, 30, 50, 0.45) 0%, transparent 55%); pointer-events: none; }
.hc-content { position: absolute; bottom: 112px; left: 0; right: 0; padding: 0 var(--mtt-container-px); max-width: var(--mtt-container-max); margin: 0 auto; z-index: 4; }
.hc-tag { display: inline-flex; align-items: center; gap: var(--mtt-space-2); font-size: var(--mtt-font-size-2xs); font-weight: var(--mtt-font-weight-bold); letter-spacing: var(--mtt-letter-spacing-label); text-transform: uppercase; color: var(--mtt-color-yellow); margin-bottom: var(--mtt-space-3); opacity: 0; transform: translateY(10px); transition: opacity 0.5s ease 0.1s, transform 0.5s ease 0.1s; }
.hc-tag::before { content: ''; display: inline-block; width: 14px; height: 3px; background: var(--mtt-color-yellow); border-radius: var(--mtt-radius-pill); }
.hc-title { font-family: var(--mtt-font-title); font-size: clamp(1.8rem, 4vw, 1.8rem); font-weight: var(--mtt-font-weight-medium); color: var(--mtt-color-white); line-height: var(--mtt-line-height-tight); margin-bottom: var(--mtt-space-3); opacity: 0; transform: translateY(14px); transition: opacity 0.55s ease 0.22s, transform 0.55s ease 0.22s; }
.hc-caption { font-size: var(--mtt-font-size-md); color: rgba(255,255,255,0.75); line-height: var(--mtt-line-height-relaxed); opacity: 0; transform: translateY(10px); transition: opacity 0.5s ease 0.34s, transform 0.5s ease 0.34s; }
.hc-slide.active .hc-tag, .hc-slide.active .hc-title, .hc-slide.active .hc-caption { opacity: 1; transform: translateY(0); }
.hc-arrow { position: absolute; top: 50%; transform: translateY(-60%); z-index: 5; width: 48px; height: 48px; background: rgba(255,255,255,0.12); backdrop-filter: blur(1px); -webkit-backdrop-filter: blur(1px); border: 1px solid rgba(255,255,255,0.2); border-radius: 50%; color: var(--mtt-color-white); font-size: 18px; display: flex; align-items: center; justify-content: center; cursor: pointer; transition: background 0.2s, transform 0.2s; }
.hc-arrow i { display: flex; }
.hc-arrow:hover { background: var(--mtt-color-accent); border-color: var(--mtt-color-accent); transform: translateY(-60%) scale(1.08); }
.hc-arrow-prev { left: var(--mtt-container-px); }
.hc-arrow-next { right: var(--mtt-container-px); }
.hc-bar { position: absolute; bottom: 0; left: 0; right: 0; height: 90px; background: rgba(255,255,255,0.01); backdrop-filter: blur(1px); -webkit-backdrop-filter: blur(1px); border-top: 1px dashed rgba(255,255,255,0.08); z-index: 5; display: flex; align-items: center; padding: 0 var(--mtt-container-px); gap: var(--mtt-gap-md); }
.hc-thumbs { display: flex; gap: var(--mtt-space-3); flex: 1; }
.hc-thumb { position: relative; width: 80px; height: 56px; border-radius: var(--mtt-radius-sm); overflow: hidden; cursor: pointer; border: 2px solid transparent; transition: border-color 0.25s, transform 0.2s; flex-shrink: 0; }
.hc-thumb img { width: 100%; height: 100%; object-fit: cover; transition: transform 0.3s ease; }
.hc-thumb:hover { transform: translateY(-2px); }
.hc-thumb:hover img { transform: scale(1.08); }
.hc-thumb.active { border-color: var(--mtt-color-yellow); }
.hc-thumb.active::after { content: ''; position: absolute; inset: 0; background: rgba(252, 224, 0, 0.15); }
.hc-bar-sep { width: 1px; height: 44px; background: rgba(255,255,255,0.1); flex-shrink: 0; }
.hc-counter { display: flex; flex-direction: row; align-items: center; gap: 6px; flex-shrink: 0; }
.hc-counter-current { font-family: var(--mtt-font-title); font-size: var(--mtt-font-size-3xl); color: var(--mtt-color-yellow); line-height: 1; }
.hc-counter-total { font-size: var(--mtt-font-size-xs); color: rgba(255,255,255,0.5); letter-spacing: 1px; }

@media (max-width: 1024px) {
  .hero-carousel { height: 480px; }
  .hc-content { padding: 0 var(--mtt-container-px-sm); bottom: 100px; }
  .hc-bar { padding: 0 var(--mtt-container-px-sm); }
  .hc-arrow-prev { left: var(--mtt-container-px-sm); }
  .hc-arrow-next { right: var(--mtt-container-px-sm); }
}
@media (max-width: 768px) {
  .hero-carousel { height: 420px; }
  .hc-arrow { width: 38px; height: 38px; font-size: 15px; }
  .hc-thumb { width: 60px; height: 44px; }
  .hc-bar { height: 72px; gap: var(--mtt-space-4); }
}
@media (max-width: 480px) {
  .hero-carousel { height: 360px; }
  .hc-title { font-size: 1.5rem; }
  .hc-caption { display: none; }
  .hc-arrow { display: none; }
  .hc-bar { gap: var(--mtt-space-3); }
  .hc-thumb { width: 52px; height: 38px; }
}

/* ── MAIN LAYOUT ── */
.tour-page-section { padding: var(--mtt-container-px) 0 var(--mtt-section-py); }
.tour-page-container { max-width: var(--mtt-container-max); margin: 0 auto; padding: 0 var(--mtt-container-px); display: grid; grid-template-columns: 1fr 350px; gap: var(--mtt-gap-xl); }
.tour-content { display: flex; flex-direction: column; gap: var(--mtt-gap-md); align-self: start; }

/* ── POSTCARD ── */
.postcard { width: 100%; position: relative; border-radius: var(--mtt-radius-md); overflow: hidden; border: 1px dashed var(--mtt-color-border); }
.postcard-border { position: absolute; inset: 0; border-radius: var(--mtt-radius-md); z-index: 0; }
.postcard-inner { position: relative; border-radius: 4px; background: var(--mtt-color-white); z-index: 1; display: flex; min-height: 340px; }
.pc-left { flex: 1; padding: 28px 24px 28px 26px; display: flex; flex-direction: column; gap: 0; position: relative; z-index: 2; }
.badge { display: inline-flex; align-items: center; gap: 5px; background: var(--mtt-color-blue-light); color: var(--mtt-color-blue); font-size: var(--mtt-font-size-xs); font-weight: var(--mtt-font-weight-semibold); letter-spacing: var(--mtt-letter-spacing-label); text-transform: uppercase; padding: 5px 13px; border-radius: var(--mtt-radius-pill); width: fit-content; margin-bottom: 14px; }
.pc-title { font-family: var(--mtt-font-title); font-size: var(--mtt-font-size-title); font-weight: var(--mtt-font-weight-medium); color: var(--mtt-color-blue); margin-bottom: var(--mtt-gap-sm); }
.pc-lines-wrap { flex: 1; display: flex; flex-direction: column; justify-content: flex-start; }
.pc-line-text { height: 100%; min-height: 100%; display: block; font-size: var(--mtt-font-size-2xl); color: var(--mtt-color-muted); line-height: 2rem; background-image: repeating-linear-gradient(to bottom, transparent, transparent calc(2rem - 1px), var(--mtt-color-border) calc(2rem - 1px), var(--mtt-color-border) 2rem); background-size: 100% 2rem; background-position: 0 0; }
.pc-divider { width: 1px; flex-shrink: 0; z-index: 2; background: repeating-linear-gradient(to bottom, var(--mtt-color-gray-light) 0px, var(--mtt-color-gray-light) 5px, transparent 5px, transparent 11px); }
.pc-right { width: 230px; flex-shrink: 0; padding: 22px 22px 26px 20px; display: flex; flex-direction: column; position: relative; z-index: 2; }
.pc-stamp { display: flex; justify-content: flex-end; margin-bottom: auto; }
.pc-stamp svg { width: 75px; height: 75px; }
.pc-info-blocks { display: flex; flex-direction: column; gap: 20px; margin-top: 20px; }
.pc-info-block { display: flex; flex-direction: column; gap: 10px; }
.pc-info-label { font-size: var(--mtt-font-size-md); color: var(--mtt-color-gray); font-weight: var(--mtt-font-weight-bold); }
.pc-info-rule { width: 100%; border: none; border-bottom: 1px solid var(--mtt-color-border); height: 20px; display: flex; align-items: flex-end; padding-bottom: 3px; }
.pc-info-value { font-size: var(--mtt-font-size-md); color: var(--mtt-color-gray); }
.pc-brand-stamp { position: absolute; top: 35%; right: 50px; transform: translateY(-50%) rotate(-15deg); width: 120px; height: 120px; opacity: 0.15; z-index: 10; pointer-events: none; }
.pc-brand-stamp svg { width: 100%; height: 100%; }

@media (max-width: 580px) {
  .postcard-inner { flex-direction: column; }
  .pc-divider { display: none; }
  .pc-line-text { font-size: var(--mtt-font-size-xl); }
  .pc-info-rule { border-bottom: none; }
  .pc-right { width: 100%; padding: 18px 22px 24px 22px; }
  .pc-stamp { display: none; }
  .pc-info-blocks { flex-direction: row; gap: 16px; margin-top: 0; }
  /*.pc-info-block { flex: 1; }*/
  .pc-left { padding: 22px 22px 20px 22px; }
}

/* ── TOUR BODY CARD ── */
.tour-body-card {
  background: var(--mtt-color-white);
  border: 1px dashed var(--mtt-color-border);
  border-radius: var(--mtt-radius-md);
  padding: var(--mtt-space-10);
  display: flex;
  flex-direction: column;
  gap: var(--mtt-gap-xl);
}
.tour-body-section { display: flex; flex-direction: column; }
.stops-grid { display: grid; grid-template-columns: 1fr 1fr; gap: var(--mtt-space-4); }
.stop-card { padding: var(--mtt-space-4) var(--mtt-space-4) var(--mtt-space-4) 0; }
.stop-card-icon { width: 44px; height: 44px; background: var(--mtt-color-blue-light); border-radius: var(--mtt-radius-sm); margin-bottom: var(--mtt-space-4); display: flex; align-items: center; justify-content: center; font-size: var(--mtt-font-size-lg); color: var(--mtt-color-blue); }
.stop-card-icon i { display: flex; }
.stop-card h3 { font-size: var(--mtt-font-size-xl); font-weight: var(--mtt-font-weight-bold); color: var(--mtt-color-blue); margin-bottom: var(--mtt-space-1); }
.stop-card p { font-size: var(--mtt-font-size-xl); line-height: var(--mtt-line-height-relaxed); color: var(--mtt-color-muted); }
.info-list { display: flex; flex-direction: column; gap: var(--mtt-space-2); }
.info-list li { font-size: var(--mtt-font-size-lg); line-height: var(--mtt-line-height-normal); color: var(--mtt-color-muted); display: flex; align-items: flex-start; gap: var(--mtt-space-3); }
.info-list li i { font-size: var(--mtt-font-size-lg); color: var(--mtt-color-accent); flex-shrink: 0; margin-top: 2px; }
.main-2col { display: grid; grid-template-columns: 1fr 1fr; gap: var(--mtt-gap-xl); align-items: start; }
.sig-group-title { font-size: var(--mtt-font-size-lg); font-weight: var(--mtt-font-weight-bold); color: var(--mtt-color-blue); margin-bottom: var(--mtt-space-3); }

/* ── SIDEBAR ── */
.sidebar-sticky-wrap { position: sticky; top: 20px; display: flex; flex-direction: column; gap: var(--mtt-gap-md); }
.sidebar-card { position: relative; background-color: var(--mtt-color-white); border: 1px dashed var(--mtt-color-border); border-radius: 0 var(--mtt-radius-md) var(--mtt-radius-md) var(--mtt-radius-md); overflow: visible; }
.sidebar-card::before { content: ""; position: absolute; top: -1px; left: -1px; border-left: 40px solid var(--mtt-color-gray-soft); border-bottom: 40px solid transparent; box-shadow: 3px 3px 3px rgba(0,0,0,0.12); z-index: 1; }
.sidebar-card-icon-wrap { display: flex; flex-direction: column; align-items: center; gap: var(--mtt-space-6); padding: var(--mtt-space-6); padding-bottom: 18px; }
.sidebar-card-icon-wrap .card-icon { display: flex; align-items: center; justify-content: center; color: var(--mtt-color-accent); font-size: 36px; }
.sidebar-card-icon-wrap .card-icon i { display: flex; }
.sidebar-card-icon-wrap .card-label { font-size: var(--mtt-font-size-xl); font-weight: var(--mtt-font-weight-bold); color: var(--mtt-color-blue); text-transform: uppercase; text-align: center; }
.sidebar-card-body { padding: var(--mtt-space-6); padding-top: 0; }
.sidebar-contact-list { display: flex; flex-direction: column; gap: var(--mtt-space-3); margin-bottom: var(--mtt-space-6); }
.sidebar-contact-list li { font-size: var(--mtt-font-size-md); color: var(--mtt-color-muted); display: flex; align-items: center; gap: var(--mtt-space-3); line-height: var(--mtt-line-height-normal); }
.sidebar-contact-list li i { display: flex; color: var(--mtt-color-blue); flex-shrink: 0; }
.sidebar-booking-btns { display: flex; flex-direction: column; gap: var(--mtt-space-3); }
.btn-book-wa, .btn-book-email { padding: 12px 28px; border-radius: var(--mtt-radius-pill); font-size: var(--mtt-font-size-sm); font-weight: var(--mtt-font-weight-bold); letter-spacing: var(--mtt-letter-spacing-btn); text-transform: uppercase; display: inline-flex; align-items: center; justify-content: center; gap: var(--mtt-space-3); transition: background var(--mtt-transition); }
.btn-book-wa i, .btn-book-email i { display: flex; font-size: var(--mtt-font-size-lg); }
.btn-book-wa { background: var(--mtt-color-whatsapp); color: var(--mtt-color-white); }
.btn-book-wa:hover { background: var(--mtt-color-whatsapp-hover); }
.btn-book-email { background: var(--mtt-color-blue); color: var(--mtt-color-blue-light); }
.btn-book-email:hover { color: var(--mtt-color-white); }
.sidebar-tips-list { display: flex; flex-direction: column; gap: var(--mtt-space-3); }
.sidebar-tips-list li { font-size: var(--mtt-font-size-md); color: var(--mtt-color-muted); display: flex; align-items: flex-start; gap: var(--mtt-space-3); line-height: var(--mtt-line-height-normal); }
.sidebar-tips-list li i { flex-shrink: 0; margin-top: 3px; font-size: var(--mtt-font-size-md); color: var(--mtt-color-accent); display: flex; }

/* ── EXTENSIONS CTA ── */
.tour-extensions-cta { position: relative; background: var(--mtt-color-white); border-radius: var(--mtt-radius-lg); border: 1px dashed var(--mtt-color-border); padding: var(--mtt-space-10); padding-left: 66px; display: flex; align-items: center; justify-content: space-between; gap: var(--mtt-gap-lg); overflow: hidden; }
.notebook-holes { position: absolute; left: 16px; top: 0; bottom: 0; display: flex; flex-direction: column; justify-content: space-evenly; align-items: center; z-index: 2; }
.notebook-hole { width: 22px; height: 22px; border-radius: 50%; background: var(--mtt-color-gray-soft); border: 1px dashed var(--mtt-color-border); flex-shrink: 0; }
@media (min-width: 1025px) { .notebook-hole:nth-child(n+8) { display: none; } }
@media (max-width: 1024px) {
  .tour-extensions-cta { padding-left: var(--mtt-space-6); padding-top: 52px; }
  .notebook-holes { left: 0; right: 0; top: 14px; bottom: auto; flex-direction: row; justify-content: space-evenly; width: 100%; height: auto; }
  .notebook-hole { display: block; }
}
@media (max-width: 768px) { .notebook-hole:nth-child(n+8) { display: none; } }
.tour-extensions-cta-text { flex: 1; display: flex; flex-direction: column; gap: var(--mtt-space-5); }
.tour-extensions-cta-text h2 { font-family: var(--mtt-font-title); font-size: var(--mtt-font-size-4xl); color: var(--mtt-color-blue); line-height: var(--mtt-line-height-tight); font-weight: var(--mtt-font-weight-medium); }
.tour-extensions-cta-text p { width: 700px; font-size: var(--mtt-font-size-xl); color: var(--mtt-color-muted); line-height: var(--mtt-line-height-loose); }
.tour-extensions-cta-action { flex-shrink: 0; }
.btn-ext-main { background: var(--mtt-color-blue); color: var(--mtt-color-white); padding: 15px 34px; border-radius: var(--mtt-radius-pill); font-size: var(--mtt-font-size-md); font-weight: var(--mtt-font-weight-bold); letter-spacing: var(--mtt-letter-spacing-btn); text-transform: uppercase; display: inline-flex; align-items: center; gap: var(--mtt-space-2); border: none; cursor: pointer; }
.btn-ext-main i {display:flex;}
.ext-taped-image { position: relative; flex-shrink: 0; width: 380px; margin-top: 28px; }
.ext-taped-image img { display: block; width: 100%; aspect-ratio: 3 / 2; object-fit: cover; border-radius: var(--mtt-radius-sm); box-shadow: 1px 1px 2px rgba(0, 0, 0, 0.3); }
.ext-tape { background-color: hsla(0,0%,100%,0.45); box-shadow: inset 0 0 1em .5em hsla(0,0%,100%,0.15); height: 2.4em; position: absolute; top: -20px; left: 0; right: 0; margin: 0 auto; width: 160px; z-index: 2; filter: drop-shadow(0 1px 0.7px hsla(0,0%,0%,.25)); }
.ext-tape::after, .ext-tape::before { background-size: .4em .4em; bottom: 0; content: ''; position: absolute; top: 0; width: .2em; }
.ext-tape::after { background-image: linear-gradient(45deg, transparent 50%, hsla(0,0%,100%,.3) 50%), linear-gradient(-45deg, transparent 50%, hsla(0,0%,100%,.3) 50%); background-position: 0 100%; left: -.2em; }
.ext-tape::before { background-image: linear-gradient(135deg, transparent 50%, hsla(0,0%,100%,.3) 50%), linear-gradient(-135deg, transparent 50%, hsla(0,0%,100%,.3) 50%); background-position: 100% 100%; right: -.2em; }
.extensions-section { padding: 0 0 var(--mtt-section-py); }
.extensions-container { max-width: var(--mtt-container-max); margin: 0 auto; padding: 0 var(--mtt-container-px); }

@media (max-width: 1300px) {
  .tour-extensions-cta { flex-direction: column; text-align: center; align-items: center; padding-left: var(--mtt-space-6); padding-top: 52px; }
  .ext-taped-image { width: 100%; max-width: 420px; }
  .tour-extensions-cta-text p { width: 100%; }
}
@media (max-width: 768px) {
  .tour-extensions-cta { padding: var(--mtt-space-6); padding-top: 66px; }
  .ext-taped-image { width: 100%; max-width: 100%; margin-top: 0; }
  .tour-extensions-cta-text p { width: 100%; }
}

/* ── RESPONSIVE (single-tour specific) ── */
@media (max-width: 1024px) {
  .tour-page-container { grid-template-columns: 1fr; }
  .tour-sidebar { align-self: auto; }
  .sidebar-sticky-wrap { position: static; }
}
@media (max-width: 768px) {
  .stops-grid { grid-template-columns: 1fr; }
  .main-2col { grid-template-columns: 1fr; }
  .tour-body-card { padding: var(--mtt-space-6); }
}

/* ── MENU ACTIVO en single tour ── */
/* WordPress pone current-menu-item en el <li>, el CSS usa .active en el <a> */
.nav-item.current-menu-item > a,
.nav-item.current-menu-parent > a,
.nav-item.current_page_parent > a { color: var(--mtt-color-accent) !important; }
.nav-item.current-menu-item > a::after,
.nav-item.current-menu-parent > a::after,
.nav-item.current_page_parent > a::after { width: 100% !important; }