  html,
  body {
       overflow-x: visible !important;
  }

  /* Terms & Conditions Content Styles */
  .terms-conditions-content {
      line-height: 1.8;
      color: #333;
  }

  .terms-conditions-content h4 {
      color: var(--black-color, #212529);
      font-weight: 600;
      margin-top: 2rem;
  }

  .terms-conditions-content h5 {
      color: #555;
      font-weight: 600;
      margin-top: 1.5rem;
  }

  .terms-conditions-content ul,
  .terms-conditions-content ol {
      margin-left: 1.5rem;
      margin-bottom: 1rem;
  }

  .terms-conditions-content ul li,
  .terms-conditions-content ol li {
      margin-bottom: 0.5rem;
  }

  .terms-conditions-content p {
      margin-bottom: 1rem;
      text-align: justify;
  }

  .terms-conditions-content blockquote {
      border-left: 4px solid #0068D9;
      padding-left: 1.5rem;
      margin: 1.5rem 0;
      font-style: italic;
      color: #555;
  }

  .terms-conditions-content table {
      width: 100%;
      border-collapse: collapse;
      margin: 1.5rem 0;
  }

  .terms-conditions-content table td,
  .terms-conditions-content table th {
      border: 1px solid #ddd;
      padding: 8px;
      text-align: left;
  }

  .terms-conditions-content table th {
      background-color: #f8f9fa;
      font-weight: 600;
  }

  .terms-conditions-content figure {
      margin: 1.5rem 0;
  }

  .terms-conditions-content figure img {
      max-width: 100%;
      height: auto;
  }

  .terms-conditions-content figcaption {
      font-size: 0.9rem;
      color: #666;
      margin-top: 0.5rem;
      text-align: center;
  }

  .terms-conditions-content pre {
      background: #f8f9fa;
      padding: 1rem;
      border-radius: 4px;
      overflow-x: auto;
      margin: 1.5rem 0;
  }

  .terms-conditions-content code {
      font-family: 'Courier New', monospace;
      font-size: 0.9em;
  }

  .terms-conditions-content hr {
      margin: 2rem 0;
      border: none;
      border-top: 1px solid #ddd;
  }

  /* Liability Waiver Content Styles */
  .liability-waiver-content {
      line-height: 1.8;
      color: #333;
  }

  .liability-waiver-content h4 {
      color: var(--black-color, #212529);
      font-weight: 600;
      margin-top: 2rem;
  }

  .liability-waiver-content h5 {
      color: #555;
      font-weight: 600;
      margin-top: 1.5rem;
  }

  .liability-waiver-content ul,
  .liability-waiver-content ol {
      margin-left: 1.5rem;
      margin-bottom: 1rem;
  }

  .liability-waiver-content ul li,
  .liability-waiver-content ol li {
      margin-bottom: 0.5rem;
  }

  .liability-waiver-content p {
      margin-bottom: 1rem;
      text-align: justify;
  }

  .tour-detail-page {
       padding: 20px 0 40px 0;
       background: #ffffff;
       min-height: 80vh;
  }

  @media (min-width: 992px) {
       .tour-detail-page .row:last-of-type .col-lg-4 {
            position: sticky !important;
          top: var(--tour-booking-sticky-top, 20px);
          /* Default, can be updated by JavaScript based on header height */
            height: fit-content !important;
            z-index: 10 !important;
       }
  }


  /* Left side content - Professional carousel style */
  .tour-title-section {
       margin-bottom: 0;
       background: transparent;
       border-radius: 0;
       padding: 0;
       box-shadow: none !important;
  }

  .tour-title {
       font-size: 36px;
       font-weight: 700;
       color: #212529;
       margin: 0;
       line-height: 1.2;
  }

  .tour-meta {
       background: transparent;
       border-radius: 0;
       padding: 0;
       display: flex;
       align-items: center;
       flex-wrap: wrap;
       gap: 12px;
       margin-bottom: 20px;
       box-shadow: none !important;
  }

  .tour-rating {
       display: flex;
       align-items: center;
       column-gap: 8px;
       flex-direction: row;
       font-size: 1rem;
       font-weight: 500;
       line-height: 1.375rem;
  }

  .tour-rating-stars {
       align-self: center;
       display: inline-flex;
       font-size: 24px;
       font-weight: 100;
       line-height: normal;
       color: #C8963E;
       letter-spacing: 0;
       -webkit-font-smoothing: antialiased;
       -moz-osx-font-smoothing: grayscale;
  }

  .tour-rating-value {
       font-weight: 500;
       color: #1a2b49;
       font-size: 1rem;
       line-height: 1.375rem;
  }

  .tour-reviews {
       color: #1a2b49;
       text-decoration: underline;
       text-decoration-thickness: 0.1em;
       text-underline-offset: 0.24em;
       text-decoration-color: #1a2b49;
       cursor: pointer;
       font-size: 1rem;
       font-weight: 500;
       line-height: 1.375rem;
       transition: color 0.2s ease-out;
  }

  .tour-reviews:hover {
       color: #304c84;
       text-decoration-color: #304c84;
  }

  .tour-provider {
       color: #63687a;
       font-size: 1rem;
       font-weight: 500;
       line-height: 1.375rem;
       width: fit-content;
       height: fit-content;
       -webkit-font-smoothing: antialiased;
  }


  .tour-actions {
       display: flex;
       gap: 16px;
       align-items: center;
       justify-content: flex-end;
       margin-bottom: 16px;
       margin-top: 0;
       padding-bottom: 0;
  }

  .tour-action-link {
       display: flex;
       align-items: center;
       gap: 8px;
       color: #1a2b49;
       background: transparent;
       border: 2px solid transparent;
       border-radius: unset;
       text-decoration: none;
       font-size: 1rem;
       font-weight: 500;
       line-height: 1.375rem;
       padding: 0.25em 0;
       cursor: pointer;
       transition: color 0.2s ease-out;
       outline: 0;
  }

  .tour-action-link:hover {
       color: #304c84;
  }

  .tour-action-link span {
       text-decoration: underline;
       text-decoration-thickness: 0.1em;
       text-underline-offset: 0.24em;
       text-decoration-color: #1a2b49;
       transition: text-decoration-color 0.2s ease-out;
  }

  .tour-action-link:hover span {
       text-decoration-color: #304c84;
  }

  .tour-action-link i,
  .tour-action-link .bi {
       align-self: center;
       display: inline-flex;
       font-size: 24px;
       font-weight: 100;
       line-height: normal;
       -webkit-font-smoothing: antialiased;
       -moz-osx-font-smoothing: grayscale;
  }

  /* Wishlist and Share Actions Bar */
  .tour-actions-bar {
       display: flex;
       gap: 16px;
       align-items: center;
       justify-content: flex-end;
       margin-bottom: 12px;
  }

  .tour-action-btn {
       display: flex;
       align-items: center;
       justify-content: center;
       gap: 6px;
       width: auto;
       height: 32px;
       padding: 0 12px;
       background: transparent;
       border: none;
       color: var(--text-color);
       cursor: pointer;
       transition: all 0.2s ease;
       text-decoration: none;
       font-size: 14px;
       font-weight: 500;
  }

  .tour-action-btn:hover {
       color: var(--primary-color1);
  }

  .tour-action-btn i {
       font-size: 20px;
  }

  .tour-action-btn span {
       text-decoration: underline;
       text-decoration-thickness: 0.1em;
       text-underline-offset: 0.24em;
  }

  @media (max-width: 768px) {
       .tour-actions-bar {
            justify-content: flex-start;
            flex-wrap: wrap;
            gap: 12px;
       }

       .tour-action-btn {
            font-size: 12px;
            height: 28px;
            padding: 0 10px;
            white-space: nowrap;
       }

       .tour-action-btn span {
            white-space: nowrap;
       }
  }

  .tour-action-btn.wishlist-btn.active {
       color: var(--primary-color1);
  }

  .tour-action-btn.wishlist-btn.active i {
       color: var(--primary-color1);
  }

  .tour-gallery {
       background: #ffffff;
       border-radius: 8px;
       padding: 16px;
       margin-bottom: 20px;
       box-shadow: none !important;
       overflow: hidden;
  }

  .tour-gallery-main {
       display: grid;
       grid-template-columns: 2fr 1fr;
       gap: 12px;
       margin-bottom: 12px;
  }

  .tour-gallery-main-image {
       width: 100%;
       max-width: 100%;
       height: 400px;
       object-fit: cover;
       border-radius: 8px;
  }

  .tour-gallery-side {
       display: flex;
       flex-direction: column;
       gap: 12px;
  }

  .tour-gallery-side-image {
       width: 100%;
       max-width: 100%;
       height: 194px;
       object-fit: cover;
       border-radius: 8px;
       position: relative;
       overflow: hidden;
  }

  .tour-gallery-thumb {
       width: 100%;
       max-width: 100%;
       height: 100%;
       object-fit: cover;
       border-radius: 8px;
  }

  .tour-gallery-main-image {
       cursor: pointer;
       transition: opacity 0.2s;
  }

  .tour-gallery-main-image:hover {
       opacity: 0.9;
  }

  .gallery-more-overlay {
       transition: background 0.2s;
  }

  .gallery-more-overlay:hover {
       background: rgba(0, 0, 0, 0.8) !important;
  }

  /* Bootstrap Carousel Modal Styles for Gallery */
  #tourGalleryModal .modal-content {
       background: #000;
  }

  #tourGalleryModal .carousel-item img {
       max-width: 100%;
       max-height: 100vh;
       object-fit: contain;
       margin: 0 auto;
  }

  /* Custom slider buttons for gallery carousel */
  #tourGalleryModal .slider-btn-grp {
       position: absolute;
       top: 50%;
       left: 0;
       right: 0;
       transform: translateY(-50%);
       display: flex;
       justify-content: space-between;
       padding: 0 20px;
       pointer-events: none;
       z-index: 10;
  }

  #tourGalleryModal .slider-btn-grp .slider-btn {
       min-width: 40px;
       max-width: 40px;
       height: 40px;
       background-color: rgba(255, 255, 255, 0.9);
       border: 1px solid rgba(255, 255, 255, 0.9);
       border-radius: 50%;
       display: flex;
       align-items: center;
       justify-content: center;
       transition: 0.5s;
       pointer-events: auto;
       cursor: pointer;
  }

  #tourGalleryModal .slider-btn-grp .slider-btn svg {
       fill: none;
       stroke: #1a2b49;
       transition: 0.5s;
  }

  #tourGalleryModal .slider-btn-grp .slider-btn:hover {
       background-color: var(--primary-color1);
       border-color: var(--primary-color1);
  }

  #tourGalleryModal .slider-btn-grp .slider-btn:hover svg {
       stroke: var(--white-color);
  }

  #tourGalleryModal .carousel-indicators {
       bottom: 20px;
       margin-bottom: 0;
  }

  #tourGalleryModal .carousel-indicators button {
       width: 12px;
       height: 12px;
       border-radius: 50%;
       background-color: rgba(255, 255, 255, 0.5);
       border: 2px solid rgba(255, 255, 255, 0.8);
  }

  #tourGalleryModal .carousel-indicators button.active {
       background-color: #fff;
  }

  /* React Gallery Modal Styles */
  .gallery-modal {
       max-width: 100vw !important;
       max-height: 100vh !important;
       margin: 0 !important;
       padding: 0 !important;
       border-radius: 0 !important;
       background: transparent !important;
       box-shadow: none !important;
  }

  .gallery-modal .gallery-carousel,
  .gallery-modal .gallery-carousel .swiper,
  .gallery-modal .gallery-carousel .swiper-wrapper,
  .gallery-modal .gallery-carousel .swiper-slide {
       height: 100%;
  }

  .gallery-modal .slider-btn-grp {
       position: absolute;
       top: 50%;
       left: 0;
       right: 0;
       transform: translateY(-50%);
       display: flex;
       justify-content: space-between;
       padding: 0 20px;
       pointer-events: none;
       z-index: 10;
  }

  .gallery-modal .slider-btn-grp .slider-btn {
       min-width: 40px;
       max-width: 40px;
       height: 40px;
       background-color: rgba(255, 255, 255, 0.9);
       border: 1px solid rgba(255, 255, 255, 0.9);
       border-radius: 50%;
       display: flex;
       align-items: center;
       justify-content: center;
       transition: 0.5s;
       pointer-events: auto;
       cursor: pointer;
  }

  .gallery-modal .slider-btn-grp .slider-btn svg {
       fill: none;
       stroke: #1a2b49;
       transition: 0.5s;
  }


  .gallery-modal .slider-btn-grp .slider-btn:hover {
       background-color: var(--primary-color1);
       border-color: var(--primary-color1);
  }

  .gallery-modal .slider-btn-grp .slider-btn:hover svg {
       stroke: var(--white-color);
  }

  .gallery-modal .swiper-pagination {
       bottom: 20px;
  }

  .gallery-modal .swiper-pagination-bullet {
       width: 12px;
       height: 12px;
       border-radius: 50%;
       background-color: rgba(255, 255, 255, 0.5);
       border: 2px solid rgba(255, 255, 255, 0.8);
       opacity: 1;
       transition: width 0.3s ease, background-color 0.3s ease;
  }

  .gallery-modal .swiper-pagination-bullet-active {
       width: 30px;
       border-radius: 50px;
       background-color: #fff;
  }

  @media (max-width: 768px) {
       .gallery-modal .slider-btn-grp {
            padding: 0 10px;
       }

       .gallery-modal .slider-btn-grp .slider-btn {
            min-width: 35px;
            max-width: 35px;
            height: 35px;
       }
  }

  @media (max-width: 768px) {
       #tourGalleryModal .slider-btn-grp {
            padding: 0 10px;
       }

       #tourGalleryModal .slider-btn-grp .slider-btn {
            min-width: 35px;
            max-width: 35px;
            height: 35px;
       }

       #tourGalleryModal .slider-btn-grp .slider-btn svg {
            width: 12px;
            height: 12px;
       }

       #tourGalleryModal .carousel-indicators {
            bottom: 10px;
       }
  }


  /* Responsive */
  @media (max-width: 992px) {
       .booking-widget {
            position: relative;
            top: 0;
       }

       .tour-gallery-main {
            grid-template-columns: 1fr;
       }

       .tour-gallery-side {
            flex-direction: row;
       }

       .tour-gallery-side-image {
            height: 200px;
       }
  }

  @media (max-width: 768px) {
       .tour-title {
            font-size: 28px;
       }
  }

  /* Booking Widget Styles */
  .booking-widget-card {
       background: var(--white-color);
       border-radius: 12px;
       padding: 12px;
       box-shadow: 0 2px 6px rgba(0, 0, 0, 0.08);
       border: 1px solid var(--borders-color);
       overflow-x: hidden;
       box-sizing: border-box;
  }

  .booking-widget-card.booking-widget-tagged {
       position: relative;
       overflow: visible;
  }

  /* Main tour booking card (desktop + mobile) */
  .tour-booking-card {
       position: relative;
       border: 2px solid #d1d5db;
       border-radius: 12px;
       background: #fff;
       overflow: visible;
  }

  .tour-booking-card[data-expanded="true"] {
       border-color: #006ce4;
  }

  .tour-booking-tag {
       position: absolute;
       top: -14px;
       left: 16px;
       z-index: 5;
       display: inline-flex;
       align-items: center;
       padding: 5px 10px;
       border-radius: 4px;
       background: #1a2b49;
       color: #ffffff;
       font-size: 14px;
       font-weight: 600;
       line-height: 1.125rem;
       box-shadow: 0 6px 12px rgba(26, 43, 73, 0.2);
       white-space: nowrap;
  }

  .tour-booking-header {
       padding-top: 12px;
  }

  .tour-booking-title {
       padding-right: 32px;
  }

  .tour-booking-duration {
       margin-top: 12px;
       display: flex;
       align-items: center;
       gap: 8px;
       color: #1a2b49;
       font-size: 14px;
       font-weight: 600;
  }

  .tour-booking-duration-icon svg {
       width: 16px;
       height: 16px;
       display: block;
  }

  .tour-booking-duration-icon img {
       width: 16px;
       height: 16px;
       display: block;
  }

  .tour-booking-collapsed-summary {
     margin: 16px 0 0 0;
     padding: 16px;
     background: #f3f4f6;
     border-top: 1px solid #e5e7eb;
     border-radius: 0 0 10px 10px;
  }

