/*
Theme Name: Manas Tour
Author: Svyatoslav Belevich
Author URI: https://ru.manas-tour.com
Version: 1.0
*/

:root {
  --bs-primary: #68b456 !important;
  --bs-primary-rgb: 104, 180, 86 !important;
  --bs-dark: #171312;
  --bs-dark-rgb: 23, 19, 18;
  --bs-light: #F4EEE3;
  --bs-light-rgb: 244, 238, 227;
  --bs-font-sans-serif: "Inter", sans-serif;
}

.font-bebas {
  font-family: "Bebas Neue", sans-serif;
}

/* Длинные подписи в дропдаунах бронирования (главная + модалка) */
.wallpaper__booking .dropdown-item,
.booking-modal .dropdown-item {
    white-space: normal;
}

.wallpaper__booking .dropdown-menu,
.booking-modal .dropdown-menu {
    max-height: 250px;
    overflow-y: auto;
}

/* Стили для блоков отзывов TripAdvisor */
.reviews .wptripadvisor_t1_outer_div .wptripadvisor_t1_DIV_1 {
    min-height: 500px;
    max-height: 500px;
    height: 500px;
    display: flex;
    flex-direction: column;
    overflow: hidden;
}

.reviews .wptripadvisor_t1_DIV_1 .wptripadvisor_t1_DIV_2 {
    flex: 1;
    display: flex;
    flex-direction: column;
    overflow: hidden;
    min-height: 0;
    position: relative;
}

.reviews .wptripadvisor_t1_DIV_2 .wptripadvisor_t1_P_3 {
    flex: 1;
    overflow: hidden;
    position: relative;
    margin-bottom: 0;
    padding-bottom: 35px;
    display: -webkit-box;
    -webkit-line-clamp: 8;
    -webkit-box-orient: vertical;
    overflow: hidden;
    text-overflow: ellipsis;
}

.reviews .wptripadvisor_t1_P_3 .wprs_rd_more {
    position: absolute !important;
    bottom: 0 !important;
    left: 0 !important;
    display: inline-block !important;
    visibility: visible !important;
    opacity: 1 !important;
    color: var(--bs-primary);
    text-decoration: underline;
    cursor: pointer;
    font-weight: 600;
    white-space: nowrap;
    z-index: 12;
    background: transparent;
    border: none;
    padding: 0;
    margin-top: 8px;
}

.reviews .wptripadvisor_t1_P_3 .wprs_rd_more:hover {
    color: var(--bs-dark);
}

.reviews .wptripadvisor_t1_P_3 .wprs_rd_more_text {
    display: none;
}

.reviews .wptripadvisor_t1_P_3 .wprs_rd_more_text.active {
    display: inline;
}

/* ============================================
   НОВЫЙ ДИЗАЙН ФОРМЫ БРОНИРОВАНИЯ
   ============================================ */

.booking-modal {
    --bs-modal-width: 900px !important;
}

@media (max-width: 991.98px) {
    .booking-modal {
        --bs-modal-width: 100% !important;
        max-width: 100% !important;
        margin: 0 !important;
    }
}

.booking-modal .modal-content {
    background: #F4EEE3 !important;
    border: none !important;
    border-radius: 24px !important;
    overflow: hidden !important;
    box-shadow: 0 20px 60px rgba(0, 0, 0, 0.3) !important;
    padding: 0 !important;
}

.booking-modal__form {
    padding: 0 !important;
    margin: 0 !important;
    width: 100% !important;
    height: 100% !important;
    display: flex !important;
    flex-direction: column !important;
}

.booking-modal__header {
    padding: 20px 30px !important;
    background: #fff !important;
    border-bottom: 1px solid rgba(104, 180, 86, 0.1) !important;
    position: relative !important;
    z-index: 10 !important;
}

.booking-modal__close {
    background-color: transparent !important;
    border: 1px solid #68b456 !important;
    color: #68b456 !important;
    height: 26px !important;
    transition: all .3s ease !important;
}

.booking-modal__close:hover {
    color: #171312 !important;
    border-color: #171312 !important;
    transform: scale(1.05) !important;
    box-shadow: 0 2px 8px rgba(104, 180, 86, 0.2) !important;
}

.booking-modal__content-wrapper {
    display: grid !important;
    grid-template-columns: 320px 1fr !important;
    min-height: 600px !important;
    width: 100% !important;
    flex: 1 !important;
}

@media (max-width: 991.98px) {
    .booking-modal__content-wrapper {
        grid-template-columns: 1fr !important;
        min-height: auto !important;
    }
}