/* Main booking card should let collapsed summary reach edges */
.tour-booking-card .tour-booking-collapsed-summary {
   margin: 16px -16px -16px;
}

@media (max-width: 991px) {
   #booking-details-section-mobile .booking-actions-row {
        margin-bottom: 12px !important;
   }
   .variant-booking-section .pickup-summary-inline {
        display: none !important;
   }

   .variant-booking-section .pickup-summary-stacked {
        display: block !important;
   }

   .variant-booking-section .variant-pickup-block {
        flex: 1 1 100% !important;
        min-width: 100% !important;
   }

   .variant-booking-section .variant-time-select {
        flex: 1 1 100% !important;
        min-width: 100% !important;
        align-self: stretch !important;
   }
   #booking-details-section-mobile[data-expanded="true"] {
        padding-bottom: 0 !important;
   }

   #booking-details-section-mobile .tour-booking-collapsed-summary {
        margin: 16px -12px -12px;
   }

   #booking-details-section-mobile .tour-booking-price-panel {
        margin: 0 -12px -12px -12px !important;
   }

   #booking-details-section-mobile[data-expanded="true"] .tour-booking-price-panel {
        margin: 0 -12px 0 -12px !important;
   }

   #booking-details-section-mobile .booking-details-content > .tour-booking-price-panel {
        margin-bottom: 0 !important;
        padding-bottom: 0 !important;
   }

   .booking-widget-card .tour-booking-price-panel {
        margin: 0 -12px -12px -12px !important;
   }

   .variant-booking-section .tour-booking-price-panel {
        margin: 0 -12px 0 -12px !important;
   }

   .tour-variants-container .tour-booking-price-panel-inner {
        flex-direction: column !important;
        align-items: center !important;
        gap: 16px !important;
   }

   .tour-variants-container .tour-booking-price-panel-inner > div:first-child {
        width: 100% !important;
        text-align: center !important;
   }

   .tour-variants-container .tour-booking-price-panel .booking-actions-row {
        width: 100% !important;
        max-width: 500px !important;
   }
}

@media (min-width: 769px) {
   .variant-booking-section .pickup-summary-stacked {
        display: none !important;
   }

   .variant-booking-section[data-expanded="true"] .tour-booking-price-panel {
        margin-bottom: 2px;
   }
}

  .tour-booking-price-value {
       font-size: 28px;
       font-weight: 700;
       color: #1a2b49;
       margin-bottom: 6px;
  }

  .tour-booking-price-breakdown {
       font-size: 14px;
       font-weight: 600;
       color: #1a2b49;
       line-height: 1.6;
       margin-bottom: 4px;
       display: flex;
       flex-wrap: wrap;
       gap: 4px 10px;
       align-items: center;
  }

  .tour-booking-price-breakdown .tour-participant-item {
       display: inline;
  }

  .tour-booking-price-note {
       font-size: 13px;
       font-weight: 500;
       color: #4b5563;
  }

  /* Mobile Booking Details - Show below right widget on mobile */
  @media (max-width: 991px) {

       /* Booking details will be moved by JavaScript to appear after right widget */
       #booking-details-section {
            margin-top: 20px;
            padding: 12px !important;
            width: 100%;
            box-sizing: border-box;
            position: relative !important;
            z-index: 1 !important;
            visibility: visible !important;
            opacity: 1 !important;
            border-radius: 12px !important;
            overflow: visible !important;
       }

       /* Reduce padding in all sections */
       #booking-details-section>div {
            padding-bottom: 10px !important;
            margin-bottom: 10px !important;
       }

       /* Reduce font sizes on mobile for better fit */
       #booking-details-section h3 {
            font-size: 18px !important;
            line-height: 1.3 !important;
       }

       /* Gray background section (price and buttons container) - last div */
       #booking-details-section>div[style*="background: #f3f4f6"],
       #booking-details-section>div:last-child {
            padding: 12px !important;
            margin: 0 -12px -12px -12px !important;
            border-radius: 0 0 10px 10px !important;
            overflow: hidden !important;
            position: relative !important;
       }
       
       /* Ensure parent container border is visible on mobile and doesn't clip children */
       #booking-details-section {
            border-radius: 12px !important;
            overflow: hidden !important;
            border: 2px solid #006ce4 !important;
            padding: 12px !important;
       }

       /* Flex container inside gray section - keep horizontal layout on mobile (like variants) */
       #booking-details-section>div:last-child>div[style*="display: flex"] {
            flex-direction: row !important;
            align-items: flex-start !important;
            gap: 20px !important;
            flex-wrap: wrap !important;
       }

       /* Price section on mobile - flex to take available space */
       #booking-details-section>div:last-child>div>div:first-child {
            flex: 1 1 auto !important;
            min-width: 0 !important;
            margin-bottom: 0 !important;
       }

       #booking-details-section #booking-total-price {
            font-size: 28px !important;
            margin-bottom: 8px !important;
       }

       #booking-details-section #booking-price-breakdown {
            font-size: 14px !important;
            margin-bottom: 4px !important;
            line-height: 1.5 !important;
       }

       /* Button container on mobile - keep horizontal layout on right side (like variants) */
       #booking-details-section>div:last-child>div>div:last-child {
            flex-direction: row !important;
            gap: 12px !important;
            flex-shrink: 0 !important;
            align-items: center !important;
            margin-left: auto !important;
       }

       /* Buttons on mobile - keep inline size (like variants) */
       #booking-details-section .btn,
       #booking-details-section .primary-btn1 {
            width: auto !important;
            min-width: auto !important;
            max-width: none !important;
            padding: 20px 24px !important;
            font-size: 15px !important;
            box-sizing: border-box !important;
            justify-content: center !important;
            white-space: nowrap !important;
       }
       
       /* On very small screens, allow buttons to wrap if needed */
       @media (max-width: 480px) {
            #booking-details-section>div:last-child>div[style*="display: flex"] {
                 flex-direction: column !important;
                 align-items: stretch !important;
                 gap: 16px !important;
            }
            
            #booking-details-section>div:last-child>div>div:last-child {
                 width: 100% !important;
                 flex-direction: row !important;
                 gap: 12px !important;
            }
            
            #booking-details-section .btn,
            #booking-details-section .primary-btn1 {
                 flex: 1 1 auto !important;
            }
       }

      /* Booking action buttons on mobile - keep buttons in a row */
      @media (max-width: 768px) {
           .booking-actions-row {
                flex-direction: row !important;
                align-items: center !important;
                justify-content: space-between !important;
                width: 100% !important;
                padding-right: 0 !important;
                box-sizing: border-box !important;
                gap: 12px !important;
           }

           .booking-actions-row .primary-btn1 {
                flex: 1 1 0 !important;
                width: 100% !important;
                max-width: 100% !important;
                justify-content: center !important;
                padding: 16px 20px !important;
           }
      }

      /* Collapsed booking header on mobile - allow full width text */
      @media (max-width: 768px) {
           .booking-details-header {
                flex-direction: column !important;
                align-items: flex-start !important;
          gap: 6px !important;
           }

           .booking-details-header > div:first-child {
                width: 100% !important;
           }

           .booking-details-header > div[style*="flexShrink: 0"] {
                margin-left: 0 !important;
                text-align: right !important;
                align-self: flex-end !important;
           }

           .booking-details-header .booking-toggle-icon {
                align-self: flex-end !important;
           }

     /* Mobile booking card compact layout */
     #booking-details-section-mobile {
          padding: 12px !important;
          border-radius: 10px !important;
          box-shadow: 0 2px 6px rgba(0, 0, 0, 0.08) !important;
     }

     #booking-details-section-mobile .tour-booking-title {
          font-size: 18px !important;
          line-height: 1.25 !important;
          margin-bottom: 2px !important;
     }

     #booking-details-section-mobile #booking-header-summary-mobile {
          font-size: 13px !important;
     }

     #booking-details-section-mobile .tour-booking-duration {
          font-size: 13px !important;
          margin-top: 4px !important;
          font-weight: 600 !important;
     }

     #booking-details-section-mobile .booking-details-content {
          padding-top: 14px !important;
     }

     #booking-details-section-mobile .booking-details-content > div {
          margin-bottom: 10px !important;
          padding-bottom: 10px !important;
     }

     .booking-widget-card {
          padding: 12px !important;
          border-radius: 10px !important;
          box-shadow: 0 2px 6px rgba(0, 0, 0, 0.08) !important;
     }
      }

       /* Select time dropdown on mobile */
       #booking-details-section #booking-time-select {
            width: 100% !important;
            min-width: 100% !important;
            max-width: 100% !important;
       }

       /* Button container on mobile - keep row layout (except booking actions) */
       #booking-details-section div[style*="display: flex; flex-direction: row"]:not(.booking-actions-row) {
            flex-direction: row !important;
       }

       /* Meeting location and other text on mobile */
       #booking-details-section label {
            font-size: 16px !important;
       }

       #booking-details-section #booking-selected-date {
            font-size: 15px !important;
       }
       
       /* Improve spacing for booking header summary on mobile */
       #booking-details-section #booking-header-summary {
            font-size: 14px !important;
            line-height: 1.4 !important;
       }
       
       /* Improve cancellation policy text on mobile */
       #booking-details-section #booking-cancellation-policy {
            font-size: 14px !important;
            line-height: 1.5 !important;
       }
       
       /* Improve meeting location display on mobile */
       #booking-details-section #booking-meeting-location {
            font-size: 15px !important;
            word-break: break-word !important;
       }
       
       /* Improve icon spacing on mobile */
       #booking-details-section i.bi {
            font-size: 16px !important;
       }
       
       /* Variant buttons on mobile - full width, stacked */
       #tour-variants-container .primary-btn1,
       #tour-variants-container .variant-book-btn,
       #tour-variants-container .variant-cart-btn {
            width: 100% !important;
            min-width: 100% !important;
            max-width: 100% !important;
            padding: 20px 24px !important;
            font-size: 15px !important;
            box-sizing: border-box !important;
            justify-content: center !important;
       }
       
       /* Variant button container on mobile - stack vertically */
       #tour-variants-container div[style*="display: flex; flex-direction: row"] {
            flex-direction: column !important;
            gap: 12px !important;
       }
  }

  @media (max-width: 991px) {
       .booking-widget-card {
            position: relative;
            top: 0;
       }

       /* Calendar mobile improvements */
       .calendar-header {
            padding: 10px 8px;
       }

       .calendar-month-year {
            font-size: 16px;
       }

       .calendar-nav-btn {
            width: 36px;
            height: 36px;
       }

       .calendar-nav-btn i {
            font-size: 16px;
       }

       .weekday {
            font-size: 13px;
            padding: 8px 0;
       }

       .calendar-date {
            min-height: 44px;
            font-size: 15px;
            padding: 12px;
       }

       .calendar-dates {
            gap: 6px;
       }

       .calendar-weekdays {
            gap: 6px;
       }
  }

  /* Small to medium mobile devices (up to 450px) - ensure Saturday fits */
  @media (max-width: 450px) {
       .booking-widget-card {
            padding: 12px !important;
       }

       .calendar-header {
            padding: 8px 6px !important;
       }

       .calendar-month-year {
            font-size: 15px !important;
       }

       .calendar-nav-btn {
            width: 32px !important;
            height: 32px !important;
       }

       .calendar-nav-btn i {
            font-size: 14px !important;
       }

       .calendar-weekdays {
            gap: 4px !important;
            margin-bottom: 8px !important;
       }

       .weekday {
            font-size: 12px !important;
            padding: 6px 0 !important;
       }

       .calendar-dates {
            gap: 4px !important;
       }

       .calendar-date {
            min-height: 40px !important;
            font-size: 14px !important;
            padding: 8px 6px !important;
       }
  }

  /* Very small devices (iPhone SE, etc.) - 390px and below */
  @media (max-width: 390px) {
       .booking-widget-card {
            padding: 10px !important;
       }

       .calendar-header {
            padding: 8px 4px !important;
       }

       .calendar-month-year {
            font-size: 14px !important;
       }

       .calendar-nav-btn {
            width: 30px !important;
            height: 30px !important;
       }

       .calendar-nav-btn i {
            font-size: 13px !important;
       }

       .calendar-weekdays {
            gap: 3px !important;
            margin-bottom: 6px !important;
       }

       .weekday {
            font-size: 11px !important;
            padding: 5px 0 !important;
       }

       .calendar-dates {
            gap: 3px !important;
       }

       .calendar-date {
            min-height: 36px !important;
            font-size: 13px !important;
            padding: 6px 3px !important;
       }
  }

  /* Extra small devices (375px and below) */
  @media (max-width: 375px) {
       .booking-widget-card {
            padding: 8px !important;
       }

       .calendar-header {
            padding: 6px 4px !important;
       }

       .calendar-month-year {
            font-size: 13px !important;
       }

       .calendar-nav-btn {
            width: 28px !important;
            height: 28px !important;
       }

       .calendar-nav-btn i {
            font-size: 12px !important;
       }

       .calendar-weekdays {
            gap: 2px !important;
            margin-bottom: 5px !important;
       }

       .weekday {
            font-size: 10px !important;
            padding: 4px 0 !important;
       }

       .calendar-dates {
            gap: 2px !important;
       }

       .calendar-date {
            min-height: 34px !important;
            font-size: 12px !important;
            padding: 5px 2px !important;
       }
  }

  /* Calendar Styles */
  .booking-calendar {
       margin-bottom: 12px;
       overflow-x: hidden;
       width: 100%;
       max-width: 100%;
       box-sizing: border-box;
  }

  /* Ensure calendar content fits within container */
  .calendar-content {
       width: 100%;
       max-width: 100%;
       box-sizing: border-box;
       overflow-x: hidden;
       overflow-y: visible;
       transition: max-height 0.3s ease, opacity 0.3s ease;
  }

  .calendar-content.collapsed {
       max-height: 0;
       opacity: 0;
       margin: 0;
  }

  .calendar-header {
       display: flex;
       align-items: center;
       justify-content: space-between;
       margin-bottom: 12px;
       cursor: pointer;
       user-select: none;
       padding: 10px 12px;
       border-radius: 8px;
       transition: background 0.2s ease;
       background: #f9fafb;
  }

  .calendar-header:hover {
       background: #f3f4f6;
  }

  .calendar-chevron {
       font-size: 16px;
       color: #1a2b49;
       transition: transform 0.3s ease;
       margin-left: 8px;
  }

  .calendar-header.collapsed .calendar-chevron {
       transform: rotate(180deg);
  }

  .calendar-nav-btn {
       width: 36px;
       height: 36px;
       border: 2px solid #e5e7eb;
       border-radius: 8px;
       background: #fff;
       display: flex;
       align-items: center;
       justify-content: center;
       cursor: pointer;
       transition: all 0.2s ease;
       color: #1a2b49;
  }

  .calendar-nav-btn:hover {
       border-color: #006ce4;
       background: #f0f7ff;
       color: #006ce4;
  }

  .calendar-nav-btn:active {
       transform: scale(0.95);
  }

  .calendar-nav-btn i {
       font-size: 16px;
  }

  .calendar-month-year {
       font-size: 18px;
       font-weight: 600;
       color: #1a2b49;
  }

  .calendar-weekdays {
       display: grid;
       grid-template-columns: repeat(7, minmax(0, 1fr));
       gap: 6px;
       margin-bottom: 10px;
       width: 100%;
       box-sizing: border-box;
       max-width: 100%;
  }

  .weekday {
       text-align: center;
       font-size: 13px;
       color: #6b7280;
       font-weight: 600;
       padding: 8px 0;
       text-transform: uppercase;
       letter-spacing: 0.5px;
  }

  .calendar-dates {
       display: grid;
       grid-template-columns: repeat(7, minmax(0, 1fr));
       gap: 6px;
       width: 100%;
       box-sizing: border-box;
       max-width: 100%;
       overflow: visible;
  }

  .calendar-date {
       aspect-ratio: 1;
       display: flex;
       align-items: center;
       justify-content: center;
       flex-direction: column;
       gap: 2px;
       border-radius: 8px;
       font-size: 15px;
       color: #1a2b49;
       cursor: pointer;
       transition: all 0.2s ease;
       position: relative;
       background: transparent;
       border: 2px solid transparent;
       padding: 10px 12px;
       min-height: 44px;
       font-weight: 500;
       box-sizing: border-box;
       width: 100%;
       max-width: 100%;
       min-width: 0;
       overflow: visible;
  }

  .calendar-date-number {
       font-size: 14px;
       line-height: 1.1;
  }

  .calendar-date-price {
       font-size: 12px;
       line-height: 1.2;
       color: #1a2b49;
       font-weight: 700;
       display: block;
       letter-spacing: 0.02em;
  }

  .calendar-date.selected .calendar-date-price,
  .calendar-date.available.selected .calendar-date-price {
       color: #fff;
  }

  .calendar-date:hover:not(.disabled):not(.closed) {
       background: #f0f7ff;
       border-color: #006ce4;
       color: #006ce4;
  }

  .calendar-date.selected {
       background: #006ce4;
       color: #fff;
       font-weight: 600;
       border-color: #006ce4;
       box-shadow: 0 2px 4px rgba(0, 108, 228, 0.2);
  }

  .calendar-date.disabled {
       color: #9ca3af;
       cursor: not-allowed;
       opacity: 0.5;
       background: #f9fafb;
       border-color: #e5e7eb;
  }

  .calendar-date.disabled:hover {
       background: #f9fafb;
       border-color: #e5e7eb;
  }

  .calendar-date.closed {
       color: #dc3545 !important;
       background: #fee2e2 !important;
       border-color: #fecaca !important;
       position: relative;
       opacity: 1;
  }

  .calendar-date.closed.disabled {
       color: #dc3545 !important;
       background: #fee2e2 !important;
       border-color: #fecaca !important;
       opacity: 1;
  }

  .calendar-date.closed.disabled:hover {
       background: #fee2e2 !important;
       border-color: #fecaca !important;
  }

  .calendar-date.available {
       color: #1a2b49;
  }

  .calendar-date.available:hover {
       background: #f0f7ff;
       border-color: #006ce4;
       color: #006ce4;
  }

  .calendar-date.available.selected {
       background: #006ce4;
       color: #fff;
       font-weight: 600;
       border-color: #006ce4;
       box-shadow: 0 2px 4px rgba(0, 108, 228, 0.2);
  }

  /* Today inside min-hours cutoff: keep clickable, visually split half normal/half red */
  .calendar-date.cutoff-mixed {
       color: #1f2937 !important;
       background: linear-gradient(135deg, #ffffff 50%, #fee2e2 50%) !important;
       border-color: #fecaca !important;
       opacity: 1;
  }

  .calendar-date.cutoff-mixed:hover {
       background: linear-gradient(135deg, #f9fafb 50%, #fecaca 50%) !important;
       border-color: #fca5a5 !important;
       color: #1f2937 !important;
  }

  .calendar-date.cutoff-mixed .calendar-date-price {
       color: #1f2937 !important;
  }

  .calendar-date.cutoff-mixed.selected,
  .calendar-date.available.cutoff-mixed.selected {
       background: linear-gradient(135deg, #f8fafc 50%, #fecaca 50%) !important;
       border-color: #f87171 !important;
       color: #111827 !important;
       box-shadow: 0 3px 8px rgba(248, 113, 113, 0.25) !important;
  }

  .calendar-date.cutoff-mixed.selected .calendar-date-price,
  .calendar-date.available.cutoff-mixed.selected .calendar-date-price {
       color: #111827 !important;
  }

  /* Date Tooltip */
  .date-tooltip {
       position: absolute;
       bottom: 100%;
       left: 50%;
       transform: translateX(-50%);
       background: #333;
       color: #fff;
       padding: 8px 12px;
       border-radius: 4px;
       font-size: 12px;
       white-space: nowrap;
       margin-bottom: 8px;
       box-shadow: 0 2px 8px rgba(0, 0, 0, 0.2);
       z-index: 10000;
       pointer-events: none;
       font-weight: 400;
       max-width: 200px;
       text-align: center;
       opacity: 1;
       visibility: visible;
  }

  .date-tooltip.tooltip-left {
       left: 0;
       transform: translateX(0);
  }

  .date-tooltip.tooltip-left::after {
       left: 20px;
  }

  .date-tooltip.tooltip-right {
       left: auto;
       right: 0;
       transform: translateX(0);
  }

  .date-tooltip.tooltip-right::after {
       left: auto;
       right: 20px;
  }

  .date-tooltip.tooltip-bottom {
       bottom: auto;
       top: 100%;
       margin-bottom: 0;
       margin-top: 8px;
  }

  .date-tooltip.tooltip-bottom::after {
       top: auto;
       bottom: 100%;
       border-top-color: transparent;
       border-bottom-color: #333;
  }

  .date-tooltip::after {
       content: '';
       position: absolute;
       top: 100%;
       left: 50%;
       transform: translateX(-50%);
       border: 6px solid transparent;
       border-top-color: #333;
  }

  /* Pickup Location Selection */
  .booking-pickup-selection {
       margin-bottom: 16px;
       border-radius: 8px;
       overflow: hidden;
       border: 1px solid var(--borders-color);
  }

  .pickup-header {
       display: flex;
       align-items: center;
       gap: 10px;
       padding: 12px;
       background: var(--black-color);
       color: var(--white-color);
       cursor: pointer;
       user-select: none;
  }

  .pickup-icon {
       font-size: 18px;
       color: var(--white-color);
  }

  .pickup-title {
       flex: 1;
       font-size: 14px;
       font-weight: 600;
       color: var(--white-color);
  }

  .pickup-chevron {
       font-size: 14px;
       color: var(--white-color);
       transition: transform 0.3s ease;
  }

  .pickup-header:not(.collapsed) .pickup-chevron {
       transform: rotate(180deg);
  }

  .pickup-content {
       background: var(--white-color);
       padding: 12px;
  }

  .pickup-content.collapsed {
       display: none;
  }

  .pickup-location-info {
       display: flex;
       flex-direction: column;
       gap: 8px;
  }

  .pickup-location-name {
       font-size: 14px;
       color: var(--text-color);
       font-weight: 500;
  }

  .pickup-location-address {
       font-size: 13px;
       color: var(--text-color);
       opacity: 0.8;
  }

  .pickup-location-link {
       display: inline-flex;
       align-items: center;
       gap: 6px;
       color: var(--primary-color1);
       text-decoration: none;
       font-size: 13px;
       transition: color 0.2s ease;
       margin-top: 4px;
  }

  .pickup-location-link:hover {
       color: var(--black-color);
       text-decoration: underline;
  }

  .pickup-location-link i {
       font-size: 14px;
  }

  /* People Selection */
  .booking-people-selection {
       margin-bottom: 16px;
       border-radius: 8px;
       overflow: hidden;
       border: 1px solid #e0e0e0;
  }

  .people-header {
       display: flex;
       align-items: center;
       gap: 12px;
       padding: 12px;
       background: #f5f5f5;
       border-radius: 8px;
       cursor: pointer;
       user-select: none;
       border: 1px solid #e0e0e0;
  }

  .people-icon {
       font-size: 18px;
       color: #1a2b49;
  }

  .people-title {
       flex: 1;
       font-size: 14px;
       font-weight: 500;
       color: #1a2b49;
  }

  .people-chevron {
       font-size: 14px;
       color: #1a2b49;
       transition: transform 0.3s ease;
  }

  .people-header:not(.collapsed) .people-chevron {
       transform: rotate(180deg);
  }

  .people-content {
       background: var(--white-color);
       padding: 12px;
  }

  .people-content.collapsed {
       display: none;
  }

  .people-row {
       display: flex;
       align-items: center;
       justify-content: space-between;
       padding: 10px 0;
       border-bottom: 1px solid var(--borders-color);
  }

  .people-row:last-child {
       border-bottom: none;
  }

  /* Van selection (independent section below people) */
  .booking-van-selection {
       margin-bottom: 16px;
       border-radius: 8px;
       overflow: hidden;
       border: 1px solid #e0e0e0;
  }

  .booking-van-selection .van-header {
       display: flex;
       align-items: center;
       gap: 12px;
       padding: 12px;
       background: #f5f5f5;
       border-radius: 8px;
       cursor: pointer;
       user-select: none;
       border: 1px solid #e0e0e0;
  }

  .booking-van-selection .van-title {
       flex: 1;
       font-size: 14px;
       font-weight: 500;
       color: #1a2b49;
  }

  .booking-van-selection .van-content {
       background: var(--white-color);
       padding: 12px;
  }

  .booking-van-selection .van-content.collapsed {
       display: none;
  }

  .booking-van-selection .people-chevron {
       font-size: 14px;
       color: #1a2b49;
       transition: transform 0.3s ease;
  }

  .booking-van-selection .van-header:not(.collapsed) .people-chevron {
       transform: rotate(180deg);
  }

  .booking-van-selection .van-icon {
       font-size: 18px;
       color: #1a2b49;
  }

  .booking-van-selection .van-header:hover .van-title-hover {
       color: #006ce4;
  }

  .van-option-btn:hover {
       border-color: #006ce4 !important;
       background: rgba(0, 108, 228, 0.06) !important;
  }

  .van-switch-link {
       border: none;
       background: transparent;
       color: #006ce4;
       font-size: 13px;
       font-weight: 500;
       padding: 0;
       cursor: pointer;
       text-decoration: underline;
       text-underline-offset: 2px;
  }

  .van-switch-link:hover {
       color: #0054b5;
  }

  .people-row:last-child {
       border-bottom: none;
  }

  .people-row-left {
       flex: 1;
       min-width: 0;
  }

  .people-label {
       font-size: 14px;
       color: var(--text-color);
       font-weight: 400;
       margin-bottom: 4px;
  }

  .people-price {
       font-size: 12px;
       color: var(--text-color);
  }

  .people-price.free {
       color: var(--primary-color3);
       font-weight: 500;
  }

  .people-quantity {
       display: flex;
       align-items: center;
       gap: 12px;
       margin: 0 12px;
  }

  .quantity-btn {
       width: 28px;
       height: 28px;
       border: 2px solid var(--text-color);
       border-radius: 50%;
       background: var(--borders-color);
       color: var(--text-color);
       font-size: 16px;
       font-weight: 600;
       cursor: pointer;
       display: flex;
       align-items: center;
       justify-content: center;
       transition: all 0.2s ease;
       padding: 0;
       line-height: 1;
  }

  .quantity-btn:hover {
       background: #d0d0d0;
       border-color: var(--black-color);
  }

  .quantity-btn:active {
       background: #c0c0c0;
  }

  .quantity-btn:disabled {
       opacity: 0.5;
       cursor: not-allowed;
  }

  .quantity-value {
       font-size: 15px;
       color: var(--text-color);
       font-weight: 500;
       min-width: 20px;
       text-align: center;
  }

  .people-total {
       min-width: 60px;
       text-align: right;
  }

  .total-price {
       font-size: 14px;
       color: var(--text-color);
       font-weight: 500;
  }


  /* Tour Content Sections */
  .tour-content-wrapper {
       margin-top: 40px;
       position: relative;
  }

  /* Tour Tabs - underline only (no tab boxes) */
  .tour-tabs-wrapper .nav-tabs {
       border: none;
       border-bottom: 1px solid #e5e7eb;
       margin: 0 0 24px 0;
       padding: 0;
       display: flex;
       flex-wrap: wrap;
       gap: 0 24px;
       list-style: none;
  }

  .tour-tabs-wrapper .nav-tabs .nav-item {
       margin: 0;
  }

  .tour-tabs-wrapper .nav-tabs .nav-link {
       background: none;
       border: none;
       border-bottom: 2px solid transparent;
       border-radius: 0;
       padding: 12px 0;
       margin-bottom: -1px;
       font-size: 15px;
       font-weight: 500;
       color: #6b7280;
       transition: color 0.2s ease, border-color 0.2s ease;
       cursor: pointer;
  }

  .tour-tabs-wrapper .nav-tabs .nav-link:hover:not(.active):not(.disabled) {
       color: #1a2b49;
  }

  .tour-tabs-wrapper .nav-tabs .nav-link.active {
       color: #1a2b49;
       border-bottom-color: #006ce4;
       font-weight: 600;
  }

  .tour-tabs-wrapper .tab-content {
       margin-top: 0;
  }

  .tour-tabs-wrapper .tab-content .tab-pane {
       padding-top: 0;
  }

  @media (max-width: 768px) {
       .tour-tabs-wrapper .nav-tabs .nav-link {
            padding: 10px 0;
            font-size: 14px;
       }
       .tour-tabs-wrapper .nav-tabs {
            gap: 0 20px;
       }
  }

  .content-section {
       margin-bottom: 40px;
  }

  .content-section-title {
       font-size: 24px;
       font-weight: 700;
       color: #212529;
       margin-bottom: 20px;
       padding-bottom: 12px;
       border-bottom: 2px solid #e0e0e0;
  }

  .content-section-body {
       font-size: 16px;
       line-height: 1.6;
       color: #212529;
  }

  .content-section-body p {
       margin-bottom: 16px;
  }

  .content-section-body h3 {
       font-size: 20px;
       font-weight: 600;
       color: #212529;
       margin-top: 24px;
       margin-bottom: 12px;
  }

  .content-section-body ul,
  .content-section-body ol {
       margin-bottom: 16px;
       padding-left: 24px;
  }

  .content-section-body li {
       margin-bottom: 8px;
  }

  .content-section-body a {
       color: var(--primary-color1);
       text-decoration: underline;
       transition: color 0.2s ease;
  }

  .content-section-body a:hover {
       color: var(--black-color);
  }

  /* Remove bullets from Inclusions and Exclusions lists */
  .tour-inclusions-content ul,
  .tour-exclusions-content ul {
       list-style: none;
       padding-left: 0;
  }

  .tour-inclusions-content ol,
  .tour-exclusions-content ol {
       list-style: none;
       padding-left: 0;
  }

  .tour-inclusions-content li,
  .tour-exclusions-content li {
       list-style: none;
       padding-left: 0;
  }

  /* Ensure images in content sections don't exceed container width */
  .content-section-body img {
       width: 100%;
       height: auto;
       display: block;
  }

  /* Itinerary Container - Two Column Layout */
  .itinerary-container {
       margin-top: 20px;
  }

  .itinerary-main-title {
       font-size: 24px;
       font-weight: 700;
       color: #1a2b49;
       margin: 0 0 30px 0;
  }

  .itinerary-list-wrapper {
       padding-right: 20px;
  }

  /* New Itinerary Timeline Styles */
  .itinerary-timeline-new {
       position: relative;
       padding-left: 56px;
       max-width: 100%;
  }

  /* Vertical line: one segment per item so line runs through and connects all markers */
  .itinerary-timeline-line {
       position: relative;
       padding-left: 0;
  }

  .itinerary-timeline-line > [class^="itinerary-item-"]::before {
       content: '';
       position: absolute;
       left: -33px;
       top: -24px;
       bottom: -24px;
       width: 12px;
       background: #1781FE;
       z-index: 1;
  }

  /* First item: line starts at center of starting marker (no line above starting point) */
  .itinerary-timeline-line > [class^="itinerary-item-"]:first-child::before {
       top: 20px;
  }

  /* Last item: line stops at center of end marker (no extension past circle) */
  .itinerary-timeline-line > [class^="itinerary-item-"]:last-child::before {
       bottom: auto;
       height: 44px;
       border-radius: 0 0 6px 6px;
  }

  /* Pass by: dotted line from below previous item (e.g. main stop) through pass-by to just above next item */
 .itinerary-timeline-line > .itinerary-item-pass_by::before {
    top: -24px;
    bottom: -24px;
      background: transparent;
     background-image: radial-gradient(circle at 8px 8px, #1781FE 6px, transparent 6px);
     background-size: 16px 16px;
     background-position: center;
      background-repeat: repeat;
 }
  .itinerary-timeline-line > .itinerary-item-pass_by:last-child::before {
    bottom: auto;
    height: 44px;
       border-radius: 0;
  }
 .itinerary-timeline-line > .itinerary-item-pass_by:first-child::before {
    top: 20px;
 }
  /* Item after pass-by: start solid line lower so gap shows only dotted (pass-by segment) */
  .itinerary-timeline-line > .itinerary-item-pass_by + [class^="itinerary-item-"]::before {
     top: 20px;
  }

  /* Itinerary Items */
  .itinerary-item-start,
  .itinerary-item-main,
  .itinerary-item-pass_by,
  .itinerary-item-optional,
  .itinerary-item-dropoff,
  .itinerary-item-free-time {
       position: relative;
       margin-bottom: 24px;
       display: flex;
       align-items: flex-start;
       gap: 16px;
  }

  .itinerary-item-start:last-child,
  .itinerary-item-main:last-child,
  .itinerary-item-pass_by:last-child,
  .itinerary-item-optional:last-child,
  .itinerary-item-dropoff:last-child,
  .itinerary-item-free-time:last-child {
       margin-bottom: 0;
  }

  /* Starting Location Marker (Logo with Blue Border) */
  .itinerary-marker-start {
       position: absolute;
       left: -47px;
       top: 0;
       width: 40px;
       height: 40px;
       border-radius: 50%;
       background: #fff;
       border: 2px solid #1781FE;
       display: flex;
       align-items: center;
       justify-content: center;
       z-index: 2;
       box-shadow: 0 2px 8px rgba(23, 129, 254, 0.3);
       padding: 4px;
  }

  .itinerary-marker-start .marker-logo {
       width: 32px;
       height: 32px;
       object-fit: contain;
       display: block;
  }

  /* Main Location Marker (Blue with Pin) */
  .itinerary-marker-main {
       position: absolute;
       left: -47px;
       top: 0;
       width: 40px;
       height: 40px;
       border-radius: 50%;
       background: #1a2b49;
       display: flex;
       align-items: center;
       justify-content: center;
       z-index: 2;
       box-shadow: 0 2px 8px rgba(26, 43, 73, 0.3);
  }

  .itinerary-marker-main i {
       color: #fff;
       font-size: 18px;
  }

  /* Optional Item Marker (White Circle with Plus Icon) */
  .itinerary-marker-optional {
       position: absolute;
       left: -47px;
       top: 0;
       width: 40px;
       height: 40px;
       border-radius: 50%;
       background: #1a2b49;
       border: 2px solid #1a2b49;
       display: flex;
       align-items: center;
       justify-content: center;
       z-index: 2;
       box-shadow: 0 2px 4px rgba(0, 0, 0, 0.1);
       color: #fff;
       font-size: 20px;
  }

  /* Pass By Location Marker (Car Icon) */
  .itinerary-marker-passby,
  .itinerary-marker-pass_by {
       position: absolute;
       left: -47px;
       top: 0;
       width: 40px;
       height: 40px;
       border-radius: 50%;
     background: #ffffff;
    border: 2px solid #1781FE;
       display: flex;
       align-items: center;
       justify-content: center;
       z-index: 2;
     box-shadow: 0 2px 8px rgba(26, 43, 73, 0.2);
     color: #1a2b49;
       font-size: 18px;
  }

.itinerary-marker-passby svg,
.itinerary-marker-pass_by svg {
     fill: #1a2b49;
     stroke: #1a2b49;
}

  /* Drop-off / End Location Marker (circle only, no icon) */
  .itinerary-marker-dropoff {
       position: absolute;
       left: -47px;
       top: 0;
       width: 40px;
       height: 40px;
       border-radius: 50%;
       background: #1781FE;
       display: flex;
       align-items: center;
       justify-content: center;
       z-index: 2;
       box-shadow: 0 2px 8px rgba(23, 129, 254, 0.3);
       color: #fff;
       font-size: 18px;
  }

.itinerary-marker-dropoff::after {
     content: '';
     width: 14px;
     height: 14px;
     border-radius: 50%;
     background: #ffffff;
     display: block;
}

  .itinerary-marker-dropoff > * {
       display: none;
  }

  /* Free Time Marker (Clock Icon) */
  .itinerary-marker-free-time {
       position: absolute;
       left: -47px;
       top: 0;
       width: 40px;
       height: 40px;
       border-radius: 50%;
       background: #1a2b49;
       display: flex;
       align-items: center;
       justify-content: center;
       z-index: 2;
       box-shadow: 0 2px 8px rgba(26, 43, 73, 0.3);
       color: #fff;
       font-size: 18px;
  }

  .itinerary-marker-main,
  .itinerary-marker-passby,
  .itinerary-marker-pass_by,
  .itinerary-marker-optional,
  .itinerary-marker-dropoff,
  .itinerary-marker-free-time {
     color: #fff;
  }

  .itinerary-marker-dropoff .marker-text {
       color: #fff;
       font-weight: 700;
       font-size: 18px;
  }

  /* Content Styles */
  .itinerary-content-new {
       flex: 1;
       padding-top: 4px;
  }

  .itinerary-location-text {
       font-size: 14px;
       color: #63687a;
       margin-bottom: 8px;
       font-weight: 500;
  }

  .itinerary-location-address {
       font-size: 14px;
       color: #1a2b49;
       margin-bottom: 4px;
       line-height: 1.5;
  }

  .itinerary-location-name {
       font-size: 16px;
       font-weight: 600;
       color: #1a2b49;
       margin-bottom: 4px;
       line-height: 1.4;
  }

  .itinerary-badges {
       display: flex;
       flex-wrap: wrap;
       gap: 8px;
       margin-top: 6px;
  }

  .itinerary-badge {
       display: inline-flex;
       align-items: center;
       gap: 6px;
       padding: 4px 10px;
       border-radius: 999px;
       font-size: 12px;
       font-weight: 600;
       background: transparent;
       color: #1a2b49;
  }

  .itinerary-badge-icon svg {
       width: 14px;
       height: 14px;
  }

  .itinerary-badge-pass_by {
       background: transparent;
       color: #1a2b49;
  }

  .itinerary-badge-optional {
       background: transparent;
       color: #1a2b49;
  }

  .itinerary-badge-free_time {
       background: transparent;
       color: #1a2b49;
  }

  .itinerary-badge-dropoff {
       background: transparent;
       color: #1a2b49;
  }

  .itinerary-map-actions {
       display: flex;
       flex-direction: column;
       gap: 12px;
       margin-bottom: 12px;
  }

  .itinerary-map-route-btn {
       display: inline-flex;
       align-items: center;
       justify-content: center;
       padding: 8px 14px;
       border-radius: 8px;
       background: #1781FE;
       color: #fff;
       font-weight: 600;
       font-size: 13px;
       text-decoration: none;
       width: fit-content;
  }

  .itinerary-map-route-btn:hover {
       color: #fff;
       opacity: 0.92;
  }

  .itinerary-map-legend {
       display: flex;
       flex-wrap: wrap;
       gap: 10px 16px;
       font-size: 12px;
       color: #63687a;
  }

  .itinerary-map-legend-item {
       display: inline-flex;
       align-items: center;
       gap: 6px;
       font-weight: 500;
  }

  .legend-dot {
       width: 10px;
       height: 10px;
       border-radius: 50%;
       display: inline-block;
  }

  .legend-start {
       background: #fff;
       border: 2px solid #1781FE;
  }

  .legend-main {
       background: #1a2b49;
  }

  .legend-passby {
       background: #1a2b49;
  }

  .legend-optional {
       background: #d1d5db;
  }

  .legend-free-time {
       background: #1a2b49;
  }

  .legend-dropoff {
       background: #1781FE;
  }

  .itinerary-activity-type {
       font-size: 14px;
       color: #63687a;
       margin-bottom: 4px;
  }

  .itinerary-description {
       font-size: 14px;
       color: #63687a;
       margin-top: 8px;
       line-height: 1.6;
  }

  .itinerary-optional-badge {
       font-size: 13px;
       color: #63687a;
       font-style: italic;
       margin-top: 4px;
  }

  /* Disclaimer */
  .itinerary-disclaimer {
       margin-top: 30px;
       padding-top: 20px;
       border-top: 1px solid #e5e7eb;
       display: flex;
       align-items: center;
       gap: 8px;
       font-size: 13px;
       color: #63687a;
  }

  .itinerary-disclaimer i {
       font-size: 16px;
       color: #006ce4;
  }

  /* Map Wrapper */
  .itinerary-map-wrapper {
       position: sticky;
       top: 20px;
       height: 600px;
       border-radius: 8px;
       overflow: hidden;
       box-shadow: 0 2px 12px rgba(0, 0, 0, 0.1);
       background: #f3f4f6;
  }

  .itinerary-map {
       width: 100%;
       height: 100%;
       border: none;
       min-height: 600px;
  }

  @media (max-width: 992px) {
       .itinerary-list-wrapper {
            padding-right: 0;
            margin-bottom: 30px;
       }

       .itinerary-map-wrapper {
            position: relative;
            top: 0;
            height: 400px;
       }
  }

  @media (max-width: 768px) {
       .itinerary-timeline-new {
            padding-left: 44px;
       }

       .itinerary-marker-start,
       .itinerary-marker-main,
       .itinerary-marker-pass_by,
       .itinerary-marker-passby,
       .itinerary-marker-optional,
       .itinerary-marker-dropoff {
            left: -39.5px;
            width: 32px;
            height: 32px;
       }

       .itinerary-marker-start .marker-text,
       .itinerary-marker-dropoff .marker-text {
            font-size: 16px;
       }

       .itinerary-marker-main i {
            font-size: 16px;
       }

       .itinerary-timeline-line > [class^="itinerary-item-"]::before {
            left: -30px;
            width: 10px;
       }

 .itinerary-timeline-line > .itinerary-item-pass_by::before {
    top: -28px;
    bottom: -28px;
      background: transparent;
     background-image: radial-gradient(circle at 7px 7px, #1781FE 5px, transparent 5px);
     background-size: 14px 14px;
     background-position: center;
      background-repeat: repeat;
 }
 .itinerary-timeline-line > .itinerary-item-pass_by:first-child::before {
    top: 16px;
 }
       .itinerary-timeline-line > .itinerary-item-pass_by:last-child::before {
    bottom: auto;
    height: 40px;
       }
       .itinerary-timeline-line > .itinerary-item-pass_by + [class^="itinerary-item-"]::before {
           top: 16px;
       }

       .itinerary-timeline-line > [class^="itinerary-item-"]:first-child::before {
            top: 16px;
       }

       .itinerary-timeline-line > [class^="itinerary-item-"]:last-child::before {
            height: 40px;
            border-radius: 0 0 5px 5px;
       }

       .itinerary-location-name {
            font-size: 15px;
       }

       .itinerary-map-wrapper {
            height: 350px;
       }
  }

  /* Booking Details Section Styles */
  #booking-details-section {
       box-sizing: border-box;
  }

  #booking-details-section *,
  #booking-details-section *::before,
  #booking-details-section *::after {
       box-sizing: border-box;
  }

  #booking-details-section p {
       margin: 0 0 2px;
  }

  #booking-details-section .btn-outline-primary:hover {
       background: #f0f7ff !important;
  }

  #booking-details-section .btn-primary:hover {
       background: #0056b3 !important;
  }

  #booking-details-section #booking-time-select,
  #booking-details-section #booking-time-select-mobile {
       transition: border-color 0.2s, box-shadow 0.2s, background-color 0.2s;
       background-color: #ffffff;
       border: 2px solid #d1d5db;
       border-radius: 8px;
       padding: 12px 40px 12px 16px;
       font-weight: 500;
       font-size: 15px;
       color: #1a2b49;
       height: 48px;
       appearance: none;
       -webkit-appearance: none;
       -moz-appearance: none;
       background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath fill='%231a2b49' d='M6 9L1 4h10z'/%3E%3C/svg%3E");
       background-repeat: no-repeat;
       background-position: right 16px center;
       background-size: 12px;
       outline: none !important;
       -webkit-tap-highlight-color: transparent !important;
  }

  #booking-details-section #booking-time-select:hover,
  #booking-details-section #booking-time-select-mobile:hover {
       border-color: #006ce4;
       background-color: #ffffff;
  }

  #booking-details-section #booking-time-select:focus,
  #booking-details-section #booking-time-select-mobile:focus {
       outline: none !important;
       border-color: #006ce4;
       box-shadow: 0 0 0 2px rgba(0, 108, 228, 0.12);
       -webkit-tap-highlight-color: transparent !important;
  }

  #booking-details-section #booking-time-select:active,
  #booking-details-section #booking-time-select-mobile:active {
       outline: none !important;
       -webkit-tap-highlight-color: transparent !important;
  }

  #booking-details-section #booking-time-select option,
  #booking-details-section #booking-time-select-mobile option {
       padding: 10px;
       font-size: 15px;
       color: #1a2b49;
  }

  /* Variant time select styles - remove default click/focus color */
  .variant-time-select {
       outline: none !important;
       -webkit-tap-highlight-color: transparent !important;
       -webkit-tap-highlight-color: rgba(0, 0, 0, 0) !important;
  }

  .variant-time-select:focus {
       outline: none !important;
       border-color: #006ce4 !important;
       box-shadow: 0 0 0 3px rgba(0, 108, 228, 0.1) !important;
       -webkit-tap-highlight-color: transparent !important;
  }

  .variant-time-select:active {
       outline: none !important;
       -webkit-tap-highlight-color: transparent !important;
  }

  .variant-time-select:hover {
       border-color: #006ce4 !important;
  }

  .variant-time-select option {
       padding: 10px;
       font-size: 15px;
       color: #1a2b49;
  }

  /* Button styling on large screens */
  @media (min-width: 992px) {
       #booking-details-section .btn {
            padding: 10px 18px !important;
            font-size: 15px !important;
            font-weight: 600 !important;
            border-radius: 8px !important;
            transition: all 0.2s !important;
       }

       #booking-details-section .btn-outline-primary {
            border: 2px solid #006ce4 !important;
            color: #006ce4 !important;
            background: #fff !important;
       }

       #booking-details-section .btn-outline-primary:hover {
            background: #006ce4 !important;
            color: #fff !important;
       }

       #booking-details-section .btn-primary {
            background: #006ce4 !important;
            color: #fff !important;
            border: none !important;
       }

       #booking-details-section .btn-primary:hover {
            background: #0056b3 !important;
       }
  }

  /* Ensure autocomplete dropdown appears above modals */
  #manhattan-pickup-autocomplete,
  #custom-manhattan-autocomplete {
       z-index: 10060 !important;
       position: absolute !important;
  }

  /* When modal is open, ensure autocomplete is still visible */
  .modal.show ~ * #manhattan-pickup-autocomplete,
  .modal.show ~ * #custom-manhattan-autocomplete,
  .modal.show #manhattan-pickup-autocomplete,
  .modal.show #custom-manhattan-autocomplete {
       z-index: 10060 !important;
  }

  /* Fix autocomplete dropdown inside meeting point modal */
  #meetingPointModal .modal-content {
       overflow: visible !important;
  }

  #meetingPointModal .modal-body {
       overflow-y: auto !important;
       overflow-x: visible !important;
       max-height: calc(100vh - 200px) !important;
  }

  /* Ensure autocomplete dropdown in modal appears above everything */
  #meetingPointModal #custom-manhattan-autocomplete,
  #meetingPointModal #manhattan-pickup-autocomplete {
       z-index: 10070 !important;
       position: absolute !important;
  }

  /* Ensure parent containers don't clip the dropdown */
  #meetingPointModal #custom-pickup-location-input-container {
       overflow: visible !important;
       position: relative !important;
  }

  #meetingPointModal #custom-pickup-location-input-container > div {
       overflow: visible !important;
       position: relative !important;
  }

  /* Ensure the locations list container allows scrolling */
  #meetingPointModal #meetingPointLocationsList {
       overflow-y: auto !important;
       overflow-x: visible !important;
       max-height: 400px !important;
   }

  /* Make sure autocomplete appears above modal backdrop and content */
  #meetingPointModal.show #custom-manhattan-autocomplete,
  #meetingPointModal.show #manhattan-pickup-autocomplete {
       z-index: 10070 !important;
  }

  /* Allow modal dialog to show overflow for autocomplete */
  #meetingPointModal .modal-dialog {
       overflow: visible !important;
  }

  /* Ensure input wrapper allows dropdown to be visible */
  #meetingPointModal #custom-pickup-location-input-container > div[style*="position: relative"] {
       overflow: visible !important;
       z-index: 1 !important;
  }

  /* Review Modal Styles */
  .star-rating-modal {
       font-size: 32px;
       cursor: pointer;
       user-select: none;
  }

  .star-rating-modal .star-modal {
       display: inline-block;
       margin-right: 5px;
       transition: transform 0.2s;
  }

  .star-rating-modal .star-modal:hover {
       transform: scale(1.2);
  }

  .image-upload-area-modal {
       border: 2px dashed #ddd;
       border-radius: 8px;
       padding: 15px;
       text-align: center;
       background: #f8f9fa;
       cursor: pointer;
       transition: all 0.3s;
  }

  .image-upload-area-modal:hover {
       border-color: #007bff;
       background: #e7f3ff;
  }

  .image-upload-area-modal.dragover {
       border-color: #007bff;
       background: #e7f3ff;
  }

  .uploaded-images-modal {
       display: flex;
       flex-wrap: wrap;
       gap: 10px;
  }

  .uploaded-image-modal {
       position: relative;
       width: 100px;
       height: 100px;
       border-radius: 8px;
       overflow: hidden;
  }

  .uploaded-image-modal img {
       width: 100%;
       height: 100%;
       object-fit: cover;
  }

  .uploaded-image-modal .remove-btn {
       position: absolute;
       top: 5px;
       right: 5px;
       background: rgba(255,0,0,0.8);
       color: white;
       border: none;
       border-radius: 50%;
       width: 24px;
       height: 24px;
       cursor: pointer;
       font-size: 14px;
       display: flex;
       align-items: center;
       justify-content: center;
  }

  /* Reviews Section Styles */
  .customer-photos-grid {
    display: grid;
    grid-template-columns: 2fr 1fr 1fr;
    grid-template-rows: 1fr 1fr;
    gap: 8px;
    height: 250px;
  }

  @media (max-width: 768px) {
    .customer-photos-grid {
      height: 200px;
    }
  }

  .customer-photo-item {
    border-radius: 8px;
    overflow: hidden;
    position: relative;
  }

  .customer-photo-item.large-photo-left {
    grid-row: span 2;
    grid-column: 1;
  }

  .customer-photo-item.small-photo {
    grid-column: auto;
    grid-row: auto;
  }

  .customer-photo-item img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    transition: transform 0.3s;
  }

  .customer-photo-item:hover img {
    transform: scale(1.05);
  }

  .review-item {
    background: #fff;
    transition: box-shadow 0.3s;
  }

  .review-item:hover {
    box-shadow: 0 2px 8px rgba(0,0,0,0.1);
  }

  .rating-bar-item {
    position: relative;
  }

  /* Country Dropdown Styles */
  .country-dropdown-wrapper.review-country-dropdown {
    position: relative;
  }

  .custom-select-dropdown {
    position: relative;
    cursor: pointer;
  }

  .custom-select-dropdown input {
    cursor: pointer;
    background-color: white;
  }

  .country-dropdown-icon {
    position: absolute;
    right: 12px;
    top: 50%;
    transform: translateY(-50%);
    font-size: 20px;
    pointer-events: none;
    transition: transform 0.3s ease;
    color: #666;
  }

  .review-country-dropdown.active .country-dropdown-icon {
    transform: translateY(-50%) rotate(180deg);
  }

  .custom-select-wrap {
    position: absolute;
    top: calc(100% + 5px);
    left: 0;
    width: 100%;
    background: white;
    border: 1px solid #ddd;
    border-radius: 8px;
    box-shadow: 0 4px 12px rgba(0,0,0,0.15);
    z-index: 1050;
    max-height: 0;
    overflow: hidden;
    opacity: 0;
    transition: all 0.3s ease;
  }

  .custom-select-wrap.active {
    max-height: 400px;
    opacity: 1;
    overflow-y: auto;
  }

  .custom-select-search-area {
    position: sticky;
    top: 0;
    background: white;
    padding: 12px;
    border-bottom: 1px solid #eee;
    display: flex;
    align-items: center;
    gap: 8px;
    z-index: 1;
  }

  .custom-select-search-area i {
    color: #999;
    font-size: 18px;
  }

  .custom-select-search-area input {
    border: 1px solid #ddd;
    border-radius: 6px;
    padding: 8px 12px;
    width: 100%;
    font-size: 14px;
    outline: none;
  }

  .custom-select-search-area input:focus {
    border-color: #1a2b49;
    box-shadow: 0 0 0 0.2rem rgba(26, 43, 73, 0.25);
    outline: none;
  }

  .option-list {
    list-style: none;
    padding: 0;
    margin: 0;
  }

  .option-list .single-item {
    display: flex;
    align-items: center;
    gap: 12px;
    padding: 10px 16px;
    cursor: pointer;
    transition: background-color 0.2s ease;
    border-bottom: 1px solid #f5f5f5;
  }

  .option-list .single-item:last-child {
    border-bottom: none;
  }

  .option-list .single-item:hover {
    background-color: #f8f9fa;
  }

  .option-list .single-item h6 {
    margin: 0;
    font-size: 14px;
    font-weight: 400;
    color: #333;
  }

  .country-flag-item {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-width: 24px;
    height: 18px;
  }

  .country-flag-item .fi {
    font-size: 20px;
  }

  /* Completely remove Bootstrap blue focus colors globally for modal */
  #writeReviewModal *:focus {
    outline: none !important;
  }

  #writeReviewModal *:focus-visible {
    outline: none !important;
  }

  /* Remove Bootstrap input focus color - Use dark color like old design */
  #writeReviewModal .form-control,
  #writeReviewModal .form-control:focus,
  #writeReviewModal .form-control:active,
  #writeReviewModal .form-control:focus-visible {
    border-color: #dee2e6 !important;
    box-shadow: none !important;
    outline: none !important;
    -webkit-box-shadow: none !important;
    -moz-box-shadow: none !important;
  }

  #writeReviewModal .form-control:focus,
  #writeReviewModal .form-control:focus-visible {
    border-color: #1a2b49 !important;
    box-shadow: none !important;
    -webkit-box-shadow: none !important;
    -moz-box-shadow: none !important;
    outline: none !important;
  }

  #writeReviewModal textarea.form-control,
  #writeReviewModal textarea.form-control:focus,
  #writeReviewModal textarea.form-control:active,
  #writeReviewModal textarea.form-control:focus-visible {
    border-color: #dee2e6 !important;
    box-shadow: none !important;
    outline: none !important;
    -webkit-box-shadow: none !important;
    -moz-box-shadow: none !important;
  }

  #writeReviewModal textarea.form-control:focus,
  #writeReviewModal textarea.form-control:focus-visible {
    border-color: #1a2b49 !important;
    box-shadow: none !important;
    -webkit-box-shadow: none !important;
    -moz-box-shadow: none !important;
    outline: none !important;
  }

  /* Country dropdown input */
  #writeReviewModal .country-dropdown-wrapper input:focus,
  #writeReviewModal .country-dropdown-wrapper input:focus-visible,
  #writeReviewModal .custom-select-dropdown input:focus,
  #writeReviewModal .custom-select-dropdown input:focus-visible,
  #writeReviewModal .review-country-dropdown input:focus,
  #writeReviewModal .review-country-dropdown input:focus-visible,
  #writeReviewModal #reviewerCountryModal:focus,
  #writeReviewModal #reviewerCountryModal:focus-visible {
    border-color: #1a2b49 !important;
    box-shadow: none !important;
    -webkit-box-shadow: none !important;
    -moz-box-shadow: none !important;
    outline: none !important;
  }

  /* Country search input */
  #writeReviewModal .custom-select-search-area input:focus,
  #writeReviewModal .custom-select-search-area input:focus-visible {
    border-color: #1a2b49 !important;
    box-shadow: none !important;
    -webkit-box-shadow: none !important;
    -moz-box-shadow: none !important;
    outline: none !important;
  }

  /* Global override for ALL inputs in review modal - remove Bootstrap blue completely */
  #writeReviewModal input:focus,
  #writeReviewModal input:focus-visible,
  #writeReviewModal textarea:focus,
  #writeReviewModal textarea:focus-visible,
  #writeReviewModal select:focus,
  #writeReviewModal select:focus-visible {
    border-color: #1a2b49 !important;
    box-shadow: none !important;
    -webkit-box-shadow: none !important;
    -moz-box-shadow: none !important;
    outline: none !important;
  }

  /* Review Page Styles */
  .review-container {
    max-width: 1200px;
    margin: 40px auto;
    padding: 40px;
    background: #fff;
  }

  /* New Review Layout (Direct Access) - Two Column */
  .new-review-layout {
    display: block;
    width: 100%;
  }

  /* Left Sidebar - Tour Display */
  .review-sidebar {
    width: 100%;
    position: sticky;
    top: 20px;
    height: fit-content;
  }

  .review-sidebar h1 {
    font-size: 32px;
    font-weight: 700;
    color: #1a2b49;
    margin-bottom: 30px;
    line-height: 1.2;
  }

  .review-sidebar-image {
    margin-bottom: 20px;
  }

  .review-sidebar-image img {
    width: 100%;
    height: auto;
    border-radius: 8px;
    object-fit: cover;
    box-shadow: 0 2px 8px rgba(0, 0, 0, 0.1);
  }

  .review-sidebar-tour-name {
    margin-top: 16px;
  }

  .review-sidebar-tour-name h4 {
    font-size: 18px;
    font-weight: 600;
    color: #1a2b49;
    margin-bottom: 8px;
  }

  .review-sidebar-tour-name p {
    font-size: 14px;
    color: #6c757d;
    margin: 0;
  }

  .review-sidebar-tour-name a {
    color: #1a2b49;
    text-decoration: underline;
  }

  .review-sidebar-image {
    display: none; /* Hide image in new layout */
  }

  .review-sidebar-tour-name {
    display: none; /* Hide tour name in sidebar */
  }

  /* Form Section */
  .review-form-section {
    width: 100%;
  }

  .review-form-section form,
  #newReviewForm {
    display: block;
    width: 100%;
  }

  /* Force each form field container to stack vertically */
  .review-form-section .mb-4,
  #newReviewForm > .mb-4,
  #newReviewForm .mb-4 {
    display: block !important;
    width: 100% !important;
    margin-bottom: 24px !important;
    clear: both !important;
    float: none !important;
    flex-basis: 100% !important;
    flex-grow: 0 !important;
    flex-shrink: 0 !important;
  }

  /* Prevent any flex or grid on form */
  #newReviewForm {
    display: block !important;
    flex-wrap: nowrap !important;
  }

  /* Force direct children of form to be block */
  #newReviewForm > * {
    display: block !important;
    width: 100% !important;
  }

  /* Force labels to be on their own line */
  .review-form-section .form-label,
  .review-form-section label {
    display: block !important;
    width: 100% !important;
    margin-bottom: 8px !important;
    font-size: 16px;
    font-weight: 600;
    color: #1a2b49;
  }

  /* Form controls take full width */
  .review-form-section .form-control {
    display: block !important;
    width: 100% !important;
    box-sizing: border-box !important;
  }

  /* Remove Bootstrap blue focus color from review page inputs */
  .review-form-section .form-control:focus,
  .review-form-section .form-control:focus-visible,
  .review-form-section input:focus,
  .review-form-section input:focus-visible,
  .review-form-section textarea:focus,
  .review-form-section textarea:focus-visible,
  .review-form-section select:focus,
  .review-form-section select:focus-visible,
  .review-container .form-control:focus,
  .review-container .form-control:focus-visible,
  .review-container input:focus,
  .review-container input:focus-visible,
  .review-container textarea:focus,
  .review-container textarea:focus-visible,
  .review-container select:focus,
  .review-container select:focus-visible {
    border-color: #1a2b49 !important;
    box-shadow: none !important;
    -webkit-box-shadow: none !important;
    -moz-box-shadow: none !important;
    outline: none !important;
  }

  /* Country and month dropdowns on review page */
  .review-form-section .country-dropdown-wrapper input:focus,
  .review-form-section .country-dropdown-wrapper input:focus-visible,
  .review-form-section .month-dropdown-wrapper input:focus,
  .review-form-section .month-dropdown-wrapper input:focus-visible,
  .review-form-section .custom-select-dropdown input:focus,
  .review-form-section .custom-select-dropdown input:focus-visible,
  .review-form-section .custom-select-search-area input:focus,
  .review-form-section .custom-select-search-area input:focus-visible,
  .review-form-section .tour-select-input:focus,
  .review-form-section .tour-select-input:focus-visible,
  .review-form-section .tour-select-search input:focus,
  .review-form-section .tour-select-search input:focus-visible {
    border-color: #1a2b49 !important;
    box-shadow: none !important;
    -webkit-box-shadow: none !important;
    -moz-box-shadow: none !important;
    outline: none !important;
  }

  /* Global override for ALL inputs on review page */
  .review-container input:focus,
  .review-container input:focus-visible,
  .review-container textarea:focus,
  .review-container textarea:focus-visible,
  .review-container select:focus,
  .review-container select:focus-visible {
    border-color: #1a2b49 !important;
    box-shadow: none !important;
    -webkit-box-shadow: none !important;
    -moz-box-shadow: none !important;
    outline: none !important;
  }

  /* Tour dropdown takes full width */
  .review-form-section .tour-select-dropdown {
    display: block !important;
    width: 100% !important;
  }

  /* Checkbox wrapper */
  .review-form-section .checkbox-wrapper {
    display: block !important;
    width: 100% !important;
  }

  /* Text areas and inputs */
  .review-form-section textarea,
  .review-form-section input[type="text"],
  .review-form-section input[type="hidden"],
  .review-form-section select {
    width: 100% !important;
    box-sizing: border-box !important;
  }

  /* Rating bubbles container */
  .review-form-section .rating-bubbles {
    display: flex !important;
    flex-wrap: wrap !important;
    gap: 8px !important;
    width: 100% !important;
  }

  /* Who with buttons container */
  .review-form-section .who-with-buttons {
    display: flex !important;
    flex-wrap: wrap !important;
    gap: 12px !important;
    width: 100% !important;
  }

  /* Review tips */
  .review-form-section .review-tips {
    display: flex !important;
    flex-wrap: wrap !important;
    gap: 8px !important;
    width: 100% !important;
  }

  /* Image upload area */
  .review-form-section .image-upload-area {
    display: block !important;
    width: 100% !important;
  }

  /* Uploaded images container */
  .review-form-section .uploaded-images {
    display: flex !important;
    flex-wrap: wrap !important;
    width: 100% !important;
  }

  /* Character counter */
  .review-form-section .char-counter {
    display: block !important;
    width: 100% !important;
  }

  /* Submit button container */
  .review-form-section .text-center {
    display: block !important;
    width: 100% !important;
    text-align: center !important;
  }

  /* Tour dropdown styles */
  .tour-select-dropdown {
    position: relative;
    margin-bottom: 30px;
  }

  .tour-select-input {
    width: 100%;
    padding: 12px 16px;
    border: 1px solid #1a2b49;
    border-radius: 8px;
    font-size: 14px;
    background: #fff;
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: space-between;
  }

  .tour-select-dropdown.active .tour-select-input {
    border-bottom-left-radius: 0;
    border-bottom-right-radius: 0;
  }

  .tour-select-options {
    position: absolute;
    top: 100%;
    left: 0;
    right: 0;
    background: #fff;
    border: 1px solid #1a2b49;
    border-top: none;
    border-radius: 0 0 8px 8px;
    max-height: 400px;
    overflow-y: auto;
    z-index: 1000;
  }

  .tour-select-search {
    padding: 12px 16px;
    border-bottom: 1px solid #f0f0f0;
  }

  .tour-select-search input {
    width: 100%;
    padding: 8px 12px;
    border: 1px solid #ddd;
    border-radius: 6px;
    font-size: 14px;
  }

  .tour-option {
    padding: 12px 16px;
    display: flex;
    align-items: center;
    gap: 12px;
    cursor: pointer;
    transition: background 0.2s;
    border-bottom: 1px solid #f0f0f0;
  }

  .tour-option:last-child {
    border-bottom: none;
  }

  .tour-option:hover {
    background: #f8f9fa;
  }

  .tour-option-image {
    width: 60px;
    height: 60px;
    border-radius: 6px;
    object-fit: cover;
    flex-shrink: 0;
  }

  .tour-option-info {
    flex: 1;
  }

  .tour-option-title {
    font-weight: 600;
    font-size: 14px;
    color: #1a2b49;
    margin-bottom: 4px;
  }

  .tour-option-subtitle {
    font-size: 12px;
    color: #6c757d;
  }

  /* Rating bubbles */
  .rating-bubble {
    padding: 12px 24px;
    border: 2px solid #ddd;
    border-radius: 8px;
    cursor: pointer;
    background: #fff;
    color: #1a2b49;
    font-weight: 600;
    font-size: 16px;
    transition: all 0.2s;
  }

  .rating-bubble:hover {
    border-color: #1a2b49;
    background: #f8f9fa;
  }

  .rating-bubble.active {
    border-color: #1a2b49;
    background: #1a2b49;
    color: #fff;
  }

  /* Rating circles */
  .rating-circles {
    display: flex;
    gap: 12px;
    align-items: center;
  }

  .rating-circle {
    width: 48px;
    height: 48px;
    border-radius: 50%;
    border: 2px solid #ddd;
    cursor: pointer;
    background: #fff;
    display: flex;
    align-items: center;
    justify-content: center;
    color: #1a2b49;
    font-weight: 600;
    font-size: 18px;
    transition: all 0.2s;
  }

  .rating-circle:hover {
    border-color: #1a2b49;
    background: #f8f9fa;
  }

  .rating-circle.active {
    border-color: #1a2b49;
    background: #1a2b49;
    color: #fff;
  }

  /* Who with buttons */
  .who-with-btn {
    padding: 10px 20px;
    border: 2px solid #ddd;
    border-radius: 8px;
    cursor: pointer;
    background: #fff;
    color: #1a2b49;
    font-weight: 500;
    font-size: 14px;
    transition: all 0.2s;
  }

  .who-with-btn:hover {
    border-color: #1a2b49;
    background: #f8f9fa;
  }

  .who-with-btn.active {
    border-color: #1a2b49;
    background: #1a2b49;
    color: #fff;
  }

  /* Review tips */
  .review-tips {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
    margin-bottom: 12px;
    font-size: 14px;
    color: #6c757d;
    align-items: center;
  }

  .review-tips span {
    padding: 4px 12px;
    background: #f0f0f0;
    border-radius: 4px;
    font-size: 12px;
  }

  /* Image upload area */
  .image-upload-area {
    border: 2px dashed #e0e0e0;
    border-radius: 12px;
    padding: 30px;
    text-align: center;
    background: #f8f9fa;
    cursor: pointer;
    transition: all 0.3s;
  }

  .image-upload-area:hover {
    border-color: #1a2b49;
    background: #f0f2f5;
  }

  .uploaded-images {
    display: flex;
    flex-wrap: wrap;
    gap: 12px;
    margin-top: 20px;
  }

  .uploaded-image {
    position: relative;
    width: 120px;
    height: 120px;
    border-radius: 8px;
    overflow: hidden;
    border: 2px solid #e0e0e0;
  }

  .uploaded-image img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    transition: transform 0.2s;
  }

  .uploaded-image:hover img {
    transform: scale(1.05);
  }

  .uploaded-image .remove-btn {
    position: absolute;
    top: 5px;
    right: 5px;
    background: rgba(220, 53, 69, 0.9);
    color: white;
    border: none;
    border-radius: 50%;
    width: 28px;
    height: 28px;
    cursor: pointer;
    font-size: 16px;
    display: flex;
    align-items: center;
    justify-content: center;
    transition: background 0.2s;
  }

  .uploaded-image .remove-btn:hover {
    background: rgba(220, 53, 69, 1);
  }

  /* Character counter */
  .char-counter {
    margin-top: 8px;
    font-size: 14px;
    color: #6c757d;
  }

  .char-counter span {
    font-weight: 600;
  }

  /* Prevent custom.js from affecting native select */
  select[data-native-select="true"],
  select#visitDate {
    appearance: auto !important;
    -webkit-appearance: menulist !important;
    -moz-appearance: menulist !important;
  }

  select[data-native-select="true"]:focus,
  select#visitDate:focus {
    outline: none !important;
    border-color: #1a2b49 !important;
    box-shadow: 0 0 0 0.2rem rgba(26, 43, 73, 0.25) !important;
  }

  /* Tours page filter inputs - COMPLETELY remove Bootstrap blue focus color */
  /* Match old site approach: remove box-shadow entirely, only change border-color */
  .unforgettable-tours-section .tours-filters input[type="text"],
  .unforgettable-tours-section .tours-filters select,
  .unforgettable-tours-section .tours-filters input[type="text"].form-control,
  .unforgettable-tours-section .tours-filters select.form-control,
  .unforgettable-tours-section .tours-filters .tours-filter-input,
  .unforgettable-tours-section .tours-filters .tours-filter-select {
    outline: none !important;
    outline-width: 0 !important;
    outline-style: none !important;
    outline-color: transparent !important;
  }

  /* FOCUS STATES - Remove Bootstrap's blue box-shadow completely, only change border */
  .unforgettable-tours-section .tours-filters input[type="text"]:focus,
  .unforgettable-tours-section .tours-filters input[type="text"]:focus-visible,
  .unforgettable-tours-section .tours-filters input[type="text"]:active,
  .unforgettable-tours-section .tours-filters select:focus,
  .unforgettable-tours-section .tours-filters select:focus-visible,
  .unforgettable-tours-section .tours-filters select:active,
  .unforgettable-tours-section .tours-filters input[type="text"].form-control:focus,
  .unforgettable-tours-section .tours-filters input[type="text"].form-control:focus-visible,
  .unforgettable-tours-section .tours-filters input[type="text"].form-control:active,
  .unforgettable-tours-section .tours-filters select.form-control:focus,
  .unforgettable-tours-section .tours-filters select.form-control:focus-visible,
  .unforgettable-tours-section .tours-filters select.form-control:active,
  .unforgettable-tours-section .tours-filters .tours-filter-input:focus,
  .unforgettable-tours-section .tours-filters .tours-filter-input:focus-visible,
  .unforgettable-tours-section .tours-filters .tours-filter-input:active,
  .unforgettable-tours-section .tours-filters .tours-filter-select:focus,
  .unforgettable-tours-section .tours-filters .tours-filter-select:focus-visible,
  .unforgettable-tours-section .tours-filters .tours-filter-select:active {
    border-color: #1a2b49 !important;
    box-shadow: none !important;
    -webkit-box-shadow: none !important;
    -moz-box-shadow: none !important;
    outline: none !important;
    outline-width: 0 !important;
    outline-style: none !important;
    outline-color: transparent !important;
    outline-offset: 0 !important;
  }

  /* Maximum specificity - override Bootstrap's .form-control:focus */
  .unforgettable-tours-section .tours-filters .form-control:focus,
  .unforgettable-tours-section .tours-filters .form-control:focus-visible,
  .unforgettable-tours-section .tours-filters .form-control:active,
  .unforgettable-tours-section .tours-filters form .form-control:focus,
  .unforgettable-tours-section .tours-filters form .form-control:focus-visible,
  .unforgettable-tours-section .tours-filters form .form-control:active,
  .unforgettable-tours-section .tours-filters form .row .col-md-3 .form-control:focus,
  .unforgettable-tours-section .tours-filters form .row .col-sm-6 .form-control:focus,
  .unforgettable-tours-section .tours-filters .row .col-md-3 .form-control:focus,
  .unforgettable-tours-section .tours-filters .row .col-sm-6 .form-control:focus {
    border-color: #1a2b49 !important;
    box-shadow: none !important;
    -webkit-box-shadow: none !important;
    -moz-box-shadow: none !important;
    outline: none !important;
    outline-width: 0 !important;
    outline-style: none !important;
    outline-color: transparent !important;
    outline-offset: 0 !important;
  }

  /* Remove all blue outlines from any element in filters */
  .unforgettable-tours-section .tours-filters *:focus,
  .unforgettable-tours-section .tours-filters *:focus-visible,
  .unforgettable-tours-section .tours-filters *:active {
    outline: none !important;
    outline-width: 0 !important;
    outline-style: none !important;
    outline-color: transparent !important;
    outline-offset: 0 !important;
  }

  /* GLOBAL OVERRIDE for tours page - must be at the end to override Bootstrap */
  .unforgettable-tours-section .tours-filters input:focus,
  .unforgettable-tours-section .tours-filters select:focus,
  .unforgettable-tours-section .tours-filters input.form-control:focus,
  .unforgettable-tours-section .tours-filters select.form-control:focus {
    border-color: #1a2b49 !important;
    box-shadow: none !important;
    -webkit-box-shadow: none !important;
    -moz-box-shadow: none !important;
    outline: none !important;
  }

  @media (max-width: 768px) {
    .review-container {
      padding: 20px;
    }

    .review-sidebar h1 {
      font-size: 22px;
      text-align: center;
    }

    .review-form-section {
      width: 100%;
    }

    .image-upload-area {
      padding: 16px 12px;
    }

    .uploaded-image {
      width: 80px;
      height: 80px;
    }
  }