/* Визуальная секция (левая часть) */
.booking-modal__visual-section {
    position: relative !important;
    background: linear-gradient(135deg, #68b456 0%, #5a9c4a 100%) !important;
    padding: 60px 40px !important;
    display: flex !important;
    flex-direction: column !important;
    justify-content: center !important;
    align-items: center !important;
    text-align: center !important;
    overflow: hidden !important;
}

@media (max-width: 991.98px) {
    .booking-modal__visual-section {
        padding: 40px 20px !important;
        min-height: 300px !important;
    }
}

.booking-modal__visual-section::before {
    content: '' !important;
    position: absolute !important;
    top: -50% !important;
    right: -50% !important;
    width: 200% !important;
    height: 200% !important;
    background: radial-gradient(circle, rgba(255, 255, 255, 0.1) 0%, transparent 70%) !important;
    animation: bookingRotate 20s linear infinite !important;
}

.booking-modal__visual-bg {
    position: absolute !important;
    top: 0 !important;
    left: 0 !important;
    right: 0 !important;
    bottom: 0 !important;
    background-image: 
        radial-gradient(circle at 20% 30%, rgba(255, 255, 255, 0.15) 0%, transparent 50%),
        radial-gradient(circle at 80% 70%, rgba(255, 255, 255, 0.1) 0%, transparent 50%) !important;
    opacity: 0.6 !important;
}

.booking-modal__visual-content {
    position: relative !important;
    z-index: 2 !important;
    color: #fff !important;
}

.booking-modal__visual-icon {
    width: 80px !important;
    height: 80px !important;
    margin: 0 auto 30px !important;
    background: rgba(255, 255, 255, 0.2) !important;
    border-radius: 50% !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    backdrop-filter: blur(10px) !important;
    animation: none !important;
}

.booking-modal__visual-icon img {
    width: 80px !important;
    height: 80px !important;
    object-fit: contain !important;
    transform: none !important;
    animation: none !important;
}

.booking-modal__visual-icon svg {
    width: 40px !important;
    height: 40px !important;
    color: #fff !important;
}

.booking-modal__visual-title {
    font-size: 42px !important;
    font-weight: 700 !important;
    line-height: 1.2 !important;
    margin-bottom: 20px !important;
    text-transform: uppercase !important;
    letter-spacing: 2px !important;
    font-family: "Bebas Neue", sans-serif !important;
    color: #fff !important;
}

@media (max-width: 991.98px) {
    .booking-modal__visual-title {
        font-size: 32px !important;
    }
}

.booking-modal__visual-text {
    font-size: 16px !important;
    line-height: 1.6 !important;
    opacity: 0.95 !important;
    max-width: 240px !important;
    margin: 0 auto !important;
    color: #fff !important;
}

@media (max-width: 991.98px) {
    .booking-modal__visual-text {
        font-size: 14px !important;
        max-width: 100% !important;
    }
}

.booking-modal__visual-decoration {
    position: absolute !important;
    bottom: 30px !important;
    left: 50% !important;
    transform: translateX(-50%) !important;
    display: flex !important;
    gap: 12px !important;
    z-index: 1 !important;
}

.booking-modal__visual-decoration .decoration-circle {
    width: 8px !important;
    height: 8px !important;
    border-radius: 50% !important;
    background: rgba(255, 255, 255, 0.5) !important;
    animation: bookingPulseDot 2s ease-in-out infinite !important;
}

.booking-modal__visual-decoration .decoration-circle:nth-child(2) {
    animation-delay: 0.3s !important;
}

.booking-modal__visual-decoration .decoration-circle:nth-child(3) {
    animation-delay: 0.6s !important;
}

/* Секция формы (правая часть) */
.booking-modal__form-section {
    padding: 50px 40px !important;
    background: #fff !important;
    position: relative !important;
}

@media (max-width: 991.98px) {
    .booking-modal__form-section {
        padding: 30px 20px !important;
    }
}

.booking-modal__form-section::before {
    display: none !important;
    content: none !important;
}

.booking-modal__form-header {
    margin-bottom: 40px !important;
    text-align: center !important;
    position: relative !important;
    padding-bottom: 20px !important;
}

.booking-modal__form-header::after {
    content: '' !important;
    position: absolute !important;
    bottom: 0 !important;
    left: 50% !important;
    transform: translateX(-50%) !important;
    width: 60px !important;
    height: 3px !important;
    background: linear-gradient(90deg, transparent, #68b456, transparent) !important;
    border-radius: 2px !important;
}

.booking-modal__form-title {
    font-size: 32px !important;
    font-weight: 700 !important;
    color: #171312 !important;
    margin-bottom: 8px !important;
    text-transform: uppercase !important;
    letter-spacing: 1px !important;
    font-family: "Bebas Neue", sans-serif !important;
}

@media (max-width: 991.98px) {
    .booking-modal__form-title {
        font-size: 24px !important;
    }
}

.booking-modal__form-subtitle {
    font-size: 14px !important;
    color: rgba(23, 19, 18, 0.6) !important;
    text-transform: uppercase !important;
    letter-spacing: 0.5px !important;
}

/* Поля формы */
.booking-modal .booking-form-field {
    position: relative !important;
    background: rgba(244, 238, 227, 0.4) !important;
    border: 2px solid rgba(104, 180, 86, 0.2) !important;
    border-radius: 10px !important;
    transition: all 0.3s ease !important;
}

.booking-modal .booking-form-field:hover {
    border-color: rgba(104, 180, 86, 0.4) !important;
    background: rgba(244, 238, 227, 0.6) !important;
}

.booking-modal .booking-form-field:focus-within {
    border-color: #68b456 !important;
    background: rgba(244, 238, 227, 0.8) !important;
    box-shadow: 0 0 0 4px rgba(104, 180, 86, 0.1) !important;
}

.booking-modal .booking-form-field-wrapper {
    position: relative !important;
}

.booking-modal .booking-form-input {
    background: rgba(244, 238, 227, 0.4) !important;
    border: 2px solid rgba(104, 180, 86, 0.2) !important;
    border-radius: 10px !important;
    transition: all 0.3s ease !important;
    width: 100% !important;
    color: #171312 !important;
    font-size: 14px !important;
}

.booking-modal .booking-form-input::placeholder {
    color: rgba(23, 19, 18, 0.4) !important;
    text-transform: none !important;
}

.booking-modal .booking-form-input:hover {
    border-color: rgba(104, 180, 86, 0.4) !important;
    background: rgba(244, 238, 227, 0.6) !important;
}

.booking-modal .booking-form-input:focus {
    border-color: #68b456 !important;
    background: rgba(244, 238, 227, 0.8) !important;
    box-shadow: 0 0 0 4px rgba(104, 180, 86, 0.1) !important;
    outline: none !important;
}

.booking-modal .booking-form-input:focus::placeholder {
    color: rgba(23, 19, 18, 0.6) !important;
}

.booking-modal .booking-form-input.is-invalid {
    border-color: #dc3545 !important;
    background: rgba(220, 53, 69, 0.1) !important;
    animation: bookingShake 0.5s ease-in-out !important;
}

.booking-modal .booking-form-label {
    display: block !important;
    font-size: 12px !important;
    font-weight: 600 !important;
    color: #68b456 !important;
    text-transform: uppercase !important;
    letter-spacing: 0.5px !important;
    margin-bottom: 8px !important;
}

.booking-modal .booking-form-row {
    display: grid !important;
    grid-template-columns: 1fr 1fr !important;
    gap: 16px !important;
}

@media (max-width: 991.98px) {
    .booking-modal .booking-form-row {
        grid-template-columns: 1fr !important;
    }
}

/* Dropdown */
.booking-modal .dropdown.custom-select button {
    background: rgba(244, 238, 227, 0.4) !important;
    border: 2px solid rgba(104, 180, 86, 0.2) !important;
    border-radius: 10px !important;
    text-align: left !important;
    padding: 12px 20px !important;
    transition: all 0.3s ease !important;
    color: #171312 !important;
    font-size: 14px !important;
    width: 100% !important;
}

.booking-modal .dropdown.custom-select button svg {
    color: #68b456 !important;
    transition: color 0.3s ease !important;
}

.booking-modal .dropdown.custom-select button:hover {
    border-color: rgba(104, 180, 86, 0.4) !important;
    background: rgba(244, 238, 227, 0.6) !important;
}

.booking-modal .dropdown.custom-select button:hover svg {
    color: #171312 !important;
}

.booking-modal .dropdown.custom-select button[aria-expanded="true"] {
    border-color: #68b456 !important;
    background: rgba(244, 238, 227, 0.8) !important;
    box-shadow: 0 0 0 4px rgba(104, 180, 86, 0.1) !important;
}

.booking-modal .dropdown.custom-select button[aria-expanded="true"] svg {
    color: #68b456 !important;
}

.booking-modal .dropdown.custom-select .dropdown-menu {
    border: 2px solid #68b456 !important;
    border-radius: 12px !important;
    box-shadow: 0 8px 30px rgba(104, 180, 86, 0.2) !important;
    margin-top: 8px !important;
}

/* Date picker */
.booking-modal .date-picker-wrapper {
    background: rgba(244, 238, 227, 0.4) !important;
    border: 2px solid rgba(104, 180, 86, 0.2) !important;
    border-radius: 10px !important;
    transition: all 0.3s ease !important;
}

.booking-modal .date-picker-wrapper svg {
    color: #68b456 !important;
    transition: color 0.3s ease !important;
}

.booking-modal .date-picker-wrapper .date-picker-value {
    color: rgba(23, 19, 18, 0.6) !important;
    flex: 1 !important;
    text-transform: uppercase !important;
    font-weight: 700 !important;
    font-size: 14px !important;
}

.booking-modal .date-picker-wrapper:hover {
    border-color: rgba(104, 180, 86, 0.4) !important;
    background: rgba(244, 238, 227, 0.6) !important;
}

.booking-modal .date-picker-wrapper:hover svg {
    color: #171312 !important;
}

.booking-modal .date-picker-wrapper.active {
    border-color: #68b456 !important;
    background: rgba(244, 238, 227, 0.8) !important;
    box-shadow: 0 0 0 4px rgba(104, 180, 86, 0.1) !important;
}

.booking-modal .date-picker-wrapper.active svg {
    color: #68b456 !important;
}

/* Кнопка отправки */
.booking-modal button[type="submit"] {
    width: 100% !important;
    height: 56px !important;
    background: linear-gradient(135deg, #68b456 0%, #5a9c4a 100%) !important;
    color: #fff !important;
    border: none !important;
    border-radius: 12px !important;
    font-weight: 700 !important;
    font-size: 16px !important;
    text-transform: uppercase !important;
    letter-spacing: 1px !important;
    transition: all 0.3s ease !important;
    position: relative !important;
    overflow: hidden !important;
    box-shadow: 0 4px 20px rgba(104, 180, 86, 0.4) !important;
    margin-top: 10px !important;
}

.booking-modal button[type="submit"]::before {
    content: '' !important;
    position: absolute !important;
    top: 0 !important;
    left: -100% !important;
    width: 100% !important;
    height: 100% !important;
    background: linear-gradient(90deg, transparent, rgba(255, 255, 255, 0.3), transparent) !important;
    transition: left 0.6s ease !important;
}

.booking-modal button[type="submit"]:hover {
    transform: translateY(-2px) !important;
    box-shadow: 0 8px 30px rgba(104, 180, 86, 0.5) !important;
}

.booking-modal button[type="submit"]:hover::before {
    left: 100% !important;
}

.booking-modal button[type="submit"]:active {
    transform: translateY(0) !important;
}

.booking-modal button[type="submit"]:disabled {
    opacity: 0.7 !important;
    cursor: not-allowed !important;
}

/* Анимации */
@keyframes bookingRotate {
    from {
        transform: rotate(0deg);
    }
    to {
        transform: rotate(360deg);
    }
}

@keyframes bookingFloatIcon {
    0%, 100% {
        transform: translateY(0);
    }
    50% {
        transform: translateY(-10px);
    }
}

@keyframes bookingPulseDot {
    0%, 100% {
        opacity: 0.5;
        transform: scale(1);
    }
    50% {
        opacity: 1;
        transform: scale(1.2);
    }
}

@keyframes bookingShake {
    0%, 100% {
        transform: translateX(0);
    }
    10%, 30%, 50%, 70%, 90% {
        transform: translateX(-5px);
    }
    20%, 40%, 60%, 80% {
        transform: translateX(5px);
    }
}

/* ============================================
   MANAS TOUR TRAVEL CATALOG REDESIGN
   Inspired by clean expedition catalog pages
   ============================================ */

:root {
  --travel-bg: #f6f1e8;
  --travel-card: #fffaf2;
  --travel-ink: #171312;
  --travel-muted: rgba(23, 19, 18, 0.62);
  --travel-line: rgba(104, 180, 86, 0.22);
  --travel-shadow: 0 18px 45px rgba(23, 19, 18, 0.10);
}

body,
main {
  background: var(--travel-bg) !important;
}

.word-badge-brand::after,
.word-badge-brand-1::after,
.word-badge-brand-2::after {
  content: "Manas Tour" !important;
}

.wallpaper {
  min-height: 620px !important;
  position: relative !important;
  overflow: hidden !important;
  background-image: none !important;
  background-color: #171312 !important;
  background-size: cover !important;
  background-position: center !important;
  border-bottom-left-radius: 42px !important;
  border-bottom-right-radius: 42px !important;
  box-shadow: var(--travel-shadow) !important;
}

.wallpaper__video {
  position: absolute !important;
  inset: 0 !important;
  z-index: 0 !important;
  width: 100% !important;
  height: 100% !important;
  object-fit: cover !important;
  object-position: center !important;
  opacity: 1 !important;
  transform: scale(1.04) !important;
  animation: heroVideoBreath 18s ease-in-out infinite alternate !important;
}

.wallpaper::before {
  content: "" !important;
  position: absolute !important;
  inset: 0 !important;
  background:
    linear-gradient(180deg, rgba(23, 19, 18, 0.16) 0%, rgba(23, 19, 18, 0.72) 100%),
    radial-gradient(circle at 20% 20%, rgba(104, 180, 86, 0.30), transparent 34%) !important;
  z-index: 1 !important;
}

.wallpaper .container {
  position: relative !important;
  z-index: 2 !important;
}

@keyframes heroVideoBreath {
  from {
    transform: scale(1.04) translate3d(0, 0, 0);
  }
  to {
    transform: scale(1.12) translate3d(1.5%, -1.5%, 0);
  }
}

.wallpaper p.text-white {
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  padding: 8px 16px !important;
  margin: 0 auto 18px !important;
  border-radius: 999px !important;
  background: rgba(255, 250, 242, 0.18) !important;
  border: 1px solid rgba(255, 250, 242, 0.35) !important;
  backdrop-filter: blur(10px) !important;
  letter-spacing: 0.08em !important;
}

.wallpaper h1 {
  max-width: 980px !important;
  margin: 0 auto !important;
  line-height: 0.92 !important;
  text-shadow: 0 18px 45px rgba(0, 0, 0, 0.35) !important;
}

.about,
.highlights,
.program,
.pricing,
.content-gallery {
  position: relative !important;
}

.about .container,
.highlights .container,
.program .container,
.pricing .container,
.content-gallery .container {
  background: transparent !important;
}

.about__content,
.pricing__content {
  background: var(--travel-card) !important;
  border: 1px solid var(--travel-line) !important;
  border-radius: 28px !important;
  padding: 30px !important;
  box-shadow: var(--travel-shadow) !important;
}

.about__content p {
  color: var(--travel-muted) !important;
  font-size: 16px !important;
  line-height: 1.72 !important;
  text-transform: none !important;
}

.btn.btn-primary {
  border-radius: 999px !important;
  padding: 14px 24px !important;
  box-shadow: 0 12px 30px rgba(104, 180, 86, 0.28) !important;
}

.content-gallery__grid {
  display: grid !important;
  grid-template-columns: repeat(4, minmax(0, 1fr)) !important;
  gap: 18px !important;
}

.content-gallery__item {
  border-radius: 24px !important;
  overflow: hidden !important;
  box-shadow: var(--travel-shadow) !important;
  background: var(--travel-card) !important;
}

.content-gallery__item img {
  width: 100% !important;
  height: 260px !important;
  object-fit: cover !important;
  transition: transform .45s ease !important;
}

.content-gallery__item:hover img {
  transform: scale(1.06) !important;
}

.highlights__grid {
  display: grid !important;
  grid-template-columns: repeat(3, minmax(0, 1fr)) !important;
  gap: 18px !important;
}

.highlights__item,
.pricing__item {
  background: var(--travel-card) !important;
  border: 1px solid var(--travel-line) !important;
  border-radius: 24px !important;
  padding: 24px !important;
  box-shadow: 0 12px 30px rgba(23, 19, 18, 0.08) !important;
}

.highlights__item h3,
.pricing__item h3,
.program__item h3 {
  color: var(--bs-primary) !important;
  font-family: "Bebas Neue", sans-serif !important;
  letter-spacing: .02em !important;
}

.highlights__item p,
.program__item p {
  color: var(--travel-muted) !important;
  line-height: 1.6 !important;
  text-transform: none !important;
}

.program__timeline {
  display: grid !important;
  grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
  gap: 18px !important;
}

.program__item {
  background: var(--travel-card) !important;
  border: 1px solid var(--travel-line) !important;
  border-radius: 24px !important;
  padding: 24px !important;
  box-shadow: 0 12px 30px rgba(23, 19, 18, 0.08) !important;
  position: relative !important;
}

.program__item::before {
  display: none !important;
  content: none !important;
}

.pricing__content {
  display: grid !important;
  grid-template-columns: repeat(3, minmax(0, 1fr)) !important;
  gap: 18px !important;
}

.pricing__item .price {
  color: var(--travel-ink) !important;
  font-size: 20px !important;
}

.header__button,
.menu-modal__close,
.booking-modal__close,
.thanks-modal__close {
  border-color: var(--bs-primary) !important;
  color: var(--bs-primary) !important;
}

.footer {
  border-top-left-radius: 42px !important;
  border-top-right-radius: 42px !important;
}

@media (max-width: 991.98px) {
  .wallpaper {
    min-height: 540px !important;
    border-bottom-left-radius: 28px !important;
    border-bottom-right-radius: 28px !important;
  }

  .wallpaper h1 {
    font-size: 56px !important;
  }

  .content-gallery__grid,
  .highlights__grid,
  .program__timeline,
  .pricing__content {
    grid-template-columns: 1fr !important;
  }

  .content-gallery__item img {
    height: 230px !important;
  }
}

@media (prefers-reduced-motion: reduce) {
  .wallpaper__video {
    animation: none !important;
    transform: scale(1.04) !important;
  }
}

/* ============================================
   HOMEPAGE POLISH: ROAD, DIRECTIONS, FAQ, CODE
   ============================================ */

pre,
code,
.wp-block-code,
.wp-block-preformatted {
  max-width: 100% !important;
  white-space: pre-wrap !important;
  word-break: break-word !important;
  overflow-x: auto !important;
  border-radius: 22px !important;
  background: #171312 !important;
  color: #fffaf2 !important;
  border: 1px solid rgba(104, 180, 86, 0.28) !important;
  box-shadow: var(--travel-shadow) !important;
}

pre,
.wp-block-code,
.wp-block-preformatted {
  padding: 22px !important;
  margin: 24px 0 !important;
}

code {
  padding: 3px 7px !important;
}

.road {
  overflow: hidden !important;
}

.road .row.mb-80,
.road .row.mb-32 {
  margin-bottom: 28px !important;
}

.road__steps {
  display: grid !important;
  grid-template-columns: repeat(3, minmax(0, 1fr)) !important;
  gap: 18px !important;
  padding: 0 !important;
}

.road__steps > svg {
  display: none !important;
}

.road__step {
  min-height: 132px !important;
  padding: 24px !important;
  border-radius: 26px !important;
  background: var(--travel-card) !important;
  border: 1px solid var(--travel-line) !important;
  box-shadow: 0 14px 32px rgba(23, 19, 18, 0.08) !important;
  color: var(--travel-ink) !important;
  text-align: left !important;
  display: flex !important;
  align-items: end !important;
  line-height: 1.15 !important;
  letter-spacing: .02em !important;
}

.road__step::before {
  content: "0" counter(road-step) !important;
  counter-increment: road-step !important;
  position: absolute !important;
  top: 18px !important;
  left: 22px !important;
  width: 42px !important;
  height: 42px !important;
  border-radius: 50% !important;
  display: grid !important;
  place-items: center !important;
  background: rgba(104, 180, 86, 0.14) !important;
  color: var(--bs-primary) !important;
  font-weight: 800 !important;
}

.road__steps {
  counter-reset: road-step;
}

.road .img-block {
  min-height: 340px !important;
  border-radius: 30px !important;
  box-shadow: var(--travel-shadow) !important;
}

.offer {
  position: relative !important;
  overflow: hidden !important;
  padding: 80px 0 !important;
  margin-bottom: 120px !important;
  background:
    radial-gradient(circle at 12% 12%, rgba(104, 180, 86, 0.14), transparent 30%),
    linear-gradient(180deg, rgba(255, 250, 242, 0.7), rgba(244, 238, 227, 0.2)) !important;
  border-radius: 42px !important;
}

.offer__images {
  display: none !important;
}

.offer__main {
  max-width: 920px !important;
  margin: 0 auto 34px !important;
  padding: 26px 30px !important;
  border-radius: 28px !important;
  background: var(--travel-card) !important;
  border: 1px solid var(--travel-line) !important;
  box-shadow: 0 16px 38px rgba(23, 19, 18, 0.08) !important;
  line-height: 1.55 !important;
  text-transform: none !important;
}

.offer .container h2.word-badge {
  margin-top: 0 !important;
  margin-bottom: 34px !important;
}

.directions__wrapper {
  display: grid !important;
  grid-template-columns: repeat(3, minmax(0, 1fr)) !important;
  gap: 20px !important;
  margin-top: 0 !important;
}

.direction {
  position: relative !important;
  min-height: 390px !important;
  border-radius: 28px !important;
  overflow: hidden !important;
  padding: 22px !important;
  background-size: cover !important;
  background-position: center !important;
  box-shadow: var(--travel-shadow) !important;
  isolation: isolate !important;
  transition: transform .25s ease, box-shadow .25s ease !important;
}

.direction::before {
  content: "" !important;
  position: absolute !important;
  inset: 0 !important;
  z-index: -1 !important;
  background: linear-gradient(180deg, rgba(23, 19, 18, 0.08) 0%, rgba(23, 19, 18, 0.72) 100%) !important;
}

.direction:hover {
  transform: translateY(-4px) !important;
  box-shadow: 0 24px 55px rgba(23, 19, 18, 0.16) !important;
}

.direction__title {
  min-height: auto !important;
  font-size: clamp(28px, 3vw, 44px) !important;
  text-shadow: 0 10px 26px rgba(0, 0, 0, 0.35) !important;
}

.direction__button button {
  min-height: 52px !important;
  border: 1px solid rgba(255, 250, 242, 0.55) !important;
  background: rgba(255, 250, 242, 0.16) !important;
  color: #fffaf2 !important;
  backdrop-filter: blur(10px) !important;
}

.directions__slider {
  margin-top: 0 !important;
  overflow: visible !important;
}

.directions__slider .swiper-slide {
  height: auto !important;
}

.faq {
  padding: 90px 0 !important;
  margin: 80px 0 120px !important;
  border-radius: 42px !important;
  background:
    radial-gradient(circle at 85% 10%, rgba(104, 180, 86, 0.18), transparent 28%),
    linear-gradient(135deg, #fffaf2 0%, #f4eee3 100%) !important;
}

.faq h2 {
  text-align: center !important;
  margin-bottom: 42px !important;
}

.faq h2::after {
  left: 50% !important;
  transform: translateX(-50%) !important;
}

.faq__accordion {
  max-width: 980px !important;
  margin: 0 auto !important;
  gap: 16px !important;
}

.faq__item {
  border-radius: 24px !important;
  border: 1px solid var(--travel-line) !important;
  box-shadow: 0 14px 34px rgba(23, 19, 18, 0.08) !important;
  background: rgba(255, 250, 242, 0.92) !important;
}

.faq__question {
  padding: 24px 26px !important;
  background: transparent !important;
}

.faq__question-text {
  font-size: 24px !important;
}

.faq__content {
  background: rgba(255, 250, 242, 0.78) !important;
  padding: 0 26px 26px !important;
}

@media (max-width: 1199.98px) {
  .directions__wrapper {
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
  }
}

@media (max-width: 991.98px) {
  .directions__wrapper {
    display: none !important;
  }

  .road__steps,
  .offer .directions__slider .swiper-wrapper {
    grid-template-columns: 1fr !important;
  }

  .road__step {
    min-height: 118px !important;
    padding: 72px 22px 22px !important;
  }

  .offer {
    padding: 54px 0 !important;
    border-radius: 30px !important;
  }

  .offer__main {
    padding: 22px !important;
    text-align: left !important;
  }

  .direction {
    min-height: 360px !important;
  }

  .faq {
    padding: 58px 0 !important;
    border-radius: 30px !important;
  }

  .faq__question-text {
    font-size: 19px !important;
  }
}

@media (min-width: 992px) {
  .directions__wrapper {
    display: grid !important;
  }
}

/* ============================================
   FINAL RHYTHM PASS: CLEAN SPACING + GUIDE/FAQ
   ============================================ */

main > section,
section.space-pb,
section.space-top,
section.space-bottom {
  margin-top: 0 !important;
  margin-bottom: clamp(64px, 8vw, 112px) !important;
}

main > section:last-child,
section.faq:last-child {
  margin-bottom: 0 !important;
}

.space-top {
  padding-top: clamp(56px, 7vw, 96px) !important;
}

.space-bottom {
  padding-bottom: clamp(56px, 7vw, 96px) !important;
}

.wallpaper.space-pb {
  margin-bottom: clamp(56px, 7vw, 92px) !important;
}

.about,
.guide,
.road,
.reviews,
.offer,
.blog,
.faq,
.highlights,
.program,
.pricing,
.content-gallery {
  padding-left: 0 !important;
  padding-right: 0 !important;
}

.guide {
  overflow: hidden !important;
  position: relative !important;
  padding-top: 34px !important;
}

.guide::before,
.guide::after {
  content: "" !important;
  position: absolute !important;
  pointer-events: none !important;
  border-radius: 999px !important;
  filter: blur(4px) !important;
}

.guide::before {
  width: 260px !important;
  height: 260px !important;
  right: -90px !important;
  top: 40px !important;
  background: rgba(104, 180, 86, 0.16) !important;
}

.guide::after {
  width: 190px !important;
  height: 190px !important;
  left: -80px !important;
  bottom: 10px !important;
  background: rgba(255, 183, 77, 0.18) !important;
}

.guide__wrapper {
  display: grid !important;
  grid-template-columns: repeat(4, minmax(0, 1fr)) !important;
  gap: 22px !important;
  min-height: auto !important;
  padding: 0 !important;
  isolation: isolate !important;
}

.guide__wrapper::before {
  content: "" !important;
  position: absolute !important;
  left: 6% !important;
  right: 6% !important;
  top: 52% !important;
  height: 3px !important;
  border-radius: 999px !important;
  background: linear-gradient(90deg, rgba(104, 180, 86, 0), rgba(104, 180, 86, 0.50), rgba(255, 183, 77, 0.45), rgba(104, 180, 86, 0)) !important;
  transform: translateY(-50%) !important;
  z-index: 0 !important;
}

.guide__svg {
  display: none !important;
  visibility: hidden !important;
  opacity: 0 !important;
}

.guide-step {
  position: relative !important;
  z-index: 1 !important;
  min-height: 210px !important;
  padding: 28px !important;
  border-radius: 32px !important;
  background:
    linear-gradient(145deg, rgba(255, 255, 255, 0.90), rgba(255, 250, 242, 0.96)),
    radial-gradient(circle at 88% 18%, rgba(104, 180, 86, 0.18), transparent 28%) !important;
  border: 0 !important;
  box-shadow: 0 20px 48px rgba(23, 19, 18, 0.10) !important;
  display: flex !important;
  flex-direction: column !important;
  justify-content: space-between !important;
  overflow: hidden !important;
  transform: translateY(0) !important;
  animation: guideCardFloatIn 0.7s ease both !important;
  transition: transform 0.25s ease, box-shadow 0.25s ease !important;
}

.guide-step::before {
  content: "" !important;
  position: absolute !important;
  right: -36px !important;
  bottom: -36px !important;
  width: 120px !important;
  height: 120px !important;
  border-radius: 999px !important;
  background: rgba(104, 180, 86, 0.13) !important;
}

.guide-step::after {
  content: "" !important;
  position: absolute !important;
  inset: 10px !important;
  border: 1px solid rgba(104, 180, 86, 0.16) !important;
  border-radius: 24px !important;
  pointer-events: none !important;
}

.guide-step:hover {
  transform: translateY(-8px) !important;
  box-shadow: 0 28px 60px rgba(23, 19, 18, 0.14) !important;
}

.guide-step_2 {
  animation-delay: 0.08s !important;
}

.guide-step_3 {
  animation-delay: 0.16s !important;
}

.guide-step_4 {
  animation-delay: 0.24s !important;
}

.guide-step__number {
  width: fit-content !important;
  border: 0 !important;
  background: var(--bs-primary) !important;
  color: var(--bs-primary) !important;
  color: #ffffff !important;
  border-radius: 999px !important;
  box-shadow: 0 10px 24px rgba(104, 180, 86, 0.28) !important;
}

.guide-step__title {
  margin: 0 !important;
  font-size: clamp(24px, 2.4vw, 34px) !important;
  color: var(--travel-ink) !important;
  position: relative !important;
  z-index: 1 !important;
}

@keyframes guideCardFloatIn {
  from {
    opacity: 0;
    transform: translateY(24px);
  }
  to {
    opacity: 1;
    transform: translateY(0);
  }
}

.faq {
  border-radius: 0 !important;
  margin-top: 0 !important;
  background: transparent !important;
}

.faq__accordion {
  gap: 14px !important;
}

.faq__item,
.faq__item:hover,
.faq__item.faq__item_active {
  border: 0 !important;
  outline: 0 !important;
  box-shadow: 0 16px 38px rgba(23, 19, 18, 0.08) !important;
  background: var(--travel-card) !important;
  border-radius: 26px !important;
  transform: none !important;
}

.faq__answer {
  border-top: 0 !important;
}

.faq__question {
  border: 0 !important;
  box-shadow: none !important;
  padding: 24px 26px !important;
}

.faq__question:hover,
.faq__question:focus {
  background: transparent !important;
  box-shadow: none !important;
}

.faq__content {
  padding: 0 26px 26px !important;
  background: transparent !important;
}

@media (max-width: 1199.98px) {
  .guide__wrapper {
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
  }

  .guide__wrapper::before {
    display: none !important;
  }
}

@media (max-width: 991.98px) {
  main > section,
  section.space-pb,
  section.space-top,
  section.space-bottom {
    margin-bottom: 64px !important;
  }

  .space-top {
    padding-top: 54px !important;
  }

  .space-bottom {
    padding-bottom: 54px !important;
  }

  .guide__wrapper {
    grid-template-columns: 1fr !important;
  }

  .guide-step {
    min-height: 150px !important;
  }

  .faq__question {
    padding: 20px !important;
  }

  .faq__content {
    padding: 0 20px 22px !important;
  }
}

/* Premium route guide */
.guide {
  padding-top: 0 !important;
  overflow: visible !important;
}

.guide > .container {
  position: relative !important;
  overflow: hidden !important;
  border-radius: clamp(28px, 4vw, 56px) !important;
  padding: clamp(28px, 5vw, 64px) !important;
  background:
    linear-gradient(135deg, rgba(15, 20, 16, 0.96), rgba(37, 45, 33, 0.94)),
    radial-gradient(circle at 12% 18%, rgba(104, 180, 86, 0.34), transparent 28%),
    radial-gradient(circle at 86% 8%, rgba(255, 183, 77, 0.22), transparent 30%) !important;
  box-shadow: 0 34px 90px rgba(23, 19, 18, 0.20) !important;
}

.guide > .container::before {
  content: "" !important;
  position: absolute !important;
  inset: 18px !important;
  border: 1px solid rgba(255, 255, 255, 0.10) !important;
  border-radius: clamp(22px, 3vw, 42px) !important;
  pointer-events: none !important;
}

.guide > .container::after {
  content: "" !important;
  position: absolute !important;
  right: -120px !important;
  bottom: -160px !important;
  width: 420px !important;
  height: 420px !important;
  border-radius: 999px !important;
  background: rgba(104, 180, 86, 0.18) !important;
  filter: blur(6px) !important;
  pointer-events: none !important;
}

.guide .row,
.guide .col {
  position: relative !important;
  z-index: 1 !important;
}

.guide__head {
  margin-bottom: clamp(26px, 4vw, 48px) !important;
}

.guide__eyebrow {
  margin: 0 0 12px !important;
  color: rgba(255, 255, 255, 0.60) !important;
  font-size: 13px !important;
  font-weight: 800 !important;
  letter-spacing: 0.18em !important;
  text-transform: uppercase !important;
}

.guide .word-badge {
  color: #ffffff !important;
}

.guide .word-badge::after {
  color: rgba(255, 255, 255, 0.08) !important;
}

.guide__lead {
  max-width: 430px !important;
  margin: 0 !important;
  color: rgba(255, 255, 255, 0.72) !important;
  font-size: clamp(16px, 1.6vw, 19px) !important;
  line-height: 1.55 !important;
}

.guide__wrapper {
  display: grid !important;
  grid-template-columns: repeat(4, minmax(0, 1fr)) !important;
  gap: 14px !important;
  min-height: auto !important;
  padding: 0 !important;
  position: relative !important;
}

.guide__wrapper::before {
  content: "" !important;
  position: absolute !important;
  left: 8% !important;
  right: 8% !important;
  top: 58px !important;
  height: 2px !important;
  border-radius: 999px !important;
  background: linear-gradient(90deg, rgba(104, 180, 86, 0), rgba(104, 180, 86, 0.9), rgba(255, 183, 77, 0.82), rgba(104, 180, 86, 0)) !important;
  z-index: 0 !important;
}

.guide-step {
  position: relative !important;
  z-index: 1 !important;
  min-height: 255px !important;
  padding: 24px !important;
  border-radius: 30px !important;
  background: rgba(255, 250, 242, 0.96) !important;
  border: 1px solid rgba(255, 255, 255, 0.38) !important;
  box-shadow: 0 22px 58px rgba(0, 0, 0, 0.22) !important;
  display: flex !important;
  flex-direction: column !important;
  justify-content: flex-start !important;
  overflow: hidden !important;
  transform: none !important;
  animation: guideCardRise 0.72s ease both !important;
  transition: transform 0.25s ease, box-shadow 0.25s ease, background 0.25s ease !important;
}

.guide-step::before {
  content: "" !important;
  position: absolute !important;
  left: 24px !important;
  top: 24px !important;
  width: 68px !important;
  height: 68px !important;
  border-radius: 22px !important;
  background:
    linear-gradient(135deg, var(--bs-primary), #8ed674) !important;
  box-shadow: 0 18px 32px rgba(104, 180, 86, 0.30) !important;
}

.guide-step::after {
  content: "" !important;
  position: absolute !important;
  right: -46px !important;
  top: -46px !important;
  width: 150px !important;
  height: 150px !important;
  border-radius: 999px !important;
  border: 26px solid rgba(104, 180, 86, 0.10) !important;
  pointer-events: none !important;
}

.guide-step:hover {
  transform: translateY(-10px) !important;
  background: #ffffff !important;
  box-shadow: 0 30px 70px rgba(0, 0, 0, 0.28) !important;
}

.guide-step__number {
  position: relative !important;
  z-index: 1 !important;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  width: 68px !important;
  height: 68px !important;
  margin: 0 0 34px !important;
  padding: 0 !important;
  border: 0 !important;
  border-radius: 22px !important;
  background: transparent !important;
  box-shadow: none !important;
  color: #ffffff !important;
  font-size: 18px !important;
  font-weight: 900 !important;
}

.guide-step__title {
  position: relative !important;
  z-index: 1 !important;
  margin: 0 0 14px !important;
  color: var(--travel-ink) !important;
  font-size: clamp(24px, 2.2vw, 32px) !important;
  line-height: 1.02 !important;
  letter-spacing: -0.04em !important;
}

.guide-step__text {
  position: relative !important;
  z-index: 1 !important;
  margin: 0 !important;
  color: rgba(23, 19, 18, 0.66) !important;
  font-size: 15px !important;
  line-height: 1.45 !important;
}

.guide-step_2 {
  margin-top: 34px !important;
  animation-delay: 0.08s !important;
}

.guide-step_3 {
  animation-delay: 0.16s !important;
}

.guide-step_4 {
  margin-top: 34px !important;
  animation-delay: 0.24s !important;
}

@keyframes guideCardRise {
  from {
    opacity: 0;
    transform: translateY(28px);
  }
  to {
    opacity: 1;
    transform: translateY(0);
  }
}

@media (max-width: 1199.98px) {
  .guide__wrapper {
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
  }

  .guide__wrapper::before {
    display: none !important;
  }

  .guide-step,
  .guide-step_2,
  .guide-step_4 {
    margin-top: 0 !important;
  }
}

@media (max-width: 767.98px) {
  .guide > .container {
    padding: 28px 18px !important;
    border-radius: 30px !important;
  }

  .guide > .container::before {
    inset: 10px !important;
    border-radius: 22px !important;
  }

  .guide__wrapper {
    grid-template-columns: 1fr !important;
  }

  .guide-step {
    min-height: auto !important;
    padding: 22px !important;
  }

  .guide-step__number,
  .guide-step::before {
    width: 58px !important;
    height: 58px !important;
    border-radius: 18px !important;
  }

  .guide-step__number {
    margin-bottom: 24px !important;
  }
}

/* Final animated homepage sections */
.guide {
  overflow: visible !important;
}

.guide > .container {
  max-width: min(1180px, calc(100% - 28px)) !important;
  padding: clamp(22px, 4vw, 46px) !important;
  border-radius: clamp(26px, 4vw, 52px) !important;
  background:
    radial-gradient(circle at 8% 12%, rgba(104, 180, 86, 0.28), transparent 28%),
    radial-gradient(circle at 96% 4%, rgba(255, 183, 77, 0.20), transparent 24%),
    linear-gradient(135deg, #152015 0%, #233020 58%, #101510 100%) !important;
  color: #ffffff !important;
  box-shadow: 0 34px 90px rgba(23, 19, 18, 0.22) !important;
}

.guide .col {
  display: grid !important;
  grid-template-columns: minmax(0, 0.9fr) minmax(0, 1.25fr) !important;
  gap: clamp(24px, 5vw, 64px) !important;
  align-items: center !important;
}

.guide__head {
  display: block !important;
  margin: 0 !important;
  position: sticky !important;
  top: 110px !important;
  align-self: start !important;
}

.guide__eyebrow {
  margin-bottom: 14px !important;
  color: rgba(255, 255, 255, 0.64) !important;
}

.guide__head .word-badge {
  max-width: 420px !important;
  color: #ffffff !important;
  font-size: clamp(44px, 7vw, 92px) !important;
  line-height: 0.88 !important;
  letter-spacing: -0.08em !important;
}

.guide__lead {
  max-width: 360px !important;
  margin-top: 24px !important;
  color: rgba(255, 255, 255, 0.74) !important;
  font-size: clamp(16px, 1.7vw, 20px) !important;
}

.guide__wrapper {
  display: grid !important;
  grid-template-columns: 1fr !important;
  gap: 14px !important;
  padding: 0 !important;
  min-height: auto !important;
}

.guide__wrapper::before {
  display: block !important;
  left: 31px !important;
  top: 28px !important;
  bottom: 28px !important;
  right: auto !important;
  width: 2px !important;
  height: auto !important;
  background: linear-gradient(180deg, rgba(104, 180, 86, 0), rgba(104, 180, 86, 0.85), rgba(255, 183, 77, 0.75), rgba(104, 180, 86, 0)) !important;
  transform: none !important;
}

.guide-step,
.guide-step_2,
.guide-step_3,
.guide-step_4 {
  display: grid !important;
  grid-template-columns: 64px minmax(0, 1fr) !important;
  gap: 18px !important;
  align-items: center !important;
  min-height: auto !important;
  margin: 0 !important;
  padding: 18px 20px !important;
  border-radius: 24px !important;
  background: rgba(255, 255, 255, 0.08) !important;
  border: 1px solid rgba(255, 255, 255, 0.12) !important;
  box-shadow: none !important;
  backdrop-filter: blur(12px) !important;
  animation: none !important;
  transition: transform 0.28s ease, background 0.28s ease, border-color 0.28s ease !important;
}

.guide-step::before,
.guide-step::after {
  display: none !important;
}

.guide-step:hover {
  transform: translateX(8px) !important;
  background: rgba(255, 255, 255, 0.14) !important;
  border-color: rgba(104, 180, 86, 0.50) !important;
}

.guide-step__number {
  grid-row: 1 / span 2 !important;
  display: inline-flex !important;
  width: 64px !important;
  height: 64px !important;
  margin: 0 !important;
  border-radius: 20px !important;
  background: linear-gradient(135deg, var(--bs-primary), #91d66f) !important;
  color: #ffffff !important;
  box-shadow: 0 14px 34px rgba(104, 180, 86, 0.30) !important;
}

.guide-step__title {
  margin: 0 !important;
  color: #ffffff !important;
  font-size: clamp(22px, 2.6vw, 34px) !important;
  line-height: 1 !important;
  letter-spacing: -0.05em !important;
  overflow-wrap: anywhere !important;
}

.guide-step__text {
  margin: 0 !important;
  color: rgba(255, 255, 255, 0.68) !important;
  font-size: 15px !important;
  line-height: 1.45 !important;
}

.road {
  overflow: hidden !important;
}

.road .row.mb-80 {
  margin-bottom: clamp(28px, 5vw, 56px) !important;
}

.road .row.mb-80 .col-12 {
  width: 100% !important;
  flex: 0 0 100% !important;
  max-width: 100% !important;
}

.road h2.word-badge {
  max-width: 760px !important;
  font-size: clamp(42px, 7vw, 86px) !important;
  letter-spacing: -0.08em !important;
}

.road .row.mb-32 .col-lg-5 {
  display: none !important;
}

.road .row.mb-32 .col-lg-7 {
  width: 100% !important;
  flex: 0 0 100% !important;
  max-width: 100% !important;
}

.road__steps {
  display: grid !important;
  grid-template-columns: repeat(3, minmax(0, 1fr)) !important;
  gap: 18px !important;
  padding: 0 !important;
}

.road__steps > svg {
  display: none !important;
}

.road__step {
  display: flex !important;
  min-height: 210px !important;
  padding: 26px !important;
  border-radius: 30px !important;
  background:
    linear-gradient(145deg, rgba(255, 255, 255, 0.96), rgba(255, 250, 242, 0.90)),
    radial-gradient(circle at 100% 0%, rgba(104, 180, 86, 0.18), transparent 36%) !important;
  box-shadow: 0 18px 48px rgba(23, 19, 18, 0.10) !important;
  flex-direction: column !important;
  justify-content: space-between !important;
  text-align: left !important;
  transform: translateY(18px) !important;
  opacity: 0 !important;
}

.road__steps.is-visible .road__step {
  animation: roadStatIn 0.75s ease both !important;
}

.road__steps.is-visible .road__step_2 {
  animation-delay: 0.12s !important;
}

.road__steps.is-visible .road__step_3 {
  animation-delay: 0.24s !important;
}

.road__metric {
  display: block !important;
  color: var(--bs-primary) !important;
  font-size: clamp(46px, 7vw, 88px) !important;
  line-height: 0.9 !important;
  font-weight: 900 !important;
  letter-spacing: -0.08em !important;
}

.road__caption {
  display: block !important;
  max-width: 220px !important;
  color: var(--travel-ink) !important;
  font-size: clamp(16px, 1.8vw, 22px) !important;
  line-height: 1.1 !important;
  font-weight: 800 !important;
  letter-spacing: -0.03em !important;
  text-transform: none !important;
}

@keyframes roadStatIn {
  from {
    opacity: 0;
    transform: translateY(28px) scale(0.96);
  }
  to {
    opacity: 1;
    transform: translateY(0) scale(1);
  }
}

.js-reveal {
  opacity: 0;
  transform: translateY(34px);
}

.js-reveal.is-visible {
  animation: sectionReveal 0.85s ease both;
}

@keyframes sectionReveal {
  from {
    opacity: 0;
    transform: translateY(34px);
  }
  to {
    opacity: 1;
    transform: translateY(0);
  }
}

@media (max-width: 991.98px) {
  .guide .col {
    grid-template-columns: 1fr !important;
  }

  .guide__head {
    position: relative !important;
    top: auto !important;
  }

  .guide__head .word-badge {
    max-width: 100% !important;
    font-size: clamp(42px, 12vw, 74px) !important;
  }

  .road__steps {
    grid-template-columns: 1fr !important;
  }

  .road__step {
    min-height: 160px !important;
  }
}

@media (max-width: 575.98px) {
  .guide > .container {
    max-width: calc(100% - 18px) !important;
    padding: 24px 14px !important;
  }

  .guide-step,
  .guide-step_2,
  .guide-step_3,
  .guide-step_4 {
    grid-template-columns: 52px minmax(0, 1fr) !important;
    gap: 14px !important;
    padding: 16px !important;
  }

  .guide__wrapper::before {
    left: 25px !important;
  }

  .guide-step__number {
    width: 52px !important;
    height: 52px !important;
    border-radius: 16px !important;
    font-size: 15px !important;
  }

  .guide-step__title {
    font-size: 22px !important;
  }

  .guide-step__text {
    font-size: 14px !important;
  }

  .road__step {
    min-height: 145px !important;
    padding: 22px !important;
  }
}

/* Stable animated travel map: overrides old absolute guide positions */
.guide > .container {
  overflow: hidden !important;
}

.guide .col {
  grid-template-columns: minmax(280px, 0.82fr) minmax(0, 1.18fr) !important;
}

.guide__head .word-badge {
  font-size: clamp(42px, 5.8vw, 78px) !important;
  line-height: 1.06 !important;
  letter-spacing: -0.025em !important;
  word-spacing: 0.08em !important;
  max-width: 360px !important;
  overflow-wrap: normal !important;
  text-wrap: balance !important;
}

.guide__wrapper {
  width: 100% !important;
  max-width: 100% !important;
  overflow: visible !important;
  gap: 16px !important;
}

.guide__wrapper::before {
  left: 31px !important;
  top: 34px !important;
  bottom: 34px !important;
  width: 3px !important;
  background: rgba(255, 255, 255, 0.14) !important;
  box-shadow: none !important;
}

.guide__wrapper::after {
  content: "" !important;
  position: absolute !important;
  left: 29px !important;
  top: 34px !important;
  width: 7px !important;
  height: 86px !important;
  border-radius: 999px !important;
  background: linear-gradient(180deg, rgba(145, 214, 111, 0), #91d66f, #ffb74d, rgba(255, 183, 77, 0)) !important;
  box-shadow: 0 0 24px rgba(145, 214, 111, 0.75) !important;
  animation: guideRoutePulse 4s ease-in-out infinite !important;
  z-index: 1 !important;
  pointer-events: none !important;
}

.guide-step,
.guide-step_1,
.guide-step_2,
.guide-step_3,
.guide-step_4 {
  position: relative !important;
  inset: auto !important;
  top: auto !important;
  right: auto !important;
  bottom: auto !important;
  left: auto !important;
  width: 100% !important;
  max-width: 100% !important;
  min-width: 0 !important;
  transform: none !important;
  translate: none !important;
  grid-template-columns: 62px minmax(0, 1fr) !important;
  padding: 16px 18px !important;
  background:
    linear-gradient(135deg, rgba(255, 255, 255, 0.13), rgba(255, 255, 255, 0.06)) !important;
  border-color: rgba(255, 255, 255, 0.16) !important;
}

.guide-step:hover {
  transform: translateX(6px) !important;
}

.guide-step__title,
.guide-step__text {
  min-width: 0 !important;
  max-width: 100% !important;
}

.guide-step__title {
  font-size: clamp(21px, 2.1vw, 30px) !important;
  line-height: 1.08 !important;
  letter-spacing: -0.025em !important;
  overflow-wrap: normal !important;
  word-break: normal !important;
}

.guide-step__text {
  overflow-wrap: anywhere !important;
}

@keyframes guideRoutePulse {
  0%,
  100% {
    transform: translateY(0);
    opacity: 0.38;
  }
  50% {
    transform: translateY(calc(100% + 170px));
    opacity: 1;
  }
}

@media (max-width: 991.98px) {
  .guide .col {
    grid-template-columns: 1fr !important;
  }

  .guide__head .word-badge {
    max-width: 100% !important;
    font-size: clamp(42px, 11vw, 70px) !important;
  }
}

@media (max-width: 575.98px) {
  .guide__wrapper::before {
    left: 25px !important;
  }

  .guide__wrapper::after {
    left: 23px !important;
  }

  .guide-step,
  .guide-step_1,
  .guide-step_2,
  .guide-step_3,
  .guide-step_4 {
    grid-template-columns: 52px minmax(0, 1fr) !important;
    padding: 15px !important;
  }
}

/* Unified homepage rhythm */
main > section:not(.wallpaper):not(.team) {
  margin-top: 0 !important;
  margin-bottom: clamp(46px, 6vw, 82px) !important;
  padding-top: 0 !important;
  padding-bottom: 0 !important;
}

.wallpaper.space-pb {
  margin-bottom: clamp(46px, 6vw, 78px) !important;
}

.team {
  display: none !important;
}

.about .row,
.road .row,
.reviews .row,
.offer .row,
.rules .row,
.blog .row {
  margin-top: 0 !important;
}

.road .row.mb-80,
.road .row.mb-32 {
  margin-bottom: clamp(22px, 3vw, 36px) !important;
}

.road .row.flex-column-reverse {
  margin-top: clamp(24px, 4vw, 42px) !important;
}

.road .img-block {
  min-height: clamp(230px, 30vw, 360px) !important;
  height: auto !important;
}

.road__step {
  opacity: 1 !important;
  transform: none !important;
}

.road__steps.is-visible .road__step {
  animation: roadStatIn 0.75s ease both !important;
}

.journey-gallery {
  overflow: hidden !important;
}

.journey-gallery__shell {
  position: relative !important;
  display: grid !important;
  grid-template-columns: minmax(260px, 0.82fr) minmax(0, 1.18fr) !important;
  gap: clamp(26px, 4vw, 58px) !important;
  align-items: center !important;
  padding: clamp(24px, 4vw, 54px) !important;
  border-radius: clamp(28px, 4vw, 54px) !important;
  background:
    radial-gradient(circle at 18% 16%, rgba(104, 180, 86, 0.32), transparent 30%),
    linear-gradient(135deg, #171312 0%, #241f1b 54%, #0f0d0c 100%) !important;
  color: #fff !important;
  box-shadow: 0 30px 80px rgba(23, 19, 18, 0.18) !important;
  isolation: isolate !important;
}

.journey-gallery__shell::before {
  content: "" !important;
  position: absolute !important;
  inset: 18px !important;
  border: 1px solid rgba(244, 238, 227, 0.12) !important;
  border-radius: inherit !important;
  pointer-events: none !important;
  z-index: -1 !important;
}

.journey-gallery__eyebrow {
  margin: 0 0 14px !important;
  color: rgba(244, 238, 227, 0.64) !important;
  font-size: 12px !important;
  font-weight: 800 !important;
  letter-spacing: 0.16em !important;
  text-transform: uppercase !important;
}

.journey-gallery__title {
  max-width: 620px !important;
  margin: 0 0 clamp(18px, 3vw, 30px) !important;
  color: #fff !important;
  font-size: clamp(44px, 6vw, 84px) !important;
  line-height: 0.98 !important;
  letter-spacing: -0.035em !important;
  text-wrap: balance !important;
}

.journey-gallery__text {
  max-width: 470px !important;
  margin: 0 !important;
  color: rgba(244, 238, 227, 0.82) !important;
  font-size: clamp(15px, 1.35vw, 18px) !important;
  line-height: 1.55 !important;
}

.journey-gallery__stats {
  display: flex !important;
  flex-wrap: wrap !important;
  gap: 10px !important;
  margin-top: clamp(22px, 3vw, 34px) !important;
}

.journey-gallery__stats span {
  display: inline-flex !important;
  align-items: center !important;
  min-height: 38px !important;
  padding: 8px 16px !important;
  border: 1px solid rgba(104, 180, 86, 0.46) !important;
  border-radius: 999px !important;
  color: #fff !important;
  background: rgba(244, 238, 227, 0.08) !important;
  font-size: 12px !important;
  font-weight: 800 !important;
  letter-spacing: 0.08em !important;
  text-transform: uppercase !important;
}

.journey-gallery__grid {
  display: grid !important;
  grid-template-columns: repeat(6, minmax(0, 1fr)) !important;
  grid-auto-rows: clamp(92px, 10vw, 150px) !important;
  gap: clamp(10px, 1.4vw, 18px) !important;
}

.journey-gallery__card {
  position: relative !important;
  min-height: 0 !important;
  margin: 0 !important;
  overflow: hidden !important;
  border-radius: clamp(18px, 2vw, 30px) !important;
  background: rgba(244, 238, 227, 0.08) !important;
  box-shadow: 0 20px 52px rgba(0, 0, 0, 0.22) !important;
}

.journey-gallery__card img {
  width: 100% !important;
  height: 100% !important;
  display: block !important;
  object-fit: cover !important;
  transform: scale(1.02) !important;
  transition: transform 0.7s ease, filter 0.7s ease !important;
}

.journey-gallery__card:hover img {
  transform: scale(1.08) !important;
  filter: saturate(1.08) contrast(1.04) !important;
}

.journey-gallery__card_main {
  grid-column: span 4 !important;
  grid-row: span 3 !important;
}

.journey-gallery__card:not(.journey-gallery__card_main) {
  grid-column: span 2 !important;
}

.journey-gallery__card:nth-child(2),
.journey-gallery__card:nth-child(3) {
  grid-row: span 1 !important;
}

.journey-gallery__card:nth-child(4),
.journey-gallery__card:nth-child(5) {
  grid-row: span 2 !important;
}

.journey-gallery__card figcaption {
  position: absolute !important;
  left: 18px !important;
  right: 18px !important;
  bottom: 18px !important;
  max-width: 340px !important;
  padding: 12px 16px !important;
  border-radius: 18px !important;
  color: #fff !important;
  background: rgba(23, 19, 18, 0.62) !important;
  backdrop-filter: blur(10px) !important;
  font-size: clamp(13px, 1.2vw, 16px) !important;
  font-weight: 700 !important;
  line-height: 1.25 !important;
}

.reviews {
  overflow: hidden !important;
  position: relative !important;
  padding-top: clamp(44px, 7vw, 86px) !important;
  padding-bottom: clamp(44px, 7vw, 86px) !important;
  margin-bottom: clamp(46px, 6vw, 82px) !important;
}

.reviews::before {
  content: "" !important;
  position: absolute !important;
  inset: 0 !important;
  pointer-events: none !important;
  background:
    radial-gradient(circle at 12% 18%, rgba(104, 180, 86, 0.12), transparent 34%),
    radial-gradient(circle at 88% 82%, rgba(255, 183, 77, 0.14), transparent 30%) !important;
}

.reviews > .container {
  position: relative !important;
  z-index: 1 !important;
}

.reviews__header {
  max-width: 760px !important;
}

.reviews__eyebrow {
  margin: 0 0 12px !important;
  color: var(--bs-primary) !important;
  font-size: clamp(12px, 1.1vw, 14px) !important;
  font-weight: 700 !important;
  letter-spacing: 0.14em !important;
  text-transform: uppercase !important;
}

.reviews__lead {
  max-width: 620px !important;
  margin-inline: auto !important;
  color: rgba(23, 19, 18, 0.72) !important;
  font-size: clamp(14px, 1.35vw, 18px) !important;
  line-height: 1.55 !important;
}

.reviews__widget {
  padding: clamp(18px, 2.4vw, 28px) !important;
  border: 1px solid rgba(104, 180, 86, 0.18) !important;
  border-radius: 24px !important;
  background: rgba(255, 255, 255, 0.72) !important;
  box-shadow: 0 24px 60px rgba(23, 19, 18, 0.08) !important;
  backdrop-filter: blur(10px) !important;
}

.offer {
  padding-top: clamp(86px, 13vw, 170px) !important;
  padding-bottom: 0 !important;
  margin-bottom: clamp(46px, 6vw, 82px) !important;
}

.offer__images {
  height: clamp(300px, 42vw, 520px) !important;
  opacity: 0.92 !important;
}

.offer__main {
  margin: 0 auto clamp(28px, 4vw, 44px) !important;
}

.offer .container h2.word-badge {
  margin-top: 0 !important;
  margin-bottom: clamp(24px, 4vw, 42px) !important;
}

.rules {
  padding-top: clamp(44px, 7vw, 86px) !important;
  padding-bottom: clamp(44px, 7vw, 86px) !important;
  margin-bottom: clamp(46px, 6vw, 82px) !important;
}

.blog.space-pb {
  margin-bottom: clamp(44px, 6vw, 76px) !important;
}

.js-reveal {
  opacity: 1 !important;
  transform: none !important;
}

.js-reveal.is-visible {
  animation: sectionReveal 0.75s ease both !important;
}

@media (max-width: 991.98px) {
  main > section:not(.wallpaper):not(.team) {
    margin-bottom: 54px !important;
  }

  .journey-gallery__shell {
    grid-template-columns: 1fr !important;
  }

  .journey-gallery__text {
    max-width: 100% !important;
  }

  .offer {
    padding-top: 96px !important;
  }

  .offer__images {
    height: 360px !important;
  }

  .rules {
    padding-top: 42px !important;
    padding-bottom: 42px !important;
  }
}

@media (max-width: 575.98px) {
  main > section:not(.wallpaper):not(.team) {
    margin-bottom: 42px !important;
  }

  .journey-gallery__shell {
    padding: 22px !important;
    border-radius: 28px !important;
  }

  .journey-gallery__grid {
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
    grid-auto-rows: 128px !important;
  }

  .journey-gallery__card_main {
    grid-column: 1 / -1 !important;
    grid-row: span 2 !important;
  }

  .journey-gallery__card:not(.journey-gallery__card_main) {
    grid-column: span 1 !important;
    grid-row: span 1 !important;
  }

  .journey-gallery__card figcaption {
    left: 12px !important;
    right: 12px !important;
    bottom: 12px !important;
  }

  .offer {
    padding-top: 74px !important;
  }

  .offer__images {
    height: 300px !important;
  }
}

/* Polished road heading, photo collage and guided sequence */
.road h2.word-badge {
  max-width: 850px !important;
  font-size: clamp(40px, 6.4vw, 82px) !important;
  line-height: 1.02 !important;
  letter-spacing: -0.025em !important;
  word-spacing: 0.08em !important;
  text-wrap: balance !important;
}

.road__metric {
  letter-spacing: -0.035em !important;
}

.road__step_3 .road__metric {
  font-size: clamp(40px, 5.2vw, 70px) !important;
}

.offer {
  padding-top: clamp(24px, 4vw, 54px) !important;
  overflow: hidden !important;
}

.offer__images {
  position: relative !important;
  top: auto !important;
  left: auto !important;
  width: min(1180px, calc(100% - 28px)) !important;
  height: clamp(260px, 38vw, 460px) !important;
  margin: 0 auto clamp(28px, 4vw, 48px) !important;
  pointer-events: none !important;
}

.offer__images::before {
  content: "" !important;
  position: absolute !important;
  inset: 8% 6% 5% !important;
  border-radius: 42px !important;
  background: rgba(104, 180, 86, 0.12) !important;
  filter: blur(8px) !important;
}

.offer__images img {
  position: absolute !important;
  display: block !important;
  object-fit: cover !important;
  border-radius: clamp(18px, 2.4vw, 34px) !important;
  box-shadow: 0 24px 64px rgba(23, 19, 18, 0.18) !important;
  transform: none !important;
  opacity: 1 !important;
}

.offer__images img:nth-child(1) {
  width: 45% !important;
  height: 72% !important;
  left: 27% !important;
  top: 8% !important;
  z-index: 3 !important;
}

.offer__images img:nth-child(2) {
  width: 22% !important;
  height: 44% !important;
  left: 5% !important;
  top: 16% !important;
  z-index: 2 !important;
}

.offer__images img:nth-child(3) {
  width: 24% !important;
  height: 46% !important;
  right: 4% !important;
  top: 10% !important;
  z-index: 2 !important;
}

.offer__images img:nth-child(4) {
  width: 26% !important;
  height: 42% !important;
  left: 12% !important;
  bottom: 2% !important;
  top: auto !important;
  z-index: 4 !important;
}

.offer__images img:nth-child(5) {
  width: 23% !important;
  height: 42% !important;
  right: 17% !important;
  bottom: 0 !important;
  top: auto !important;
  left: auto !important;
  z-index: 4 !important;
}

.guide__wrapper::after {
  opacity: 0 !important;
  animation: none !important;
}

.guide__wrapper.is-visible::after {
  animation: guideRoutePulse 2.4s ease-in-out 0.1s 1 forwards, guideRouteGlow 3.6s ease-in-out 2.5s infinite !important;
}

@keyframes guideRouteGlow {
  0%,
  100% {
    transform: translateY(0);
    opacity: 0.42;
  }
  50% {
    transform: translateY(calc(100% + 170px));
    opacity: 1;
  }
}

@media (max-width: 767.98px) {
  .offer__images {
    height: 360px !important;
  }

  .offer__images img:nth-child(1) {
    width: 68% !important;
    height: 56% !important;
    left: 16% !important;
    top: 4% !important;
  }

  .offer__images img:nth-child(2) {
    width: 38% !important;
    height: 34% !important;
    left: 0 !important;
    top: 48% !important;
  }

  .offer__images img:nth-child(3) {
    width: 40% !important;
    height: 34% !important;
    right: 0 !important;
    top: 46% !important;
  }

  .offer__images img:nth-child(4),
  .offer__images img:nth-child(5) {
    display: none !important;
  }
}

/* Tour pages redesign */
.road__step::before,
.road__step::after {
  display: none !important;
  content: none !important;
}

.road__caption {
  text-transform: none !important;
}

.content-gallery,
.highlights,
.program,
.pricing {
  margin-bottom: clamp(46px, 6vw, 84px) !important;
}

.content-gallery h2,
.highlights h2,
.program h2,
.pricing h2,
.about h2 {
  font-size: clamp(42px, 6vw, 76px) !important;
  line-height: 0.95 !important;
  letter-spacing: -0.035em !important;
  text-transform: uppercase !important;
}

.content-gallery__grid {
  display: grid !important;
  grid-template-columns: repeat(6, minmax(0, 1fr)) !important;
  grid-auto-flow: dense !important;
  gap: clamp(12px, 1.6vw, 20px) !important;
  column-count: initial !important;
}

.content-gallery__item {
  min-height: 240px !important;
  margin: 0 !important;
  border-radius: clamp(22px, 2vw, 34px) !important;
}

.content-gallery__item:nth-child(1) {
  grid-column: span 3 !important;
  grid-row: span 2 !important;
}

.content-gallery__item:nth-child(2),
.content-gallery__item:nth-child(3) {
  grid-column: span 3 !important;
}

.content-gallery__item:nth-child(n+4) {
  grid-column: span 2 !important;
}

.content-gallery__item a,
.content-gallery__item img {
  height: 100% !important;
}

.content-gallery__item img {
  min-height: 240px !important;
  object-fit: cover !important;
}

.content-gallery__item:nth-child(1) img {
  min-height: 500px !important;
}

.highlights__grid,
.pricing__content {
  display: grid !important;
  grid-template-columns: repeat(4, minmax(0, 1fr)) !important;
  gap: clamp(14px, 1.6vw, 20px) !important;
  align-items: stretch !important;
}

.highlights__item,
.pricing__item {
  min-height: 190px !important;
  display: flex !important;
  flex-direction: column !important;
  justify-content: space-between !important;
  border-radius: 30px !important;
  background:
    linear-gradient(145deg, rgba(255, 255, 255, 0.96), rgba(255, 250, 242, 0.92)),
    radial-gradient(circle at 100% 0%, rgba(104, 180, 86, 0.14), transparent 34%) !important;
}

.highlights__grid .highlights__item:nth-last-child(1):nth-child(4n + 1),
.pricing__content .pricing__item:nth-last-child(1):nth-child(4n + 1) {
  grid-column: span 4 !important;
}

.highlights__grid .highlights__item:nth-last-child(2):nth-child(4n + 1),
.highlights__grid .highlights__item:nth-last-child(1):nth-child(4n + 2),
.pricing__content .pricing__item:nth-last-child(2):nth-child(4n + 1),
.pricing__content .pricing__item:nth-last-child(1):nth-child(4n + 2) {
  grid-column: span 2 !important;
}

.program__timeline {
  display: grid !important;
  grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
  gap: clamp(14px, 1.6vw, 20px) !important;
  padding-left: 0 !important;
  border: 0 !important;
}

.program__item {
  min-height: 170px !important;
  border: 1px solid rgba(104, 180, 86, 0.26) !important;
  border-radius: 30px !important;
  overflow: hidden !important;
}

.program__item::before {
  display: none !important;
  content: none !important;
}

.program__timeline .program__item:nth-last-child(1):nth-child(2n + 1) {
  grid-column: span 2 !important;
}

@media (max-width: 1199.98px) {
  .highlights__grid,
  .pricing__content {
    grid-template-columns: repeat(3, minmax(0, 1fr)) !important;
  }

  .highlights__grid .highlights__item,
  .pricing__content .pricing__item {
    grid-column: auto !important;
  }

  .highlights__grid .highlights__item:nth-last-child(1):nth-child(3n + 1),
  .pricing__content .pricing__item:nth-last-child(1):nth-child(3n + 1) {
    grid-column: span 3 !important;
  }

  .highlights__grid .highlights__item:nth-last-child(2):nth-child(3n + 1),
  .highlights__grid .highlights__item:nth-last-child(1):nth-child(3n + 2),
  .pricing__content .pricing__item:nth-last-child(2):nth-child(3n + 1),
  .pricing__content .pricing__item:nth-last-child(1):nth-child(3n + 2) {
    grid-column: span 1 !important;
  }
}

@media (max-width: 991.98px) {
  .content-gallery__grid {
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
  }

  .content-gallery__item,
  .content-gallery__item:nth-child(n) {
    grid-column: span 1 !important;
    grid-row: span 1 !important;
    min-height: 260px !important;
  }

  .content-gallery__item:nth-child(1) {
    grid-column: span 2 !important;
  }

  .content-gallery__item:nth-child(1) img {
    min-height: 360px !important;
  }

  .highlights__grid,
  .pricing__content,
  .program__timeline {
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
  }

  .highlights__grid .highlights__item:nth-child(n),
  .pricing__content .pricing__item:nth-child(n),
  .program__timeline .program__item:nth-child(n) {
    grid-column: auto !important;
  }
}

@media (max-width: 575.98px) {
  .content-gallery__grid,
  .highlights__grid,
  .pricing__content,
  .program__timeline {
    grid-template-columns: 1fr !important;
  }

  .content-gallery__item:nth-child(n),
  .highlights__grid .highlights__item:nth-child(n),
  .pricing__content .pricing__item:nth-child(n),
  .program__timeline .program__item:nth-child(n) {
    grid-column: auto !important;
  }

  .content-gallery__item:nth-child(1) img,
  .content-gallery__item img {
    min-height: 280px !important;
  }
}

/* Reliable no-orphan tour card grids */
.content-gallery {
  padding-bottom: 0 !important;
}

.highlights__grid,
.pricing__content {
  grid-template-columns: repeat(12, minmax(0, 1fr)) !important;
}

.highlights__grid .highlights__item,
.pricing__content .pricing__item {
  grid-column: span 3 !important;
}

.highlights__grid .highlights__item:nth-last-child(1):nth-child(4n + 1),
.pricing__content .pricing__item:nth-last-child(1):nth-child(4n + 1) {
  grid-column: span 12 !important;
}

.highlights__grid .highlights__item:nth-last-child(2):nth-child(4n + 1),
.highlights__grid .highlights__item:nth-last-child(1):nth-child(4n + 2),
.pricing__content .pricing__item:nth-last-child(2):nth-child(4n + 1),
.pricing__content .pricing__item:nth-last-child(1):nth-child(4n + 2) {
  grid-column: span 6 !important;
}

.highlights__grid .highlights__item:nth-last-child(3):nth-child(4n + 1),
.highlights__grid .highlights__item:nth-last-child(2):nth-child(4n + 2),
.highlights__grid .highlights__item:nth-last-child(1):nth-child(4n + 3),
.pricing__content .pricing__item:nth-last-child(3):nth-child(4n + 1),
.pricing__content .pricing__item:nth-last-child(2):nth-child(4n + 2),
.pricing__content .pricing__item:nth-last-child(1):nth-child(4n + 3) {
  grid-column: span 4 !important;
}

@media (max-width: 1199.98px) {
  .highlights__grid .highlights__item,
  .pricing__content .pricing__item {
    grid-column: span 4 !important;
  }

  .highlights__grid .highlights__item:nth-last-child(1):nth-child(3n + 1),
  .pricing__content .pricing__item:nth-last-child(1):nth-child(3n + 1) {
    grid-column: span 12 !important;
  }

  .highlights__grid .highlights__item:nth-last-child(2):nth-child(3n + 1),
  .highlights__grid .highlights__item:nth-last-child(1):nth-child(3n + 2),
  .pricing__content .pricing__item:nth-last-child(2):nth-child(3n + 1),
  .pricing__content .pricing__item:nth-last-child(1):nth-child(3n + 2) {
    grid-column: span 6 !important;
  }
}

@media (max-width: 991.98px) {
  .highlights__grid .highlights__item,
  .pricing__content .pricing__item {
    grid-column: span 6 !important;
  }
}

@media (max-width: 575.98px) {
  .highlights__grid .highlights__item,
  .pricing__content .pricing__item {
    grid-column: span 12 !important;
  }
}

/* Final tour reliability, centered hero subtitles and premium FAQ */
.wallpaper:not(.space-pb) .row {
  align-items: center !important;
}

.wallpaper:not(.space-pb) .col {
  display: flex !important;
  flex-direction: column !important;
  align-items: center !important;
  justify-content: center !important;
  text-align: center !important;
  min-width: 0 !important;
}

.wallpaper.space-pb {
  min-height: clamp(720px, 92vh, 920px) !important;
}

.wallpaper.space-pb .container,
.wallpaper.space-pb .row,
.wallpaper.space-pb .col {
  height: 100% !important;
}

.wallpaper.space-pb .row {
  align-items: flex-end !important;
}

.wallpaper.space-pb .col {
  display: flex !important;
  flex-direction: column !important;
  align-items: center !important;
  justify-content: flex-end !important;
  padding-bottom: clamp(28px, 5vw, 64px) !important;
}

.wallpaper.space-pb h1 {
  order: 1 !important;
  margin-bottom: clamp(18px, 2.4vw, 32px) !important;
}

.wallpaper.space-pb p.shadows {
  order: 2 !important;
  margin-bottom: clamp(28px, 4vw, 48px) !important;
}

.wallpaper.space-pb .wallpaper__booking {
  order: 3 !important;
  width: min(100%, 760px) !important;
  margin-top: clamp(8px, 1.5vw, 18px) !important;
}

.wallpaper:not(.space-pb) h1 {
  order: 1 !important;
  width: min(100%, 980px) !important;
  margin: 0 auto !important;
  text-align: center !important;
}

.wallpaper:not(.space-pb) p.text-white {
  order: 2 !important;
  display: block !important;
  width: fit-content !important;
  max-width: min(92vw, 760px) !important;
  margin: clamp(12px, 2vw, 18px) auto 0 !important;
  text-align: center !important;
}

.wallpaper--image-missing {
  background-image:
    radial-gradient(circle at 20% 20%, rgba(104, 180, 86, 0.26), transparent 34%),
    linear-gradient(135deg, #171312 0%, #2b241f 55%, #0f0d0c 100%) !important;
}

.content-gallery__item.is-image-missing {
  display: none !important;
}

img.is-image-missing {
  visibility: hidden !important;
}

.highlights__grid,
.pricing__content {
  overflow: visible !important;
}

.highlights__item,
.pricing__item {
  min-width: 0 !important;
  overflow: hidden !important;
  padding: clamp(22px, 2.6vw, 34px) !important;
}

.highlights__item h3,
.pricing__item h3,
.program__item h3 {
  max-width: 100% !important;
  overflow-wrap: anywhere !important;
  word-break: normal !important;
  line-height: 1.04 !important;
}

.highlights__item p,
.pricing__item p,
.program__item p {
  max-width: 100% !important;
  overflow-wrap: anywhere !important;
  word-break: normal !important;
  margin-bottom: 0 !important;
}

.faq {
  margin: clamp(54px, 7vw, 98px) 0 !important;
  padding: 0 !important;
  background: transparent !important;
  overflow: visible !important;
}

.faq__layout {
  display: grid !important;
  grid-template-columns: minmax(320px, 1fr) minmax(320px, 1fr) !important;
  gap: clamp(24px, 4vw, 58px) !important;
  align-items: stretch !important;
}

.faq__header {
  margin-bottom: clamp(28px, 4vw, 48px) !important;
  text-align: center !important;
}

.faq__header h2 {
  margin-bottom: 0 !important;
}

.faq__visual {
  min-width: 0 !important;
}

.faq__visual-card {
  position: sticky !important;
  top: 92px !important;
  min-height: clamp(520px, 52vw, 760px) !important;
  height: 100% !important;
  display: flex !important;
  flex-direction: column !important;
  justify-content: space-between !important;
  padding: clamp(24px, 4vw, 46px) !important;
  border-radius: clamp(28px, 4vw, 52px) !important;
  color: #fff !important;
  background:
    radial-gradient(circle at 18% 14%, rgba(145, 214, 111, 0.22), transparent 28%),
    linear-gradient(145deg, #171312 0%, #2a241f 58%, #11100f 100%) !important;
  box-shadow: 0 28px 80px rgba(23, 19, 18, 0.18) !important;
  overflow: hidden !important;
}

.faq__visual-card::before {
  content: "" !important;
  position: absolute !important;
  inset: 18px !important;
  border: 1px solid rgba(244, 238, 227, 0.13) !important;
  border-radius: inherit !important;
}

.faq__visual-badge {
  position: relative !important;
  z-index: 2 !important;
  width: max-content !important;
  padding: 10px 16px !important;
  border: 1px solid rgba(244, 238, 227, 0.22) !important;
  border-radius: 999px !important;
  color: #f4eee3 !important;
  font-size: 12px !important;
  font-weight: 800 !important;
  letter-spacing: 0.18em !important;
}

.faq__mountains,
.faq__route {
  display: none !important;
}

.faq__parallax {
  position: relative !important;
  z-index: 1 !important;
  flex: 1 1 auto !important;
  min-height: clamp(280px, 34vw, 520px) !important;
  margin: clamp(12px, 2vw, 24px) 0 !important;
  border-radius: clamp(22px, 3vw, 34px) !important;
  overflow: hidden !important;
  isolation: isolate !important;
}

.faq__parallax::after {
  content: "" !important;
  position: absolute !important;
  inset: 0 !important;
  background: linear-gradient(180deg, rgba(23, 19, 18, 0.08) 0%, rgba(23, 19, 18, 0.42) 100%) !important;
  pointer-events: none !important;
  z-index: 4 !important;
}

.faq__parallax-layer {
  position: absolute !important;
  inset: auto 0 0 0 !important;
  width: 118% !important;
  max-width: none !important;
  height: auto !important;
  min-height: 100% !important;
  object-fit: cover !important;
  object-position: center bottom !important;
  will-change: transform !important;
  pointer-events: none !important;
}

.faq__parallax-layer--sky {
  z-index: 1 !important;
  bottom: 8% !important;
  opacity: 0.92 !important;
}

.faq__parallax-layer--mid {
  z-index: 2 !important;
  bottom: 0 !important;
  opacity: 0.96 !important;
}

.faq__parallax-layer--front {
  z-index: 3 !important;
  bottom: -4% !important;
  opacity: 1 !important;
}

.faq__visual-card p {
  position: relative !important;
  z-index: 2 !important;
  max-width: 320px !important;
  margin: 0 !important;
  color: rgba(244, 238, 227, 0.82) !important;
  font-size: clamp(15px, 1.4vw, 18px) !important;
  line-height: 1.5 !important;
}

.faq__panel {
  min-width: 0 !important;
  min-height: clamp(520px, 52vw, 760px) !important;
  display: flex !important;
  flex-direction: column !important;
  padding: clamp(24px, 4vw, 44px) !important;
  border: 1px solid rgba(104, 180, 86, 0.18) !important;
  border-radius: clamp(28px, 4vw, 52px) !important;
  background:
    linear-gradient(145deg, rgba(255, 255, 255, 0.92), rgba(255, 250, 242, 0.76)),
    radial-gradient(circle at 100% 0, rgba(104, 180, 86, 0.12), transparent 34%) !important;
  box-shadow: 0 24px 70px rgba(23, 19, 18, 0.08) !important;
}

.faq__eyebrow {
  margin: 0 0 12px !important;
  color: var(--bs-primary) !important;
  font-size: 12px !important;
  font-weight: 800 !important;
  letter-spacing: 0.16em !important;
  text-transform: uppercase !important;
}

.faq h2 {
  max-width: 620px !important;
  margin: 0 0 clamp(24px, 4vw, 42px) !important;
  text-align: left !important;
  font-size: clamp(42px, 5.6vw, 76px) !important;
  line-height: 0.96 !important;
  letter-spacing: -0.035em !important;
}

.faq h2::after {
  display: none !important;
}

.faq__accordion {
  max-width: none !important;
  margin: 0 !important;
  display: grid !important;
  gap: 12px !important;
}

.faq__item,
.faq__item:hover,
.faq__item.faq__item_active {
  border: 1px solid rgba(104, 180, 86, 0.18) !important;
  border-radius: 24px !important;
  background: rgba(255, 255, 255, 0.82) !important;
  box-shadow: none !important;
  overflow: hidden !important;
}

.faq__question {
  padding: clamp(18px, 2vw, 24px) !important;
}

.faq__question-text {
  font-size: clamp(17px, 1.6vw, 22px) !important;
  line-height: 1.18 !important;
}

.faq__content {
  padding: 0 clamp(18px, 2vw, 24px) clamp(18px, 2vw, 24px) !important;
}

@keyframes faqRouteGlow {
  0%, 100% {
    opacity: 0.5;
    transform: translateY(0);
  }
  50% {
    opacity: 1;
    transform: translateY(-8px);
  }
}

@media (max-width: 991.98px) {
  .faq__layout {
    grid-template-columns: 1fr !important;
  }

  .faq__visual-card,
  .faq__panel {
    min-height: 420px !important;
  }

  .faq__header {
    text-align: left !important;
  }

  .faq h2 {
    text-align: left !important;
  }
}

@media (max-width: 575.98px) {
  .wallpaper h1 {
    font-size: clamp(42px, 14vw, 58px) !important;
  }

  .faq__visual-card {
    min-height: 300px !important;
  }

  .faq__panel {
    padding: 22px !important;
  }
}